/opt/cloudlinux/venv/lib/python3.11/site-packages/numpy/distutils/checks
/** * Testing ASM VSX register number fixer '%x<n>' * * old versions of CLANG doesn't support %x<n> in the inline asm template * which fixes register number when using any of the register constraints wa, wd, wf. * * xref: * - https://bugs.llvm.org/show_bug.cgi?id=31837 * - https://gcc.gnu.org/onlinedocs/gcc/Machine-Constraints.html */ #ifndef __VSX__ #error "VSX is not supported" #endif #include <altivec.h> #if (defined(__GNUC__) && !defined(vec_xl)) || (defined(__clang__) && !defined(__IBMC__)) #define vsx_ld vec_vsx_ld #define vsx_st vec_vsx_st #else #define vsx_ld vec_xl #define vsx_st vec_xst #endif int main(void) { float z4[] = {0, 0, 0, 0}; signed int zout[] = {0, 0, 0, 0}; __vector float vz4 = vsx_ld(0, z4); __vector signed int asm_ret = vsx_ld(0, zout); __asm__ ("xvcvspsxws %x0,%x1" : "=wa" (vz4) : "wa" (asm_ret)); vsx_st(asm_ret, 0, zout); return zout[0]; }
.
Edit
..
Edit
cpu_asimd.c
Edit
cpu_asimddp.c
Edit
cpu_asimdfhm.c
Edit
cpu_asimdhp.c
Edit
cpu_avx.c
Edit
cpu_avx2.c
Edit
cpu_avx512_clx.c
Edit
cpu_avx512_cnl.c
Edit
cpu_avx512_icl.c
Edit
cpu_avx512_knl.c
Edit
cpu_avx512_knm.c
Edit
cpu_avx512_skx.c
Edit
cpu_avx512_spr.c
Edit
cpu_avx512cd.c
Edit
cpu_avx512f.c
Edit
cpu_f16c.c
Edit
cpu_fma3.c
Edit
cpu_fma4.c
Edit
cpu_neon.c
Edit
cpu_neon_fp16.c
Edit
cpu_neon_vfpv4.c
Edit
cpu_popcnt.c
Edit
cpu_sse.c
Edit
cpu_sse2.c
Edit
cpu_sse3.c
Edit
cpu_sse41.c
Edit
cpu_sse42.c
Edit
cpu_ssse3.c
Edit
cpu_vsx.c
Edit
cpu_vsx2.c
Edit
cpu_vsx3.c
Edit
cpu_vsx4.c
Edit
cpu_vx.c
Edit
cpu_vxe.c
Edit
cpu_vxe2.c
Edit
cpu_xop.c
Edit
extra_avx512bw_mask.c
Edit
extra_avx512dq_mask.c
Edit
extra_avx512f_reduce.c
Edit
extra_vsx4_mma.c
Edit
extra_vsx_asm.c
Edit
test_flags.c
Edit