[NFC][RemoveDIs] Prefer iterators over inst-pointers in InstCombine
[llvm-project.git] / llvm / test / CodeGen / AArch64 / machine-outliner-retaddr-sign-sp-mod.ll
blob33ee4d9decd743d8933795d6b4849f6b4fd72c22
1 ; RUN: llc -mtriple aarch64 -enable-machine-outliner \
2 ; RUN:  -verify-machineinstrs %s -o - | FileCheck %s
4 @v = common dso_local global ptr null, align 8
6 ; CHECK-LABEL:  foo:                                    // @foo
7 ; CHECK-NEXT:   // %bb.0:                               // %entry
8 ; CHECK-NEXT:       paciasp
9 ; CHECK-NOT:        OUTLINED_FUNCTION_
10 ; CHECK:            retaa
11 define dso_local void @foo(i32 %x) #0 {
12 entry:
13   %0 = zext i32 %x to i64
14   %vla = alloca i32, i64 %0, align 4
15   store volatile ptr %vla, ptr @v, align 8
16   store volatile ptr %vla, ptr @v, align 8
17   store volatile ptr %vla, ptr @v, align 8
18   store volatile ptr %vla, ptr @v, align 8
19   store volatile ptr %vla, ptr @v, align 8
20   store volatile ptr %vla, ptr @v, align 8
21   ret void
24 ; CHECK-LABEL:  bar:                                    // @bar
25 ; CHECK-NEXT:   // %bb.0:                               // %entry
26 ; CHECK-NEXT:       paciasp
27 ; CHECK-NOT:        OUTLINED_FUNCTION_
28 ; CHECK:            retaa
29 define dso_local void @bar(i32 %x) #0 {
30 entry:
31   %0 = zext i32 %x to i64
32   %vla = alloca i32, i64 %0, align 4
33   store volatile ptr null, ptr @v, align 8
34   store volatile ptr %vla, ptr @v, align 8
35   store volatile ptr %vla, ptr @v, align 8
36   store volatile ptr %vla, ptr @v, align 8
37   store volatile ptr %vla, ptr @v, align 8
38   store volatile ptr %vla, ptr @v, align 8
39   ret void
42 attributes #0 = { nounwind "target-features"="+v8.3a" "frame-pointer"="all" "sign-return-address"="all" "sign-return-address-key"="a_key" }
44 ; CHECK-NOT:  OUTLINED_FUNCTION_