aboutsummaryrefslogtreecommitdiff
path: root/gcc/testsuite/gcc.target/powerpc/pr91275.c
diff options
context:
space:
mode:
authorgccadmin <gccadmin@138bc75d-0d04-0410-961f-82ee72b054a4>2019-10-17 00:16:05 +0000
committergccadmin <gccadmin@138bc75d-0d04-0410-961f-82ee72b054a4>2019-10-17 00:16:05 +0000
commitcb73f7448091806286514e3a251f358b60053a82 (patch)
tree88cbcc563369204fc3fb15ad0675a8103de9609b /gcc/testsuite/gcc.target/powerpc/pr91275.c
parent4f81768e3acf1633764b2a3a1c69551d3dee966c (diff)
Daily bump.
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/branches/gcc-7-branch@277085 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'gcc/testsuite/gcc.target/powerpc/pr91275.c')
-rw-r--r--gcc/testsuite/gcc.target/powerpc/pr91275.c21
1 files changed, 21 insertions, 0 deletions
diff --git a/gcc/testsuite/gcc.target/powerpc/pr91275.c b/gcc/testsuite/gcc.target/powerpc/pr91275.c
new file mode 100644
index 00000000000..b23d75be29b
--- /dev/null
+++ b/gcc/testsuite/gcc.target/powerpc/pr91275.c
@@ -0,0 +1,21 @@
+/* Test that we generate vpmsumd correctly without a swap error. */
+
+/* { dg-do run { target { p8vector_hw } } } */
+/* { dg-options "-O2 -std=gnu11" } */
+
+#include <altivec.h>
+
+int main() {
+
+ const unsigned long long r0l = 0x8e7dfceac070e3a0;
+ vector unsigned long long r0 = (vector unsigned long long) {r0l, 0}, v;
+ const vector unsigned long long pd
+ = (vector unsigned long) {0xc2LLU << 56, 0};
+
+ v = __builtin_crypto_vpmsumd ((vector unsigned long long) {r0[0], 0}, pd);
+
+ if (v[0] != 0x4000000000000000 || v[1] != 0x65bd7ab605a4a8ff)
+ __builtin_abort ();
+
+ return 0;
+}