Viewing file: vec-signed-compile.c (1.13 KB) -rw-r--r-- Select action/file-type: (+) | (+) | (+) | Code (+) | Session (+) | (+) | SDB (+) | (+) | (+) | (+) | (+) | (+) |
/* { dg-do compile } */ /* { dg-options "-O3 -mzarch -march=arch13 -mzvector -fno-asynchronous-unwind-tables -dp" } */
#include <vecintrin.h>
vector signed int vcfeb (vector float a) { return vec_signed (a); }
/* { dg-final { scan-assembler-times "vcfeb.*\n\tvcfeb.*fix_truncv4sfv4si2" 1 } } */
vector signed long long vcgdb (vector double a) { return vec_signed (a); }
/* { dg-final { scan-assembler-times "vcgdb.*\n\tvcgdb.*fix_truncv2dfv2di2" 1 } } */
vector signed int vcfeb_mem (vector float *a) { return vec_signed (*a); }
vector signed long long vcgdb_mem (vector double *a) { return vec_signed (*a); }
/* The following immediates are being converted and directly stored in the literal pool so no explicit conversion is necessary. */ /* { dg-final { scan-assembler-times "vl\t%v\[0-9\]+,\.L\[0-9\]+\-\.L\[0-9\]+\\(%r\[0-9\]+\\)" 2 } } */
vector signed int vcfeb_imm () { return vec_signed ((vector float) { 1.0f, 2.0f }); }
vector signed long long vcgdb_imm () { return vec_signed ((vector double){ 1.0, 2.0 }); }
/* { dg-final { scan-assembler-times "vcfeb\t" 2 } } */ /* { dg-final { scan-assembler-times "vcgdb\t" 2 } } */
|