[llvm-commits] CVS: llvm/test/Regression/Transforms/Inline/inline_cleanup.ll

Chris Lattner lattner at cs.uiuc.edu
Wed Sep 13 12:23:57 PDT 2006



Changes in directory llvm/test/Regression/Transforms/Inline:

inline_cleanup.ll added (r1.1)
---
Log message:

new testcase


---
Diffs of the changes:  (+65 -0)

 inline_cleanup.ll |   65 ++++++++++++++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 65 insertions(+)


Index: llvm/test/Regression/Transforms/Inline/inline_cleanup.ll
diff -c /dev/null llvm/test/Regression/Transforms/Inline/inline_cleanup.ll:1.1
*** /dev/null	Wed Sep 13 14:23:53 2006
--- llvm/test/Regression/Transforms/Inline/inline_cleanup.ll	Wed Sep 13 14:23:43 2006
***************
*** 0 ****
--- 1,65 ----
+ ; Test that the inliner doesn't leave around dead allocas, and that it folds
+ ; uncond branches away after it is done specializing.
+ 
+ ; RUN: llvm-as < %s | opt -inline -disable-output &&
+ ; RUN: llvm-as < %s | opt -inline | llvm-dis | not grep 'alloca.*uses=0' &&
+ ; RUN: llvm-as < %s | opt -inline | llvm-dis | not grep 'br label'
+ 
+ %A = weak global int 0		; <int*> [#uses=1]
+ %B = weak global int 0		; <int*> [#uses=1]
+ %C = weak global int 0		; <int*> [#uses=1]
+ 
+ implementation   ; Functions:
+ 
+ internal fastcc void %foo(int %X) {
+ entry:
+ 	%ALL = alloca int, align 4		; <int*> [#uses=1]
+ 	%tmp1 = and int %X, 1		; <int> [#uses=1]
+ 	%tmp1 = seteq int %tmp1, 0		; <bool> [#uses=1]
+ 	br bool %tmp1, label %cond_next, label %cond_true
+ 
+ cond_true:		; preds = %entry
+ 	store int 1, int* %A
+ 	br label %cond_next
+ 
+ cond_next:		; preds = %entry, %cond_true
+ 	%tmp4 = and int %X, 2		; <int> [#uses=1]
+ 	%tmp4 = seteq int %tmp4, 0		; <bool> [#uses=1]
+ 	br bool %tmp4, label %cond_next7, label %cond_true5
+ 
+ cond_true5:		; preds = %cond_next
+ 	store int 1, int* %B
+ 	br label %cond_next7
+ 
+ cond_next7:		; preds = %cond_next, %cond_true5
+ 	%tmp10 = and int %X, 4		; <int> [#uses=1]
+ 	%tmp10 = seteq int %tmp10, 0		; <bool> [#uses=1]
+ 	br bool %tmp10, label %cond_next13, label %cond_true11
+ 
+ cond_true11:		; preds = %cond_next7
+ 	store int 1, int* %C
+ 	br label %cond_next13
+ 
+ cond_next13:		; preds = %cond_next7, %cond_true11
+ 	%tmp16 = and int %X, 8		; <int> [#uses=1]
+ 	%tmp16 = seteq int %tmp16, 0		; <bool> [#uses=1]
+ 	br bool %tmp16, label %UnifiedReturnBlock, label %cond_true17
+ 
+ cond_true17:		; preds = %cond_next13
+ 	call void %ext( int* %ALL )
+ 	ret void
+ 
+ UnifiedReturnBlock:		; preds = %cond_next13
+ 	ret void
+ }
+ 
+ declare void %ext(int*)
+ 
+ void %test() {
+ entry:
+ 	tail call fastcc void %foo( int 1 )
+ 	tail call fastcc void %foo( int 2 )
+ 	tail call fastcc void %foo( int 3 )
+ 	tail call fastcc void %foo( int 8 )
+ 	ret void
+ }






More information about the llvm-commits mailing list