visium.c (visium_gimplify_va_arg): Emit a big-endian correction if the type is smalle...
authorEric Botcazou <ebotcazou@adacore.com>
Wed, 12 Oct 2016 21:04:26 +0000 (21:04 +0000)
committerEric Botcazou <ebotcazou@gcc.gnu.org>
Wed, 12 Oct 2016 21:04:26 +0000 (21:04 +0000)
* config/visium/visium.c (visium_gimplify_va_arg): Emit a big-endian
correction if the type is smaller than a word.
(visium_select_cc_mode): Add ... fall through ... comment.

From-SVN: r241076

gcc/ChangeLog
gcc/config/visium/visium.c

index 3a67339b3b88695fa050b908be0c87bcde6bb2a4..12a324cc1f341eaa58fb7e7522f191f5577b83aa 100644 (file)
@@ -1,3 +1,9 @@
+2016-10-12  Eric Botcazou  <ebotcazou@adacore.com>
+
+       * config/visium/visium.c (visium_gimplify_va_arg): Emit a big-endian
+       correction if the type is smaller than a word.
+       (visium_select_cc_mode): Add ... fall through ... comment.
+
 2016-10-12  Segher Boessenkool  <segher@kernel.crashing.org>
 
        * config/rs6000/rs6000.c (machine_function): Add new fields
index 4585af578949990c7f5dff163bdd7c0b671dfd00..a0035c6bd1e0d8060e349383ac3cd0fb9bf610c3 100644 (file)
@@ -1626,8 +1626,8 @@ visium_gimplify_va_arg (tree valist, tree type, gimple_seq *pre_p,
      7:   {
      8:     bytes = 0;
      9:     addr_rtx = ovfl;
-     10:     ovfl += rsize;
-     11:   }
+     10:    ovfl += rsize;
+     11:  }
 
    */
 
@@ -1691,6 +1691,16 @@ visium_gimplify_va_arg (tree valist, tree type, gimple_seq *pre_p,
   gimplify_and_add (t, pre_p);
   t = build1 (LABEL_EXPR, void_type_node, lab_over);
   gimplify_and_add (t, pre_p);
+
+  /* Emit a big-endian correction if size < UNITS_PER_WORD.  */
+  if (size < UNITS_PER_WORD)
+    {
+      t = build2 (POINTER_PLUS_EXPR, TREE_TYPE (addr), addr,
+                 size_int (UNITS_PER_WORD - size));
+      t = build2 (MODIFY_EXPR, void_type_node, addr, t);
+      gimplify_and_add (t, pre_p);
+    }
+
   addr = fold_convert (ptrtype, addr);
 
   return build_va_arg_indirect_ref (addr);
@@ -2848,6 +2858,9 @@ visium_select_cc_mode (enum rtx_code code, rtx op0, rtx op1)
     case CONST_INT:
       /* This is a degenerate case, typically an uninitialized variable.  */
       gcc_assert (op0 == constm1_rtx);
+
+      /* ... fall through ... */
+
     case REG:
     case AND:
     case IOR: