[ARM] Split large truncating MVE stores
[llvm-complete.git] / test / CodeGen / WebAssembly / signext-arg.ll
blob0bfc8f48dff5e779e2ca44ec46d3b3c699da0566
1 ; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
2 ; RUN: llc < %s -asm-verbose=false -wasm-disable-explicit-locals -wasm-keep-registers | FileCheck %s
4 target datalayout = "e-m:e-p:32:32-i64:64-n32:64-S128"
5 target triple = "wasm32-unknown-unknown"
7 declare i32 @get_int(i16 %arg)
9 define i32 @func_1(i16 %arg1 , i32 %arg2) #0 {
10 ; CHECK-LABEL: func_1:
11 ; CHECK:         i32.const $push1=, 16
12 ; CHECK-NEXT:    i32.shl $push2=, $0, $pop1
13 ; CHECK-NEXT:    i32.const $push4=, 16
14 ; CHECK-NEXT:    i32.shr_s $push3=, $pop2, $pop4
15 ; CHECK-NEXT:    i32.call $push0=, get_int, $pop3
16 ; CHECK-NEXT:    end_function
17 entry:
18   %retval = call i32 @get_int(i16 signext %arg1)
19   ret i32 %retval
22 attributes #0 = {noinline nounwind optnone}