summaryrefslogtreecommitdiffstats
path: root/llvm/test/CodeGen/X86/sjlj-shadow-stack-liveness.mir
blob: 9536ba1dbc23c74d1992dfa792b181929ae8a66b (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
# RUN: llc -mtriple=x86_64-- -run-pass=finalize-isel -verify-machineinstrs -o - %s | FileCheck %s
# Check that we're not copying the kill flags with the operands from the pseudo
# instruction.
--- |
  define void @bar() { ret void }

  !llvm.module.flags = !{!0}

  !0 = !{i32 4, !"cf-protection-return", i32 1}
...
---
name:            bar
# CHECK-LABEL: name: bar
alignment:       16
tracksRegLiveness: true
body:             |
  bb.0:
    %0:gr64 = IMPLICIT_DEF
    ; CHECK: %0:gr64 = IMPLICIT_DEF
    EH_SjLj_LongJmp64 killed %0, 1, $noreg, 0, $noreg
    ; CHECK: bb.3:
    ; CHECK: MOV64rm %0
    ; CHECK-NOT: MOV64rm killed %0
    ; CHECK: bb.7:
    ; CHECK-NEXT: MOV64rm %0
    ; CHECK-NOT: MOV64rm killed %0
    ; CHECK-NEXT: MOV64rm %0
    ; CHECK-NOT: MOV64rm killed %0
    ; CHECK-NEXT: MOV64rm killed %0

  ; FIXME: Dummy PHI to set the property NoPHIs to false. PR38439.
  bb.2:
    %1:gr64 = PHI undef %1, %bb.2, undef %1, %bb.2
    JMP_1 %bb.2
...
OpenPOWER on IntegriCloud