aboutsummaryrefslogtreecommitdiffstats
path: root/gcc-4.9/gcc/testsuite/gcc.dg/vmx/1c-01.c
diff options
context:
space:
mode:
authorBen Cheng <bccheng@google.com>2014-03-25 22:37:19 -0700
committerBen Cheng <bccheng@google.com>2014-03-25 22:37:19 -0700
commit1bc5aee63eb72b341f506ad058502cd0361f0d10 (patch)
treec607e8252f3405424ff15bc2d00aa38dadbb2518 /gcc-4.9/gcc/testsuite/gcc.dg/vmx/1c-01.c
parent283a0bf58fcf333c58a2a92c3ebbc41fb9eb1fdb (diff)
downloadtoolchain_gcc-1bc5aee63eb72b341f506ad058502cd0361f0d10.tar.gz
toolchain_gcc-1bc5aee63eb72b341f506ad058502cd0361f0d10.tar.bz2
toolchain_gcc-1bc5aee63eb72b341f506ad058502cd0361f0d10.zip
Initial checkin of GCC 4.9.0 from trunk (r208799).
Change-Id: I48a3c08bb98542aa215912a75f03c0890e497dba
Diffstat (limited to 'gcc-4.9/gcc/testsuite/gcc.dg/vmx/1c-01.c')
-rw-r--r--gcc-4.9/gcc/testsuite/gcc.dg/vmx/1c-01.c56
1 files changed, 56 insertions, 0 deletions
diff --git a/gcc-4.9/gcc/testsuite/gcc.dg/vmx/1c-01.c b/gcc-4.9/gcc/testsuite/gcc.dg/vmx/1c-01.c
new file mode 100644
index 000000000..974bda19e
--- /dev/null
+++ b/gcc-4.9/gcc/testsuite/gcc.dg/vmx/1c-01.c
@@ -0,0 +1,56 @@
+#include <stddef.h>
+#include "harness.h"
+
+/* Declare vector types. */
+vector unsigned char u8;
+vector signed char s8;
+vector bool char b8;
+vector unsigned short u16;
+vector signed short s16;
+vector bool short b16;
+vector unsigned int u32;
+vector signed int s32;
+vector bool int b32;
+vector float f32;
+vector pixel p16;
+
+vector unsigned char *u8c = &u8;
+vector signed char *s8c = &s8;
+vector bool char *b8c = &b8;
+vector unsigned short *u16c = &u16;
+vector signed short *s16c = &s16;
+vector bool short *b16c = &b16;
+vector unsigned int *u32c = &u32;
+vector signed int *s32c = &s32;
+vector bool int *b32c = &b32;
+vector float *f32c = &f32;
+vector pixel *p16c = &p16;
+
+static void test()
+{
+ check(((ptrdiff_t)u8c & 15) == 0, "alignof(u8)");
+ check(((ptrdiff_t)u8c & 15) == 0, "alignof(u8)");
+ check(((ptrdiff_t)s8c & 15) == 0, "alignof(s8)");
+ check(((ptrdiff_t)b8c & 15) == 0, "alignof(b8)");
+ check(((ptrdiff_t)u16c & 15) == 0, "alignof(u16)");
+ check(((ptrdiff_t)s16c & 15) == 0, "alignof(s16)");
+ check(((ptrdiff_t)b16c & 15) == 0, "alignof(b16)");
+ check(((ptrdiff_t)u32c & 15) == 0, "alignof(u32)");
+ check(((ptrdiff_t)s32c & 15) == 0, "alignof(s32)");
+ check(((ptrdiff_t)b32c & 15) == 0, "alignof(b32)");
+ check(((ptrdiff_t)f32c & 15) == 0, "alignof(f32)");
+ check(((ptrdiff_t)p16c & 15) == 0, "alignof(p16)");
+
+ check((ptrdiff_t)u8c == (ptrdiff_t)&u8, "u8c == &u8");
+ check((ptrdiff_t)u8c == (ptrdiff_t)&u8, "u8c == &u8");
+ check((ptrdiff_t)s8c == (ptrdiff_t)&s8, "s8c == &s8");
+ check((ptrdiff_t)b8c == (ptrdiff_t)&b8, "b8c == &b8");
+ check((ptrdiff_t)u16c == (ptrdiff_t)&u16, "u16c == &u16");
+ check((ptrdiff_t)s16c == (ptrdiff_t)&s16, "s16c == &s16");
+ check((ptrdiff_t)b16c == (ptrdiff_t)&b16, "b16c == &b16");
+ check((ptrdiff_t)u32c == (ptrdiff_t)&u32, "u32c == &u32");
+ check((ptrdiff_t)s32c == (ptrdiff_t)&s32, "s32c == &s32");
+ check((ptrdiff_t)b32c == (ptrdiff_t)&b32, "b32c == &b32");
+ check((ptrdiff_t)f32c == (ptrdiff_t)&f32, "f32c == &f32");
+ check((ptrdiff_t)p16c == (ptrdiff_t)&p16, "p16c == &p16");
+}