1*9880d681SAndroid Build Coastguard Worker; RUN: llc -mtriple=i686-linux-gnu %s -o - | FileCheck %s 2*9880d681SAndroid Build Coastguard Worker 3*9880d681SAndroid Build Coastguard Worker 4*9880d681SAndroid Build Coastguard Workerdefine i32 @branch_eq(i64 %a, i64 %b) { 5*9880d681SAndroid Build Coastguard Workerentry: 6*9880d681SAndroid Build Coastguard Worker %cmp = icmp eq i64 %a, %b 7*9880d681SAndroid Build Coastguard Worker br i1 %cmp, label %bb1, label %bb2 8*9880d681SAndroid Build Coastguard Workerbb1: 9*9880d681SAndroid Build Coastguard Worker ret i32 1 10*9880d681SAndroid Build Coastguard Workerbb2: 11*9880d681SAndroid Build Coastguard Worker ret i32 2 12*9880d681SAndroid Build Coastguard Worker 13*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: branch_eq: 14*9880d681SAndroid Build Coastguard Worker; CHECK: movl 4(%esp), [[LHSLo:%[a-z]+]] 15*9880d681SAndroid Build Coastguard Worker; CHECK: movl 8(%esp), [[LHSHi:%[a-z]+]] 16*9880d681SAndroid Build Coastguard Worker; CHECK: xorl 16(%esp), [[LHSHi]] 17*9880d681SAndroid Build Coastguard Worker; CHECK: xorl 12(%esp), [[LHSLo]] 18*9880d681SAndroid Build Coastguard Worker; CHECK: orl [[LHSHi]], [[LHSLo]] 19*9880d681SAndroid Build Coastguard Worker; CHECK: jne [[FALSE:.LBB[0-9_]+]] 20*9880d681SAndroid Build Coastguard Worker; CHECK: movl $1, %eax 21*9880d681SAndroid Build Coastguard Worker; CHECK: retl 22*9880d681SAndroid Build Coastguard Worker; CHECK: [[FALSE]]: 23*9880d681SAndroid Build Coastguard Worker; CHECK: movl $2, %eax 24*9880d681SAndroid Build Coastguard Worker; CHECK: retl 25*9880d681SAndroid Build Coastguard Worker} 26*9880d681SAndroid Build Coastguard Worker 27*9880d681SAndroid Build Coastguard Workerdefine i32 @branch_slt(i64 %a, i64 %b) { 28*9880d681SAndroid Build Coastguard Workerentry: 29*9880d681SAndroid Build Coastguard Worker %cmp = icmp slt i64 %a, %b 30*9880d681SAndroid Build Coastguard Worker br i1 %cmp, label %bb1, label %bb2 31*9880d681SAndroid Build Coastguard Workerbb1: 32*9880d681SAndroid Build Coastguard Worker ret i32 1 33*9880d681SAndroid Build Coastguard Workerbb2: 34*9880d681SAndroid Build Coastguard Worker ret i32 2 35*9880d681SAndroid Build Coastguard Worker 36*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: branch_slt: 37*9880d681SAndroid Build Coastguard Worker; CHECK: movl 4(%esp), [[LHSLo:%[a-z]+]] 38*9880d681SAndroid Build Coastguard Worker; CHECK: movl 8(%esp), [[LHSHi:%[a-z]+]] 39*9880d681SAndroid Build Coastguard Worker; CHECK: cmpl 12(%esp), [[LHSLo]] 40*9880d681SAndroid Build Coastguard Worker; CHECK: sbbl 16(%esp), [[LHSHi]] 41*9880d681SAndroid Build Coastguard Worker; CHECK: jge [[FALSE:.LBB[0-9_]+]] 42*9880d681SAndroid Build Coastguard Worker; CHECK: movl $1, %eax 43*9880d681SAndroid Build Coastguard Worker; CHECK: retl 44*9880d681SAndroid Build Coastguard Worker; CHECK: [[FALSE]]: 45*9880d681SAndroid Build Coastguard Worker; CHECK: movl $2, %eax 46*9880d681SAndroid Build Coastguard Worker; CHECK: retl 47*9880d681SAndroid Build Coastguard Worker} 48*9880d681SAndroid Build Coastguard Worker 49*9880d681SAndroid Build Coastguard Workerdefine i32 @branch_ule(i64 %a, i64 %b) { 50*9880d681SAndroid Build Coastguard Workerentry: 51*9880d681SAndroid Build Coastguard Worker %cmp = icmp ule i64 %a, %b 52*9880d681SAndroid Build Coastguard Worker br i1 %cmp, label %bb1, label %bb2 53*9880d681SAndroid Build Coastguard Workerbb1: 54*9880d681SAndroid Build Coastguard Worker ret i32 1 55*9880d681SAndroid Build Coastguard Workerbb2: 56*9880d681SAndroid Build Coastguard Worker ret i32 2 57*9880d681SAndroid Build Coastguard Worker 58*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: branch_ule: 59*9880d681SAndroid Build Coastguard Worker; CHECK: movl 12(%esp), [[RHSLo:%[a-z]+]] 60*9880d681SAndroid Build Coastguard Worker; CHECK: movl 16(%esp), [[RHSHi:%[a-z]+]] 61*9880d681SAndroid Build Coastguard Worker; CHECK: cmpl 4(%esp), [[RHSLo]] 62*9880d681SAndroid Build Coastguard Worker; CHECK: sbbl 8(%esp), [[RHSHi]] 63*9880d681SAndroid Build Coastguard Worker; CHECK: jb [[FALSE:.LBB[0-9_]+]] 64*9880d681SAndroid Build Coastguard Worker; CHECK: movl $1, %eax 65*9880d681SAndroid Build Coastguard Worker; CHECK: retl 66*9880d681SAndroid Build Coastguard Worker; CHECK: [[FALSE]]: 67*9880d681SAndroid Build Coastguard Worker; CHECK: movl $2, %eax 68*9880d681SAndroid Build Coastguard Worker; CHECK: retl 69*9880d681SAndroid Build Coastguard Worker} 70*9880d681SAndroid Build Coastguard Worker 71*9880d681SAndroid Build Coastguard Workerdefine i32 @set_gt(i64 %a, i64 %b) { 72*9880d681SAndroid Build Coastguard Workerentry: 73*9880d681SAndroid Build Coastguard Worker %cmp = icmp sgt i64 %a, %b 74*9880d681SAndroid Build Coastguard Worker %res = select i1 %cmp, i32 1, i32 0 75*9880d681SAndroid Build Coastguard Worker ret i32 %res 76*9880d681SAndroid Build Coastguard Worker 77*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: set_gt: 78*9880d681SAndroid Build Coastguard Worker; CHECK: movl 12(%esp), [[RHSLo:%[a-z]+]] 79*9880d681SAndroid Build Coastguard Worker; CHECK: movl 16(%esp), [[RHSHi:%[a-z]+]] 80*9880d681SAndroid Build Coastguard Worker; CHECK: cmpl 4(%esp), [[RHSLo]] 81*9880d681SAndroid Build Coastguard Worker; CHECK: sbbl 8(%esp), [[RHSHi]] 82*9880d681SAndroid Build Coastguard Worker; CHECK: setl %al 83*9880d681SAndroid Build Coastguard Worker; CHECK: retl 84*9880d681SAndroid Build Coastguard Worker} 85*9880d681SAndroid Build Coastguard Worker 86*9880d681SAndroid Build Coastguard Workerdefine i32 @test_wide(i128 %a, i128 %b) { 87*9880d681SAndroid Build Coastguard Workerentry: 88*9880d681SAndroid Build Coastguard Worker %cmp = icmp slt i128 %a, %b 89*9880d681SAndroid Build Coastguard Worker br i1 %cmp, label %bb1, label %bb2 90*9880d681SAndroid Build Coastguard Workerbb1: 91*9880d681SAndroid Build Coastguard Worker ret i32 1 92*9880d681SAndroid Build Coastguard Workerbb2: 93*9880d681SAndroid Build Coastguard Worker ret i32 2 94*9880d681SAndroid Build Coastguard Worker 95*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: test_wide: 96*9880d681SAndroid Build Coastguard Worker; CHECK: cmpl 24(%esp) 97*9880d681SAndroid Build Coastguard Worker; CHECK: sbbl 28(%esp) 98*9880d681SAndroid Build Coastguard Worker; CHECK: sbbl 32(%esp) 99*9880d681SAndroid Build Coastguard Worker; CHECK: sbbl 36(%esp) 100*9880d681SAndroid Build Coastguard Worker; CHECK: jge [[FALSE:.LBB[0-9_]+]] 101*9880d681SAndroid Build Coastguard Worker; CHECK: movl $1, %eax 102*9880d681SAndroid Build Coastguard Worker; CHECK: retl 103*9880d681SAndroid Build Coastguard Worker; CHECK: [[FALSE]]: 104*9880d681SAndroid Build Coastguard Worker; CHECK: movl $2, %eax 105*9880d681SAndroid Build Coastguard Worker; CHECK: retl 106*9880d681SAndroid Build Coastguard Worker} 107*9880d681SAndroid Build Coastguard Worker 108*9880d681SAndroid Build Coastguard Workerdefine i32 @test_carry_false(i64 %a, i64 %b) { 109*9880d681SAndroid Build Coastguard Workerentry: 110*9880d681SAndroid Build Coastguard Worker %x = and i64 %a, -4294967296 ;0xffffffff00000000 111*9880d681SAndroid Build Coastguard Worker %y = and i64 %b, -4294967296 112*9880d681SAndroid Build Coastguard Worker %cmp = icmp slt i64 %x, %y 113*9880d681SAndroid Build Coastguard Worker br i1 %cmp, label %bb1, label %bb2 114*9880d681SAndroid Build Coastguard Workerbb1: 115*9880d681SAndroid Build Coastguard Worker ret i32 1 116*9880d681SAndroid Build Coastguard Workerbb2: 117*9880d681SAndroid Build Coastguard Worker ret i32 2 118*9880d681SAndroid Build Coastguard Worker 119*9880d681SAndroid Build Coastguard Worker; The comparison of the low bits will be folded to a CARRY_FALSE node. Make 120*9880d681SAndroid Build Coastguard Worker; sure the code can handle that. 121*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: carry_false: 122*9880d681SAndroid Build Coastguard Worker; CHECK: movl 8(%esp), [[LHSHi:%[a-z]+]] 123*9880d681SAndroid Build Coastguard Worker; CHECK: cmpl 16(%esp), [[LHSHi]] 124*9880d681SAndroid Build Coastguard Worker; CHECK: jge [[FALSE:.LBB[0-9_]+]] 125*9880d681SAndroid Build Coastguard Worker; CHECK: movl $1, %eax 126*9880d681SAndroid Build Coastguard Worker; CHECK: retl 127*9880d681SAndroid Build Coastguard Worker; CHECK: [[FALSE]]: 128*9880d681SAndroid Build Coastguard Worker; CHECK: movl $2, %eax 129*9880d681SAndroid Build Coastguard Worker; CHECK: retl 130*9880d681SAndroid Build Coastguard Worker} 131