ubsan: v850: left shift cannot be represented in type 'int'
authorAlan Modra <amodra@gmail.com>
Thu, 26 Dec 2019 05:26:25 +0000 (15:56 +1030)
committerAlan Modra <amodra@gmail.com>
Thu, 26 Dec 2019 07:19:03 +0000 (17:49 +1030)
Another 1 << 31 complaint.

* v850-dis.c (disassemble): Avoid signed overflow.  Don't use
long vars when unsigned int will do.

opcodes/ChangeLog
opcodes/v850-dis.c

index bdbb5f74b1f05e4b07b0b775e23f73f53700f3b6..07f30e27d6be9e2a73d68290380952cd7c84cf97 100644 (file)
@@ -1,3 +1,8 @@
+2019-12-26  Alan Modra  <amodra@gmail.com>
+
+       * v850-dis.c (disassemble): Avoid signed overflow.  Don't use
+       long vars when unsigned int will do.
+
 2019-12-24  Alan Modra  <amodra@gmail.com>
 
        * arm-dis.c (print_insn_arm): Don't shift by 32 on unsigned int var.
index 45e6c65d83a19c25ee866b4d6e4334bcf03e95f2..df2c2a5d39b718ae7a4a7296c616e71260a797aa 100644 (file)
@@ -499,7 +499,7 @@ disassemble (bfd_vma memaddr,
                                                     0,  0, 0, 0, 0, 31, 29, 28, 23, 22, 21, 20, 27, 26, 25, 24 };
                    int *regs;
                    int i;
-                   unsigned long int mask = 0;
+                   unsigned int mask = 0;
                    int pc = 0;
 
                    switch (operand->shift)
@@ -514,12 +514,12 @@ disassemble (bfd_vma memaddr,
 
                    for (i = 0; i < 32; i++)
                      {
-                       if (value & (1 << i))
+                       if (value & (1u << i))
                          {
                            switch (regs[ i ])
                              {
                              default:
-                               mask |= (1 << regs[ i ]);
+                               mask |= (1u << regs[ i ]);
                                break;
                              case 0:
                                /* xgettext:c-format */
@@ -543,10 +543,10 @@ disassemble (bfd_vma memaddr,
                            int shown_one = 0;
 
                            for (bit = 0; bit < 32; bit++)
-                             if (mask & (1 << bit))
+                             if (mask & (1u << bit))
                                {
-                                 unsigned long int first = bit;
-                                 unsigned long int last;
+                                 unsigned int first = bit;
+                                 unsigned int last;
 
                                  if (shown_one)
                                    info->fprintf_func (info->stream, ", ");
@@ -556,7 +556,7 @@ disassemble (bfd_vma memaddr,
                                  info->fprintf_func (info->stream, "%s", get_v850_reg_name (first));
 
                                  for (bit++; bit < 32; bit++)
-                                   if ((mask & (1 << bit)) == 0)
+                                   if ((mask & (1u << bit)) == 0)
                                      break;
 
                                  last = bit;