aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorHartmut Penner <hpenner@de.ibm.com>2004-01-08 07:27:09 +0000
committerHartmut Penner <hpenner@gcc.gnu.org>2004-01-08 07:27:09 +0000
commit417b11de06fd86a2c9efd6ab5572c498baf65b58 (patch)
treedfca3b627a8fd5f1cdd65bae8f3c814edd1f7241
parentce1f50b212408a151c9171eb0ac9c5ef0ac10439 (diff)
downloadgcc-417b11de06fd86a2c9efd6ab5572c498baf65b58.zip
gcc-417b11de06fd86a2c9efd6ab5572c498baf65b58.tar.gz
gcc-417b11de06fd86a2c9efd6ab5572c498baf65b58.tar.bz2
* gcc.dg/altivec-11.c: New test.
From-SVN: r75535
-rw-r--r--gcc/testsuite/ChangeLog4
-rw-r--r--gcc/testsuite/gcc.dg/altivec-11.c45
2 files changed, 49 insertions, 0 deletions
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog
index 45d4c24..778a82e 100644
--- a/gcc/testsuite/ChangeLog
+++ b/gcc/testsuite/ChangeLog
@@ -1,3 +1,7 @@
+2004-01-08 Hartmut Penner <hpenner@de.ibm.com>
+
+ * gcc.dg/altivec-11.c: New test.
+
2004-01-07 Mark Mitchell <mark@codesourcery.com>
* g++.dg/abi/vbase10.C: Use -mstructure-size-boundary=8 on ARM.
diff --git a/gcc/testsuite/gcc.dg/altivec-11.c b/gcc/testsuite/gcc.dg/altivec-11.c
new file mode 100644
index 0000000..3b71f2a
--- /dev/null
+++ b/gcc/testsuite/gcc.dg/altivec-11.c
@@ -0,0 +1,45 @@
+/* { dg-do compile { target powerpc*-*-* } } */
+/* { dg-options "-O2 -maltivec -mabi=altivec" } */
+/* { dg-final { scan-assembler-not "lvx" } } */
+#include <altivec.h>
+
+void foo (vector int);
+void foo_s (vector short);
+void foo_c (vector char);
+
+/* All constants should be loaded into vector register without
+ load from memory. */
+void
+bar (void)
+{
+ foo ((vector int) {0, 0, 0, 0});
+ foo ((vector int) {1, 1, 1, 1});
+ foo ((vector int) {15, 15, 15, 15});
+ foo ((vector int) {-16, -16, -16, -16});
+ foo ((vector int) {0x10001, 0x10001, 0x10001, 0x10001});
+ foo ((vector int) {0xf000f, 0xf000f, 0xf000f, 0xf000f});
+ foo ((vector int) {0xfff0fff0, 0xfff0fff0, 0xfff0fff0, 0xfff0fff0});
+ foo ((vector int) {0x1010101, 0x1010101, 0x1010101, 0x1010101});
+ foo ((vector int) {0xf0f0f0f, 0xf0f0f0f, 0xf0f0f0f, 0xf0f0f0f});
+ foo ((vector int) {0xf0f0f0f0, 0xf0f0f0f0, 0xf0f0f0f0, 0xf0f0f0f0});
+ foo ((vector int) {0x10, 0x10, 0x10, 0x10});
+ foo ((vector int) {0x1e, 0x1e, 0x1e, 0x1e});
+
+ foo_s ((vector short int) {0, 0, 0, 0, 0, 0, 0, 0});
+ foo_s ((vector short int) {1, 1, 1, 1, 1, 1, 1, 1});
+ foo_s ((vector short int) {15, 15, 15, 15, 15, 15, 15, 15});
+ foo_s ((vector short int) {-16, -16, -16, -16, -16, -16, -16, -16});
+ foo_s ((vector short int) {0xf0f0, 0xf0f0, 0xf0f0, 0xf0f0,
+ 0xf0f0, 0xf0f0, 0xf0f0, 0xf0f0});
+ foo_s ((vector short int) {0xf0f, 0xf0f, 0xf0f, 0xf0f,
+ 0xf0f, 0xf0f, 0xf0f, 0xf0f});
+
+ foo_c ((vector char) {0, 0, 0, 0, 0, 0, 0, 0,
+ 0, 0, 0, 0, 0, 0, 0, 0});
+ foo_c ((vector char) {1, 1, 1, 1, 1, 1, 1, 1,
+ 1, 1, 1, 1, 1, 1, 1, 1});
+ foo_c ((vector char) {15, 15, 15, 15, 15, 15, 15, 15,
+ 15, 15, 15, 15, 15, 15, 15, 15});
+ foo_c ((vector char) {-16, -16, -16, -16, -16, -16, -16, -16,
+ -16, -16, -16, -16, -16, -16, -16, -16});
+}