30 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			LLVM
		
	
	
	
			
		
		
	
	
			30 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			LLVM
		
	
	
	
| ; Test target-specific stack cookie location.
 | |
| ; RUN: llc -mtriple=aarch64-linux-android < %s -o - | FileCheck --check-prefix=ANDROID-AARCH64 %s
 | |
| ; RUN: llc -mtriple=aarch64-fuchsia < %s -o - | FileCheck --check-prefixes=FUCHSIA-AARCH64-COMMON,FUCHSIA-AARCH64-USER %s
 | |
| ; RUN: llc -mtriple=aarch64-fuchsia -code-model=kernel < %s -o - | FileCheck --check-prefixes=FUCHSIA-AARCH64-COMMON,FUCHSIA-AARCH64-KERNEL %s
 | |
| 
 | |
| define void @_Z1fv() sspreq {
 | |
| entry:
 | |
|   %x = alloca i32, align 4
 | |
|   %0 = bitcast i32* %x to i8*
 | |
|   call void @_Z7CapturePi(i32* nonnull %x)
 | |
|   ret void
 | |
| }
 | |
| 
 | |
| declare void @_Z7CapturePi(i32*)
 | |
| 
 | |
| ; ANDROID-AARCH64: mrs [[A:.*]], TPIDR_EL0
 | |
| ; ANDROID-AARCH64: ldr [[B:.*]], {{\[}}[[A]], #40]
 | |
| ; ANDROID-AARCH64: str [[B]], [sp,
 | |
| ; ANDROID-AARCH64: ldr [[C:.*]], {{\[}}[[A]], #40]
 | |
| ; ANDROID-AARCH64: ldr [[D:.*]], [sp,
 | |
| ; ANDROID-AARCH64: cmp [[C]], [[D]]
 | |
| 
 | |
| ; FUCHSIA-AARCH64-USER: mrs [[A:.*]], TPIDR_EL0
 | |
| ; FUCHSIA-AARCH64-KERNEL: mrs [[A:.*]], TPIDR_EL1
 | |
| ; FUCHSIA-AARCH64-COMMON: ldur [[B:.*]], {{\[}}[[A]], #-16]
 | |
| ; FUCHSIA-AARCH64-COMMON: str [[B]], [sp,
 | |
| ; FUCHSIA-AARCH64-COMMON: ldur [[C:.*]], {{\[}}[[A]], #-16]
 | |
| ; FUCHSIA-AARCH64-COMMON: ldr [[D:.*]], [sp,
 | |
| ; FUCHSIA-AARCH64-COMMON: cmp [[C]], [[D]]
 |