Changes in directory llvm/test/CodeGen/Generic:
2007-02-16-BranchFold.ll updated: 1.3 -> 1.4 switch-lower-feature.ll updated: 1.2 -> 1.3 --- Log message: Next stage into switch lowering refactoring 1. Fix some bugs in the jump table lowering threshold 2. Implement much better metric for optimal pivot selection 3. Tune thresholds for different lowering methods 4. Implement shift-and trick for lowering small (<machine word length) cases with few destinations. Good testcase will follow. --- Diffs of the changes: (+40 -18) 2007-02-16-BranchFold.ll | 53 ++++++++++++++++++++++++++++++++++------------- switch-lower-feature.ll | 5 ---- 2 files changed, 40 insertions(+), 18 deletions(-) Index: llvm/test/CodeGen/Generic/2007-02-16-BranchFold.ll diff -u llvm/test/CodeGen/Generic/2007-02-16-BranchFold.ll:1.3 llvm/test/CodeGen/Generic/2007-02-16-BranchFold.ll:1.4 --- llvm/test/CodeGen/Generic/2007-02-16-BranchFold.ll:1.3 Tue Mar 27 21:38:26 2007 +++ llvm/test/CodeGen/Generic/2007-02-16-BranchFold.ll Mon Apr 9 07:31:58 2007 @@ -2,7 +2,7 @@ ; RUN: llvm-as < %s | llc | grep jmp | wc -l | grep 0 ; PR 1200 -; ModuleID = 'bugpoint.test.bc' +; ModuleID = '<stdin>' target datalayout = "e-p:32:32" target triple = "i686-apple-darwin8" %struct.FILE = type { i8*, i32, i32, i16, i16, %struct.__sbuf, i32, i8*, i32 (i8*)*, i32 (i8*, i8*, i32)*, i64 (i8*, i64, i32)*, i32 (i8*, i8*, i32)*, %struct.__sbuf, %struct.__sFILEX*, i32, [3 x i8], [1 x i8], %struct.__sbuf, i32, i64 } @@ -25,30 +25,32 @@ @outfile = external global %struct.FILE* ; <%struct.FILE**> [#uses=1] @str1 = external global [11 x i8] ; <[11 x i8]*> [#uses=1] - declare i32 @fprintf(%struct.FILE*, i8*, ...) define i16 @main_bb_2E_i9_2E_i_2E_i932_2E_ce(%struct.list* %l_addr.01.0.i2.i.i929, %struct.operator** %tmp66.i62.i.out) { newFuncRoot: br label %bb.i9.i.i932.ce -bb36.i.i.exitStub: ; preds = %bb.i9.i.i932.ce +NewDefault: ; preds = %LeafBlock, %LeafBlock1, %LeafBlock2, %LeafBlock3 + br label %bb36.i.i.exitStub + +bb36.i.i.exitStub: ; preds = %NewDefault store %struct.operator* %tmp66.i62.i, %struct.operator** %tmp66.i62.i.out ret i16 0 -bb.i14.i.exitStub: ; preds = %bb.i9.i.i932.ce +bb.i14.i.exitStub: ; preds = %LeafBlock store %struct.operator* %tmp66.i62.i, %struct.operator** %tmp66.i62.i.out ret i16 1 -bb12.i.i935.exitStub: ; preds = %bb.i9.i.i932.ce +bb12.i.i935.exitStub: ; preds = %LeafBlock1 store %struct.operator* %tmp66.i62.i, %struct.operator** %tmp66.i62.i.out ret i16 2 -bb20.i.i937.exitStub: ; preds = %bb.i9.i.i932.ce +bb20.i.i937.exitStub: ; preds = %LeafBlock2 store %struct.operator* %tmp66.i62.i, %struct.operator** %tmp66.i62.i.out ret i16 3 -bb28.i.i938.exitStub: ; preds = %bb.i9.i.i932.ce +bb28.i.i938.exitStub: ; preds = %LeafBlock3 store %struct.operator* %tmp66.i62.i, %struct.operator** %tmp66.i62.i.out ret i16 4 @@ -61,11 +63,34 @@ %tmp3.i8.i = load %struct.FILE** @outfile ; <%struct.FILE*> [#uses=1] %tmp5.i9.i = call i32 (%struct.FILE*, i8*, ...)* @fprintf( %struct.FILE* %tmp3.i8.i, i8* getelementptr ([11 x i8]* @str1, i32 0, i32 0), i32 %tmp2.i7.i ) ; <i32> [#uses=0] %tmp7.i10.i = getelementptr %struct.operator* %tmp66.i62.i, i32 0, i32 5 ; <i32*> [#uses=1] - %tmp8.i11.i = load i32* %tmp7.i10.i ; <i32> [#uses=1] - switch i32 %tmp8.i11.i, label %bb36.i.i.exitStub [ - i32 -1, label %bb.i14.i.exitStub - i32 0, label %bb12.i.i935.exitStub - i32 1, label %bb20.i.i937.exitStub - i32 2, label %bb28.i.i938.exitStub - ] + %tmp8.i11.i = load i32* %tmp7.i10.i ; <i32> [#uses=7] + br label %NodeBlock5 + +NodeBlock5: ; preds = %bb.i9.i.i932.ce + icmp slt i32 %tmp8.i11.i, 1 ; <i1>:0 [#uses=1] + br i1 %0, label %NodeBlock, label %NodeBlock4 + +NodeBlock4: ; preds = %NodeBlock5 + icmp slt i32 %tmp8.i11.i, 2 ; <i1>:1 [#uses=1] + br i1 %1, label %LeafBlock2, label %LeafBlock3 + +LeafBlock3: ; preds = %NodeBlock4 + icmp eq i32 %tmp8.i11.i, 2 ; <i1>:2 [#uses=1] + br i1 %2, label %bb28.i.i938.exitStub, label %NewDefault + +LeafBlock2: ; preds = %NodeBlock4 + icmp eq i32 %tmp8.i11.i, 1 ; <i1>:3 [#uses=1] + br i1 %3, label %bb20.i.i937.exitStub, label %NewDefault + +NodeBlock: ; preds = %NodeBlock5 + icmp slt i32 %tmp8.i11.i, 0 ; <i1>:4 [#uses=1] + br i1 %4, label %LeafBlock, label %LeafBlock1 + +LeafBlock1: ; preds = %NodeBlock + icmp eq i32 %tmp8.i11.i, 0 ; <i1>:5 [#uses=1] + br i1 %5, label %bb12.i.i935.exitStub, label %NewDefault + +LeafBlock: ; preds = %NodeBlock + icmp eq i32 %tmp8.i11.i, -1 ; <i1>:6 [#uses=1] + br i1 %6, label %bb.i14.i.exitStub, label %NewDefault } Index: llvm/test/CodeGen/Generic/switch-lower-feature.ll diff -u llvm/test/CodeGen/Generic/switch-lower-feature.ll:1.2 llvm/test/CodeGen/Generic/switch-lower-feature.ll:1.3 --- llvm/test/CodeGen/Generic/switch-lower-feature.ll:1.2 Wed Apr 4 16:14:49 2007 +++ llvm/test/CodeGen/Generic/switch-lower-feature.ll Mon Apr 9 07:31:58 2007 @@ -1,10 +1,7 @@ ; RUN: llvm-as < %s | llc -march=x86 -o - | grep \$7 | wc -l | grep 1 && ; RUN: llvm-as < %s | llc -march=x86 -o - | grep \$6 | wc -l | grep 1 && ; RUN: llvm-as < %s | llc -march=x86 -o - | grep 1024 | wc -l | grep 1 && -; RUN: llvm-as < %s | llc -march=x86 -o - | grep 1023 | wc -l | grep 1 && -; RUN: llvm-as < %s | llc -march=x86 -o - | grep jg | wc -l | grep 1 && -; RUN: llvm-as < %s | llc -march=x86 -o - | grep jb | wc -l | grep 1 && -; RUN: llvm-as < %s | llc -march=x86 -o - | grep jae | wc -l | grep 1 && +; RUN: llvm-as < %s | llc -march=x86 -o - | grep jb | wc -l | grep 2 && ; RUN: llvm-as < %s | llc -march=x86 -o - | grep je | wc -l | grep 1 define i32 @main(i32 %tmp158) { _______________________________________________ llvm-commits mailing list llvm-commits@cs.uiuc.edu http://lists.cs.uiuc.edu/mailman/listinfo/llvm-commits