blob: 30654e0c3c0745abbfdf0b4ded2bbc8677df0909 [file] [log] [blame]
# NOTE: Assertions have been autogenerated by utils/update_mir_test_checks.py
# RUN: llc -mtriple=amdgcn-amd-amdhsa -mcpu=fiji -run-pass=amdgpu-postlegalizer-combiner -verify-machineinstrs %s -o - | FileCheck %s
---
name: cvt_f32_ubyte0_lshr_0
tracksRegLiveness: true
body: |
bb.0:
liveins: $vgpr0
; CHECK-LABEL: name: cvt_f32_ubyte0_lshr_0
; CHECK: liveins: $vgpr0
; CHECK: %arg:_(s32) = COPY $vgpr0
; CHECK: %result:_(s32) = G_AMDGPU_CVT_F32_UBYTE0 %arg
; CHECK: $vgpr0 = COPY %result(s32)
%arg:_(s32) = COPY $vgpr0
%shiftamt:_(s32) = G_CONSTANT i32 0
%shift:_(s32) = G_LSHR %arg, %shiftamt
%result:_(s32) = G_AMDGPU_CVT_F32_UBYTE0 %shift
$vgpr0 = COPY %result
...
---
name: cvt_f32_ubyte0_lshr_8
tracksRegLiveness: true
body: |
bb.0:
liveins: $vgpr0
; CHECK-LABEL: name: cvt_f32_ubyte0_lshr_8
; CHECK: liveins: $vgpr0
; CHECK: %arg:_(s32) = COPY $vgpr0
; CHECK: %result:_(s32) = G_AMDGPU_CVT_F32_UBYTE1 %arg
; CHECK: $vgpr0 = COPY %result(s32)
%arg:_(s32) = COPY $vgpr0
%shiftamt:_(s32) = G_CONSTANT i32 8
%shift:_(s32) = G_LSHR %arg, %shiftamt
%result:_(s32) = G_AMDGPU_CVT_F32_UBYTE0 %shift
$vgpr0 = COPY %result
...
---
name: cvt_f32_ubyte0_lshr_16
tracksRegLiveness: true
body: |
bb.0:
liveins: $vgpr0
; CHECK-LABEL: name: cvt_f32_ubyte0_lshr_16
; CHECK: liveins: $vgpr0
; CHECK: %arg:_(s32) = COPY $vgpr0
; CHECK: %result:_(s32) = G_AMDGPU_CVT_F32_UBYTE2 %arg
; CHECK: $vgpr0 = COPY %result(s32)
%arg:_(s32) = COPY $vgpr0
%shiftamt:_(s32) = G_CONSTANT i32 16
%shift:_(s32) = G_LSHR %arg, %shiftamt
%result:_(s32) = G_AMDGPU_CVT_F32_UBYTE0 %shift
$vgpr0 = COPY %result
...
---
name: cvt_f32_ubyte0_lshr_24
tracksRegLiveness: true
body: |
bb.0:
liveins: $vgpr0
; CHECK-LABEL: name: cvt_f32_ubyte0_lshr_24
; CHECK: liveins: $vgpr0
; CHECK: %arg:_(s32) = COPY $vgpr0
; CHECK: %result:_(s32) = G_AMDGPU_CVT_F32_UBYTE3 %arg
; CHECK: $vgpr0 = COPY %result(s32)
%arg:_(s32) = COPY $vgpr0
%shiftamt:_(s32) = G_CONSTANT i32 24
%shift:_(s32) = G_LSHR %arg, %shiftamt
%result:_(s32) = G_AMDGPU_CVT_F32_UBYTE0 %shift
$vgpr0 = COPY %result
...
---
name: cvt_f32_ubyte1_lshr_8
tracksRegLiveness: true
body: |
bb.0:
liveins: $vgpr0
; CHECK-LABEL: name: cvt_f32_ubyte1_lshr_8
; CHECK: liveins: $vgpr0
; CHECK: %arg:_(s32) = COPY $vgpr0
; CHECK: %result:_(s32) = G_AMDGPU_CVT_F32_UBYTE2 %arg
; CHECK: $vgpr0 = COPY %result(s32)
%arg:_(s32) = COPY $vgpr0
%shiftamt:_(s32) = G_CONSTANT i32 8
%shift:_(s32) = G_LSHR %arg, %shiftamt
%result:_(s32) = G_AMDGPU_CVT_F32_UBYTE1 %shift
$vgpr0 = COPY %result
...
---
name: cvt_f32_ubyte1_lshr_16
tracksRegLiveness: true
body: |
bb.0:
liveins: $vgpr0
; CHECK-LABEL: name: cvt_f32_ubyte1_lshr_16
; CHECK: liveins: $vgpr0
; CHECK: %arg:_(s32) = COPY $vgpr0
; CHECK: %result:_(s32) = G_AMDGPU_CVT_F32_UBYTE3 %arg
; CHECK: $vgpr0 = COPY %result(s32)
%arg:_(s32) = COPY $vgpr0
%shiftamt:_(s32) = G_CONSTANT i32 16
%shift:_(s32) = G_LSHR %arg, %shiftamt
%result:_(s32) = G_AMDGPU_CVT_F32_UBYTE1 %shift
$vgpr0 = COPY %result
...
---
name: cvt_f32_ubyte1_lshr_24
tracksRegLiveness: true
body: |
bb.0:
liveins: $vgpr0
; CHECK-LABEL: name: cvt_f32_ubyte1_lshr_24
; CHECK: liveins: $vgpr0
; CHECK: %arg:_(s32) = COPY $vgpr0
; CHECK: %shiftamt:_(s32) = G_CONSTANT i32 24
; CHECK: %shift:_(s32) = G_LSHR %arg, %shiftamt(s32)
; CHECK: %result:_(s32) = G_AMDGPU_CVT_F32_UBYTE1 %shift
; CHECK: $vgpr0 = COPY %result(s32)
%arg:_(s32) = COPY $vgpr0
%shiftamt:_(s32) = G_CONSTANT i32 24
%shift:_(s32) = G_LSHR %arg, %shiftamt
%result:_(s32) = G_AMDGPU_CVT_F32_UBYTE1 %shift
$vgpr0 = COPY %result
...
---
name: cvt_f32_ubyte2_lshr_8
tracksRegLiveness: true
body: |
bb.0:
liveins: $vgpr0
; CHECK-LABEL: name: cvt_f32_ubyte2_lshr_8
; CHECK: liveins: $vgpr0
; CHECK: %arg:_(s32) = COPY $vgpr0
; CHECK: %result:_(s32) = G_AMDGPU_CVT_F32_UBYTE3 %arg
; CHECK: $vgpr0 = COPY %result(s32)
%arg:_(s32) = COPY $vgpr0
%shiftamt:_(s32) = G_CONSTANT i32 8
%shift:_(s32) = G_LSHR %arg, %shiftamt
%result:_(s32) = G_AMDGPU_CVT_F32_UBYTE2 %shift
$vgpr0 = COPY %result
...
---
name: cvt_f32_ubyte2_lshr_16
tracksRegLiveness: true
body: |
bb.0:
liveins: $vgpr0
; CHECK-LABEL: name: cvt_f32_ubyte2_lshr_16
; CHECK: liveins: $vgpr0
; CHECK: %arg:_(s32) = COPY $vgpr0
; CHECK: %shiftamt:_(s32) = G_CONSTANT i32 16
; CHECK: %shift:_(s32) = G_LSHR %arg, %shiftamt(s32)
; CHECK: %result:_(s32) = G_AMDGPU_CVT_F32_UBYTE2 %shift
; CHECK: $vgpr0 = COPY %result(s32)
%arg:_(s32) = COPY $vgpr0
%shiftamt:_(s32) = G_CONSTANT i32 16
%shift:_(s32) = G_LSHR %arg, %shiftamt
%result:_(s32) = G_AMDGPU_CVT_F32_UBYTE2 %shift
$vgpr0 = COPY %result
...
---
name: cvt_f32_ubyte2_lshr_24
tracksRegLiveness: true
body: |
bb.0:
liveins: $vgpr0
; CHECK-LABEL: name: cvt_f32_ubyte2_lshr_24
; CHECK: liveins: $vgpr0
; CHECK: %arg:_(s32) = COPY $vgpr0
; CHECK: %shiftamt:_(s32) = G_CONSTANT i32 24
; CHECK: %shift:_(s32) = G_LSHR %arg, %shiftamt(s32)
; CHECK: %result:_(s32) = G_AMDGPU_CVT_F32_UBYTE2 %shift
; CHECK: $vgpr0 = COPY %result(s32)
%arg:_(s32) = COPY $vgpr0
%shiftamt:_(s32) = G_CONSTANT i32 24
%shift:_(s32) = G_LSHR %arg, %shiftamt
%result:_(s32) = G_AMDGPU_CVT_F32_UBYTE2 %shift
$vgpr0 = COPY %result
...
---
name: cvt_f32_ubyte3_lshr_8
tracksRegLiveness: true
body: |
bb.0:
liveins: $vgpr0
; CHECK-LABEL: name: cvt_f32_ubyte3_lshr_8
; CHECK: liveins: $vgpr0
; CHECK: %arg:_(s32) = COPY $vgpr0
; CHECK: %shiftamt:_(s32) = G_CONSTANT i32 8
; CHECK: %shift:_(s32) = G_LSHR %arg, %shiftamt(s32)
; CHECK: %result:_(s32) = G_AMDGPU_CVT_F32_UBYTE3 %shift
; CHECK: $vgpr0 = COPY %result(s32)
%arg:_(s32) = COPY $vgpr0
%shiftamt:_(s32) = G_CONSTANT i32 8
%shift:_(s32) = G_LSHR %arg, %shiftamt
%result:_(s32) = G_AMDGPU_CVT_F32_UBYTE3 %shift
$vgpr0 = COPY %result
...
---
name: cvt_f32_ubyte0_zext_lshr_8
tracksRegLiveness: true
body: |
bb.0:
liveins: $vgpr0
; CHECK-LABEL: name: cvt_f32_ubyte0_zext_lshr_8
; CHECK: liveins: $vgpr0
; CHECK: %arg:_(s32) = COPY $vgpr0
; CHECK: %trunc:_(s16) = G_TRUNC %arg(s32)
; CHECK: [[ANYEXT:%[0-9]+]]:_(s32) = G_ANYEXT %trunc(s16)
; CHECK: %result:_(s32) = G_AMDGPU_CVT_F32_UBYTE1 [[ANYEXT]]
; CHECK: $vgpr0 = COPY %result(s32)
%arg:_(s32) = COPY $vgpr0
%trunc:_(s16) = G_TRUNC %arg
%shiftamt:_(s32) = G_CONSTANT i32 8
%shift:_(s16) = G_LSHR %trunc, %shiftamt
%zext:_(s32) = G_ZEXT %shift
%result:_(s32) = G_AMDGPU_CVT_F32_UBYTE0 %zext
$vgpr0 = COPY %result
...
---
name: cvt_f32_ubyte0_zext_lshr_16
tracksRegLiveness: true
body: |
bb.0:
liveins: $vgpr0
; CHECK-LABEL: name: cvt_f32_ubyte0_zext_lshr_16
; CHECK: liveins: $vgpr0
; CHECK: %arg:_(s32) = COPY $vgpr0
; CHECK: %trunc:_(s16) = G_TRUNC %arg(s32)
; CHECK: [[ANYEXT:%[0-9]+]]:_(s32) = G_ANYEXT %trunc(s16)
; CHECK: %result:_(s32) = G_AMDGPU_CVT_F32_UBYTE2 [[ANYEXT]]
; CHECK: $vgpr0 = COPY %result(s32)
%arg:_(s32) = COPY $vgpr0
%trunc:_(s16) = G_TRUNC %arg
%shiftamt:_(s32) = G_CONSTANT i32 16
%shift:_(s16) = G_LSHR %trunc, %shiftamt
%zext:_(s32) = G_ZEXT %shift
%result:_(s32) = G_AMDGPU_CVT_F32_UBYTE0 %zext
$vgpr0 = COPY %result
...
---
name: cvt_f32_ubyte0_zext_lshr_24
tracksRegLiveness: true
body: |
bb.0:
liveins: $vgpr0
; CHECK-LABEL: name: cvt_f32_ubyte0_zext_lshr_24
; CHECK: liveins: $vgpr0
; CHECK: %arg:_(s32) = COPY $vgpr0
; CHECK: %trunc:_(s16) = G_TRUNC %arg(s32)
; CHECK: [[ANYEXT:%[0-9]+]]:_(s32) = G_ANYEXT %trunc(s16)
; CHECK: %result:_(s32) = G_AMDGPU_CVT_F32_UBYTE3 [[ANYEXT]]
; CHECK: $vgpr0 = COPY %result(s32)
%arg:_(s32) = COPY $vgpr0
%trunc:_(s16) = G_TRUNC %arg
%shiftamt:_(s32) = G_CONSTANT i32 24
%shift:_(s16) = G_LSHR %trunc, %shiftamt
%zext:_(s32) = G_ZEXT %shift
%result:_(s32) = G_AMDGPU_CVT_F32_UBYTE0 %zext
$vgpr0 = COPY %result
...
---
name: cvt_f32_ubyte1_zext_lshr_8
tracksRegLiveness: true
body: |
bb.0:
liveins: $vgpr0
; CHECK-LABEL: name: cvt_f32_ubyte1_zext_lshr_8
; CHECK: liveins: $vgpr0
; CHECK: %arg:_(s32) = COPY $vgpr0
; CHECK: %trunc:_(s16) = G_TRUNC %arg(s32)
; CHECK: [[ANYEXT:%[0-9]+]]:_(s32) = G_ANYEXT %trunc(s16)
; CHECK: %result:_(s32) = G_AMDGPU_CVT_F32_UBYTE2 [[ANYEXT]]
; CHECK: $vgpr0 = COPY %result(s32)
%arg:_(s32) = COPY $vgpr0
%trunc:_(s16) = G_TRUNC %arg
%shiftamt:_(s32) = G_CONSTANT i32 8
%shift:_(s16) = G_LSHR %trunc, %shiftamt
%zext:_(s32) = G_ZEXT %shift
%result:_(s32) = G_AMDGPU_CVT_F32_UBYTE1 %zext
$vgpr0 = COPY %result
...
---
name: cvt_f32_ubyte0_shl_8
tracksRegLiveness: true
body: |
bb.0:
liveins: $vgpr0
; CHECK-LABEL: name: cvt_f32_ubyte0_shl_8
; CHECK: liveins: $vgpr0
; CHECK: %arg:_(s32) = COPY $vgpr0
; CHECK: %shiftamt:_(s32) = G_CONSTANT i32 8
; CHECK: %shift:_(s32) = G_SHL %arg, %shiftamt(s32)
; CHECK: %result:_(s32) = G_AMDGPU_CVT_F32_UBYTE0 %shift
; CHECK: $vgpr0 = COPY %result(s32)
%arg:_(s32) = COPY $vgpr0
%shiftamt:_(s32) = G_CONSTANT i32 8
%shift:_(s32) = G_SHL %arg, %shiftamt
%result:_(s32) = G_AMDGPU_CVT_F32_UBYTE0 %shift
$vgpr0 = COPY %result
...
---
name: cvt_f32_ubyte1_shl_8
tracksRegLiveness: true
body: |
bb.0:
liveins: $vgpr0
; CHECK-LABEL: name: cvt_f32_ubyte1_shl_8
; CHECK: liveins: $vgpr0
; CHECK: %arg:_(s32) = COPY $vgpr0
; CHECK: %shiftamt:_(s32) = G_CONSTANT i32 8
; CHECK: %shift:_(s32) = G_SHL %arg, %shiftamt(s32)
; CHECK: %result:_(s32) = G_AMDGPU_CVT_F32_UBYTE1 %shift
; CHECK: $vgpr0 = COPY %result(s32)
%arg:_(s32) = COPY $vgpr0
%shiftamt:_(s32) = G_CONSTANT i32 8
%shift:_(s32) = G_SHL %arg, %shiftamt
%result:_(s32) = G_AMDGPU_CVT_F32_UBYTE1 %shift
$vgpr0 = COPY %result
...
---
name: cvt_f32_ubyte2_shl_8
tracksRegLiveness: true
body: |
bb.0:
liveins: $vgpr0
; CHECK-LABEL: name: cvt_f32_ubyte2_shl_8
; CHECK: liveins: $vgpr0
; CHECK: %arg:_(s32) = COPY $vgpr0
; CHECK: %result:_(s32) = G_AMDGPU_CVT_F32_UBYTE1 %arg
; CHECK: $vgpr0 = COPY %result(s32)
%arg:_(s32) = COPY $vgpr0
%shiftamt:_(s32) = G_CONSTANT i32 8
%shift:_(s32) = G_SHL %arg, %shiftamt
%result:_(s32) = G_AMDGPU_CVT_F32_UBYTE2 %shift
$vgpr0 = COPY %result
...
---
name: cvt_f32_ubyte3_shl_8
tracksRegLiveness: true
body: |
bb.0:
liveins: $vgpr0
; CHECK-LABEL: name: cvt_f32_ubyte3_shl_8
; CHECK: liveins: $vgpr0
; CHECK: %arg:_(s32) = COPY $vgpr0
; CHECK: %result:_(s32) = G_AMDGPU_CVT_F32_UBYTE2 %arg
; CHECK: $vgpr0 = COPY %result(s32)
%arg:_(s32) = COPY $vgpr0
%shiftamt:_(s32) = G_CONSTANT i32 8
%shift:_(s32) = G_SHL %arg, %shiftamt
%result:_(s32) = G_AMDGPU_CVT_F32_UBYTE3 %shift
$vgpr0 = COPY %result
...
---
name: cvt_f32_ubyte0_shl_16
tracksRegLiveness: true
body: |
bb.0:
liveins: $vgpr0
; CHECK-LABEL: name: cvt_f32_ubyte0_shl_16
; CHECK: liveins: $vgpr0
; CHECK: %arg:_(s32) = COPY $vgpr0
; CHECK: %shiftamt:_(s32) = G_CONSTANT i32 16
; CHECK: %shift:_(s32) = G_SHL %arg, %shiftamt(s32)
; CHECK: %result:_(s32) = G_AMDGPU_CVT_F32_UBYTE0 %shift
; CHECK: $vgpr0 = COPY %result(s32)
%arg:_(s32) = COPY $vgpr0
%shiftamt:_(s32) = G_CONSTANT i32 16
%shift:_(s32) = G_SHL %arg, %shiftamt
%result:_(s32) = G_AMDGPU_CVT_F32_UBYTE0 %shift
$vgpr0 = COPY %result
...
---
name: cvt_f32_ubyte1_shl_16
tracksRegLiveness: true
body: |
bb.0:
liveins: $vgpr0
; CHECK-LABEL: name: cvt_f32_ubyte1_shl_16
; CHECK: liveins: $vgpr0
; CHECK: %arg:_(s32) = COPY $vgpr0
; CHECK: %shiftamt:_(s32) = G_CONSTANT i32 16
; CHECK: %shift:_(s32) = G_SHL %arg, %shiftamt(s32)
; CHECK: %result:_(s32) = G_AMDGPU_CVT_F32_UBYTE1 %shift
; CHECK: $vgpr0 = COPY %result(s32)
%arg:_(s32) = COPY $vgpr0
%shiftamt:_(s32) = G_CONSTANT i32 16
%shift:_(s32) = G_SHL %arg, %shiftamt
%result:_(s32) = G_AMDGPU_CVT_F32_UBYTE1 %shift
$vgpr0 = COPY %result
...
---
name: cvt_f32_ubyte2_shl_16
tracksRegLiveness: true
body: |
bb.0:
liveins: $vgpr0
; CHECK-LABEL: name: cvt_f32_ubyte2_shl_16
; CHECK: liveins: $vgpr0
; CHECK: %arg:_(s32) = COPY $vgpr0
; CHECK: %shiftamt:_(s32) = G_CONSTANT i32 16
; CHECK: %shift:_(s32) = G_SHL %arg, %shiftamt(s32)
; CHECK: %result:_(s32) = G_AMDGPU_CVT_F32_UBYTE2 %shift
; CHECK: $vgpr0 = COPY %result(s32)
%arg:_(s32) = COPY $vgpr0
%shiftamt:_(s32) = G_CONSTANT i32 16
%shift:_(s32) = G_SHL %arg, %shiftamt
%result:_(s32) = G_AMDGPU_CVT_F32_UBYTE2 %shift
$vgpr0 = COPY %result
...
---
name: cvt_f32_ubyte3_shl_16
tracksRegLiveness: true
body: |
bb.0:
liveins: $vgpr0
; CHECK-LABEL: name: cvt_f32_ubyte3_shl_16
; CHECK: liveins: $vgpr0
; CHECK: %arg:_(s32) = COPY $vgpr0
; CHECK: %result:_(s32) = G_AMDGPU_CVT_F32_UBYTE1 %arg
; CHECK: $vgpr0 = COPY %result(s32)
%arg:_(s32) = COPY $vgpr0
%shiftamt:_(s32) = G_CONSTANT i32 16
%shift:_(s32) = G_SHL %arg, %shiftamt
%result:_(s32) = G_AMDGPU_CVT_F32_UBYTE3 %shift
$vgpr0 = COPY %result
...
---
name: cvt_f32_ubyte0_shl_24
tracksRegLiveness: true
body: |
bb.0:
liveins: $vgpr0
; CHECK-LABEL: name: cvt_f32_ubyte0_shl_24
; CHECK: liveins: $vgpr0
; CHECK: %arg:_(s32) = COPY $vgpr0
; CHECK: %shiftamt:_(s32) = G_CONSTANT i32 24
; CHECK: %shift:_(s32) = G_SHL %arg, %shiftamt(s32)
; CHECK: %result:_(s32) = G_AMDGPU_CVT_F32_UBYTE0 %shift
; CHECK: $vgpr0 = COPY %result(s32)
%arg:_(s32) = COPY $vgpr0
%shiftamt:_(s32) = G_CONSTANT i32 24
%shift:_(s32) = G_SHL %arg, %shiftamt
%result:_(s32) = G_AMDGPU_CVT_F32_UBYTE0 %shift
$vgpr0 = COPY %result
...
---
name: cvt_f32_ubyte1_shl_24
tracksRegLiveness: true
body: |
bb.0:
liveins: $vgpr0
; CHECK-LABEL: name: cvt_f32_ubyte1_shl_24
; CHECK: liveins: $vgpr0
; CHECK: %arg:_(s32) = COPY $vgpr0
; CHECK: %shiftamt:_(s32) = G_CONSTANT i32 24
; CHECK: %shift:_(s32) = G_SHL %arg, %shiftamt(s32)
; CHECK: %result:_(s32) = G_AMDGPU_CVT_F32_UBYTE1 %shift
; CHECK: $vgpr0 = COPY %result(s32)
%arg:_(s32) = COPY $vgpr0
%shiftamt:_(s32) = G_CONSTANT i32 24
%shift:_(s32) = G_SHL %arg, %shiftamt
%result:_(s32) = G_AMDGPU_CVT_F32_UBYTE1 %shift
$vgpr0 = COPY %result
...
---
name: cvt_f32_ubyte2_shl_24
tracksRegLiveness: true
body: |
bb.0:
liveins: $vgpr0
; CHECK-LABEL: name: cvt_f32_ubyte2_shl_24
; CHECK: liveins: $vgpr0
; CHECK: %arg:_(s32) = COPY $vgpr0
; CHECK: %shiftamt:_(s32) = G_CONSTANT i32 24
; CHECK: %shift:_(s32) = G_SHL %arg, %shiftamt(s32)
; CHECK: %result:_(s32) = G_AMDGPU_CVT_F32_UBYTE2 %shift
; CHECK: $vgpr0 = COPY %result(s32)
%arg:_(s32) = COPY $vgpr0
%shiftamt:_(s32) = G_CONSTANT i32 24
%shift:_(s32) = G_SHL %arg, %shiftamt
%result:_(s32) = G_AMDGPU_CVT_F32_UBYTE2 %shift
$vgpr0 = COPY %result
...
---
name: cvt_f32_ubyte3_shl_24
tracksRegLiveness: true
body: |
bb.0:
liveins: $vgpr0
; CHECK-LABEL: name: cvt_f32_ubyte3_shl_24
; CHECK: liveins: $vgpr0
; CHECK: %arg:_(s32) = COPY $vgpr0
; CHECK: %shiftamt:_(s32) = G_CONSTANT i32 24
; CHECK: %shift:_(s32) = G_SHL %arg, %shiftamt(s32)
; CHECK: %result:_(s32) = G_AMDGPU_CVT_F32_UBYTE3 %shift
; CHECK: $vgpr0 = COPY %result(s32)
%arg:_(s32) = COPY $vgpr0
%shiftamt:_(s32) = G_CONSTANT i32 24
%shift:_(s32) = G_SHL %arg, %shiftamt
%result:_(s32) = G_AMDGPU_CVT_F32_UBYTE3 %shift
$vgpr0 = COPY %result
...
# Shift amount is wrong
---
name: cvt_f32_ubyte1_shl_7
tracksRegLiveness: true
body: |
bb.0:
liveins: $vgpr0
; CHECK-LABEL: name: cvt_f32_ubyte1_shl_7
; CHECK: liveins: $vgpr0
; CHECK: %arg:_(s32) = COPY $vgpr0
; CHECK: %shiftamt:_(s32) = G_CONSTANT i32 7
; CHECK: %shift:_(s32) = G_SHL %arg, %shiftamt(s32)
; CHECK: %result:_(s32) = G_AMDGPU_CVT_F32_UBYTE1 %shift
; CHECK: $vgpr0 = COPY %result(s32)
%arg:_(s32) = COPY $vgpr0
%shiftamt:_(s32) = G_CONSTANT i32 7
%shift:_(s32) = G_SHL %arg, %shiftamt
%result:_(s32) = G_AMDGPU_CVT_F32_UBYTE1 %shift
$vgpr0 = COPY %result
...
---
name: cvt_f32_ubyte3_shl_17
tracksRegLiveness: true
body: |
bb.0:
liveins: $vgpr0
; CHECK-LABEL: name: cvt_f32_ubyte3_shl_17
; CHECK: liveins: $vgpr0
; CHECK: %arg:_(s32) = COPY $vgpr0
; CHECK: %shiftamt:_(s32) = G_CONSTANT i32 17
; CHECK: %shift:_(s32) = G_SHL %arg, %shiftamt(s32)
; CHECK: %result:_(s32) = G_AMDGPU_CVT_F32_UBYTE3 %shift
; CHECK: $vgpr0 = COPY %result(s32)
%arg:_(s32) = COPY $vgpr0
%shiftamt:_(s32) = G_CONSTANT i32 17
%shift:_(s32) = G_SHL %arg, %shiftamt
%result:_(s32) = G_AMDGPU_CVT_F32_UBYTE3 %shift
$vgpr0 = COPY %result
...