hanbeom 1fee51c40b
[WebAssembly] Fold sign-extending shifts into signed loads in FastISel (#185906)
WebAssembly FastISel currently fails to fold sign-extension patterns
composed of zero-extending loads followed by shift operations. This
results in redundant shift and constant instructions in the output.

Before:
  i32.load8_u $push3=, 0($0)
  i32.const $push0=, 24
  i32.shl $push1=, $pop3, $pop0
  i32.const $push4=, 24
  i32.shr_s $push2=, $pop1, $pop4

The matched shift instruction sequence is removed and safely folded into
a single sign-extending load, erasing the dead code via the
MachineBasicBlock iterator.

After:
  i32.load8_s $push0=, 0($0)

Fixed: #184302
2026-03-18 10:30:00 +09:00

828 lines
31 KiB
LLVM

; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py UTC_ARGS: --version 6
; RUN: llc < %s --mtriple=wasm32-unknown-unknown -disable-wasm-fallthrough-return-opt -wasm-disable-explicit-locals -wasm-keep-registers | FileCheck %s --check-prefixes=WASM32-DAG
; RUN: llc < %s --mtriple=wasm32-unknown-unknown -disable-wasm-fallthrough-return-opt -wasm-disable-explicit-locals -wasm-keep-registers -mcpu=mvp | FileCheck %s --check-prefixes=WASM32-DAG-MVP
; RUN: llc < %s --mtriple=wasm32-unknown-unknown -disable-wasm-fallthrough-return-opt -wasm-disable-explicit-locals -wasm-keep-registers -fast-isel -fast-isel-abort=1 | FileCheck %s --check-prefixes=WASM32-FAST
; RUN: llc < %s --mtriple=wasm32-unknown-unknown -disable-wasm-fallthrough-return-opt -wasm-disable-explicit-locals -wasm-keep-registers -fast-isel -fast-isel-abort=1 -mcpu=mvp | FileCheck %s --check-prefixes=WASM32-FAST-MVP
; RUN: llc < %s --mtriple=wasm64-unknown-unknown -disable-wasm-fallthrough-return-opt -wasm-disable-explicit-locals -wasm-keep-registers | FileCheck %s --check-prefixes=WASM64-DAG
; RUN: llc < %s --mtriple=wasm64-unknown-unknown -disable-wasm-fallthrough-return-opt -wasm-disable-explicit-locals -wasm-keep-registers -mcpu=mvp | FileCheck %s --check-prefixes=WASM64-DAG-MVP
; RUN: llc < %s --mtriple=wasm64-unknown-unknown -disable-wasm-fallthrough-return-opt -wasm-disable-explicit-locals -wasm-keep-registers -fast-isel -fast-isel-abort=1 | FileCheck %s --check-prefixes=WASM64-FAST
; RUN: llc < %s --mtriple=wasm64-unknown-unknown -disable-wasm-fallthrough-return-opt -wasm-disable-explicit-locals -wasm-keep-registers -fast-isel -fast-isel-abort=1 -mcpu=mvp | FileCheck %s --check-prefixes=WASM64-FAST-MVP
; Test that extending loads are assembled properly.
@gv8 = global i8 0
@gv16 = global i16 0
define i32 @global_sext_i8_i32() {
; WASM32-DAG-LABEL: global_sext_i8_i32:
; WASM32-DAG: .functype global_sext_i8_i32 () -> (i32)
; WASM32-DAG-NEXT: # %bb.0:
; WASM32-DAG-NEXT: i32.const $push0=, 0
; WASM32-DAG-NEXT: i32.load8_s $push1=, gv8($pop0)
; WASM32-DAG-NEXT: return $pop1
;
; WASM32-DAG-MVP-LABEL: global_sext_i8_i32:
; WASM32-DAG-MVP: .functype global_sext_i8_i32 () -> (i32)
; WASM32-DAG-MVP-NEXT: # %bb.0:
; WASM32-DAG-MVP-NEXT: i32.const $push0=, 0
; WASM32-DAG-MVP-NEXT: i32.load8_s $push1=, gv8($pop0)
; WASM32-DAG-MVP-NEXT: return $pop1
;
; WASM32-FAST-LABEL: global_sext_i8_i32:
; WASM32-FAST: .functype global_sext_i8_i32 () -> (i32)
; WASM32-FAST-NEXT: # %bb.0:
; WASM32-FAST-NEXT: i32.const $push1=, 0
; WASM32-FAST-NEXT: i32.load8_s $push0=, gv8($pop1)
; WASM32-FAST-NEXT: return $pop0
;
; WASM32-FAST-MVP-LABEL: global_sext_i8_i32:
; WASM32-FAST-MVP: .functype global_sext_i8_i32 () -> (i32)
; WASM32-FAST-MVP-NEXT: # %bb.0:
; WASM32-FAST-MVP-NEXT: i32.const $push1=, 0
; WASM32-FAST-MVP-NEXT: i32.load8_s $push0=, gv8($pop1)
; WASM32-FAST-MVP-NEXT: return $pop0
;
; WASM64-DAG-LABEL: global_sext_i8_i32:
; WASM64-DAG: .functype global_sext_i8_i32 () -> (i32)
; WASM64-DAG-NEXT: # %bb.0:
; WASM64-DAG-NEXT: i64.const $push0=, 0
; WASM64-DAG-NEXT: i32.load8_s $push1=, gv8($pop0)
; WASM64-DAG-NEXT: return $pop1
;
; WASM64-DAG-MVP-LABEL: global_sext_i8_i32:
; WASM64-DAG-MVP: .functype global_sext_i8_i32 () -> (i32)
; WASM64-DAG-MVP-NEXT: # %bb.0:
; WASM64-DAG-MVP-NEXT: i64.const $push0=, 0
; WASM64-DAG-MVP-NEXT: i32.load8_s $push1=, gv8($pop0)
; WASM64-DAG-MVP-NEXT: return $pop1
;
; WASM64-FAST-LABEL: global_sext_i8_i32:
; WASM64-FAST: .functype global_sext_i8_i32 () -> (i32)
; WASM64-FAST-NEXT: # %bb.0:
; WASM64-FAST-NEXT: i64.const $push1=, 0
; WASM64-FAST-NEXT: i32.load8_s $push0=, gv8($pop1)
; WASM64-FAST-NEXT: return $pop0
;
; WASM64-FAST-MVP-LABEL: global_sext_i8_i32:
; WASM64-FAST-MVP: .functype global_sext_i8_i32 () -> (i32)
; WASM64-FAST-MVP-NEXT: # %bb.0:
; WASM64-FAST-MVP-NEXT: i64.const $push1=, 0
; WASM64-FAST-MVP-NEXT: i32.load8_s $push0=, gv8($pop1)
; WASM64-FAST-MVP-NEXT: return $pop0
%ld = load i8, ptr @gv8
%conv = sext i8 %ld to i32
ret i32 %conv
}
define i32 @global_sext_i16_i32() {
; WASM32-DAG-LABEL: global_sext_i16_i32:
; WASM32-DAG: .functype global_sext_i16_i32 () -> (i32)
; WASM32-DAG-NEXT: # %bb.0:
; WASM32-DAG-NEXT: i32.const $push0=, 0
; WASM32-DAG-NEXT: i32.load16_s $push1=, gv16($pop0)
; WASM32-DAG-NEXT: return $pop1
;
; WASM32-DAG-MVP-LABEL: global_sext_i16_i32:
; WASM32-DAG-MVP: .functype global_sext_i16_i32 () -> (i32)
; WASM32-DAG-MVP-NEXT: # %bb.0:
; WASM32-DAG-MVP-NEXT: i32.const $push0=, 0
; WASM32-DAG-MVP-NEXT: i32.load16_s $push1=, gv16($pop0)
; WASM32-DAG-MVP-NEXT: return $pop1
;
; WASM32-FAST-LABEL: global_sext_i16_i32:
; WASM32-FAST: .functype global_sext_i16_i32 () -> (i32)
; WASM32-FAST-NEXT: # %bb.0:
; WASM32-FAST-NEXT: i32.const $push1=, 0
; WASM32-FAST-NEXT: i32.load16_s $push0=, gv16($pop1)
; WASM32-FAST-NEXT: return $pop0
;
; WASM32-FAST-MVP-LABEL: global_sext_i16_i32:
; WASM32-FAST-MVP: .functype global_sext_i16_i32 () -> (i32)
; WASM32-FAST-MVP-NEXT: # %bb.0:
; WASM32-FAST-MVP-NEXT: i32.const $push1=, 0
; WASM32-FAST-MVP-NEXT: i32.load16_s $push0=, gv16($pop1)
; WASM32-FAST-MVP-NEXT: return $pop0
;
; WASM64-DAG-LABEL: global_sext_i16_i32:
; WASM64-DAG: .functype global_sext_i16_i32 () -> (i32)
; WASM64-DAG-NEXT: # %bb.0:
; WASM64-DAG-NEXT: i64.const $push0=, 0
; WASM64-DAG-NEXT: i32.load16_s $push1=, gv16($pop0)
; WASM64-DAG-NEXT: return $pop1
;
; WASM64-DAG-MVP-LABEL: global_sext_i16_i32:
; WASM64-DAG-MVP: .functype global_sext_i16_i32 () -> (i32)
; WASM64-DAG-MVP-NEXT: # %bb.0:
; WASM64-DAG-MVP-NEXT: i64.const $push0=, 0
; WASM64-DAG-MVP-NEXT: i32.load16_s $push1=, gv16($pop0)
; WASM64-DAG-MVP-NEXT: return $pop1
;
; WASM64-FAST-LABEL: global_sext_i16_i32:
; WASM64-FAST: .functype global_sext_i16_i32 () -> (i32)
; WASM64-FAST-NEXT: # %bb.0:
; WASM64-FAST-NEXT: i64.const $push1=, 0
; WASM64-FAST-NEXT: i32.load16_s $push0=, gv16($pop1)
; WASM64-FAST-NEXT: return $pop0
;
; WASM64-FAST-MVP-LABEL: global_sext_i16_i32:
; WASM64-FAST-MVP: .functype global_sext_i16_i32 () -> (i32)
; WASM64-FAST-MVP-NEXT: # %bb.0:
; WASM64-FAST-MVP-NEXT: i64.const $push1=, 0
; WASM64-FAST-MVP-NEXT: i32.load16_s $push0=, gv16($pop1)
; WASM64-FAST-MVP-NEXT: return $pop0
%ld = load i16, ptr @gv16
%conv = sext i16 %ld to i32
ret i32 %conv
}
define i64 @global_sext_i8_i64() {
; WASM32-DAG-LABEL: global_sext_i8_i64:
; WASM32-DAG: .functype global_sext_i8_i64 () -> (i64)
; WASM32-DAG-NEXT: # %bb.0:
; WASM32-DAG-NEXT: i32.const $push0=, 0
; WASM32-DAG-NEXT: i64.load8_s $push1=, gv8($pop0)
; WASM32-DAG-NEXT: return $pop1
;
; WASM32-DAG-MVP-LABEL: global_sext_i8_i64:
; WASM32-DAG-MVP: .functype global_sext_i8_i64 () -> (i64)
; WASM32-DAG-MVP-NEXT: # %bb.0:
; WASM32-DAG-MVP-NEXT: i32.const $push0=, 0
; WASM32-DAG-MVP-NEXT: i64.load8_s $push1=, gv8($pop0)
; WASM32-DAG-MVP-NEXT: return $pop1
;
; WASM32-FAST-LABEL: global_sext_i8_i64:
; WASM32-FAST: .functype global_sext_i8_i64 () -> (i64)
; WASM32-FAST-NEXT: # %bb.0:
; WASM32-FAST-NEXT: i32.const $push3=, 0
; WASM32-FAST-NEXT: i32.load8_u $push2=, gv8($pop3)
; WASM32-FAST-NEXT: i64.extend_i32_u $push0=, $pop2
; WASM32-FAST-NEXT: i64.extend8_s $push1=, $pop0
; WASM32-FAST-NEXT: return $pop1
;
; WASM32-FAST-MVP-LABEL: global_sext_i8_i64:
; WASM32-FAST-MVP: .functype global_sext_i8_i64 () -> (i64)
; WASM32-FAST-MVP-NEXT: # %bb.0:
; WASM32-FAST-MVP-NEXT: i32.const $push2=, 0
; WASM32-FAST-MVP-NEXT: i32.load8_s $push1=, gv8($pop2)
; WASM32-FAST-MVP-NEXT: i64.extend_i32_s $push0=, $pop1
; WASM32-FAST-MVP-NEXT: return $pop0
;
; WASM64-DAG-LABEL: global_sext_i8_i64:
; WASM64-DAG: .functype global_sext_i8_i64 () -> (i64)
; WASM64-DAG-NEXT: # %bb.0:
; WASM64-DAG-NEXT: i64.const $push0=, 0
; WASM64-DAG-NEXT: i64.load8_s $push1=, gv8($pop0)
; WASM64-DAG-NEXT: return $pop1
;
; WASM64-DAG-MVP-LABEL: global_sext_i8_i64:
; WASM64-DAG-MVP: .functype global_sext_i8_i64 () -> (i64)
; WASM64-DAG-MVP-NEXT: # %bb.0:
; WASM64-DAG-MVP-NEXT: i64.const $push0=, 0
; WASM64-DAG-MVP-NEXT: i64.load8_s $push1=, gv8($pop0)
; WASM64-DAG-MVP-NEXT: return $pop1
;
; WASM64-FAST-LABEL: global_sext_i8_i64:
; WASM64-FAST: .functype global_sext_i8_i64 () -> (i64)
; WASM64-FAST-NEXT: # %bb.0:
; WASM64-FAST-NEXT: i64.const $push3=, 0
; WASM64-FAST-NEXT: i32.load8_u $push2=, gv8($pop3)
; WASM64-FAST-NEXT: i64.extend_i32_u $push0=, $pop2
; WASM64-FAST-NEXT: i64.extend8_s $push1=, $pop0
; WASM64-FAST-NEXT: return $pop1
;
; WASM64-FAST-MVP-LABEL: global_sext_i8_i64:
; WASM64-FAST-MVP: .functype global_sext_i8_i64 () -> (i64)
; WASM64-FAST-MVP-NEXT: # %bb.0:
; WASM64-FAST-MVP-NEXT: i64.const $push2=, 0
; WASM64-FAST-MVP-NEXT: i32.load8_s $push1=, gv8($pop2)
; WASM64-FAST-MVP-NEXT: i64.extend_i32_s $push0=, $pop1
; WASM64-FAST-MVP-NEXT: return $pop0
%ld = load i8, ptr @gv8
%conv = sext i8 %ld to i64
ret i64 %conv
}
define i64 @global_sext_i16_i64() {
; WASM32-DAG-LABEL: global_sext_i16_i64:
; WASM32-DAG: .functype global_sext_i16_i64 () -> (i64)
; WASM32-DAG-NEXT: # %bb.0:
; WASM32-DAG-NEXT: i32.const $push0=, 0
; WASM32-DAG-NEXT: i64.load16_s $push1=, gv16($pop0)
; WASM32-DAG-NEXT: return $pop1
;
; WASM32-DAG-MVP-LABEL: global_sext_i16_i64:
; WASM32-DAG-MVP: .functype global_sext_i16_i64 () -> (i64)
; WASM32-DAG-MVP-NEXT: # %bb.0:
; WASM32-DAG-MVP-NEXT: i32.const $push0=, 0
; WASM32-DAG-MVP-NEXT: i64.load16_s $push1=, gv16($pop0)
; WASM32-DAG-MVP-NEXT: return $pop1
;
; WASM32-FAST-LABEL: global_sext_i16_i64:
; WASM32-FAST: .functype global_sext_i16_i64 () -> (i64)
; WASM32-FAST-NEXT: # %bb.0:
; WASM32-FAST-NEXT: i32.const $push3=, 0
; WASM32-FAST-NEXT: i32.load16_u $push2=, gv16($pop3)
; WASM32-FAST-NEXT: i64.extend_i32_u $push0=, $pop2
; WASM32-FAST-NEXT: i64.extend16_s $push1=, $pop0
; WASM32-FAST-NEXT: return $pop1
;
; WASM32-FAST-MVP-LABEL: global_sext_i16_i64:
; WASM32-FAST-MVP: .functype global_sext_i16_i64 () -> (i64)
; WASM32-FAST-MVP-NEXT: # %bb.0:
; WASM32-FAST-MVP-NEXT: i32.const $push2=, 0
; WASM32-FAST-MVP-NEXT: i32.load16_s $push1=, gv16($pop2)
; WASM32-FAST-MVP-NEXT: i64.extend_i32_s $push0=, $pop1
; WASM32-FAST-MVP-NEXT: return $pop0
;
; WASM64-DAG-LABEL: global_sext_i16_i64:
; WASM64-DAG: .functype global_sext_i16_i64 () -> (i64)
; WASM64-DAG-NEXT: # %bb.0:
; WASM64-DAG-NEXT: i64.const $push0=, 0
; WASM64-DAG-NEXT: i64.load16_s $push1=, gv16($pop0)
; WASM64-DAG-NEXT: return $pop1
;
; WASM64-DAG-MVP-LABEL: global_sext_i16_i64:
; WASM64-DAG-MVP: .functype global_sext_i16_i64 () -> (i64)
; WASM64-DAG-MVP-NEXT: # %bb.0:
; WASM64-DAG-MVP-NEXT: i64.const $push0=, 0
; WASM64-DAG-MVP-NEXT: i64.load16_s $push1=, gv16($pop0)
; WASM64-DAG-MVP-NEXT: return $pop1
;
; WASM64-FAST-LABEL: global_sext_i16_i64:
; WASM64-FAST: .functype global_sext_i16_i64 () -> (i64)
; WASM64-FAST-NEXT: # %bb.0:
; WASM64-FAST-NEXT: i64.const $push3=, 0
; WASM64-FAST-NEXT: i32.load16_u $push2=, gv16($pop3)
; WASM64-FAST-NEXT: i64.extend_i32_u $push0=, $pop2
; WASM64-FAST-NEXT: i64.extend16_s $push1=, $pop0
; WASM64-FAST-NEXT: return $pop1
;
; WASM64-FAST-MVP-LABEL: global_sext_i16_i64:
; WASM64-FAST-MVP: .functype global_sext_i16_i64 () -> (i64)
; WASM64-FAST-MVP-NEXT: # %bb.0:
; WASM64-FAST-MVP-NEXT: i64.const $push2=, 0
; WASM64-FAST-MVP-NEXT: i32.load16_s $push1=, gv16($pop2)
; WASM64-FAST-MVP-NEXT: i64.extend_i32_s $push0=, $pop1
; WASM64-FAST-MVP-NEXT: return $pop0
%ld= load i16, ptr @gv16
%conv = sext i16 %ld to i64
ret i64 %conv
}
define i32 @sext_i8_i32(ptr %p) {
; WASM32-DAG-LABEL: sext_i8_i32:
; WASM32-DAG: .functype sext_i8_i32 (i32) -> (i32)
; WASM32-DAG-NEXT: # %bb.0:
; WASM32-DAG-NEXT: i32.load8_s $push0=, 0($0)
; WASM32-DAG-NEXT: return $pop0
;
; WASM32-DAG-MVP-LABEL: sext_i8_i32:
; WASM32-DAG-MVP: .functype sext_i8_i32 (i32) -> (i32)
; WASM32-DAG-MVP-NEXT: # %bb.0:
; WASM32-DAG-MVP-NEXT: i32.load8_s $push0=, 0($0)
; WASM32-DAG-MVP-NEXT: return $pop0
;
; WASM32-FAST-LABEL: sext_i8_i32:
; WASM32-FAST: .functype sext_i8_i32 (i32) -> (i32)
; WASM32-FAST-NEXT: # %bb.0:
; WASM32-FAST-NEXT: i32.load8_s $push0=, 0($0)
; WASM32-FAST-NEXT: return $pop0
;
; WASM32-FAST-MVP-LABEL: sext_i8_i32:
; WASM32-FAST-MVP: .functype sext_i8_i32 (i32) -> (i32)
; WASM32-FAST-MVP-NEXT: # %bb.0:
; WASM32-FAST-MVP-NEXT: i32.load8_s $push0=, 0($0)
; WASM32-FAST-MVP-NEXT: return $pop0
;
; WASM64-DAG-LABEL: sext_i8_i32:
; WASM64-DAG: .functype sext_i8_i32 (i64) -> (i32)
; WASM64-DAG-NEXT: # %bb.0:
; WASM64-DAG-NEXT: i32.load8_s $push0=, 0($0)
; WASM64-DAG-NEXT: return $pop0
;
; WASM64-DAG-MVP-LABEL: sext_i8_i32:
; WASM64-DAG-MVP: .functype sext_i8_i32 (i64) -> (i32)
; WASM64-DAG-MVP-NEXT: # %bb.0:
; WASM64-DAG-MVP-NEXT: i32.load8_s $push0=, 0($0)
; WASM64-DAG-MVP-NEXT: return $pop0
;
; WASM64-FAST-LABEL: sext_i8_i32:
; WASM64-FAST: .functype sext_i8_i32 (i64) -> (i32)
; WASM64-FAST-NEXT: # %bb.0:
; WASM64-FAST-NEXT: i32.load8_s $push0=, 0($0)
; WASM64-FAST-NEXT: return $pop0
;
; WASM64-FAST-MVP-LABEL: sext_i8_i32:
; WASM64-FAST-MVP: .functype sext_i8_i32 (i64) -> (i32)
; WASM64-FAST-MVP-NEXT: # %bb.0:
; WASM64-FAST-MVP-NEXT: i32.load8_s $push0=, 0($0)
; WASM64-FAST-MVP-NEXT: return $pop0
%v = load i8, ptr %p
%e = sext i8 %v to i32
ret i32 %e
}
define i32 @zext_i8_i32(ptr %p) {
; WASM32-DAG-LABEL: zext_i8_i32:
; WASM32-DAG: .functype zext_i8_i32 (i32) -> (i32)
; WASM32-DAG-NEXT: # %bb.0:
; WASM32-DAG-NEXT: i32.load8_u $push0=, 0($0)
; WASM32-DAG-NEXT: return $pop0
;
; WASM32-DAG-MVP-LABEL: zext_i8_i32:
; WASM32-DAG-MVP: .functype zext_i8_i32 (i32) -> (i32)
; WASM32-DAG-MVP-NEXT: # %bb.0:
; WASM32-DAG-MVP-NEXT: i32.load8_u $push0=, 0($0)
; WASM32-DAG-MVP-NEXT: return $pop0
;
; WASM32-FAST-LABEL: zext_i8_i32:
; WASM32-FAST: .functype zext_i8_i32 (i32) -> (i32)
; WASM32-FAST-NEXT: # %bb.0:
; WASM32-FAST-NEXT: i32.load8_u $push0=, 0($0)
; WASM32-FAST-NEXT: return $pop0
;
; WASM32-FAST-MVP-LABEL: zext_i8_i32:
; WASM32-FAST-MVP: .functype zext_i8_i32 (i32) -> (i32)
; WASM32-FAST-MVP-NEXT: # %bb.0:
; WASM32-FAST-MVP-NEXT: i32.load8_u $push0=, 0($0)
; WASM32-FAST-MVP-NEXT: return $pop0
;
; WASM64-DAG-LABEL: zext_i8_i32:
; WASM64-DAG: .functype zext_i8_i32 (i64) -> (i32)
; WASM64-DAG-NEXT: # %bb.0:
; WASM64-DAG-NEXT: i32.load8_u $push0=, 0($0)
; WASM64-DAG-NEXT: return $pop0
;
; WASM64-DAG-MVP-LABEL: zext_i8_i32:
; WASM64-DAG-MVP: .functype zext_i8_i32 (i64) -> (i32)
; WASM64-DAG-MVP-NEXT: # %bb.0:
; WASM64-DAG-MVP-NEXT: i32.load8_u $push0=, 0($0)
; WASM64-DAG-MVP-NEXT: return $pop0
;
; WASM64-FAST-LABEL: zext_i8_i32:
; WASM64-FAST: .functype zext_i8_i32 (i64) -> (i32)
; WASM64-FAST-NEXT: # %bb.0:
; WASM64-FAST-NEXT: i32.load8_u $push0=, 0($0)
; WASM64-FAST-NEXT: return $pop0
;
; WASM64-FAST-MVP-LABEL: zext_i8_i32:
; WASM64-FAST-MVP: .functype zext_i8_i32 (i64) -> (i32)
; WASM64-FAST-MVP-NEXT: # %bb.0:
; WASM64-FAST-MVP-NEXT: i32.load8_u $push0=, 0($0)
; WASM64-FAST-MVP-NEXT: return $pop0
%v = load i8, ptr %p
%e = zext i8 %v to i32
ret i32 %e
}
define i32 @sext_i16_i32(ptr %p) {
; WASM32-DAG-LABEL: sext_i16_i32:
; WASM32-DAG: .functype sext_i16_i32 (i32) -> (i32)
; WASM32-DAG-NEXT: # %bb.0:
; WASM32-DAG-NEXT: i32.load16_s $push0=, 0($0)
; WASM32-DAG-NEXT: return $pop0
;
; WASM32-DAG-MVP-LABEL: sext_i16_i32:
; WASM32-DAG-MVP: .functype sext_i16_i32 (i32) -> (i32)
; WASM32-DAG-MVP-NEXT: # %bb.0:
; WASM32-DAG-MVP-NEXT: i32.load16_s $push0=, 0($0)
; WASM32-DAG-MVP-NEXT: return $pop0
;
; WASM32-FAST-LABEL: sext_i16_i32:
; WASM32-FAST: .functype sext_i16_i32 (i32) -> (i32)
; WASM32-FAST-NEXT: # %bb.0:
; WASM32-FAST-NEXT: i32.load16_s $push0=, 0($0)
; WASM32-FAST-NEXT: return $pop0
;
; WASM32-FAST-MVP-LABEL: sext_i16_i32:
; WASM32-FAST-MVP: .functype sext_i16_i32 (i32) -> (i32)
; WASM32-FAST-MVP-NEXT: # %bb.0:
; WASM32-FAST-MVP-NEXT: i32.load16_s $push0=, 0($0)
; WASM32-FAST-MVP-NEXT: return $pop0
;
; WASM64-DAG-LABEL: sext_i16_i32:
; WASM64-DAG: .functype sext_i16_i32 (i64) -> (i32)
; WASM64-DAG-NEXT: # %bb.0:
; WASM64-DAG-NEXT: i32.load16_s $push0=, 0($0)
; WASM64-DAG-NEXT: return $pop0
;
; WASM64-DAG-MVP-LABEL: sext_i16_i32:
; WASM64-DAG-MVP: .functype sext_i16_i32 (i64) -> (i32)
; WASM64-DAG-MVP-NEXT: # %bb.0:
; WASM64-DAG-MVP-NEXT: i32.load16_s $push0=, 0($0)
; WASM64-DAG-MVP-NEXT: return $pop0
;
; WASM64-FAST-LABEL: sext_i16_i32:
; WASM64-FAST: .functype sext_i16_i32 (i64) -> (i32)
; WASM64-FAST-NEXT: # %bb.0:
; WASM64-FAST-NEXT: i32.load16_s $push0=, 0($0)
; WASM64-FAST-NEXT: return $pop0
;
; WASM64-FAST-MVP-LABEL: sext_i16_i32:
; WASM64-FAST-MVP: .functype sext_i16_i32 (i64) -> (i32)
; WASM64-FAST-MVP-NEXT: # %bb.0:
; WASM64-FAST-MVP-NEXT: i32.load16_s $push0=, 0($0)
; WASM64-FAST-MVP-NEXT: return $pop0
%v = load i16, ptr %p
%e = sext i16 %v to i32
ret i32 %e
}
define i32 @zext_i16_i32(ptr %p) {
; WASM32-DAG-LABEL: zext_i16_i32:
; WASM32-DAG: .functype zext_i16_i32 (i32) -> (i32)
; WASM32-DAG-NEXT: # %bb.0:
; WASM32-DAG-NEXT: i32.load16_u $push0=, 0($0)
; WASM32-DAG-NEXT: return $pop0
;
; WASM32-DAG-MVP-LABEL: zext_i16_i32:
; WASM32-DAG-MVP: .functype zext_i16_i32 (i32) -> (i32)
; WASM32-DAG-MVP-NEXT: # %bb.0:
; WASM32-DAG-MVP-NEXT: i32.load16_u $push0=, 0($0)
; WASM32-DAG-MVP-NEXT: return $pop0
;
; WASM32-FAST-LABEL: zext_i16_i32:
; WASM32-FAST: .functype zext_i16_i32 (i32) -> (i32)
; WASM32-FAST-NEXT: # %bb.0:
; WASM32-FAST-NEXT: i32.load16_u $push0=, 0($0)
; WASM32-FAST-NEXT: return $pop0
;
; WASM32-FAST-MVP-LABEL: zext_i16_i32:
; WASM32-FAST-MVP: .functype zext_i16_i32 (i32) -> (i32)
; WASM32-FAST-MVP-NEXT: # %bb.0:
; WASM32-FAST-MVP-NEXT: i32.load16_u $push0=, 0($0)
; WASM32-FAST-MVP-NEXT: return $pop0
;
; WASM64-DAG-LABEL: zext_i16_i32:
; WASM64-DAG: .functype zext_i16_i32 (i64) -> (i32)
; WASM64-DAG-NEXT: # %bb.0:
; WASM64-DAG-NEXT: i32.load16_u $push0=, 0($0)
; WASM64-DAG-NEXT: return $pop0
;
; WASM64-DAG-MVP-LABEL: zext_i16_i32:
; WASM64-DAG-MVP: .functype zext_i16_i32 (i64) -> (i32)
; WASM64-DAG-MVP-NEXT: # %bb.0:
; WASM64-DAG-MVP-NEXT: i32.load16_u $push0=, 0($0)
; WASM64-DAG-MVP-NEXT: return $pop0
;
; WASM64-FAST-LABEL: zext_i16_i32:
; WASM64-FAST: .functype zext_i16_i32 (i64) -> (i32)
; WASM64-FAST-NEXT: # %bb.0:
; WASM64-FAST-NEXT: i32.load16_u $push0=, 0($0)
; WASM64-FAST-NEXT: return $pop0
;
; WASM64-FAST-MVP-LABEL: zext_i16_i32:
; WASM64-FAST-MVP: .functype zext_i16_i32 (i64) -> (i32)
; WASM64-FAST-MVP-NEXT: # %bb.0:
; WASM64-FAST-MVP-NEXT: i32.load16_u $push0=, 0($0)
; WASM64-FAST-MVP-NEXT: return $pop0
%v = load i16, ptr %p
%e = zext i16 %v to i32
ret i32 %e
}
define i64 @sext_i8_i64(ptr %p) {
; WASM32-DAG-LABEL: sext_i8_i64:
; WASM32-DAG: .functype sext_i8_i64 (i32) -> (i64)
; WASM32-DAG-NEXT: # %bb.0:
; WASM32-DAG-NEXT: i64.load8_s $push0=, 0($0)
; WASM32-DAG-NEXT: return $pop0
;
; WASM32-DAG-MVP-LABEL: sext_i8_i64:
; WASM32-DAG-MVP: .functype sext_i8_i64 (i32) -> (i64)
; WASM32-DAG-MVP-NEXT: # %bb.0:
; WASM32-DAG-MVP-NEXT: i64.load8_s $push0=, 0($0)
; WASM32-DAG-MVP-NEXT: return $pop0
;
; WASM32-FAST-LABEL: sext_i8_i64:
; WASM32-FAST: .functype sext_i8_i64 (i32) -> (i64)
; WASM32-FAST-NEXT: # %bb.0:
; WASM32-FAST-NEXT: i32.load8_u $push2=, 0($0)
; WASM32-FAST-NEXT: i64.extend_i32_u $push0=, $pop2
; WASM32-FAST-NEXT: i64.extend8_s $push1=, $pop0
; WASM32-FAST-NEXT: return $pop1
;
; WASM32-FAST-MVP-LABEL: sext_i8_i64:
; WASM32-FAST-MVP: .functype sext_i8_i64 (i32) -> (i64)
; WASM32-FAST-MVP-NEXT: # %bb.0:
; WASM32-FAST-MVP-NEXT: i32.load8_s $push1=, 0($0)
; WASM32-FAST-MVP-NEXT: i64.extend_i32_s $push0=, $pop1
; WASM32-FAST-MVP-NEXT: return $pop0
;
; WASM64-DAG-LABEL: sext_i8_i64:
; WASM64-DAG: .functype sext_i8_i64 (i64) -> (i64)
; WASM64-DAG-NEXT: # %bb.0:
; WASM64-DAG-NEXT: i64.load8_s $push0=, 0($0)
; WASM64-DAG-NEXT: return $pop0
;
; WASM64-DAG-MVP-LABEL: sext_i8_i64:
; WASM64-DAG-MVP: .functype sext_i8_i64 (i64) -> (i64)
; WASM64-DAG-MVP-NEXT: # %bb.0:
; WASM64-DAG-MVP-NEXT: i64.load8_s $push0=, 0($0)
; WASM64-DAG-MVP-NEXT: return $pop0
;
; WASM64-FAST-LABEL: sext_i8_i64:
; WASM64-FAST: .functype sext_i8_i64 (i64) -> (i64)
; WASM64-FAST-NEXT: # %bb.0:
; WASM64-FAST-NEXT: i32.load8_u $push2=, 0($0)
; WASM64-FAST-NEXT: i64.extend_i32_u $push0=, $pop2
; WASM64-FAST-NEXT: i64.extend8_s $push1=, $pop0
; WASM64-FAST-NEXT: return $pop1
;
; WASM64-FAST-MVP-LABEL: sext_i8_i64:
; WASM64-FAST-MVP: .functype sext_i8_i64 (i64) -> (i64)
; WASM64-FAST-MVP-NEXT: # %bb.0:
; WASM64-FAST-MVP-NEXT: i32.load8_s $push1=, 0($0)
; WASM64-FAST-MVP-NEXT: i64.extend_i32_s $push0=, $pop1
; WASM64-FAST-MVP-NEXT: return $pop0
%v = load i8, ptr %p
%e = sext i8 %v to i64
ret i64 %e
}
define i64 @zext_i8_i64(ptr %p) {
; WASM32-DAG-LABEL: zext_i8_i64:
; WASM32-DAG: .functype zext_i8_i64 (i32) -> (i64)
; WASM32-DAG-NEXT: # %bb.0:
; WASM32-DAG-NEXT: i64.load8_u $push0=, 0($0)
; WASM32-DAG-NEXT: return $pop0
;
; WASM32-DAG-MVP-LABEL: zext_i8_i64:
; WASM32-DAG-MVP: .functype zext_i8_i64 (i32) -> (i64)
; WASM32-DAG-MVP-NEXT: # %bb.0:
; WASM32-DAG-MVP-NEXT: i64.load8_u $push0=, 0($0)
; WASM32-DAG-MVP-NEXT: return $pop0
;
; WASM32-FAST-LABEL: zext_i8_i64:
; WASM32-FAST: .functype zext_i8_i64 (i32) -> (i64)
; WASM32-FAST-NEXT: # %bb.0:
; WASM32-FAST-NEXT: i32.load8_u $push0=, 0($0)
; WASM32-FAST-NEXT: i64.extend_i32_u $push1=, $pop0
; WASM32-FAST-NEXT: return $pop1
;
; WASM32-FAST-MVP-LABEL: zext_i8_i64:
; WASM32-FAST-MVP: .functype zext_i8_i64 (i32) -> (i64)
; WASM32-FAST-MVP-NEXT: # %bb.0:
; WASM32-FAST-MVP-NEXT: i32.load8_u $push0=, 0($0)
; WASM32-FAST-MVP-NEXT: i64.extend_i32_u $push1=, $pop0
; WASM32-FAST-MVP-NEXT: return $pop1
;
; WASM64-DAG-LABEL: zext_i8_i64:
; WASM64-DAG: .functype zext_i8_i64 (i64) -> (i64)
; WASM64-DAG-NEXT: # %bb.0:
; WASM64-DAG-NEXT: i64.load8_u $push0=, 0($0)
; WASM64-DAG-NEXT: return $pop0
;
; WASM64-DAG-MVP-LABEL: zext_i8_i64:
; WASM64-DAG-MVP: .functype zext_i8_i64 (i64) -> (i64)
; WASM64-DAG-MVP-NEXT: # %bb.0:
; WASM64-DAG-MVP-NEXT: i64.load8_u $push0=, 0($0)
; WASM64-DAG-MVP-NEXT: return $pop0
;
; WASM64-FAST-LABEL: zext_i8_i64:
; WASM64-FAST: .functype zext_i8_i64 (i64) -> (i64)
; WASM64-FAST-NEXT: # %bb.0:
; WASM64-FAST-NEXT: i32.load8_u $push0=, 0($0)
; WASM64-FAST-NEXT: i64.extend_i32_u $push1=, $pop0
; WASM64-FAST-NEXT: return $pop1
;
; WASM64-FAST-MVP-LABEL: zext_i8_i64:
; WASM64-FAST-MVP: .functype zext_i8_i64 (i64) -> (i64)
; WASM64-FAST-MVP-NEXT: # %bb.0:
; WASM64-FAST-MVP-NEXT: i32.load8_u $push0=, 0($0)
; WASM64-FAST-MVP-NEXT: i64.extend_i32_u $push1=, $pop0
; WASM64-FAST-MVP-NEXT: return $pop1
%v = load i8, ptr %p
%e = zext i8 %v to i64
ret i64 %e
}
define i64 @sext_i16_i64(ptr %p) {
; WASM32-DAG-LABEL: sext_i16_i64:
; WASM32-DAG: .functype sext_i16_i64 (i32) -> (i64)
; WASM32-DAG-NEXT: # %bb.0:
; WASM32-DAG-NEXT: i64.load16_s $push0=, 0($0)
; WASM32-DAG-NEXT: return $pop0
;
; WASM32-DAG-MVP-LABEL: sext_i16_i64:
; WASM32-DAG-MVP: .functype sext_i16_i64 (i32) -> (i64)
; WASM32-DAG-MVP-NEXT: # %bb.0:
; WASM32-DAG-MVP-NEXT: i64.load16_s $push0=, 0($0)
; WASM32-DAG-MVP-NEXT: return $pop0
;
; WASM32-FAST-LABEL: sext_i16_i64:
; WASM32-FAST: .functype sext_i16_i64 (i32) -> (i64)
; WASM32-FAST-NEXT: # %bb.0:
; WASM32-FAST-NEXT: i32.load16_u $push2=, 0($0)
; WASM32-FAST-NEXT: i64.extend_i32_u $push0=, $pop2
; WASM32-FAST-NEXT: i64.extend16_s $push1=, $pop0
; WASM32-FAST-NEXT: return $pop1
;
; WASM32-FAST-MVP-LABEL: sext_i16_i64:
; WASM32-FAST-MVP: .functype sext_i16_i64 (i32) -> (i64)
; WASM32-FAST-MVP-NEXT: # %bb.0:
; WASM32-FAST-MVP-NEXT: i32.load16_s $push1=, 0($0)
; WASM32-FAST-MVP-NEXT: i64.extend_i32_s $push0=, $pop1
; WASM32-FAST-MVP-NEXT: return $pop0
;
; WASM64-DAG-LABEL: sext_i16_i64:
; WASM64-DAG: .functype sext_i16_i64 (i64) -> (i64)
; WASM64-DAG-NEXT: # %bb.0:
; WASM64-DAG-NEXT: i64.load16_s $push0=, 0($0)
; WASM64-DAG-NEXT: return $pop0
;
; WASM64-DAG-MVP-LABEL: sext_i16_i64:
; WASM64-DAG-MVP: .functype sext_i16_i64 (i64) -> (i64)
; WASM64-DAG-MVP-NEXT: # %bb.0:
; WASM64-DAG-MVP-NEXT: i64.load16_s $push0=, 0($0)
; WASM64-DAG-MVP-NEXT: return $pop0
;
; WASM64-FAST-LABEL: sext_i16_i64:
; WASM64-FAST: .functype sext_i16_i64 (i64) -> (i64)
; WASM64-FAST-NEXT: # %bb.0:
; WASM64-FAST-NEXT: i32.load16_u $push2=, 0($0)
; WASM64-FAST-NEXT: i64.extend_i32_u $push0=, $pop2
; WASM64-FAST-NEXT: i64.extend16_s $push1=, $pop0
; WASM64-FAST-NEXT: return $pop1
;
; WASM64-FAST-MVP-LABEL: sext_i16_i64:
; WASM64-FAST-MVP: .functype sext_i16_i64 (i64) -> (i64)
; WASM64-FAST-MVP-NEXT: # %bb.0:
; WASM64-FAST-MVP-NEXT: i32.load16_s $push1=, 0($0)
; WASM64-FAST-MVP-NEXT: i64.extend_i32_s $push0=, $pop1
; WASM64-FAST-MVP-NEXT: return $pop0
%v = load i16, ptr %p
%e = sext i16 %v to i64
ret i64 %e
}
define i64 @zext_i16_i64(ptr %p) {
; WASM32-DAG-LABEL: zext_i16_i64:
; WASM32-DAG: .functype zext_i16_i64 (i32) -> (i64)
; WASM32-DAG-NEXT: # %bb.0:
; WASM32-DAG-NEXT: i64.load16_u $push0=, 0($0)
; WASM32-DAG-NEXT: return $pop0
;
; WASM32-DAG-MVP-LABEL: zext_i16_i64:
; WASM32-DAG-MVP: .functype zext_i16_i64 (i32) -> (i64)
; WASM32-DAG-MVP-NEXT: # %bb.0:
; WASM32-DAG-MVP-NEXT: i64.load16_u $push0=, 0($0)
; WASM32-DAG-MVP-NEXT: return $pop0
;
; WASM32-FAST-LABEL: zext_i16_i64:
; WASM32-FAST: .functype zext_i16_i64 (i32) -> (i64)
; WASM32-FAST-NEXT: # %bb.0:
; WASM32-FAST-NEXT: i32.load16_u $push0=, 0($0)
; WASM32-FAST-NEXT: i64.extend_i32_u $push1=, $pop0
; WASM32-FAST-NEXT: return $pop1
;
; WASM32-FAST-MVP-LABEL: zext_i16_i64:
; WASM32-FAST-MVP: .functype zext_i16_i64 (i32) -> (i64)
; WASM32-FAST-MVP-NEXT: # %bb.0:
; WASM32-FAST-MVP-NEXT: i32.load16_u $push0=, 0($0)
; WASM32-FAST-MVP-NEXT: i64.extend_i32_u $push1=, $pop0
; WASM32-FAST-MVP-NEXT: return $pop1
;
; WASM64-DAG-LABEL: zext_i16_i64:
; WASM64-DAG: .functype zext_i16_i64 (i64) -> (i64)
; WASM64-DAG-NEXT: # %bb.0:
; WASM64-DAG-NEXT: i64.load16_u $push0=, 0($0)
; WASM64-DAG-NEXT: return $pop0
;
; WASM64-DAG-MVP-LABEL: zext_i16_i64:
; WASM64-DAG-MVP: .functype zext_i16_i64 (i64) -> (i64)
; WASM64-DAG-MVP-NEXT: # %bb.0:
; WASM64-DAG-MVP-NEXT: i64.load16_u $push0=, 0($0)
; WASM64-DAG-MVP-NEXT: return $pop0
;
; WASM64-FAST-LABEL: zext_i16_i64:
; WASM64-FAST: .functype zext_i16_i64 (i64) -> (i64)
; WASM64-FAST-NEXT: # %bb.0:
; WASM64-FAST-NEXT: i32.load16_u $push0=, 0($0)
; WASM64-FAST-NEXT: i64.extend_i32_u $push1=, $pop0
; WASM64-FAST-NEXT: return $pop1
;
; WASM64-FAST-MVP-LABEL: zext_i16_i64:
; WASM64-FAST-MVP: .functype zext_i16_i64 (i64) -> (i64)
; WASM64-FAST-MVP-NEXT: # %bb.0:
; WASM64-FAST-MVP-NEXT: i32.load16_u $push0=, 0($0)
; WASM64-FAST-MVP-NEXT: i64.extend_i32_u $push1=, $pop0
; WASM64-FAST-MVP-NEXT: return $pop1
%v = load i16, ptr %p
%e = zext i16 %v to i64
ret i64 %e
}
define i64 @sext_i32_i64(ptr %p) {
; WASM32-DAG-LABEL: sext_i32_i64:
; WASM32-DAG: .functype sext_i32_i64 (i32) -> (i64)
; WASM32-DAG-NEXT: # %bb.0:
; WASM32-DAG-NEXT: i64.load32_s $push0=, 0($0)
; WASM32-DAG-NEXT: return $pop0
;
; WASM32-DAG-MVP-LABEL: sext_i32_i64:
; WASM32-DAG-MVP: .functype sext_i32_i64 (i32) -> (i64)
; WASM32-DAG-MVP-NEXT: # %bb.0:
; WASM32-DAG-MVP-NEXT: i64.load32_s $push0=, 0($0)
; WASM32-DAG-MVP-NEXT: return $pop0
;
; WASM32-FAST-LABEL: sext_i32_i64:
; WASM32-FAST: .functype sext_i32_i64 (i32) -> (i64)
; WASM32-FAST-NEXT: # %bb.0:
; WASM32-FAST-NEXT: i64.load32_s $push0=, 0($0)
; WASM32-FAST-NEXT: return $pop0
;
; WASM32-FAST-MVP-LABEL: sext_i32_i64:
; WASM32-FAST-MVP: .functype sext_i32_i64 (i32) -> (i64)
; WASM32-FAST-MVP-NEXT: # %bb.0:
; WASM32-FAST-MVP-NEXT: i32.load $push1=, 0($0)
; WASM32-FAST-MVP-NEXT: i64.extend_i32_s $push0=, $pop1
; WASM32-FAST-MVP-NEXT: return $pop0
;
; WASM64-DAG-LABEL: sext_i32_i64:
; WASM64-DAG: .functype sext_i32_i64 (i64) -> (i64)
; WASM64-DAG-NEXT: # %bb.0:
; WASM64-DAG-NEXT: i64.load32_s $push0=, 0($0)
; WASM64-DAG-NEXT: return $pop0
;
; WASM64-DAG-MVP-LABEL: sext_i32_i64:
; WASM64-DAG-MVP: .functype sext_i32_i64 (i64) -> (i64)
; WASM64-DAG-MVP-NEXT: # %bb.0:
; WASM64-DAG-MVP-NEXT: i64.load32_s $push0=, 0($0)
; WASM64-DAG-MVP-NEXT: return $pop0
;
; WASM64-FAST-LABEL: sext_i32_i64:
; WASM64-FAST: .functype sext_i32_i64 (i64) -> (i64)
; WASM64-FAST-NEXT: # %bb.0:
; WASM64-FAST-NEXT: i64.load32_s $push0=, 0($0)
; WASM64-FAST-NEXT: return $pop0
;
; WASM64-FAST-MVP-LABEL: sext_i32_i64:
; WASM64-FAST-MVP: .functype sext_i32_i64 (i64) -> (i64)
; WASM64-FAST-MVP-NEXT: # %bb.0:
; WASM64-FAST-MVP-NEXT: i32.load $push1=, 0($0)
; WASM64-FAST-MVP-NEXT: i64.extend_i32_s $push0=, $pop1
; WASM64-FAST-MVP-NEXT: return $pop0
%v = load i32, ptr %p
%e = sext i32 %v to i64
ret i64 %e
}
define i64 @zext_i32_i64(ptr %p) {
; WASM32-DAG-LABEL: zext_i32_i64:
; WASM32-DAG: .functype zext_i32_i64 (i32) -> (i64)
; WASM32-DAG-NEXT: # %bb.0:
; WASM32-DAG-NEXT: i64.load32_u $push0=, 0($0)
; WASM32-DAG-NEXT: return $pop0
;
; WASM32-DAG-MVP-LABEL: zext_i32_i64:
; WASM32-DAG-MVP: .functype zext_i32_i64 (i32) -> (i64)
; WASM32-DAG-MVP-NEXT: # %bb.0:
; WASM32-DAG-MVP-NEXT: i64.load32_u $push0=, 0($0)
; WASM32-DAG-MVP-NEXT: return $pop0
;
; WASM32-FAST-LABEL: zext_i32_i64:
; WASM32-FAST: .functype zext_i32_i64 (i32) -> (i64)
; WASM32-FAST-NEXT: # %bb.0:
; WASM32-FAST-NEXT: i32.load $push1=, 0($0)
; WASM32-FAST-NEXT: i64.extend_i32_u $push0=, $pop1
; WASM32-FAST-NEXT: return $pop0
;
; WASM32-FAST-MVP-LABEL: zext_i32_i64:
; WASM32-FAST-MVP: .functype zext_i32_i64 (i32) -> (i64)
; WASM32-FAST-MVP-NEXT: # %bb.0:
; WASM32-FAST-MVP-NEXT: i32.load $push1=, 0($0)
; WASM32-FAST-MVP-NEXT: i64.extend_i32_u $push0=, $pop1
; WASM32-FAST-MVP-NEXT: return $pop0
;
; WASM64-DAG-LABEL: zext_i32_i64:
; WASM64-DAG: .functype zext_i32_i64 (i64) -> (i64)
; WASM64-DAG-NEXT: # %bb.0:
; WASM64-DAG-NEXT: i64.load32_u $push0=, 0($0)
; WASM64-DAG-NEXT: return $pop0
;
; WASM64-DAG-MVP-LABEL: zext_i32_i64:
; WASM64-DAG-MVP: .functype zext_i32_i64 (i64) -> (i64)
; WASM64-DAG-MVP-NEXT: # %bb.0:
; WASM64-DAG-MVP-NEXT: i64.load32_u $push0=, 0($0)
; WASM64-DAG-MVP-NEXT: return $pop0
;
; WASM64-FAST-LABEL: zext_i32_i64:
; WASM64-FAST: .functype zext_i32_i64 (i64) -> (i64)
; WASM64-FAST-NEXT: # %bb.0:
; WASM64-FAST-NEXT: i32.load $push1=, 0($0)
; WASM64-FAST-NEXT: i64.extend_i32_u $push0=, $pop1
; WASM64-FAST-NEXT: return $pop0
;
; WASM64-FAST-MVP-LABEL: zext_i32_i64:
; WASM64-FAST-MVP: .functype zext_i32_i64 (i64) -> (i64)
; WASM64-FAST-MVP-NEXT: # %bb.0:
; WASM64-FAST-MVP-NEXT: i32.load $push1=, 0($0)
; WASM64-FAST-MVP-NEXT: i64.extend_i32_u $push0=, $pop1
; WASM64-FAST-MVP-NEXT: return $pop0
%v = load i32, ptr %p
%e = zext i32 %v to i64
ret i64 %e
}