forked from OSchip/llvm-project
				
			
		
			
				
	
	
		
			47 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			C
		
	
	
	
			
		
		
	
	
			47 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			C
		
	
	
	
| // REQUIRES: hexagon-registered-target
 | |
| // RUN: %clang_cc1 -emit-llvm -O2 -o - -triple hexagon-unknown-elf %s | FileCheck %s
 | |
| // This unit test validates that the store to "dst" variable needs to be eliminated.
 | |
| 
 | |
| // CHECK: @brev_store_elimination_test1
 | |
| // CHECK: llvm.hexagon.L2.loadri.pbr
 | |
| // CHECK-NOT: store
 | |
| 
 | |
| int *brev_store_elimination_test1(int *ptr, int mod) {
 | |
|   int dst = 100;
 | |
|   return __builtin_brev_ldw(ptr, &dst, mod);
 | |
| }
 | |
| 
 | |
| // CHECK: @brev_store_elimination_test2
 | |
| // CHECK: llvm.hexagon.L2.loadri.pbr
 | |
| // CHECK-NOT: store
 | |
| extern int add(int a);
 | |
| int brev_store_elimination_test2(int *ptr, int mod) {
 | |
|   int dst = 100;
 | |
|   __builtin_brev_ldw(ptr, &dst, mod);
 | |
|   return add(dst);
 | |
| }
 | |
| 
 | |
| // CHECK: @brev_store_elimination_test3
 | |
| // CHECK: llvm.hexagon.L2.loadri.pbr
 | |
| // CHECK-NOT: store
 | |
| int brev_store_elimination_test3(int *ptr, int mod, int inc) {
 | |
|   int dst = 100;
 | |
|   for (int i = 0; i < inc; ++i) {
 | |
|     __builtin_brev_ldw(ptr, &dst, mod);
 | |
|     dst = add(dst);
 | |
|   }
 | |
|   return dst;
 | |
| }
 | |
| 
 | |
| // brev_store_elimination_test4 validates the fact that we are not deleting the
 | |
| // stores if the value is passed by reference later.
 | |
| // CHECK: @brev_store_elimination_test4
 | |
| // CHECK: llvm.hexagon.L2.loadri.pbr
 | |
| // CHECK: store
 | |
| extern int sub(int *a);
 | |
| int brev_store_elimination_test4(int *ptr, int mod) {
 | |
|   int dst = 100;
 | |
|   __builtin_brev_ldw(ptr, &dst, mod);
 | |
|   return sub(&dst);
 | |
| }
 |