1*9880d681SAndroid Build Coastguard Worker; RUN: llc < %s -mtriple=x86_64-linux | FileCheck %s 2*9880d681SAndroid Build Coastguard Worker; RUN: llc < %s -mtriple=x86_64-linux-gnux32 | FileCheck %s 3*9880d681SAndroid Build Coastguard Worker; RUN: llc < %s -mtriple=x86_64-nacl | FileCheck %s 4*9880d681SAndroid Build Coastguard Worker; RUN: llc < %s -mtriple=x86_64-win32 | FileCheck %s 5*9880d681SAndroid Build Coastguard Worker 6*9880d681SAndroid Build Coastguard Worker; CHECK: leaq (,[[A0:%rdi|%rcx]],4), %rax 7*9880d681SAndroid Build Coastguard Workerdefine i64 @test2(i64 %a) { 8*9880d681SAndroid Build Coastguard Worker %tmp2 = shl i64 %a, 2 9*9880d681SAndroid Build Coastguard Worker %tmp3 = or i64 %tmp2, %a 10*9880d681SAndroid Build Coastguard Worker ret i64 %tmp3 11*9880d681SAndroid Build Coastguard Worker} 12*9880d681SAndroid Build Coastguard Worker 13*9880d681SAndroid Build Coastguard Worker; CHECK: leal ([[A0]],[[A0]],2), %eax 14*9880d681SAndroid Build Coastguard Workerdefine i32 @test(i32 %a) { 15*9880d681SAndroid Build Coastguard Worker %tmp2 = mul i32 %a, 3 ; <i32> [#uses=1] 16*9880d681SAndroid Build Coastguard Worker ret i32 %tmp2 17*9880d681SAndroid Build Coastguard Worker} 18*9880d681SAndroid Build Coastguard Worker 19*9880d681SAndroid Build Coastguard Worker; CHECK: leaq (,[[A0]],8), %rax 20*9880d681SAndroid Build Coastguard Workerdefine i64 @test3(i64 %a) { 21*9880d681SAndroid Build Coastguard Worker %tmp2 = shl i64 %a, 3 22*9880d681SAndroid Build Coastguard Worker ret i64 %tmp2 23*9880d681SAndroid Build Coastguard Worker} 24*9880d681SAndroid Build Coastguard Worker 25