1; An integer truncation to i1 should be done with an and instruction to make
2; sure only the LSBit survives. Test that this is the case both for a returned
3; value and as the operand of a branch.
4; RUN: llc < %s -march=x86 | FileCheck %s
5
6define zeroext i1 @test1(i32 %X)  nounwind {
7    %Y = trunc i32 %X to i1
8    ret i1 %Y
9}
10; CHECK-LABEL: test1:
11; CHECK: andl $1, %eax
12
13define i1 @test2(i32 %val, i32 %mask) nounwind {
14entry:
15    %shifted = ashr i32 %val, %mask
16    %anded = and i32 %shifted, 1
17    %trunced = trunc i32 %anded to i1
18    br i1 %trunced, label %ret_true, label %ret_false
19ret_true:
20    ret i1 true
21ret_false:
22    ret i1 false
23}
24; CHECK-LABEL: test2:
25; CHECK: btl
26
27define i32 @test3(i8* %ptr) nounwind {
28    %val = load i8, i8* %ptr
29    %tmp = trunc i8 %val to i1
30    br i1 %tmp, label %cond_true, label %cond_false
31cond_true:
32    ret i32 21
33cond_false:
34    ret i32 42
35}
36; CHECK-LABEL: test3:
37; CHECK: testb $1, (%eax)
38
39define i32 @test4(i8* %ptr) nounwind {
40    %tmp = ptrtoint i8* %ptr to i1
41    br i1 %tmp, label %cond_true, label %cond_false
42cond_true:
43    ret i32 21
44cond_false:
45    ret i32 42
46}
47; CHECK-LABEL: test4:
48; CHECK: testb $1, 4(%esp)
49
50define i32 @test5(double %d) nounwind {
51    %tmp = fptosi double %d to i1
52    br i1 %tmp, label %cond_true, label %cond_false
53cond_true:
54    ret i32 21
55cond_false:
56    ret i32 42
57}
58; CHECK-LABEL: test5:
59; CHECK: testb $1
60