diff options
| author | Chris Lattner <sabre@nondot.org> | 2006-03-01 07:13:56 +0000 | 
|---|---|---|
| committer | Chris Lattner <sabre@nondot.org> | 2006-03-01 07:13:56 +0000 | 
| commit | 0454b2d080a1b7a9d3903f6d7fe2a98cc761d67e (patch) | |
| tree | ce4929b15f15018468c4bb0f79bf0ffa4ebe9978 | |
| parent | 3cb349a068379a8d9013c9654d305a349ab7ca51 (diff) | |
| download | bcm5719-llvm-0454b2d080a1b7a9d3903f6d7fe2a98cc761d67e.tar.gz bcm5719-llvm-0454b2d080a1b7a9d3903f6d7fe2a98cc761d67e.zip  | |
load (x|y)  -> load (x+y)  iff x and y have no common bits.
llvm-svn: 26449
| -rw-r--r-- | llvm/test/Regression/CodeGen/PowerPC/or-addressing-mode.ll | 23 | 
1 files changed, 23 insertions, 0 deletions
diff --git a/llvm/test/Regression/CodeGen/PowerPC/or-addressing-mode.ll b/llvm/test/Regression/CodeGen/PowerPC/or-addressing-mode.ll new file mode 100644 index 00000000000..0d4fd965e8e --- /dev/null +++ b/llvm/test/Regression/CodeGen/PowerPC/or-addressing-mode.ll @@ -0,0 +1,23 @@ +; RUN: llvm-as < %s | llc && +; RUN: llvm-as < %s | llc | not grep ori &&  +; RUN: llvm-as < %s | llc | not grep rlwimi + +int %test1(sbyte* %P) {  ;; or -> lwzx +        %tmp.2.i = cast sbyte* %P to uint +        %tmp.4.i = and uint %tmp.2.i, 4294901760 +        %tmp.10.i = shr uint %tmp.2.i, ubyte 5 +        %tmp.11.i = and uint %tmp.10.i, 2040 +        %tmp.13.i = or uint %tmp.11.i, %tmp.4.i +        %tmp.14.i = cast uint %tmp.13.i to int* +        %tmp.3 = load int* %tmp.14.i +        ret int %tmp.3 +} + +int %test2(int %P) {    ;; or -> lwz +        %tmp.2 = shl int %P, ubyte 4 +        %tmp.3 = or int %tmp.2, 2 +        %tmp.4 = cast int %tmp.3 to int* +        %tmp.5 = load int* %tmp.4 +        ret int %tmp.5 +} +  | 

