blob: ca7ddb1406f558e7ccfe322331dc0de8f04bff85 [file] [log] [blame]
/* 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);
}