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);
 | |
| }
 |