2009-09-09 02:09:15 +02:00
|
|
|
; RUN: llc < %s -march=thumb -mattr=+thumb2 | FileCheck %s
|
2009-06-27 00:37:07 +02:00
|
|
|
|
|
|
|
define i32 @f1(i32 %a, i32 %b, i32 %c) {
|
2013-07-14 08:24:09 +02:00
|
|
|
; CHECK-LABEL: f1:
|
2012-02-24 01:33:36 +01:00
|
|
|
; CHECK: muls r0, r1, r0
|
2009-06-27 00:37:07 +02:00
|
|
|
%tmp = mul i32 %a, %b
|
|
|
|
ret i32 %tmp
|
|
|
|
}
|
2011-02-05 05:15:50 +01:00
|
|
|
|
|
|
|
%struct.CMPoint = type { %struct.Point, float, float, [5 x float] }
|
|
|
|
%struct.Point = type { float, float }
|
|
|
|
|
|
|
|
define %struct.CMPoint* @t1(i32 %i, i32 %j, i32 %n, %struct.CMPoint* %thePoints) nounwind readnone ssp {
|
|
|
|
entry:
|
2013-07-14 08:24:09 +02:00
|
|
|
; CHECK-LABEL: t1:
|
2011-02-05 05:15:50 +01:00
|
|
|
; CHECK: mla r0, r2, r0, r1
|
|
|
|
; CHECK: add.w r0, r0, r0, lsl #3
|
2012-12-06 22:24:47 +01:00
|
|
|
; CHECK: add.w r0, r3, r0, lsl #2
|
2011-02-05 05:15:50 +01:00
|
|
|
%mul = mul i32 %n, %i
|
|
|
|
%add = add i32 %mul, %j
|
|
|
|
%0 = ptrtoint %struct.CMPoint* %thePoints to i32
|
|
|
|
%mul5 = mul i32 %add, 36
|
|
|
|
%add6 = add i32 %mul5, %0
|
|
|
|
%1 = inttoptr i32 %add6 to %struct.CMPoint*
|
|
|
|
ret %struct.CMPoint* %1
|
|
|
|
}
|