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 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96
|
# RUN: llc -march=amdgcn -mcpu=gfx900 -run-pass si-insert-waitcnts %s -o - | FileCheck %s
# Ensure we insert waitcnts after any meta instructions at the start of
# non-kernel functions. Without this, the inserted waitcnts can affect e.g. the
# PC ranges covered by CFI and debug values.
---
# CHECK-LABEL: name: skip_implicit_def{{$}}
# CHECK: IMPLICIT_DEF
# CHECK: S_WAITCNT
name: skip_implicit_def
machineFunctionInfo:
body: |
bb.0:
$sgpr0 = IMPLICIT_DEF
...
---
# CHECK-LABEL: name: skip_kill{{$}}
# CHECK: KILL
# CHECK: S_WAITCNT
name: skip_kill
machineFunctionInfo:
body: |
bb.0:
KILL $sgpr0
...
---
# CHECK-LABEL: name: skip_cfi{{$}}
# CHECK: CFI_INSTRUCTION
# CHECK: S_WAITCNT
name: skip_cfi
machineFunctionInfo:
body: |
bb.0:
CFI_INSTRUCTION undefined $sgpr0
...
---
# CHECK-LABEL: name: skip_eh_label{{$}}
# CHECK: EH_LABEL
# CHECK: S_WAITCNT
name: skip_eh_label
machineFunctionInfo:
body: |
bb.0:
EH_LABEL 0
...
---
# CHECK-LABEL: name: skip_gc_label{{$}}
# CHECK: GC_LABEL
# CHECK: S_WAITCNT
name: skip_gc_label
machineFunctionInfo:
body: |
bb.0:
GC_LABEL 0
...
---
# CHECK-LABEL: name: skip_dbg_value{{$}}
# CHECK: DBG_VALUE
# CHECK: S_WAITCNT
name: skip_dbg_value
machineFunctionInfo:
body: |
bb.0:
DBG_VALUE 0
...
---
# CHECK-LABEL: name: skip_dbg_label{{$}}
# CHECK: DBG_LABEL
# CHECK: S_WAITCNT
name: skip_dbg_label
machineFunctionInfo:
body: |
bb.0:
DBG_LABEL 0
...
---
# CHECK-LABEL: name: skip_lifetime_start{{$}}
# CHECK: LIFETIME_START
# CHECK: S_WAITCNT
name: skip_lifetime_start
machineFunctionInfo:
body: |
bb.0:
LIFETIME_START 0
...
---
# CHECK-LABEL: name: skip_lifetime_end{{$}}
# CHECK: LIFETIME_END
# CHECK: S_WAITCNT
name: skip_lifetime_end
machineFunctionInfo:
body: |
bb.0:
LIFETIME_END 0
...
|