mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-11-25 04:02:41 +01:00
fe6fe553f7
The size savings are significant, and from what I can tell, both ICC and GCC do this. Differential Revision: http://reviews.llvm.org/D18573 llvm-svn: 264966
25 lines
854 B
LLVM
25 lines
854 B
LLVM
; RUN: llc < %s -mtriple=i686-apple-darwin -mattr=+sse2 -no-x86-call-frame-opt | grep mov | count 6
|
|
|
|
%struct.quad_struct = type { i32, i32, %struct.quad_struct*, %struct.quad_struct*, %struct.quad_struct*, %struct.quad_struct*, %struct.quad_struct* }
|
|
|
|
define i32 @perimeter(%struct.quad_struct* %tree, i32 %size) nounwind {
|
|
entry:
|
|
switch i32 %size, label %UnifiedReturnBlock [
|
|
i32 2, label %bb
|
|
i32 0, label %bb50
|
|
]
|
|
|
|
bb: ; preds = %entry
|
|
%tmp31 = tail call i32 @perimeter( %struct.quad_struct* null, i32 0 ) nounwind ; <i32> [#uses=1]
|
|
%tmp40 = tail call i32 @perimeter( %struct.quad_struct* null, i32 0 ) nounwind ; <i32> [#uses=1]
|
|
%tmp33 = add i32 0, %tmp31 ; <i32> [#uses=1]
|
|
%tmp42 = add i32 %tmp33, %tmp40 ; <i32> [#uses=1]
|
|
ret i32 %tmp42
|
|
|
|
bb50: ; preds = %entry
|
|
ret i32 0
|
|
|
|
UnifiedReturnBlock: ; preds = %entry
|
|
ret i32 0
|
|
}
|