forked from OSchip/llvm-project
[WebAssembly] Call signExtend to get sign extended register
Patch by Jatin Bhateja! Differential Revision: https://reviews.llvm.org/D39529 llvm-svn: 317710
This commit is contained in:
parent
a3efbb0836
commit
0828ba1e1e
|
@ -541,7 +541,7 @@ unsigned WebAssemblyFastISel::getRegForUnsignedValue(const Value *V) {
|
|||
unsigned WebAssemblyFastISel::getRegForSignedValue(const Value *V) {
|
||||
MVT::SimpleValueType From = getSimpleType(V->getType());
|
||||
MVT::SimpleValueType To = getLegalType(From);
|
||||
return zeroExtend(getRegForValue(V), V, From, To);
|
||||
return signExtend(getRegForValue(V), V, From, To);
|
||||
}
|
||||
|
||||
unsigned WebAssemblyFastISel::getRegForPromotedValue(const Value *V,
|
||||
|
|
|
@ -0,0 +1,22 @@
|
|||
; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
|
||||
; RUN: llc < %s -march=wasm32 | FileCheck %s
|
||||
|
||||
declare i32 @get_int(i16 %arg)
|
||||
|
||||
define i32 @func_1(i16 %arg1 , i32 %arg2) #0 {
|
||||
; CHECK-LABEL: func_1:
|
||||
; CHECK: # BB#0: # %entry
|
||||
; CHECK-NEXT: i32.const $push1=, 16
|
||||
; CHECK-NEXT: i32.shl $push2=, $0, $pop1
|
||||
; CHECK-NEXT: i32.const $push4=, 16
|
||||
; CHECK-NEXT: i32.shr_s $push3=, $pop2, $pop4
|
||||
; CHECK-NEXT: i32.call $push0=, get_int@FUNCTION, $pop3
|
||||
; CHECK-NEXT: # fallthrough-return: $pop0
|
||||
; CHECK-NEXT: .endfunc
|
||||
entry:
|
||||
%retval = call i32 @get_int(i16 signext %arg1)
|
||||
ret i32 %retval
|
||||
}
|
||||
|
||||
attributes #0 = {noinline nounwind optnone}
|
||||
|
Loading…
Reference in New Issue