mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-11-22 10:42:39 +01:00
f7ea499702
Part of the effort to refactoring frame pointer code generation. We used to use two function attributes "no-frame-pointer-elim" and "no-frame-pointer-elim-non-leaf" to represent three kinds of frame pointer usage: (all) frames use frame pointer, (non-leaf) frames use frame pointer, (none) frame use frame pointer. This CL makes the idea explicit by using only one enum function attribute "frame-pointer" Option "-frame-pointer=" replaces "-disable-fp-elim" for tools such as llc. "no-frame-pointer-elim" and "no-frame-pointer-elim-non-leaf" are still supported for easy migration to "frame-pointer". tests are mostly updated with // replace command line args ‘-disable-fp-elim=false’ with ‘-frame-pointer=none’ grep -iIrnl '\-disable-fp-elim=false' * | xargs sed -i '' -e "s/-disable-fp-elim=false/-frame-pointer=none/g" // replace command line args ‘-disable-fp-elim’ with ‘-frame-pointer=all’ grep -iIrnl '\-disable-fp-elim' * | xargs sed -i '' -e "s/-disable-fp-elim/-frame-pointer=all/g" Patch by Yuanfang Chen (tabloid.adroit)! Differential Revision: https://reviews.llvm.org/D56351 llvm-svn: 351049
45 lines
1.9 KiB
LLVM
45 lines
1.9 KiB
LLVM
; RUN: llc < %s -mtriple=thumbv7-apple-darwin10 -relocation-model=pic -frame-pointer=all -mcpu=cortex-a8 | FileCheck %s
|
|
|
|
; Do not form Thumb2 ldrd / strd if the offset is not multiple of 4.
|
|
; rdar://9133587
|
|
|
|
%struct.Outer = type { i32, [2 x %"struct.Outer::Inner"] }
|
|
%"struct.Outer::Inner" = type { i32, i32, i8, i8 }
|
|
|
|
@oStruct = external global %struct.Outer, align 4
|
|
|
|
define void @main(i8 %val8) nounwind {
|
|
; CHECK-LABEL: main:
|
|
; CHECK-NOT: ldrd
|
|
; CHECK: mul
|
|
for.body.lr.ph:
|
|
br label %for.body
|
|
|
|
for.body: ; preds = %_Z14printIsNotZeroi.exit17.for.body_crit_edge, %for.body.lr.ph
|
|
%tmp3 = phi i1 [ false, %for.body.lr.ph ], [ %phitmp27, %_Z14printIsNotZeroi.exit17.for.body_crit_edge ]
|
|
%i.022 = phi i32 [ 0, %for.body.lr.ph ], [ %inc, %_Z14printIsNotZeroi.exit17.for.body_crit_edge ]
|
|
%x = getelementptr %struct.Outer, %struct.Outer* @oStruct, i32 0, i32 1, i32 %i.022, i32 0
|
|
%y = getelementptr %struct.Outer, %struct.Outer* @oStruct, i32 0, i32 1, i32 %i.022, i32 1
|
|
%inc = add i32 %i.022, 1
|
|
%tmp8 = load i32, i32* %x, align 4
|
|
%tmp11 = load i32, i32* %y, align 4
|
|
%mul = mul nsw i32 %tmp11, %tmp8
|
|
%tobool.i14 = icmp eq i32 %mul, 0
|
|
br i1 %tobool.i14, label %_Z14printIsNotZeroi.exit17, label %if.then.i16
|
|
|
|
if.then.i16: ; preds = %_Z14printIsNotZeroi.exit
|
|
ret void
|
|
|
|
_Z14printIsNotZeroi.exit17: ; preds = %_Z14printIsNotZeroi.exit
|
|
br label %_Z14printIsNotZeroi.exit17.for.body_crit_edge
|
|
|
|
_Z14printIsNotZeroi.exit17.for.body_crit_edge: ; preds = %_Z14printIsNotZeroi.exit17
|
|
%b.phi.trans.insert = getelementptr %struct.Outer, %struct.Outer* @oStruct, i32 0, i32 1, i32 %inc, i32 3
|
|
%tmp3.pre = load i8, i8* %b.phi.trans.insert, align 1
|
|
%phitmp27 = icmp eq i8 %val8, 0
|
|
br label %for.body
|
|
|
|
for.end: ; preds = %_Z14printIsNotZeroi.exit17
|
|
ret void
|
|
}
|