diff options
author | Devang Patel <dpatel@apple.com> | 2008-03-07 20:06:16 +0000 |
---|---|---|
committer | Devang Patel <dpatel@apple.com> | 2008-03-07 20:06:16 +0000 |
commit | fed044165c8f62721d97f8b9b863330321b7b87f (patch) | |
tree | bef5c1f1dce01f6d076d8d6315e324d260e1fbd8 /test/Transforms/SRETPromotion | |
parent | 3d46fe0abd0016a5ef538025aa7ec6bf47f9390e (diff) | |
download | external_llvm-fed044165c8f62721d97f8b9b863330321b7b87f.zip external_llvm-fed044165c8f62721d97f8b9b863330321b7b87f.tar.gz external_llvm-fed044165c8f62721d97f8b9b863330321b7b87f.tar.bz2 |
Update inliner to handle functions that return multiple values.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@48020 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'test/Transforms/SRETPromotion')
-rw-r--r-- | test/Transforms/SRETPromotion/2008-03-07-Inline-2.ll | 46 | ||||
-rw-r--r-- | test/Transforms/SRETPromotion/2008-03-07-Inline.ll | 46 |
2 files changed, 92 insertions, 0 deletions
diff --git a/test/Transforms/SRETPromotion/2008-03-07-Inline-2.ll b/test/Transforms/SRETPromotion/2008-03-07-Inline-2.ll new file mode 100644 index 0000000..4aceea4 --- /dev/null +++ b/test/Transforms/SRETPromotion/2008-03-07-Inline-2.ll @@ -0,0 +1,46 @@ +; RUN: llvm-as < %s | opt -inline -sretpromotion -disable-output + %struct.Demand = type { double, double } + %struct.branch = type { %struct.Demand, double, double, double, double, %struct.branch*, [12 x %struct.leaf*] } + %struct.leaf = type { %struct.Demand, double, double } +@P = external global double ; <double*> [#uses=1] + +define %struct.leaf* @build_leaf() nounwind { +entry: + unreachable +} + +define void @Compute_Branch(%struct.Demand* sret %agg.result, %struct.branch* %br, double %theta_R, double %theta_I, double %pi_R, double %pi_I) nounwind { +entry: + %a2 = alloca %struct.Demand ; <%struct.Demand*> [#uses=2] + br i1 false, label %bb46, label %bb + +bb: ; preds = %entry + ret void + +bb46: ; preds = %entry + br label %bb72 + +bb49: ; preds = %bb72 + call void @Compute_Leaf( %struct.Demand* sret %a2, %struct.leaf* null, double 0.000000e+00, double 0.000000e+00 ) nounwind + %tmp66 = getelementptr %struct.Demand* %a2, i32 0, i32 1 ; <double*> [#uses=0] + br label %bb72 + +bb72: ; preds = %bb49, %bb46 + br i1 false, label %bb49, label %bb77 + +bb77: ; preds = %bb72 + ret void +} + +define void @Compute_Leaf(%struct.Demand* sret %agg.result, %struct.leaf* %l, double %pi_R, double %pi_I) nounwind { +entry: + %tmp10 = load double* @P, align 8 ; <double> [#uses=1] + %tmp11 = fcmp olt double %tmp10, 0.000000e+00 ; <i1> [#uses=1] + br i1 %tmp11, label %bb, label %bb13 + +bb: ; preds = %entry + br label %bb13 + +bb13: ; preds = %bb, %entry + ret void +} diff --git a/test/Transforms/SRETPromotion/2008-03-07-Inline.ll b/test/Transforms/SRETPromotion/2008-03-07-Inline.ll new file mode 100644 index 0000000..b04c5a9 --- /dev/null +++ b/test/Transforms/SRETPromotion/2008-03-07-Inline.ll @@ -0,0 +1,46 @@ +; RUN: llvm-as < %s | opt -inline -sretpromotion -disable-output + %struct.Demand = type { double, double } + %struct.branch = type { %struct.Demand, double, double, double, double, %struct.branch*, [12 x %struct.leaf*] } + %struct.leaf = type { %struct.Demand, double, double } +@P = external global double ; <double*> [#uses=1] + +define %struct.leaf* @build_leaf() nounwind { +entry: + unreachable +} + +define void @Compute_Branch(%struct.Demand* sret %agg.result, %struct.branch* %br, double %theta_R, double %theta_I, double %pi_R, double %pi_I) nounwind { +entry: + %a2 = alloca %struct.Demand ; <%struct.Demand*> [#uses=2] + br i1 false, label %bb46, label %bb + +bb: ; preds = %entry + ret void + +bb46: ; preds = %entry + br label %bb72 + +bb49: ; preds = %bb72 + call void @Compute_Leaf( %struct.Demand* sret %a2, %struct.leaf* null, double 0.000000e+00, double 0.000000e+00 ) nounwind + %tmp66 = getelementptr %struct.Demand* %a2, i32 0, i32 1 ; <double*> [#uses=0] + br label %bb72 + +bb72: ; preds = %bb49, %bb46 + br i1 false, label %bb49, label %bb77 + +bb77: ; preds = %bb72 + ret void +} + +define void @Compute_Leaf(%struct.Demand* sret %agg.result, %struct.leaf* %l, double %pi_R, double %pi_I) nounwind { +entry: + %tmp10 = load double* @P, align 8 ; <double> [#uses=1] + %tmp11 = fcmp olt double %tmp10, 0.000000e+00 ; <i1> [#uses=1] + br i1 %tmp11, label %bb, label %bb13 + +bb: ; preds = %entry + ret void + +bb13: ; preds = %entry + ret void +} |