1*9880d681SAndroid Build Coastguard Worker; RUN: llc < %s -mtriple=x86_64-apple-darwin | FileCheck %s 2*9880d681SAndroid Build Coastguard Worker; rdar://7527734 3*9880d681SAndroid Build Coastguard Worker 4*9880d681SAndroid Build Coastguard Workerdefine i32 @test1(i32 %x) nounwind readnone ssp { 5*9880d681SAndroid Build Coastguard Workerentry: 6*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: test1: 7*9880d681SAndroid Build Coastguard Worker; CHECK: leal 3(%rdi), %eax 8*9880d681SAndroid Build Coastguard Worker %0 = shl i32 %x, 5 ; <i32> [#uses=1] 9*9880d681SAndroid Build Coastguard Worker %1 = or i32 %0, 3 ; <i32> [#uses=1] 10*9880d681SAndroid Build Coastguard Worker ret i32 %1 11*9880d681SAndroid Build Coastguard Worker} 12*9880d681SAndroid Build Coastguard Worker 13*9880d681SAndroid Build Coastguard Workerdefine i64 @test2(i8 %A, i8 %B) nounwind { 14*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: test2: 15*9880d681SAndroid Build Coastguard Worker; CHECK: shrq $4 16*9880d681SAndroid Build Coastguard Worker; CHECK-NOT: movq 17*9880d681SAndroid Build Coastguard Worker; CHECK-NOT: orq 18*9880d681SAndroid Build Coastguard Worker; CHECK: leaq 19*9880d681SAndroid Build Coastguard Worker; CHECK: ret 20*9880d681SAndroid Build Coastguard Worker %C = zext i8 %A to i64 ; <i64> [#uses=1] 21*9880d681SAndroid Build Coastguard Worker %D = shl i64 %C, 4 ; <i64> [#uses=1] 22*9880d681SAndroid Build Coastguard Worker %E = and i64 %D, 48 ; <i64> [#uses=1] 23*9880d681SAndroid Build Coastguard Worker %F = zext i8 %B to i64 ; <i64> [#uses=1] 24*9880d681SAndroid Build Coastguard Worker %G = lshr i64 %F, 4 ; <i64> [#uses=1] 25*9880d681SAndroid Build Coastguard Worker %H = or i64 %G, %E ; <i64> [#uses=1] 26*9880d681SAndroid Build Coastguard Worker ret i64 %H 27*9880d681SAndroid Build Coastguard Worker} 28*9880d681SAndroid Build Coastguard Worker 29*9880d681SAndroid Build Coastguard Worker;; Test that OR is only emitted as LEA, not as ADD. 30*9880d681SAndroid Build Coastguard Worker 31*9880d681SAndroid Build Coastguard Workerdefine void @test3(i32 %x, i32* %P) nounwind readnone ssp { 32*9880d681SAndroid Build Coastguard Workerentry: 33*9880d681SAndroid Build Coastguard Worker; No reason to emit an add here, should be an or. 34*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: test3: 35*9880d681SAndroid Build Coastguard Worker; CHECK: orl $3, %edi 36*9880d681SAndroid Build Coastguard Worker %0 = shl i32 %x, 5 37*9880d681SAndroid Build Coastguard Worker %1 = or i32 %0, 3 38*9880d681SAndroid Build Coastguard Worker store i32 %1, i32* %P 39*9880d681SAndroid Build Coastguard Worker ret void 40*9880d681SAndroid Build Coastguard Worker} 41*9880d681SAndroid Build Coastguard Worker 42*9880d681SAndroid Build Coastguard Workerdefine i32 @test4(i32 %a, i32 %b) nounwind readnone ssp { 43*9880d681SAndroid Build Coastguard Workerentry: 44*9880d681SAndroid Build Coastguard Worker %and = and i32 %a, 6 45*9880d681SAndroid Build Coastguard Worker %and2 = and i32 %b, 16 46*9880d681SAndroid Build Coastguard Worker %or = or i32 %and2, %and 47*9880d681SAndroid Build Coastguard Worker ret i32 %or 48*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: test4: 49*9880d681SAndroid Build Coastguard Worker; CHECK: leal (%rsi,%rdi), %eax 50*9880d681SAndroid Build Coastguard Worker} 51*9880d681SAndroid Build Coastguard Worker 52*9880d681SAndroid Build Coastguard Workerdefine void @test5(i32 %a, i32 %b, i32* nocapture %P) nounwind ssp { 53*9880d681SAndroid Build Coastguard Workerentry: 54*9880d681SAndroid Build Coastguard Worker %and = and i32 %a, 6 55*9880d681SAndroid Build Coastguard Worker %and2 = and i32 %b, 16 56*9880d681SAndroid Build Coastguard Worker %or = or i32 %and2, %and 57*9880d681SAndroid Build Coastguard Worker store i32 %or, i32* %P, align 4 58*9880d681SAndroid Build Coastguard Worker ret void 59*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: test5: 60*9880d681SAndroid Build Coastguard Worker; CHECK: orl 61*9880d681SAndroid Build Coastguard Worker} 62