diff options
| author | Tanya Lattner <tonic@nondot.org> | 2008-03-01 09:15:35 +0000 |
|---|---|---|
| committer | Tanya Lattner <tonic@nondot.org> | 2008-03-01 09:15:35 +0000 |
| commit | 5640bd186a4e1ab0c6dc8134b0722830762aef41 (patch) | |
| tree | 1a6c3d0f03cb94ded9bec9476b296b30dd1011f2 /llvm/test/Transforms/GlobalOpt/ctor-list-opt.ll | |
| parent | ffe0da0eb2160281222a4f8862f435d333792dd2 (diff) | |
| download | bcm5719-llvm-5640bd186a4e1ab0c6dc8134b0722830762aef41.tar.gz bcm5719-llvm-5640bd186a4e1ab0c6dc8134b0722830762aef41.zip | |
Remove llvm-upgrade and update test cases.
llvm-svn: 47793
Diffstat (limited to 'llvm/test/Transforms/GlobalOpt/ctor-list-opt.ll')
| -rw-r--r-- | llvm/test/Transforms/GlobalOpt/ctor-list-opt.ll | 124 |
1 files changed, 56 insertions, 68 deletions
diff --git a/llvm/test/Transforms/GlobalOpt/ctor-list-opt.ll b/llvm/test/Transforms/GlobalOpt/ctor-list-opt.ll index 6270f4fabc1..56aeadb3861 100644 --- a/llvm/test/Transforms/GlobalOpt/ctor-list-opt.ll +++ b/llvm/test/Transforms/GlobalOpt/ctor-list-opt.ll @@ -1,97 +1,85 @@ -; RUN: llvm-upgrade < %s | llvm-as | opt -globalopt | llvm-dis | not grep CTOR +; RUN: llvm-as < %s | opt -globalopt | llvm-dis | not grep CTOR +@llvm.global_ctors = appending global [10 x { i32, void ()* }] [ { i32, void ()* } { i32 65535, void ()* @CTOR1 }, { i32, void ()* } { i32 65535, void ()* @CTOR1 }, { i32, void ()* } { i32 65535, void ()* @CTOR2 }, { i32, void ()* } { i32 65535, void ()* @CTOR3 }, { i32, void ()* } { i32 65535, void ()* @CTOR4 }, { i32, void ()* } { i32 65535, void ()* @CTOR5 }, { i32, void ()* } { i32 65535, void ()* @CTOR6 }, { i32, void ()* } { i32 65535, void ()* @CTOR7 }, { i32, void ()* } { i32 65535, void ()* @CTOR8 }, { i32, void ()* } { i32 2147483647, void ()* null } ] ; <[10 x { i32, void ()* }]*> [#uses=0] +@G = global i32 0 ; <i32*> [#uses=1] +@G2 = global i32 0 ; <i32*> [#uses=1] +@G3 = global i32 -123 ; <i32*> [#uses=2] +@X = global { i32, [2 x i32] } { i32 0, [2 x i32] [ i32 17, i32 21 ] } ; <{ i32, [2 x i32] }*> [#uses=2] +@Y = global i32 -1 ; <i32*> [#uses=2] +@Z = global i32 123 ; <i32*> [#uses=1] +@D = global double 0.000000e+00 ; <double*> [#uses=1] +@CTORGV = internal global i1 false ; <i1*> [#uses=2] -%llvm.global_ctors = appending global [10 x { int, void ()* }] [ - { int, void ()* } { int 65535, void ()* %CTOR1 }, - { int, void ()* } { int 65535, void ()* %CTOR1 }, - { int, void ()* } { int 65535, void ()* %CTOR2 }, - { int, void ()* } { int 65535, void ()* %CTOR3 }, - { int, void ()* } { int 65535, void ()* %CTOR4 }, - { int, void ()* } { int 65535, void ()* %CTOR5 }, - { int, void ()* } { int 65535, void ()* %CTOR6 }, - { int, void ()* } { int 65535, void ()* %CTOR7 }, - { int, void ()* } { int 65535, void ()* %CTOR8 }, - { int, void ()* } { int 2147483647, void ()* null } -] - -%G = global int 0 -%G2 = global int 0 -%G3 = global int -123 -%X = global {int, [2 x int]} { int 0, [2 x int] [ int 17, int 21] } -%Y = global int -1 -%Z = global int 123 -%D = global double 0.0 - -%CTORGV = internal global bool false ;; Should become constant after eval - -implementation - -internal void %CTOR1() { ;; noop ctor, remove. - ret void +define internal void @CTOR1() { + ret void } -internal void %CTOR2() { ;; evaluate the store - %A = add int 1, 23 - store int %A, int* %G - store bool true, bool* %CTORGV - ret void +define internal void @CTOR2() { + %A = add i32 1, 23 ; <i32> [#uses=1] + store i32 %A, i32* @G + store i1 true, i1* @CTORGV + ret void } -internal void %CTOR3() { - %X = or bool true, false +define internal void @CTOR3() { + %X = or i1 true, false ; <i1> [#uses=1] br label %Cont -Cont: - br bool %X, label %S, label %T -S: - store int 24, int* %G2 + +Cont: ; preds = %0 + br i1 %X, label %S, label %T + +S: ; preds = %Cont + store i32 24, i32* @G2 ret void -T: + +T: ; preds = %Cont ret void } -internal void %CTOR4() { - %X = load int* %G3 - %Y = add int %X, 123 - store int %Y, int* %G3 +define internal void @CTOR4() { + %X = load i32* @G3 ; <i32> [#uses=1] + %Y = add i32 %X, 123 ; <i32> [#uses=1] + store i32 %Y, i32* @G3 ret void } -internal void %CTOR5() { - %X.2p = getelementptr {int,[2 x int]}* %X, int 0, uint 1, int 0 - %X.2 = load int* %X.2p - %X.1p = getelementptr {int,[2 x int]}* %X, int 0, uint 0 - store int %X.2, int* %X.1p - store int 42, int* %X.2p +define internal void @CTOR5() { + %X.2p = getelementptr { i32, [2 x i32] }* @X, i32 0, i32 1, i32 0 ; <i32*> [#uses=2] + %X.2 = load i32* %X.2p ; <i32> [#uses=1] + %X.1p = getelementptr { i32, [2 x i32] }* @X, i32 0, i32 0 ; <i32*> [#uses=1] + store i32 %X.2, i32* %X.1p + store i32 42, i32* %X.2p ret void } -internal void %CTOR6() { - %A = alloca int - %y = load int* %Y - store int %y, int* %A - %Av = load int* %A - %Av1 = add int %Av, 1 - store int %Av1, int* %Y +define internal void @CTOR6() { + %A = alloca i32 ; <i32*> [#uses=2] + %y = load i32* @Y ; <i32> [#uses=1] + store i32 %y, i32* %A + %Av = load i32* %A ; <i32> [#uses=1] + %Av1 = add i32 %Av, 1 ; <i32> [#uses=1] + store i32 %Av1, i32* @Y ret void } -internal void %CTOR7() { - call void %setto(int* %Z, int 0) +define internal void @CTOR7() { + call void @setto( i32* @Z, i32 0 ) ret void } -void %setto(int* %P, int %V) { - store int %V, int* %P +define void @setto(i32* %P, i32 %V) { + store i32 %V, i32* %P ret void } -declare double %cos(double) +declare double @cos(double) -internal void %CTOR8() { - %X = call double %cos(double 1.0) - store double %X, double* %D +define internal void @CTOR8() { + %X = call double @cos( double 1.000000e+00 ) ; <double> [#uses=1] + store double %X, double* @D ret void } -bool %accessor() { - %V = load bool* %CTORGV ;; constant true - ret bool %V + +define i1 @accessor() { + %V = load i1* @CTORGV ; <i1> [#uses=1] + ret i1 %V } |

