diff options
| author | Chris Lattner <sabre@nondot.org> | 2005-11-05 08:57:56 +0000 |
|---|---|---|
| committer | Chris Lattner <sabre@nondot.org> | 2005-11-05 08:57:56 +0000 |
| commit | 75fe59c4ead311d292bec997ff6a08c00e644b6d (patch) | |
| tree | 997593c06ef93db73fe050d3c87a236bc09a24a0 | |
| parent | 16b29e95626ffc03eca49c24c6280893c9d00640 (diff) | |
| download | bcm5719-llvm-75fe59c4ead311d292bec997ff6a08c00e644b6d.tar.gz bcm5719-llvm-75fe59c4ead311d292bec997ff6a08c00e644b6d.zip | |
add a case Nate sent me
llvm-svn: 24195
| -rw-r--r-- | llvm/lib/Target/PowerPC/README.txt | 23 |
1 files changed, 23 insertions, 0 deletions
diff --git a/llvm/lib/Target/PowerPC/README.txt b/llvm/lib/Target/PowerPC/README.txt index 463e406779a..88582966994 100644 --- a/llvm/lib/Target/PowerPC/README.txt +++ b/llvm/lib/Target/PowerPC/README.txt @@ -217,3 +217,26 @@ _test: stw r2, 0(r3) blr +===-------------------------------------------------------------------------=== + +Compile this: + +int %f1(int %a, int %b) { + %tmp.1 = and int %a, 15 ; <int> [#uses=1] + %tmp.3 = and int %b, 240 ; <int> [#uses=1] + %tmp.4 = or int %tmp.3, %tmp.1 ; <int> [#uses=1] + ret int %tmp.4 +} + +without a copy. We make this currently: + +_f1: + rlwinm r2, r4, 0, 24, 27 + rlwimi r2, r3, 0, 28, 31 + or r3, r2, r2 + blr + +The two-addr pass or RA needs to learn when it is profitable to commute an +instruction to avoid a copy AFTER the 2-addr instruction. The 2-addr pass +currently only commutes to avoid inserting a copy BEFORE the two addr instr. + |

