llvm.org GIT mirror llvm / 6f31a46 test / CodeGen / WebAssembly / signext-arg.ll
6f31a46

Tree @6f31a46 (Download .tar.gz)

signext-arg.ll @6f31a46

40486d7
a26aa42
64b3797
 
8d1235f
40486d7
 
 
 
 
64b3797
40486d7
 
 
 
64b3797
40486d7
 
 
 
 
 
; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
; RUN: llc < %s -asm-verbose=false -wasm-disable-explicit-locals -wasm-keep-registers | FileCheck %s

target datalayout = "e-m:e-p:32:32-i64:64-n32:64-S128"
target triple = "wasm32-unknown-unknown"

declare i32 @get_int(i16 %arg)

define i32 @func_1(i16 %arg1 , i32 %arg2) #0 {
; CHECK-LABEL: func_1:
; CHECK:         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:    end_function
entry:
  %retval = call i32 @get_int(i16 signext %arg1)
  ret i32 %retval
}

attributes #0 = {noinline nounwind optnone}