blob: effe2fedf26d1802c605e5ff2fd30a9ff59a1d7e [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 Gohmand0bf9812015-09-26 01:09:44 +00008; CHECK-LABEL: (func $load_u_i1_i32
9; CHECK: (setlocal @1 (load_u_i8_i32 @0))
JF Bastien73ff6af2015-08-31 22:24:11 +000010; CHECK-NEXT: (return @1)
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 Gohmand0bf9812015-09-26 01:09:44 +000017; CHECK-LABEL: (func $load_s_i1_i32
18; CHECK: (setlocal @1 (load_u_i8_i32 @0))
JF Bastien73ff6af2015-08-31 22:24:11 +000019; CHECK-NEXT: (setlocal @2 (immediate 31))
20; CHECK-NEXT: (setlocal @3 (shl @1 @2))
JF Bastien749ed882015-09-08 17:21:21 +000021; CHECK-NEXT: (setlocal @4 (shr_s @3 @2))
JF Bastien73ff6af2015-08-31 22:24:11 +000022; CHECK-NEXT: (return @4)
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 Gohmand0bf9812015-09-26 01:09:44 +000029; CHECK-LABEL: (func $load_u_i1_i64
30; CHECK: (setlocal @1 (load_u_i8_i64 @0))
JF Bastien73ff6af2015-08-31 22:24:11 +000031; CHECK-NEXT: (return @1)
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 Gohmand0bf9812015-09-26 01:09:44 +000038; CHECK-LABEL: (func $load_s_i1_i64
39; CHECK: (setlocal @1 (load_u_i8_i64 @0))
JF Bastien73ff6af2015-08-31 22:24:11 +000040; CHECK-NEXT: (setlocal @2 (immediate 63))
41; CHECK-NEXT: (setlocal @3 (shl @1 @2))
JF Bastien749ed882015-09-08 17:21:21 +000042; CHECK-NEXT: (setlocal @4 (shr_s @3 @2))
JF Bastien73ff6af2015-08-31 22:24:11 +000043; CHECK-NEXT: (return @4)
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
50; CHECK-LABEL: (func $store_i32_i1
51; CHECK: (setlocal @2 (immediate 1))
52; CHECK-NEXT: (setlocal @3 (and @1 @2))
53; CHECK-NEXT: (store_i8 @0 @3)
54define 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
60; CHECK-LABEL: (func $store_i64_i1
61; CHECK: (setlocal @2 (immediate 1))
62; CHECK-NEXT: (setlocal @3 (and @1 @2))
63; CHECK-NEXT: (store_i8 @0 @3)
64define 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}