Re-land [openmp] Fix warnings when building on Windows with latest MSVC or Clang...
[llvm-project.git] / llvm / test / CodeGen / AArch64 / blr-bti-preserves-operands.mir
blob760ae4794e304317eeb06efc19b6173e3b7ea6bc
1 # RUN: llc -mtriple=aarch64-none-linux-gnu -run-pass=aarch64-expand-pseudo -o - %s | FileCheck %s
3 # When expanding a BLR_BTI, we should copy all the operands to the branch in the
4 # bundle. Otherwise we could end up using a register after the BL which was
5 # clobbered by the function that was called, or overwriting an argument to that
6 # function before we take the branch.
8 # The arguments to the call must become implicit arguments, because the branch
9 # only expects to get 1 explicit operand which is the branch target.
11 # CHECK:    BUNDLE implicit-def $lr, implicit-def $w30, implicit-def $sp, implicit-def $wsp, implicit $sp, implicit $x0, implicit $w1 {
12 # CHECK:      BL @_setjmp, csr_aarch64_aapcs, implicit-def $lr, implicit $sp, implicit $x0, implicit $w1, implicit-def dead $lr, implicit $sp, implicit-def $sp
13 # CHECK:      HINT 36
14 # CHECK:    }
16 --- |
17   define void @a() {
18     ret void
19   }
21   declare void @_setjmp(...)
22 ...
23 ---
24 name: a
25 body: |
26   bb.0:
27     BLR_BTI @_setjmp, $x0, $w1, csr_aarch64_aapcs, implicit-def dead $lr, implicit $sp, implicit-def $sp
28 ...