blob: 4d894d96bc445293b5ddc7dbca7fbff50007f52f [file] [log] [blame]
JF Bastien73ff6af2015-08-31 22:24:11 +00001; RUN: llc < %s -asm-verbose=false | FileCheck %s
2
3; Test that i1 extending loads and truncating stores are assembled properly.
4
Dan Gohman5e066842015-09-09 20:54:31 +00005target datalayout = "e-p:32:32-i64:64-n32:64-S128"
JF Bastien73ff6af2015-08-31 22:24:11 +00006target triple = "wasm32-unknown-unknown"
7
Dan Gohmane51c0582015-10-06 00:27:55 +00008; CHECK-LABEL: load_u_i1_i32:
Dan Gohman4ba48162015-11-18 16:12:01 +00009; CHECK: i32.load8_u $[[NUM0:[0-9]+]], $0{{$}}
10; CHECK-NEXT: return $[[NUM0]]{{$}}
Dan Gohmand0bf9812015-09-26 01:09:44 +000011define i32 @load_u_i1_i32(i1* %p) {
JF Bastien73ff6af2015-08-31 22:24:11 +000012 %v = load i1, i1* %p
13 %e = zext i1 %v to i32
14 ret i32 %e
15}
16
Dan Gohmane51c0582015-10-06 00:27:55 +000017; CHECK-LABEL: load_s_i1_i32:
Dan Gohman4ba48162015-11-18 16:12:01 +000018; CHECK: i32.load8_u $[[NUM0:[0-9]+]], $0{{$}}
19; CHECK-NEXT: i32.const $[[NUM1:[0-9]+]], 31{{$}}
20; CHECK-NEXT: shl $push[[NUM2:[0-9]+]], $[[NUM0]], $[[NUM1]]{{$}}
21; CHECK-NEXT: shr_s $push[[NUM3:[0-9]+]], $pop[[NUM2]], $[[NUM1]]{{$}}
22; CHECK-NEXT: return $pop[[NUM3]]{{$}}
Dan Gohmand0bf9812015-09-26 01:09:44 +000023define i32 @load_s_i1_i32(i1* %p) {
JF Bastien73ff6af2015-08-31 22:24:11 +000024 %v = load i1, i1* %p
25 %e = sext i1 %v to i32
26 ret i32 %e
27}
28
Dan Gohmane51c0582015-10-06 00:27:55 +000029; CHECK-LABEL: load_u_i1_i64:
Dan Gohman4ba48162015-11-18 16:12:01 +000030; CHECK: i64.load8_u $[[NUM0:[0-9]+]], $0{{$}}
31; CHECK-NEXT: return $[[NUM0]]{{$}}
Dan Gohmand0bf9812015-09-26 01:09:44 +000032define i64 @load_u_i1_i64(i1* %p) {
JF Bastien73ff6af2015-08-31 22:24:11 +000033 %v = load i1, i1* %p
34 %e = zext i1 %v to i64
35 ret i64 %e
36}
37
Dan Gohmane51c0582015-10-06 00:27:55 +000038; CHECK-LABEL: load_s_i1_i64:
Dan Gohman4ba48162015-11-18 16:12:01 +000039; CHECK: i64.load8_u $[[NUM0:[0-9]+]], $0{{$}}
40; CHECK-NEXT: i64.const $[[NUM1:[0-9]+]], 63{{$}}
41; CHECK-NEXT: shl $push[[NUM2:[0-9]+]], $[[NUM0]], $[[NUM1]]{{$}}
42; CHECK-NEXT: shr_s $push[[NUM3:[0-9]+]], $pop[[NUM2]], $[[NUM1]]{{$}}
43; CHECK-NEXT: return $pop[[NUM3]]{{$}}
Dan Gohmand0bf9812015-09-26 01:09:44 +000044define i64 @load_s_i1_i64(i1* %p) {
JF Bastien73ff6af2015-08-31 22:24:11 +000045 %v = load i1, i1* %p
46 %e = sext i1 %v to i64
47 ret i64 %e
48}
49
Dan Gohmane51c0582015-10-06 00:27:55 +000050; CHECK-LABEL: store_i32_i1:
Dan Gohman4ba48162015-11-18 16:12:01 +000051; CHECK: i32.const $push[[NUM0:[0-9]+]], 1{{$}}
52; CHECK-NEXT: i32.and $push[[NUM1:[0-9]+]], $1, $pop[[NUM0]]{{$}}
Dan Gohman7054ac12015-11-23 21:16:35 +000053; CHECK-NEXT: i32.store8 $discard, $0, $pop[[NUM1]]{{$}}
JF Bastien73ff6af2015-08-31 22:24:11 +000054define void @store_i32_i1(i1* %p, i32 %v) {
55 %t = trunc i32 %v to i1
56 store i1 %t, i1* %p
57 ret void
58}
59
Dan Gohmane51c0582015-10-06 00:27:55 +000060; CHECK-LABEL: store_i64_i1:
Dan Gohman4ba48162015-11-18 16:12:01 +000061; CHECK: i64.const $push[[NUM0:[0-9]+]], 1{{$}}
62; CHECK-NEXT: i64.and $push[[NUM1:[0-9]+]], $1, $pop[[NUM0]]{{$}}
Dan Gohman7054ac12015-11-23 21:16:35 +000063; CHECK-NEXT: i64.store8 $discard, $0, $pop[[NUM1]]{{$}}
JF Bastien73ff6af2015-08-31 22:24:11 +000064define void @store_i64_i1(i1* %p, i64 %v) {
65 %t = trunc i64 %v to i1
66 store i1 %t, i1* %p
67 ret void
68}