You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
593 lines
17 KiB
593 lines
17 KiB
4 months ago
|
# 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: %result:_(s32) = G_AMDGPU_CVT_F32_UBYTE1 %arg
|
||
|
; 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: %result:_(s32) = G_AMDGPU_CVT_F32_UBYTE2 %arg
|
||
|
; 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: %result:_(s32) = G_AMDGPU_CVT_F32_UBYTE3 %arg
|
||
|
; 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: %result:_(s32) = G_AMDGPU_CVT_F32_UBYTE2 %arg
|
||
|
; 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
|
||
|
...
|