1*9880d681SAndroid Build Coastguard Worker; RUN: llc < %s -asm-verbose=false | FileCheck %s 2*9880d681SAndroid Build Coastguard Worker 3*9880d681SAndroid Build Coastguard Worker; Test that truncating stores are assembled properly. 4*9880d681SAndroid Build Coastguard Worker 5*9880d681SAndroid Build Coastguard Workertarget datalayout = "e-m:e-p:32:32-i64:64-n32:64-S128" 6*9880d681SAndroid Build Coastguard Workertarget triple = "wasm32-unknown-unknown" 7*9880d681SAndroid Build Coastguard Worker 8*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: trunc_i8_i32: 9*9880d681SAndroid Build Coastguard Worker; CHECK: i32.store8 $drop=, 0($0), $1{{$}} 10*9880d681SAndroid Build Coastguard Workerdefine void @trunc_i8_i32(i8 *%p, i32 %v) { 11*9880d681SAndroid Build Coastguard Worker %t = trunc i32 %v to i8 12*9880d681SAndroid Build Coastguard Worker store i8 %t, i8* %p 13*9880d681SAndroid Build Coastguard Worker ret void 14*9880d681SAndroid Build Coastguard Worker} 15*9880d681SAndroid Build Coastguard Worker 16*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: trunc_i16_i32: 17*9880d681SAndroid Build Coastguard Worker; CHECK: i32.store16 $drop=, 0($0), $1{{$}} 18*9880d681SAndroid Build Coastguard Workerdefine void @trunc_i16_i32(i16 *%p, i32 %v) { 19*9880d681SAndroid Build Coastguard Worker %t = trunc i32 %v to i16 20*9880d681SAndroid Build Coastguard Worker store i16 %t, i16* %p 21*9880d681SAndroid Build Coastguard Worker ret void 22*9880d681SAndroid Build Coastguard Worker} 23*9880d681SAndroid Build Coastguard Worker 24*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: trunc_i8_i64: 25*9880d681SAndroid Build Coastguard Worker; CHECK: i64.store8 $drop=, 0($0), $1{{$}} 26*9880d681SAndroid Build Coastguard Workerdefine void @trunc_i8_i64(i8 *%p, i64 %v) { 27*9880d681SAndroid Build Coastguard Worker %t = trunc i64 %v to i8 28*9880d681SAndroid Build Coastguard Worker store i8 %t, i8* %p 29*9880d681SAndroid Build Coastguard Worker ret void 30*9880d681SAndroid Build Coastguard Worker} 31*9880d681SAndroid Build Coastguard Worker 32*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: trunc_i16_i64: 33*9880d681SAndroid Build Coastguard Worker; CHECK: i64.store16 $drop=, 0($0), $1{{$}} 34*9880d681SAndroid Build Coastguard Workerdefine void @trunc_i16_i64(i16 *%p, i64 %v) { 35*9880d681SAndroid Build Coastguard Worker %t = trunc i64 %v to i16 36*9880d681SAndroid Build Coastguard Worker store i16 %t, i16* %p 37*9880d681SAndroid Build Coastguard Worker ret void 38*9880d681SAndroid Build Coastguard Worker} 39*9880d681SAndroid Build Coastguard Worker 40*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: trunc_i32_i64: 41*9880d681SAndroid Build Coastguard Worker; CHECK: i64.store32 $drop=, 0($0), $1{{$}} 42*9880d681SAndroid Build Coastguard Workerdefine void @trunc_i32_i64(i32 *%p, i64 %v) { 43*9880d681SAndroid Build Coastguard Worker %t = trunc i64 %v to i32 44*9880d681SAndroid Build Coastguard Worker store i32 %t, i32* %p 45*9880d681SAndroid Build Coastguard Worker ret void 46*9880d681SAndroid Build Coastguard Worker} 47