Changeset View
Changeset View
Standalone View
Standalone View
llvm/test/CodeGen/AArch64/stack-protector-target.ll
; Test target-specific stack cookie location. | ; Test target-specific stack cookie location. | ||||
; RUN: llc -mtriple=aarch64-linux-android < %s -o - | FileCheck --check-prefix=ANDROID-AARCH64 %s | ; 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 < %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-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 | ; RUN: llc -mtriple=aarch64-windows < %s -o - | FileCheck --check-prefix=WINDOWS-AARCH64 %s | ||||
; RUN: llc -mtriple=arm64ec-windows-msvc < %s -o - | FileCheck --check-prefix=WINDOWS-ARM64EC %s | ; RUN: llc -mtriple=arm64ec-windows-msvc < %s -o - | FileCheck --check-prefix=WINDOWS-ARM64EC %s | ||||
define void @_Z1fv() sspreq { | define void @_Z1fv() sspreq { | ||||
entry: | entry: | ||||
%x = alloca i32, align 4 | %x = alloca i32, align 4 | ||||
%0 = bitcast i32* %x to i8* | %0 = bitcast i32* %x to i8* | ||||
call void @_Z7CapturePi(i32* nonnull %x) | call void @_Z7CapturePi(i32* nonnull %x) | ||||
ret void | ret void | ||||
} | } | ||||
declare void @_Z7CapturePi(i32*) | declare dso_local void @_Z7CapturePi(i32*) | ||||
; ANDROID-AARCH64: mrs [[A:.*]], TPIDR_EL0 | ; ANDROID-AARCH64: mrs [[A:.*]], TPIDR_EL0 | ||||
; ANDROID-AARCH64: ldr [[B:.*]], [[[A]], #40] | ; ANDROID-AARCH64: ldr [[B:.*]], [[[A]], #40] | ||||
; ANDROID-AARCH64: str [[B]], [sp, | ; ANDROID-AARCH64: str [[B]], [sp, | ||||
; ANDROID-AARCH64: ldr [[C:.*]], [[[A]], #40] | ; ANDROID-AARCH64: ldr [[C:.*]], [[[A]], #40] | ||||
; ANDROID-AARCH64: ldr [[D:.*]], [sp, | ; ANDROID-AARCH64: ldr [[D:.*]], [sp, | ||||
; ANDROID-AARCH64: cmp [[C]], [[D]] | ; ANDROID-AARCH64: cmp [[C]], [[D]] | ||||
Show All 21 Lines |