Viewing file: larch-builtin.c (6.22 KB) -rw-r--r-- Select action/file-type: (+) | (+) | (+) | Code (+) | Session (+) | (+) | SDB (+) | (+) | (+) | (+) | (+) | (+) |
/* Test for LoongArch intrinsics. */
/* { dg-do compile } */
/* { dg-final { scan-assembler-times "test_rdtime_d:.*rdtime\\.d.*\\.size test_rdtime_d" 1 } } */ /* { dg-final { scan-assembler-times "test_rdtimeh_w:.*rdtimeh\\.w.*\\.size test_rdtimeh_w" 1 } } */ /* { dg-final { scan-assembler-times "test_rdtimel_w:.*rdtimel\\.w.*\\.size test_rdtimel_w" 1 } } */ /* { dg-final { scan-assembler-times "test_movfcsr2gr:.*movfcsr2gr.*\\.size test_movfcsr2gr" 1 } } */ /* { dg-final { scan-assembler-times "test_movgr2fcsr:.*movgr2fcsr.*\\.size test_movgr2fcsr" 1 } } */ /* { dg-final { scan-assembler-times "test_cacop_d:.*cacop.*\\.size test_cacop_d" 1 } } */ /* { dg-final { scan-assembler-times "test_cpucfg:.*cpucfg.*\\.size test_cpucfg" 1 } } */ /* { dg-final { scan-assembler-times "test_asrtle_d:.*asrtle\\.d.*\\.size test_asrtle_d" 1 } } */ /* { dg-final { scan-assembler-times "test_asrtgt_d:.*asrtgt\\.d.*\\.size test_asrtgt_d" 1 } } */ /* { dg-final { scan-assembler-times "test_lddir_d:.*lddir.*\\.size test_lddir_d" 1 } } */ /* { dg-final { scan-assembler-times "test_ldpte_d:.*ldpte.*\\.size test_ldpte_d" 1 } } */ /* { dg-final { scan-assembler-times "test_crc_w_b_w:.*crc\\.w\\.b\\.w.*\\.size test_crc_w_b_w" 1 } } */ /* { dg-final { scan-assembler-times "test_crc_w_h_w:.*crc\\.w\\.h\\.w.*\\.size test_crc_w_h_w" 1 } } */ /* { dg-final { scan-assembler-times "test_crc_w_w_w:.*crc\\.w\\.w\\.w.*\\.size test_crc_w_w_w" 1 } } */ /* { dg-final { scan-assembler-times "test_crc_w_d_w:.*crc\\.w\\.d\\.w.*\\.size test_crc_w_d_w" 1 } } */ /* { dg-final { scan-assembler-times "test_crcc_w_b_w:.*crcc\\.w\\.b\\.w.*\\.size test_crcc_w_b_w" 1 } } */ /* { dg-final { scan-assembler-times "test_crcc_w_h_w:.*crcc\\.w\\.h\\.w.*\\.size test_crcc_w_h_w" 1 } } */ /* { dg-final { scan-assembler-times "test_crcc_w_w_w:.*crcc\\.w\\.w\\.w.*\\.size test_crcc_w_w_w" 1 } } */ /* { dg-final { scan-assembler-times "test_crcc_w_d_w:.*crcc\\.w\\.d\\.w.*\\.size test_crcc_w_d_w" 1 } } */ /* { dg-final { scan-assembler-times "test_csrrd_w:.*csrrd.*\\.size test_csrrd_w" 1 } } */ /* { dg-final { scan-assembler-times "test_csrwr_w:.*csrwr.*\\.size test_csrwr_w" 1 } } */ /* { dg-final { scan-assembler-times "test_csrxchg_w:.*csrxchg.*\\.size test_csrxchg_w" 1 } } */ /* { dg-final { scan-assembler-times "test_csrrd_d:.*csrrd.*\\.size test_csrrd_d" 1 } } */ /* { dg-final { scan-assembler-times "test_csrwr_d:.*csrwr.*\\.size test_csrwr_d" 1 } } */ /* { dg-final { scan-assembler-times "test_csrxchg_d:.*csrxchg.*\\.size test_csrxchg_d" 1 } } */ /* { dg-final { scan-assembler-times "test_iocsrrd_b:.*iocsrrd\\.b.*\\.size test_iocsrrd_b" 1 } } */ /* { dg-final { scan-assembler-times "test_iocsrrd_h:.*iocsrrd\\.h.*\\.size test_iocsrrd_h" 1 } } */ /* { dg-final { scan-assembler-times "test_iocsrrd_w:.*iocsrrd\\.w.*\\.size test_iocsrrd_w" 1 } } */ /* { dg-final { scan-assembler-times "test_iocsrrd_d:.*iocsrrd\\.d.*\\.size test_iocsrrd_d" 1 } } */ /* { dg-final { scan-assembler-times "test_iocsrwr_b:.*iocsrwr\\.b.*\\.size test_iocsrwr_b" 1 } } */ /* { dg-final { scan-assembler-times "test_iocsrwr_h:.*iocsrwr\\.h.*\\.size test_iocsrwr_h" 1 } } */ /* { dg-final { scan-assembler-times "test_iocsrwr_w:.*iocsrwr\\.w.*\\.size test_iocsrwr_w" 1 } } */ /* { dg-final { scan-assembler-times "test_iocsrwr_d:.*iocsrwr\\.d.*\\.size test_iocsrwr_d" 1 } } */ /* { dg-final { scan-assembler-times "test_dbar:.*dbar.*\\.size test_dbar" 1 } } */ /* { dg-final { scan-assembler-times "test_ibar:.*ibar.*\\.size test_ibar" 1 } } */ /* { dg-final { scan-assembler-times "test_syscall:.*syscall.*\\.size test_syscall" 1 } } */ /* { dg-final { scan-assembler-times "test_break:.*break.*\\.size test_break" 1 } } */
#include<larchintrin.h>
__drdtime_t test_rdtime_d () { return __rdtime_d (); }
__rdtime_t test_rdtimeh_w () { return __rdtimeh_w (); }
__rdtime_t test_rdtimel_w () { return __rdtimel_w (); }
unsigned int test_movfcsr2gr () { return __movfcsr2gr (1); }
void test_movgr2fcsr (unsigned int _1) { __movgr2fcsr (1, _1); }
void test_cacop_d (unsigned long int _1) { __cacop_d (1, _1, 1); }
unsigned int test_cpucfg (unsigned int _1) { return __cpucfg (_1); }
void test_asrtle_d (long int _1, long int _2) { __asrtle_d (_1, _2); }
void test_asrtgt_d (long int _1, long int _2) { __asrtgt_d (_1, _2); }
long int test_lddir_d (long int _1) { return __lddir_d (_1, 1); }
void test_ldpte_d (long int _1) { __ldpte_d (_1, 1); }
int test_crc_w_b_w (char _1, int _2) { return __crc_w_b_w (_1, _2); }
int test_crc_w_h_w (short _1, int _2) { return __crc_w_h_w (_1, _2); }
int test_crc_w_w_w (int _1, int _2) { return __crc_w_w_w (_1, _2); }
int test_crc_w_d_w (long int _1, int _2) { return __crc_w_d_w (_1, _2); }
int test_crcc_w_b_w (char _1, int _2) { return __crcc_w_b_w (_1, _2); }
int test_crcc_w_h_w (short _1, int _2) { return __crcc_w_h_w (_1, _2); }
int test_crcc_w_w_w (int _1, int _2) { return __crcc_w_w_w (_1, _2); }
int test_crcc_w_d_w (long int _1, int _2) { return __crcc_w_d_w (_1, _2); }
unsigned int test_csrrd_w () { return __csrrd_w (1); }
unsigned int test_csrwr_w (unsigned int _1) { return __csrwr_w (_1, 1); }
unsigned int test_csrxchg_w (unsigned int _1, unsigned int _2) { return __csrxchg_w (_1, _2, 1); }
unsigned long int test_csrrd_d () { return __csrrd_d (1); }
unsigned long int test_csrwr_d (unsigned long int _1) { return __csrwr_d (_1, 1); }
unsigned long int test_csrxchg_d (unsigned long int _1, unsigned long int _2) { return __csrxchg_d (_1, _2, 1); }
unsigned char test_iocsrrd_b (unsigned int _1) { return __iocsrrd_b (_1); }
unsigned char test_iocsrrd_h (unsigned int _1) { return __iocsrrd_h (_1); }
unsigned int test_iocsrrd_w (unsigned int _1) { return __iocsrrd_w (_1); }
unsigned long int test_iocsrrd_d (unsigned int _1) { return __iocsrrd_d (_1); }
void test_iocsrwr_b (unsigned char _1, unsigned int _2) { __iocsrwr_b (_1, _2); }
void test_iocsrwr_h (unsigned short _1, unsigned int _2) { __iocsrwr_h (_1, _2); }
void test_iocsrwr_w (unsigned int _1, unsigned int _2) { __iocsrwr_w (_1, _2); }
void test_iocsrwr_d (unsigned long int _1, unsigned int _2) { __iocsrwr_d (_1, _2); }
void test_dbar () { __dbar (1); }
void test_ibar () { __ibar (1); }
void test_syscall () { __syscall (1); }
void test_break () { __break (1); }
|