blob: ebd293e68f5d152d53c465ece26d42a905fa17a1 [file]
# NOTE: Assertions have been autogenerated by utils/update_mir_test_checks.py UTC_ARGS: --version 6
# RUN: llc -mtriple=wasm32-unknown-unknown -run-pass=legalizer,regbankselect,instruction-select -verify-machineinstrs %s -o - | FileCheck %s
---
name: lshr_i32_i8
tracksRegLiveness: true
body: |
bb.1.entry:
liveins: $arguments
; CHECK-LABEL: name: lshr_i32_i8
; CHECK: liveins: $arguments
; CHECK-NEXT: {{ $}}
; CHECK-NEXT: [[ARGUMENT_i32_:%[0-9]+]]:i32 = ARGUMENT_i32 0, implicit $arguments
; CHECK-NEXT: [[CONST_I32_:%[0-9]+]]:i32 = CONST_I32 21, implicit-def dead $arguments
; CHECK-NEXT: [[SHR_U_I32_:%[0-9]+]]:i32 = SHR_U_I32 [[ARGUMENT_i32_]], [[CONST_I32_]], implicit-def dead $arguments
; CHECK-NEXT: RETURN [[SHR_U_I32_]], implicit-def $arguments
%0:i32(s32) = ARGUMENT_i32 0, implicit $arguments
%1:_(s8) = G_CONSTANT i8 21
%2:_(s32) = G_LSHR %0, %1
RETURN %2(s32), implicit-def $arguments
...
---
name: lshrv_i32_i8
tracksRegLiveness: true
body: |
bb.1.entry:
liveins: $arguments
; CHECK-LABEL: name: lshrv_i32_i8
; CHECK: liveins: $arguments
; CHECK-NEXT: {{ $}}
; CHECK-NEXT: [[ARGUMENT_i32_:%[0-9]+]]:i32 = ARGUMENT_i32 0, implicit $arguments
; CHECK-NEXT: [[ARGUMENT_i32_1:%[0-9]+]]:i32 = ARGUMENT_i32 1, implicit $arguments
; CHECK-NEXT: [[CONST_I32_:%[0-9]+]]:i32 = CONST_I32 255, implicit-def dead $arguments
; CHECK-NEXT: [[AND_I32_:%[0-9]+]]:i32 = AND_I32 [[ARGUMENT_i32_1]], [[CONST_I32_]], implicit-def dead $arguments
; CHECK-NEXT: [[SHR_U_I32_:%[0-9]+]]:i32 = SHR_U_I32 [[ARGUMENT_i32_]], [[AND_I32_]], implicit-def dead $arguments
; CHECK-NEXT: RETURN [[SHR_U_I32_]], implicit-def $arguments
%0:i32(s32) = ARGUMENT_i32 0, implicit $arguments
%2:i32(s32) = ARGUMENT_i32 1, implicit $arguments
%1:_(s8) = G_TRUNC %2(s32)
%3:_(s32) = G_LSHR %0, %1
RETURN %3(s32), implicit-def $arguments
...
---
name: lshr_i64_i8
tracksRegLiveness: true
body: |
bb.1.entry:
liveins: $arguments
; CHECK-LABEL: name: lshr_i64_i8
; CHECK: liveins: $arguments
; CHECK-NEXT: {{ $}}
; CHECK-NEXT: [[ARGUMENT_i64_:%[0-9]+]]:i64 = ARGUMENT_i64 0, implicit $arguments
; CHECK-NEXT: [[CONST_I64_:%[0-9]+]]:i64 = CONST_I64 37, implicit-def dead $arguments
; CHECK-NEXT: [[CONST_I64_1:%[0-9]+]]:i64 = CONST_I64 255, implicit-def dead $arguments
; CHECK-NEXT: [[AND_I64_:%[0-9]+]]:i64 = AND_I64 [[CONST_I64_]], [[CONST_I64_1]], implicit-def dead $arguments
; CHECK-NEXT: [[SHR_U_I64_:%[0-9]+]]:i64 = SHR_U_I64 [[ARGUMENT_i64_]], [[AND_I64_]], implicit-def dead $arguments
; CHECK-NEXT: RETURN [[SHR_U_I64_]], implicit-def $arguments
%0:i64(s64) = ARGUMENT_i64 0, implicit $arguments
%1:_(s8) = G_CONSTANT i8 37
%2:_(s64) = G_LSHR %0, %1
RETURN %2(s64), implicit-def $arguments
...
---
name: lshrv_i64_i8
tracksRegLiveness: true
body: |
bb.1.entry:
liveins: $arguments
; CHECK-LABEL: name: lshrv_i64_i8
; CHECK: liveins: $arguments
; CHECK-NEXT: {{ $}}
; CHECK-NEXT: [[ARGUMENT_i64_:%[0-9]+]]:i64 = ARGUMENT_i64 0, implicit $arguments
; CHECK-NEXT: [[ARGUMENT_i32_:%[0-9]+]]:i32 = ARGUMENT_i32 1, implicit $arguments
; CHECK-NEXT: [[I64_EXTEND_U_I32_:%[0-9]+]]:i64 = I64_EXTEND_U_I32 [[ARGUMENT_i32_]], implicit-def dead $arguments
; CHECK-NEXT: [[CONST_I64_:%[0-9]+]]:i64 = CONST_I64 255, implicit-def dead $arguments
; CHECK-NEXT: [[AND_I64_:%[0-9]+]]:i64 = AND_I64 [[I64_EXTEND_U_I32_]], [[CONST_I64_]], implicit-def dead $arguments
; CHECK-NEXT: [[SHR_U_I64_:%[0-9]+]]:i64 = SHR_U_I64 [[ARGUMENT_i64_]], [[AND_I64_]], implicit-def dead $arguments
; CHECK-NEXT: RETURN [[SHR_U_I64_]], implicit-def $arguments
%0:i64(s64) = ARGUMENT_i64 0, implicit $arguments
%2:i32(s32) = ARGUMENT_i32 1, implicit $arguments
%1:_(s8) = G_TRUNC %2(s32)
%3:_(s64) = G_LSHR %0, %1
RETURN %3(s64), implicit-def $arguments
...