From 1bc5aee63eb72b341f506ad058502cd0361f0d10 Mon Sep 17 00:00:00 2001 From: Ben Cheng Date: Tue, 25 Mar 2014 22:37:19 -0700 Subject: Initial checkin of GCC 4.9.0 from trunk (r208799). Change-Id: I48a3c08bb98542aa215912a75f03c0890e497dba --- gcc-4.9/gcc/testsuite/gcc.target/sparc/pdist-3.c | 37 ++++++++++++++++++++++++ 1 file changed, 37 insertions(+) create mode 100644 gcc-4.9/gcc/testsuite/gcc.target/sparc/pdist-3.c (limited to 'gcc-4.9/gcc/testsuite/gcc.target/sparc/pdist-3.c') diff --git a/gcc-4.9/gcc/testsuite/gcc.target/sparc/pdist-3.c b/gcc-4.9/gcc/testsuite/gcc.target/sparc/pdist-3.c new file mode 100644 index 000000000..03df4d96d --- /dev/null +++ b/gcc-4.9/gcc/testsuite/gcc.target/sparc/pdist-3.c @@ -0,0 +1,37 @@ +/* { dg-do run } */ +/* { dg-require-effective-target ultrasparc_hw } */ +/* { dg-options "-mcpu=ultrasparc -mvis -O1" } */ + +typedef long long int64_t; +typedef unsigned char vec8 __attribute__((vector_size(8))); + +extern void abort (); +extern void exit (int); + +#define _(A) (unsigned char)A + +int64_t foo (vec8 a, vec8 b) { + int64_t d = 2; + d = __builtin_vis_pdist (a, b, d); + return d; +} + +int64_t bar () { + int64_t d = 2; + vec8 a = { _(1), _(2), _(3), _(4), _(5), _(6), _(7), _(255) }; + vec8 b = { _(2), _(4), _(8), _(16), _(32), _(64), _(128), _(8) }; + d = __builtin_vis_pdist (a, b, d); + return d; +} + + +static vec8 a = { 1, 2, 3, 4, 5, 6, 7, 255 }; +static vec8 b = { 2, 4, 8, 16, 32, 64, 128, 8 }; + +int main (int argc, char *argv[]) { + + if (foo (a, b) != bar ()) + abort (); + + exit (0); +} -- cgit v1.2.3