mirror of
https://github.com/Stichting-MINIX-Research-Foundation/pkgsrc-ng.git
synced 2025-09-28 06:26:12 -04:00
54 lines
2.4 KiB
C
54 lines
2.4 KiB
C
$NetBSD$
|
|
|
|
--- gcc/testsuite/gcc.target/powerpc/cell_builtin-2.c.orig Wed May 21 19:48:58 2014
|
|
+++ gcc/testsuite/gcc.target/powerpc/cell_builtin-2.c
|
|
@@ -0,0 +1,48 @@
|
|
+/* { dg-do compile { target { powerpc*-*-* } } } */
|
|
+/* { dg-skip-if "" { powerpc*-*-darwin* } { "*" } { "" } } */
|
|
+/* { dg-require-effective-target powerpc_altivec_ok } */
|
|
+/* { dg-options "-O2 -maltivec -mcpu=cell" } */
|
|
+/* { dg-final { scan-assembler-times "lvlxl" 19 } } */
|
|
+
|
|
+#include <altivec.h>
|
|
+
|
|
+typedef __vector signed char vsc;
|
|
+typedef __vector signed short vss;
|
|
+typedef __vector signed int vsi;
|
|
+typedef __vector unsigned char vuc;
|
|
+typedef __vector unsigned short vus;
|
|
+typedef __vector unsigned int vui;
|
|
+typedef __vector bool char vbc;
|
|
+typedef __vector bool short vbs;
|
|
+typedef __vector bool int vbi;
|
|
+typedef __vector float vsf;
|
|
+typedef __vector pixel vp;
|
|
+typedef signed char sc;
|
|
+typedef signed short ss;
|
|
+typedef signed int si;
|
|
+typedef signed long sl;
|
|
+typedef unsigned char uc;
|
|
+typedef unsigned short us;
|
|
+typedef unsigned int ui;
|
|
+typedef unsigned long ul;
|
|
+typedef float sf;
|
|
+
|
|
+vsc lc2(long a, void *p) { return __builtin_altivec_lvlxl (a,p); }
|
|
+vsf llxl01(long a, vsf *p) { return __builtin_vec_lvlxl (a,p); }
|
|
+vsf llxl02(long a, sf *p) { return __builtin_vec_lvlxl (a,p); }
|
|
+vbi llxl03(long a, vbi *p) { return __builtin_vec_lvlxl (a,p); }
|
|
+vsi llxl04(long a, vsi *p) { return __builtin_vec_lvlxl (a,p); }
|
|
+vsi llxl05(long a, si *p) { return __builtin_vec_lvlxl (a,p); }
|
|
+vui llxl06(long a, vui *p) { return __builtin_vec_lvlxl (a,p); }
|
|
+vui llxl07(long a, ui *p) { return __builtin_vec_lvlxl (a,p); }
|
|
+vbs llxl08(long a, vbs *p) { return __builtin_vec_lvlxl (a,p); }
|
|
+vp llxl09(long a, vp *p) { return __builtin_vec_lvlxl (a,p); }
|
|
+vss llxl10(long a, vss *p) { return __builtin_vec_lvlxl (a,p); }
|
|
+vss llxl11(long a, ss *p) { return __builtin_vec_lvlxl (a,p); }
|
|
+vus llxl12(long a, vus *p) { return __builtin_vec_lvlxl (a,p); }
|
|
+vus llxl13(long a, us *p) { return __builtin_vec_lvlxl (a,p); }
|
|
+vbc llxl14(long a, vbc *p) { return __builtin_vec_lvlxl (a,p); }
|
|
+vsc llxl15(long a, vsc *p) { return __builtin_vec_lvlxl (a,p); }
|
|
+vsc llxl16(long a, sc *p) { return __builtin_vec_lvlxl (a,p); }
|
|
+vuc llxl17(long a, vuc *p) { return __builtin_vec_lvlxl (a,p); }
|
|
+vuc llxl18(long a, uc *p) { return __builtin_vec_lvlxl (a,p); }
|