blob: 5ba6361bd0c341f4cc009544333e573529aa53c4 [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
5target datalayout = "e-p:32:32-i64:64-v128:8:128-n32:64-S128"
6target triple = "wasm32-unknown-unknown"
7
8; CHECK-LABEL: (func $load_unsigned_i1_i32
9; CHECK: (setlocal @1 (load_zx_i8_i32 @0))
10; CHECK-NEXT: (return @1)
11define i32 @load_unsigned_i1_i32(i1* %p) {
12 %v = load i1, i1* %p
13 %e = zext i1 %v to i32
14 ret i32 %e
15}
16
17; CHECK-LABEL: (func $load_signed_i1_i32
18; CHECK: (setlocal @1 (load_zx_i8_i32 @0))
19; 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)
23define i32 @load_signed_i1_i32(i1* %p) {
24 %v = load i1, i1* %p
25 %e = sext i1 %v to i32
26 ret i32 %e
27}
28
29; CHECK-LABEL: (func $load_unsigned_i1_i64
30; CHECK: (setlocal @1 (load_zx_i8_i64 @0))
31; CHECK-NEXT: (return @1)
32define i64 @load_unsigned_i1_i64(i1* %p) {
33 %v = load i1, i1* %p
34 %e = zext i1 %v to i64
35 ret i64 %e
36}
37
38; CHECK-LABEL: (func $load_signed_i1_i64
39; CHECK: (setlocal @1 (load_zx_i8_i64 @0))
40; 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)
44define i64 @load_signed_i1_i64(i1* %p) {
45 %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}