1*9880d681SAndroid Build Coastguard Worker; RUN: llc < %s -mtriple=armv7a-eabi | FileCheck %s -check-prefix=CHECK -check-prefix=CHECK-AT2 2*9880d681SAndroid Build Coastguard Worker; RUN: llc < %s -mtriple=thumbv7m-eabi | FileCheck %s -check-prefix=CHECK -check-prefix=CHECK-AT2 3*9880d681SAndroid Build Coastguard Worker; RUN: llc < %s -mtriple=thumbv6m-eabi | FileCheck %s -check-prefix=CHECK -check-prefix=CHECK-T1 4*9880d681SAndroid Build Coastguard Worker 5*9880d681SAndroid Build Coastguard Worker; This test checks that various kinds of getelementptr are all optimised to a 6*9880d681SAndroid Build Coastguard Worker; simple multiply plus add, with the add being done by a register offset if the 7*9880d681SAndroid Build Coastguard Worker; result is used in a load. 8*9880d681SAndroid Build Coastguard Worker 9*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: calc_1d: 10*9880d681SAndroid Build Coastguard Worker; CHECK: mov{{s?}} [[REG1:r[0-9]+]], #84 11*9880d681SAndroid Build Coastguard Worker; CHECK-AT2: mla r0, r1, [[REG1]], r0 12*9880d681SAndroid Build Coastguard Worker; CHECK-T1: muls [[REG2:r[0-9]+]], r1, [[REG1]] 13*9880d681SAndroid Build Coastguard Worker; CHECK-T1: adds r0, r0, [[REG2]] 14*9880d681SAndroid Build Coastguard Workerdefine i32* @calc_1d(i32* %p, i32 %n) { 15*9880d681SAndroid Build Coastguard Workerentry: 16*9880d681SAndroid Build Coastguard Worker %mul = mul nsw i32 %n, 21 17*9880d681SAndroid Build Coastguard Worker %add.ptr = getelementptr inbounds i32, i32* %p, i32 %mul 18*9880d681SAndroid Build Coastguard Worker ret i32* %add.ptr 19*9880d681SAndroid Build Coastguard Worker} 20*9880d681SAndroid Build Coastguard Worker 21*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: load_1d: 22*9880d681SAndroid Build Coastguard Worker; CHECK: mov{{s?}} [[REG1:r[0-9]+]], #84 23*9880d681SAndroid Build Coastguard Worker; CHECK: mul{{s?}} [[REG2:r[0-9]+]],{{( r1,)?}} [[REG1]]{{(, r1)?}} 24*9880d681SAndroid Build Coastguard Worker; CHECK: ldr r0, [r0, [[REG2]]] 25*9880d681SAndroid Build Coastguard Workerdefine i32 @load_1d(i32* %p, i32 %n) #1 { 26*9880d681SAndroid Build Coastguard Workerentry: 27*9880d681SAndroid Build Coastguard Worker %mul = mul nsw i32 %n, 21 28*9880d681SAndroid Build Coastguard Worker %arrayidx = getelementptr inbounds i32, i32* %p, i32 %mul 29*9880d681SAndroid Build Coastguard Worker %0 = load i32, i32* %arrayidx, align 4 30*9880d681SAndroid Build Coastguard Worker ret i32 %0 31*9880d681SAndroid Build Coastguard Worker} 32*9880d681SAndroid Build Coastguard Worker 33*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: calc_2d_a: 34*9880d681SAndroid Build Coastguard Worker; CHECK: mov{{s?}} [[REG1:r[0-9]+]], #84 35*9880d681SAndroid Build Coastguard Worker; CHECK-AT2: mla r0, r1, [[REG1]], r0 36*9880d681SAndroid Build Coastguard Worker; CHECK-T1: muls [[REG2:r[0-9]+]], r1, [[REG1]] 37*9880d681SAndroid Build Coastguard Worker; CHECK-T1: adds r0, r0, [[REG2]] 38*9880d681SAndroid Build Coastguard Workerdefine i32* @calc_2d_a([100 x i32]* %p, i32 %n) { 39*9880d681SAndroid Build Coastguard Workerentry: 40*9880d681SAndroid Build Coastguard Worker %mul = mul nsw i32 %n, 21 41*9880d681SAndroid Build Coastguard Worker %arrayidx1 = getelementptr inbounds [100 x i32], [100 x i32]* %p, i32 0, i32 %mul 42*9880d681SAndroid Build Coastguard Worker ret i32* %arrayidx1 43*9880d681SAndroid Build Coastguard Worker} 44*9880d681SAndroid Build Coastguard Worker 45*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: load_2d_a: 46*9880d681SAndroid Build Coastguard Worker; CHECK: mov{{s?}} [[REG1:r[0-9]+]], #84 47*9880d681SAndroid Build Coastguard Worker; CHECK: mul{{s?}} [[REG2:r[0-9]+]],{{( r1,)?}} [[REG1]]{{(, r1)?}} 48*9880d681SAndroid Build Coastguard Worker; CHECK: ldr r0, [r0, [[REG2]]] 49*9880d681SAndroid Build Coastguard Workerdefine i32 @load_2d_a([100 x i32]* %p, i32 %n) #1 { 50*9880d681SAndroid Build Coastguard Workerentry: 51*9880d681SAndroid Build Coastguard Worker %mul = mul nsw i32 %n, 21 52*9880d681SAndroid Build Coastguard Worker %arrayidx1 = getelementptr inbounds [100 x i32], [100 x i32]* %p, i32 0, i32 %mul 53*9880d681SAndroid Build Coastguard Worker %0 = load i32, i32* %arrayidx1, align 4 54*9880d681SAndroid Build Coastguard Worker ret i32 %0 55*9880d681SAndroid Build Coastguard Worker} 56*9880d681SAndroid Build Coastguard Worker 57*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: calc_2d_b: 58*9880d681SAndroid Build Coastguard Worker; CHECK: mov{{s?}} [[REG1:r[0-9]+]], #84 59*9880d681SAndroid Build Coastguard Worker; CHECK-AT2: mla r0, r1, [[REG1]], r0 60*9880d681SAndroid Build Coastguard Worker; CHECK-T1: muls [[REG2:r[0-9]+]], r1, [[REG1]] 61*9880d681SAndroid Build Coastguard Worker; CHECK-T1: adds r0, r0, [[REG2]] 62*9880d681SAndroid Build Coastguard Workerdefine i32* @calc_2d_b([21 x i32]* %p, i32 %n) { 63*9880d681SAndroid Build Coastguard Workerentry: 64*9880d681SAndroid Build Coastguard Worker %arrayidx1 = getelementptr inbounds [21 x i32], [21 x i32]* %p, i32 %n, i32 0 65*9880d681SAndroid Build Coastguard Worker ret i32* %arrayidx1 66*9880d681SAndroid Build Coastguard Worker} 67*9880d681SAndroid Build Coastguard Worker 68*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: load_2d_b: 69*9880d681SAndroid Build Coastguard Worker; CHECK: mov{{s?}} [[REG1:r[0-9]+]], #84 70*9880d681SAndroid Build Coastguard Worker; CHECK: mul{{s?}} [[REG2:r[0-9]+]],{{( r1,)?}} [[REG1]]{{(, r1)?}} 71*9880d681SAndroid Build Coastguard Worker; CHECK: ldr r0, [r0, [[REG2]]] 72*9880d681SAndroid Build Coastguard Workerdefine i32 @load_2d_b([21 x i32]* %p, i32 %n) { 73*9880d681SAndroid Build Coastguard Workerentry: 74*9880d681SAndroid Build Coastguard Worker %arrayidx1 = getelementptr inbounds [21 x i32], [21 x i32]* %p, i32 %n, i32 0 75*9880d681SAndroid Build Coastguard Worker %0 = load i32, i32* %arrayidx1, align 4 76*9880d681SAndroid Build Coastguard Worker ret i32 %0 77*9880d681SAndroid Build Coastguard Worker} 78