1*9880d681SAndroid Build Coastguard Worker; RUN: llc < %s -mtriple=x86_64-linux -O0 | FileCheck %s --check-prefix=X64 2*9880d681SAndroid Build Coastguard Worker; RUN: llc < %s -mtriple=x86_64-windows-itanium -O0 | FileCheck %s --check-prefix=X64 3*9880d681SAndroid Build Coastguard Worker; RUN: llc < %s -march=x86 -O0 | FileCheck %s --check-prefix=X32 4*9880d681SAndroid Build Coastguard Worker 5*9880d681SAndroid Build Coastguard Worker; GEP indices are interpreted as signed integers, so they 6*9880d681SAndroid Build Coastguard Worker; should be sign-extended to 64 bits on 64-bit targets. 7*9880d681SAndroid Build Coastguard Worker; PR3181 8*9880d681SAndroid Build Coastguard Workerdefine i32 @test1(i32 %t3, i32* %t1) nounwind { 9*9880d681SAndroid Build Coastguard Worker %t9 = getelementptr i32, i32* %t1, i32 %t3 ; <i32*> [#uses=1] 10*9880d681SAndroid Build Coastguard Worker %t15 = load i32, i32* %t9 ; <i32> [#uses=1] 11*9880d681SAndroid Build Coastguard Worker ret i32 %t15 12*9880d681SAndroid Build Coastguard Worker; X32-LABEL: test1: 13*9880d681SAndroid Build Coastguard Worker; X32: movl (%eax,%ecx,4), %eax 14*9880d681SAndroid Build Coastguard Worker; X32: ret 15*9880d681SAndroid Build Coastguard Worker 16*9880d681SAndroid Build Coastguard Worker; X64-LABEL: test1: 17*9880d681SAndroid Build Coastguard Worker; X64: movslq %e[[A0:di|cx]], %rax 18*9880d681SAndroid Build Coastguard Worker; X64: movl (%r[[A1:si|dx]],%rax,4), %eax 19*9880d681SAndroid Build Coastguard Worker; X64: ret 20*9880d681SAndroid Build Coastguard Worker 21*9880d681SAndroid Build Coastguard Worker} 22*9880d681SAndroid Build Coastguard Workerdefine i32 @test2(i64 %t3, i32* %t1) nounwind { 23*9880d681SAndroid Build Coastguard Worker %t9 = getelementptr i32, i32* %t1, i64 %t3 ; <i32*> [#uses=1] 24*9880d681SAndroid Build Coastguard Worker %t15 = load i32, i32* %t9 ; <i32> [#uses=1] 25*9880d681SAndroid Build Coastguard Worker ret i32 %t15 26*9880d681SAndroid Build Coastguard Worker; X32-LABEL: test2: 27*9880d681SAndroid Build Coastguard Worker; X32: movl (%edx,%ecx,4), %e 28*9880d681SAndroid Build Coastguard Worker; X32: ret 29*9880d681SAndroid Build Coastguard Worker 30*9880d681SAndroid Build Coastguard Worker; X64-LABEL: test2: 31*9880d681SAndroid Build Coastguard Worker; X64: movl (%r[[A1]],%r[[A0]],4), %eax 32*9880d681SAndroid Build Coastguard Worker; X64: ret 33*9880d681SAndroid Build Coastguard Worker} 34*9880d681SAndroid Build Coastguard Worker 35*9880d681SAndroid Build Coastguard Worker 36*9880d681SAndroid Build Coastguard Worker 37*9880d681SAndroid Build Coastguard Worker; PR4984 38*9880d681SAndroid Build Coastguard Workerdefine i8 @test3(i8* %start) nounwind { 39*9880d681SAndroid Build Coastguard Workerentry: 40*9880d681SAndroid Build Coastguard Worker %A = getelementptr i8, i8* %start, i64 -2 ; <i8*> [#uses=1] 41*9880d681SAndroid Build Coastguard Worker %B = load i8, i8* %A, align 1 ; <i8> [#uses=1] 42*9880d681SAndroid Build Coastguard Worker ret i8 %B 43*9880d681SAndroid Build Coastguard Worker 44*9880d681SAndroid Build Coastguard Worker 45*9880d681SAndroid Build Coastguard Worker; X32-LABEL: test3: 46*9880d681SAndroid Build Coastguard Worker; X32: movl 4(%esp), %eax 47*9880d681SAndroid Build Coastguard Worker; X32: movb -2(%eax), %al 48*9880d681SAndroid Build Coastguard Worker; X32: ret 49*9880d681SAndroid Build Coastguard Worker 50*9880d681SAndroid Build Coastguard Worker; X64-LABEL: test3: 51*9880d681SAndroid Build Coastguard Worker; X64: movb -2(%r[[A0]]), %al 52*9880d681SAndroid Build Coastguard Worker; X64: ret 53*9880d681SAndroid Build Coastguard Worker 54*9880d681SAndroid Build Coastguard Worker} 55*9880d681SAndroid Build Coastguard Worker 56*9880d681SAndroid Build Coastguard Workerdefine double @test4(i64 %x, double* %p) nounwind { 57*9880d681SAndroid Build Coastguard Workerentry: 58*9880d681SAndroid Build Coastguard Worker %x.addr = alloca i64, align 8 ; <i64*> [#uses=2] 59*9880d681SAndroid Build Coastguard Worker %p.addr = alloca double*, align 8 ; <double**> [#uses=2] 60*9880d681SAndroid Build Coastguard Worker store i64 %x, i64* %x.addr 61*9880d681SAndroid Build Coastguard Worker store double* %p, double** %p.addr 62*9880d681SAndroid Build Coastguard Worker %tmp = load i64, i64* %x.addr ; <i64> [#uses=1] 63*9880d681SAndroid Build Coastguard Worker %add = add nsw i64 %tmp, 16 ; <i64> [#uses=1] 64*9880d681SAndroid Build Coastguard Worker %tmp1 = load double*, double** %p.addr ; <double*> [#uses=1] 65*9880d681SAndroid Build Coastguard Worker %arrayidx = getelementptr inbounds double, double* %tmp1, i64 %add ; <double*> [#uses=1] 66*9880d681SAndroid Build Coastguard Worker %tmp2 = load double, double* %arrayidx ; <double> [#uses=1] 67*9880d681SAndroid Build Coastguard Worker ret double %tmp2 68*9880d681SAndroid Build Coastguard Worker 69*9880d681SAndroid Build Coastguard Worker; X32-LABEL: test4: 70*9880d681SAndroid Build Coastguard Worker; X32: 128(%e{{.*}},%e{{.*}},8) 71*9880d681SAndroid Build Coastguard Worker; X64-LABEL: test4: 72*9880d681SAndroid Build Coastguard Worker; X64: 128(%r{{.*}},%r{{.*}},8) 73*9880d681SAndroid Build Coastguard Worker} 74*9880d681SAndroid Build Coastguard Worker 75*9880d681SAndroid Build Coastguard Worker; PR8961 - Make sure the sext for the GEP addressing comes before the load that 76*9880d681SAndroid Build Coastguard Worker; is folded. 77*9880d681SAndroid Build Coastguard Workerdefine i64 @test5(i8* %A, i32 %I, i64 %B) nounwind { 78*9880d681SAndroid Build Coastguard Worker %v8 = getelementptr i8, i8* %A, i32 %I 79*9880d681SAndroid Build Coastguard Worker %v9 = bitcast i8* %v8 to i64* 80*9880d681SAndroid Build Coastguard Worker %v10 = load i64, i64* %v9 81*9880d681SAndroid Build Coastguard Worker %v11 = add i64 %B, %v10 82*9880d681SAndroid Build Coastguard Worker ret i64 %v11 83*9880d681SAndroid Build Coastguard Worker; X64-LABEL: test5: 84*9880d681SAndroid Build Coastguard Worker; X64: movslq %e[[A1]], %rax 85*9880d681SAndroid Build Coastguard Worker; X64-NEXT: (%r[[A0]],%rax), 86*9880d681SAndroid Build Coastguard Worker; X64: ret 87*9880d681SAndroid Build Coastguard Worker} 88*9880d681SAndroid Build Coastguard Worker 89*9880d681SAndroid Build Coastguard Worker; PR9500, rdar://9156159 - Don't do non-local address mode folding, 90*9880d681SAndroid Build Coastguard Worker; because it may require values which wouldn't otherwise be live out 91*9880d681SAndroid Build Coastguard Worker; of their blocks. 92*9880d681SAndroid Build Coastguard Workerdefine void @test6() personality i32 (...)* @__gxx_personality_v0 { 93*9880d681SAndroid Build Coastguard Workerif.end: ; preds = %if.then, %invoke.cont 94*9880d681SAndroid Build Coastguard Worker %tmp15 = load i64, i64* undef 95*9880d681SAndroid Build Coastguard Worker %dec = add i64 %tmp15, 13 96*9880d681SAndroid Build Coastguard Worker store i64 %dec, i64* undef 97*9880d681SAndroid Build Coastguard Worker %call17 = invoke i8* @_ZNK18G__FastAllocString4dataEv() 98*9880d681SAndroid Build Coastguard Worker to label %invoke.cont16 unwind label %lpad 99*9880d681SAndroid Build Coastguard Worker 100*9880d681SAndroid Build Coastguard Workerinvoke.cont16: ; preds = %if.then14 101*9880d681SAndroid Build Coastguard Worker %arrayidx18 = getelementptr inbounds i8, i8* %call17, i64 %dec 102*9880d681SAndroid Build Coastguard Worker store i8 0, i8* %arrayidx18 103*9880d681SAndroid Build Coastguard Worker unreachable 104*9880d681SAndroid Build Coastguard Worker 105*9880d681SAndroid Build Coastguard Workerlpad: ; preds = %if.end19, %if.then14, %if.end, %entry 106*9880d681SAndroid Build Coastguard Worker %exn = landingpad {i8*, i32} 107*9880d681SAndroid Build Coastguard Worker cleanup 108*9880d681SAndroid Build Coastguard Worker unreachable 109*9880d681SAndroid Build Coastguard Worker} 110*9880d681SAndroid Build Coastguard Workerdeclare i8* @_ZNK18G__FastAllocString4dataEv() nounwind 111*9880d681SAndroid Build Coastguard Worker 112*9880d681SAndroid Build Coastguard Worker 113*9880d681SAndroid Build Coastguard Worker; PR10605 / rdar://9930964 - Don't fold loads incorrectly. The load should 114*9880d681SAndroid Build Coastguard Worker; happen before the store. 115*9880d681SAndroid Build Coastguard Workerdefine i32 @test7({i32,i32,i32}* %tmp1, i32 %tmp71, i32 %tmp63) nounwind { 116*9880d681SAndroid Build Coastguard Worker; X64-LABEL: test7: 117*9880d681SAndroid Build Coastguard Worker; X64: movl 8({{%rdi|%rcx}}), %eax 118*9880d681SAndroid Build Coastguard Worker; X64: movl $4, 8({{%rdi|%rcx}}) 119*9880d681SAndroid Build Coastguard Worker 120*9880d681SAndroid Build Coastguard Worker 121*9880d681SAndroid Build Coastguard Worker %tmp29 = getelementptr inbounds {i32,i32,i32}, {i32,i32,i32}* %tmp1, i32 0, i32 2 122*9880d681SAndroid Build Coastguard Worker %tmp30 = load i32, i32* %tmp29, align 4 123*9880d681SAndroid Build Coastguard Worker 124*9880d681SAndroid Build Coastguard Worker %p2 = getelementptr inbounds {i32,i32,i32}, {i32,i32,i32}* %tmp1, i32 0, i32 2 125*9880d681SAndroid Build Coastguard Worker store i32 4, i32* %p2 126*9880d681SAndroid Build Coastguard Worker 127*9880d681SAndroid Build Coastguard Worker %tmp72 = or i32 %tmp71, %tmp30 128*9880d681SAndroid Build Coastguard Worker %tmp73 = icmp ne i32 %tmp63, 32 129*9880d681SAndroid Build Coastguard Worker br i1 %tmp73, label %T, label %F 130*9880d681SAndroid Build Coastguard Worker 131*9880d681SAndroid Build Coastguard WorkerT: 132*9880d681SAndroid Build Coastguard Worker ret i32 %tmp72 133*9880d681SAndroid Build Coastguard Worker 134*9880d681SAndroid Build Coastguard WorkerF: 135*9880d681SAndroid Build Coastguard Worker ret i32 4 136*9880d681SAndroid Build Coastguard Worker} 137*9880d681SAndroid Build Coastguard Worker 138*9880d681SAndroid Build Coastguard Workerdeclare i32 @__gxx_personality_v0(...) 139