Run DCE after a LoopFlatten test to reduce spurious output [nfc]
[llvm-project.git] / llvm / test / CodeGen / AArch64 / i1-contents.ll
blob6fc01fd19335bfb33f5745390c175b7a877773fc
1 ; RUN: llc -mtriple=aarch64-linux-gnu -o - %s | FileCheck %s --check-prefixes CHECK,CHECK-SDAG
2 ; RUN: llc -global-isel -mtriple=aarch64-linux-gnu -o - %s | FileCheck %s --check-prefixes CHECK,CHECK-GISEL
3 %big = type i32
5 @var = dso_local global %big 0
7 ; AAPCS: low 8 bits of %in (== w0) will be either 0 or 1. Need to extend to
8 ; 32-bits.
9 define dso_local void @consume_i1_arg(i1 %in) {
10 ; CHECK-LABEL: consume_i1_arg:
11 ; CHECK: and [[BOOL32:w[0-9]+]], w0, #{{0x1|0xff}}
12 ; CHECK: str [[BOOL32]], [{{x[0-9]+}}, :lo12:var]
13   %val = zext i1 %in to %big
14   store %big %val, ptr @var
15   ret void
18 ; AAPCS: low 8 bits of %val1 (== w0) will be either 0 or 1. Need to extend to
19 ; 32-bits (doesn't really matter if it's from 1 or 8 bits).
20 define dso_local void @consume_i1_ret() {
21 ; CHECK-LABEL: consume_i1_ret:
22 ; CHECK: bl produce_i1_ret
23 ; CHECK: and [[BOOL32:w[0-9]+]], w0, #{{0x1|0xff}}
24 ; CHECK: str [[BOOL32]], [{{x[0-9]+}}, :lo12:var]
25   %val1 = call i1 @produce_i1_ret()
26   %val = zext i1 %val1 to %big
27   store %big %val, ptr @var
28   ret void
31 ; AAPCS: low 8 bits of w0 must be either 0 or 1. Need to mask them off.
32 define dso_local i1 @produce_i1_ret() {
33 ; CHECK-LABEL: produce_i1_ret:
34 ; CHECK: ldr [[VAR32:w[0-9]+]], [{{x[0-9]+}}, :lo12:var]
35 ; CHECK: and w0, [[VAR32]], #{{0x1|0xff}}
36   %val = load %big, ptr @var
37   %val1 = trunc %big %val to i1
38   ret i1 %val1
41 define dso_local void @produce_i1_arg() {
42 ; CHECK-LABEL: produce_i1_arg:
43 ; CHECK: ldr [[VAR32:w[0-9]+]], [{{x[0-9]+}}, :lo12:var]
44 ; CHECK: and w0, [[VAR32]], #{{0x1|0xff}}
45 ; CHECK: bl consume_i1_arg
46   %val = load %big, ptr @var
47   %val1 = trunc %big %val to i1
48   call void @consume_i1_arg(i1 %val1)
49   ret void
53 define dso_local void @forward_i1_arg1(i1 %in) {
54 ; CHECK-LABEL: forward_i1_arg1:
55 ; CHECK-NOT: and
56 ; CHECK: bl consume_i1_arg
57   call void @consume_i1_arg(i1 %in)
58   ret void
61 define dso_local void @forward_i1_arg2(i1 %in, i1 %cond) {
62 ; CHECK-LABEL: forward_i1_arg2:
64 ; The optimization in SelectionDAG currently fails to recognize that
65 ; %in is already zero-extended to i8 if the call is not in the entry
66 ; block.
68 ; CHECK-SDAG: and
69 ; CHECK-GISEL-NOT: and
71 ; CHECK: bl consume_i1_arg
72   br i1 %cond, label %true, label %false
73 true:
74   call void @consume_i1_arg(i1 %in)
75   ret void
77 false:
78   ret void
81 ;define zeroext i1 @foo(i8 %in) {
82 ;  %val = trunc i8 %in to i1
83 ;  ret i1 %val