2012-04-16 Ulrich Weigand <ulrich.weigand@linaro.org>
authoruweigand <uweigand@138bc75d-0d04-0410-961f-82ee72b054a4>
Mon, 16 Apr 2012 15:19:43 +0000 (15:19 +0000)
committeruweigand <uweigand@138bc75d-0d04-0410-961f-82ee72b054a4>
Mon, 16 Apr 2012 15:19:43 +0000 (15:19 +0000)
PR target/51819
* config/arm/arm.c (arm_print_operand): Fix invalid alignment
hints for 'A' operand types.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@186498 138bc75d-0d04-0410-961f-82ee72b054a4

gcc/ChangeLog
gcc/config/arm/arm.c

index a2f6461..38df9e7 100644 (file)
@@ -1,3 +1,9 @@
+2012-04-16  Ulrich Weigand  <ulrich.weigand@linaro.org>
+
+       PR target/51819
+       * config/arm/arm.c (arm_print_operand): Fix invalid alignment
+       hints for 'A' operand types.
+
 2012-04-16  Jan Hubicka  <jh@suse.cz>
 
        * cgraph.h (symtab_node_base): Add next and previous pointers.
index 5522fc1..2cecf45 100644 (file)
@@ -17877,9 +17877,9 @@ arm_print_operand (FILE *stream, rtx x, int code)
        memsize = MEM_SIZE (x);
 
        /* Only certain alignment specifiers are supported by the hardware.  */
-       if (memsize == 16 && (align % 32) == 0)
+       if (memsize == 32 && (align % 32) == 0)
          align_bits = 256;
-       else if (memsize == 16 && (align % 16) == 0)
+       else if ((memsize == 16 || memsize == 32) && (align % 16) == 0)
          align_bits = 128;
        else if (memsize >= 8 && (align % 8) == 0)
          align_bits = 64;