forked from OSchip/llvm-project
157 lines
4.3 KiB
C
157 lines
4.3 KiB
C
// REQUIRES: hexagon-registered-target
|
|
// RUN: %clang_cc1 -triple hexagon-unknown-elf -target-cpu hexagonv60 -emit-llvm %s -o - | FileCheck %s
|
|
|
|
// CHECK-LABEL: test1
|
|
// CHECK: @llvm.hexagon.L2.loadrub.pci
|
|
unsigned char test1(int mod, void *start) {
|
|
unsigned char *base = start;
|
|
return __builtin_HEXAGON_L2_loadrub_pci(&base, 4, mod, start);
|
|
}
|
|
|
|
// CHECK-LABEL: test2
|
|
// CHECK: @llvm.hexagon.L2.loadrb.pci
|
|
unsigned char test2(int mod, void *start) {
|
|
char *base = start;
|
|
return __builtin_HEXAGON_L2_loadrb_pci(&base, 4, mod, start);
|
|
}
|
|
|
|
// CHECK-LABEL: test3
|
|
// CHECK: @llvm.hexagon.L2.loadruh.pci
|
|
unsigned short test3(int mod, void *start) {
|
|
unsigned short *base = start;
|
|
return __builtin_HEXAGON_L2_loadruh_pci(&base, 4, mod, start);
|
|
}
|
|
|
|
// CHECK-LABEL: test4
|
|
// CHECK: @llvm.hexagon.L2.loadrh.pci
|
|
short test4(int mod, void *start) {
|
|
short *base = start;
|
|
return __builtin_HEXAGON_L2_loadrh_pci(&base, 4, mod, start);
|
|
}
|
|
|
|
// CHECK-LABEL: test5
|
|
// CHECK: @llvm.hexagon.L2.loadri.pci
|
|
int test5(int mod, void *start) {
|
|
int *base = start;
|
|
return __builtin_HEXAGON_L2_loadri_pci(&base, 4, mod, start);
|
|
}
|
|
|
|
// CHECK-LABEL: test6
|
|
// CHECK: @llvm.hexagon.L2.loadrd.pci
|
|
long long test6(int mod, void *start) {
|
|
long long *base = start;
|
|
return __builtin_HEXAGON_L2_loadrd_pci(&base, 8, mod, start);
|
|
}
|
|
|
|
// CHECK-LABEL: test7
|
|
// CHECK: @llvm.hexagon.L2.loadrub.pcr
|
|
unsigned char test7(int mod, void *start) {
|
|
unsigned char *base = start;
|
|
return __builtin_HEXAGON_L2_loadrub_pcr(&base, mod, start);
|
|
}
|
|
|
|
// CHECK-LABEL: test8
|
|
// CHECK: @llvm.hexagon.L2.loadrb.pcr
|
|
unsigned char test8(int mod, void *start) {
|
|
char *base = start;
|
|
return __builtin_HEXAGON_L2_loadrb_pcr(&base, mod, start);
|
|
}
|
|
|
|
// CHECK-LABEL: test9
|
|
// CHECK: @llvm.hexagon.L2.loadruh.pcr
|
|
unsigned short test9(int mod, void *start) {
|
|
unsigned short *base = start;
|
|
return __builtin_HEXAGON_L2_loadruh_pcr(&base, mod, start);
|
|
}
|
|
|
|
// CHECK-LABEL: test10
|
|
// CHECK: @llvm.hexagon.L2.loadrh.pcr
|
|
short test10(int mod, void *start) {
|
|
short *base = start;
|
|
return __builtin_HEXAGON_L2_loadrh_pcr(&base, mod, start);
|
|
}
|
|
|
|
// CHECK-LABEL: test11
|
|
// CHECK: @llvm.hexagon.L2.loadri.pcr
|
|
int test11(int mod, void *start) {
|
|
int *base = start;
|
|
return __builtin_HEXAGON_L2_loadri_pcr(&base, mod, start);
|
|
}
|
|
|
|
// CHECK-LABEL: test12
|
|
// CHECK: @llvm.hexagon.L2.loadrd.pcr
|
|
long long test12(int mod, void *start) {
|
|
long long *base = start;
|
|
return __builtin_HEXAGON_L2_loadrd_pcr(&base, mod, start);
|
|
}
|
|
|
|
// CHECK-LABEL: test13
|
|
// CHECK: @llvm.hexagon.S2.storerb.pci
|
|
void test13(int mod, void *start, char v) {
|
|
void *base = start;
|
|
__builtin_HEXAGON_S2_storerb_pci(&base, 4, mod, v, start);
|
|
}
|
|
|
|
// CHECK-LABEL: test14
|
|
// CHECK: @llvm.hexagon.S2.storerh.pci
|
|
void test14(int mod, void *start, short v) {
|
|
void *base = start;
|
|
__builtin_HEXAGON_S2_storerh_pci(&base, 4, mod, v, start);
|
|
}
|
|
|
|
// CHECK-LABEL: test15
|
|
// CHECK: @llvm.hexagon.S2.storerf.pci
|
|
void test15(int mod, void *start, short v) {
|
|
void *base = start;
|
|
__builtin_HEXAGON_S2_storerf_pci(&base, 4, mod, v, start);
|
|
}
|
|
|
|
// CHECK-LABEL: test16
|
|
// CHECK: @llvm.hexagon.S2.storeri.pci
|
|
void test16(int mod, void *start, int v) {
|
|
void *base = start;
|
|
__builtin_HEXAGON_S2_storeri_pci(&base, 4, mod, v, start);
|
|
}
|
|
|
|
// CHECK-LABEL: test17
|
|
// CHECK: @llvm.hexagon.S2.storerd.pci
|
|
void test17(int mod, void *start, long long v) {
|
|
void *base = start;
|
|
__builtin_HEXAGON_S2_storerd_pci(&base, 8, mod, v, start);
|
|
}
|
|
|
|
// CHECK-LABEL: test18
|
|
// CHECK: @llvm.hexagon.S2.storerb.pcr
|
|
void test18(int mod, void *start, char v) {
|
|
void *base = start;
|
|
__builtin_HEXAGON_S2_storerb_pcr(&base, mod, v, start);
|
|
}
|
|
|
|
// CHECK-LABEL: test19
|
|
// CHECK: @llvm.hexagon.S2.storerh.pcr
|
|
void test19(int mod, void *start, short v) {
|
|
void *base = start;
|
|
__builtin_HEXAGON_S2_storerh_pcr(&base, mod, v, start);
|
|
}
|
|
|
|
// CHECK-LABEL: test20
|
|
// CHECK: @llvm.hexagon.S2.storerf.pcr
|
|
void test20(int mod, void *start, short v) {
|
|
void *base = start;
|
|
__builtin_HEXAGON_S2_storerf_pcr(&base, mod, v, start);
|
|
}
|
|
|
|
// CHECK-LABEL: test21
|
|
// CHECK: @llvm.hexagon.S2.storeri.pcr
|
|
void test21(int mod, void *start, int v) {
|
|
void *base = start;
|
|
__builtin_HEXAGON_S2_storeri_pcr(&base, mod, v, start);
|
|
}
|
|
|
|
// CHECK-LABEL: test22
|
|
// CHECK: @llvm.hexagon.S2.storerd.pcr
|
|
void test22(int mod, void *start, long long v) {
|
|
void *base = start;
|
|
__builtin_HEXAGON_S2_storerd_pcr(&base, mod, v, start);
|
|
}
|