blob: 0b48bad23db62e1b45cb8dbf00297bbc3e639494 [file]
# RUN: not --crash llc -mtriple=amdgcn-amd-amdhsa -mcpu=gfx1250 -run-pass=none -filetype=null %s 2>&1 | FileCheck %s
---
name: salu_64_bit_inst_reads_flat_scratch_base_hi
tracksRegLiveness: true
body: |
bb.0:
%0:sreg_64 = IMPLICIT_DEF
$sgpr0_sgpr1 = IMPLICIT_DEF
; CHECK: *** Bad machine code: Instruction cannot read flat_scratch_base_hi ***
; CHECK: S_ASHR_I64
%1:sreg_64 = S_ASHR_I64 %0:sreg_64, $src_flat_scratch_base_hi, implicit-def $scc
; CHECK: *** Bad machine code: Instruction cannot read flat_scratch_base_hi ***
; CHECK: S_LSHL_B64
%2:sreg_64 = S_LSHL_B64 %0:sreg_64, $src_flat_scratch_base_hi, implicit-def $scc
; CHECK: *** Bad machine code: Instruction cannot read flat_scratch_base_hi ***
; CHECK: S_LSHR_B64
%3:sreg_64 = S_LSHR_B64 %0:sreg_64, $src_flat_scratch_base_hi, implicit-def $scc
; CHECK: *** Bad machine code: Instruction cannot read flat_scratch_base_hi ***
; CHECK: S_BFE_I64
%4:sreg_64 = S_BFE_I64 %0:sreg_64, $src_flat_scratch_base_hi, implicit-def $scc
; CHECK: *** Bad machine code: Instruction cannot read flat_scratch_base_hi ***
; CHECK: S_BFE_U64
%5:sreg_64 = S_BFE_U64 %0:sreg_64, $src_flat_scratch_base_hi, implicit-def $scc
; CHECK: *** Bad machine code: Instruction cannot read flat_scratch_base_hi ***
; CHECK: S_BFM_B64
%6:sreg_64 = S_BFM_B64 $src_flat_scratch_base_hi, 1, implicit-def $scc
; CHECK: *** Bad machine code: Instruction cannot read flat_scratch_base_hi ***
; CHECK: S_BITCMP0_B64
S_BITCMP0_B64 %0:sreg_64, $src_flat_scratch_base_hi, implicit $scc, implicit-def $scc
; CHECK: *** Bad machine code: Instruction cannot read flat_scratch_base_hi ***
; CHECK: S_BITCMP1_B64
S_BITCMP1_B64 %0:sreg_64, $src_flat_scratch_base_hi, implicit $scc, implicit-def $scc
; CHECK: *** Bad machine code: Instruction cannot read flat_scratch_base_hi ***
; CHECK: S_BITREPLICATE_B64_B32
%7:sreg_64 = S_BITREPLICATE_B64_B32 $src_flat_scratch_base_hi, implicit-def $scc
; CHECK: *** Bad machine code: Instruction cannot read flat_scratch_base_hi ***
; CHECK: S_BITSET0_B64
$sgpr0_sgpr1 = S_BITSET0_B64 $src_flat_scratch_base_hi, $sgpr0_sgpr1, implicit-def $scc
; CHECK: *** Bad machine code: Instruction cannot read flat_scratch_base_hi ***
; CHECK: S_BITSET1_B64
$sgpr0_sgpr1 = S_BITSET1_B64 $src_flat_scratch_base_hi, $sgpr0_sgpr1, implicit-def $scc
...