Two sets of changes. Sorry they are intermingled.
[oota-llvm.git] / test / CodeGen / thumb2-mul.ll
1 ; RUN: llc < %s -mtriple=thumbv7-apple-darwin10 | FileCheck %s
2
3 %struct.CMPoint = type { %struct.Point, float, float, [5 x float] }
4 %struct.Point = type { float, float }
5
6 define %struct.CMPoint* @t1(i32 %i, i32 %j, i32 %n, %struct.CMPoint* %thePoints) nounwind readnone ssp {
7 entry:
8 ; CHECK: mla     r0, r2, r0, r1
9 ; CHECK: add.w   r0, r0, r0, lsl #3
10 ; CHECL: add.w   r0, r3, r0, lsl #2
11   %mul = mul i32 %n, %i
12   %add = add i32 %mul, %j
13   %0 = ptrtoint %struct.CMPoint* %thePoints to i32
14   %mul5 = mul i32 %add, 36
15   %add6 = add i32 %mul5, %0
16   %1 = inttoptr i32 %add6 to %struct.CMPoint*
17   ret %struct.CMPoint* %1
18 }