[MIParser] Set RegClassOrRegBank during instruction parsing
[llvm-complete.git] / test / CodeGen / AArch64 / GlobalISel / arm64-irtranslator-stackprotect.ll
blobad01264f1a43f19362aec25d92e7682a25feb39c
1 ; RUN: llc -verify-machineinstrs -mtriple=aarch64-apple-ios %s -stop-after=irtranslator -o - -global-isel | FileCheck %s
4 ; CHECK: name: test_stack_guard
6 ; CHECK: frameInfo:
7 ; CHECK: stackProtector:  '%stack.0.StackGuardSlot'
9 ; CHECK: stack:
10 ; CHECK:  - { id: 0, name: StackGuardSlot,  type: default, offset: 0, size: 8, alignment: 8,
11 ; CHECK-NOT: id: 1
13 ; CHECK: [[GUARD_SLOT:%[0-9]+]]:_(p0) = G_FRAME_INDEX %stack.0.StackGuardSlot
14 ; CHECK: [[GUARD:%[0-9]+]]:gpr64sp(p0) = LOAD_STACK_GUARD :: (dereferenceable invariant load 8 from @__stack_chk_guard)
15 ; CHECK: G_STORE [[GUARD]](p0), [[GUARD_SLOT]](p0) :: (volatile store 8 into %stack.0.StackGuardSlot)
16 declare void @llvm.stackprotector(i8*, i8**)
17 define void @test_stack_guard_remat2() {
18   %StackGuardSlot = alloca i8*
19   call void @llvm.stackprotector(i8* undef, i8** %StackGuardSlot)
20   ret void
23 @__stack_chk_guard = external global i64*