Handle POLY_INT_CSTs in declare_return_value
authorRichard Sandiford <richard.sandiford@arm.com>
Fri, 8 Nov 2019 09:06:50 +0000 (09:06 +0000)
committerRichard Sandiford <rsandifo@gcc.gnu.org>
Fri, 8 Nov 2019 09:06:50 +0000 (09:06 +0000)
SVE allows variable-length vectors to be returned by value,
which tripped the assert in declare_return_variable.

2019-11-08  Richard Sandiford  <richard.sandiford@arm.com>

gcc/
* tree-inline.c (declare_return_variable): Check for poly_int_tree_p
instead of INTEGER_CST.

gcc/testsuite/
* gcc.target/aarch64/sve/acle/general/inline_1.c: New test.

From-SVN: r277956

gcc/ChangeLog
gcc/testsuite/ChangeLog
gcc/testsuite/gcc.target/aarch64/sve/acle/general/inline_1.c [new file with mode: 0644]
gcc/tree-inline.c

index 4b1f408d851b840c77dceb7687b4ea4aaf956a3e..b50456e74fc2da3032381fc7a75f64dee6127189 100644 (file)
@@ -1,3 +1,8 @@
+2019-11-08  Richard Sandiford  <richard.sandiford@arm.com>
+
+       * tree-inline.c (declare_return_variable): Check for poly_int_tree_p
+       instead of INTEGER_CST.
+
 2019-11-08  Richard Biener  <rguenther@suse.de>
 
        PR tree-optimization/92324
index 358bbf5eb342901c5b804ecbe13de63fa054c378..9d5702b1c27fc0aa0d0ada50bece85e79d18d5d7 100644 (file)
@@ -1,3 +1,7 @@
+2019-11-08  Richard Sandiford  <richard.sandiford@arm.com>
+
+       * gcc.target/aarch64/sve/acle/general/inline_1.c: New test.
+
 2019-11-08  Richard Biener  <rguenther@suse.de>
 
        PR tree-optimization/92324
diff --git a/gcc/testsuite/gcc.target/aarch64/sve/acle/general/inline_1.c b/gcc/testsuite/gcc.target/aarch64/sve/acle/general/inline_1.c
new file mode 100644 (file)
index 0000000..f736ac3
--- /dev/null
@@ -0,0 +1,6 @@
+/* { dg-options "-O2" } */
+
+#pragma GCC aarch64 "arm_sve.h"
+
+static inline svint32_t foo () { return svdup_s32 (32); }
+svint32_t bar () { return svadd_x (svptrue_b8 (), foo (), 1); }
index 2b8b9ee58c196c4658c7e052e94a09436154d314..9d0acd97f7729c68adbbbfeb6cced8a7a0d19866 100644 (file)
@@ -3654,7 +3654,7 @@ declare_return_variable (copy_body_data *id, tree return_slot, tree modify_dest,
       /* ??? If we're assigning to a variable sized type, then we must
         reuse the destination variable, because we've no good way to
         create variable sized temporaries at this point.  */
-      else if (TREE_CODE (TYPE_SIZE_UNIT (caller_type)) != INTEGER_CST)
+      else if (!poly_int_tree_p (TYPE_SIZE_UNIT (caller_type)))
        use_it = true;
 
       /* If the callee cannot possibly modify MODIFY_DEST, then we can
@@ -3689,7 +3689,7 @@ declare_return_variable (copy_body_data *id, tree return_slot, tree modify_dest,
        }
     }
 
-  gcc_assert (TREE_CODE (TYPE_SIZE_UNIT (callee_type)) == INTEGER_CST);
+  gcc_assert (poly_int_tree_p (TYPE_SIZE_UNIT (callee_type)));
 
   var = copy_result_decl_to_var (result, id);
   DECL_SEEN_IN_BIND_EXPR_P (var) = 1;