mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2025-01-31 12:41:49 +01:00
418299d811
Under --target=aarch64-fuchsia, -mcmodel=kernel has the effect of (the default) -mcmodel=small plus -mtp=el1 (which did not exist when this behavior was added). Fuchsia's kernel now uses -mtp=el1 directly instead of -mcmodel=kernel, so remove this special support. Patch By: mcgrathr Differential Revision: https://reviews.llvm.org/D73409
38 lines
1.5 KiB
LLVM
38 lines
1.5 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 -mattr=+tpidr-el1 < %s -o - | FileCheck --check-prefixes=FUCHSIA-AARCH64-COMMON,FUCHSIA-AARCH64-KERNEL %s
|
|
; RUN: llc -mtriple=aarch64-windows < %s -o - | FileCheck --check-prefix=WINDOWS-AARCH64 %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]]
|
|
|
|
; WINDOWS-AARCH64: adrp x8, __security_cookie
|
|
; WINDOWS-AARCH64: ldr x8, [x8, __security_cookie]
|
|
; WINDOWS-AARCH64: str x8, [sp, #8]
|
|
; WINDOWS-AARCH64: bl _Z7CapturePi
|
|
; WINDOWS-AARCH64: ldr x0, [sp, #8]
|
|
; WINDOWS-AARCH64: bl __security_check_cookie
|