diff options
author | Chris Lattner <sabre@nondot.org> | 2004-12-13 20:13:10 +0000 |
---|---|---|
committer | Chris Lattner <sabre@nondot.org> | 2004-12-13 20:13:10 +0000 |
commit | e171d5c812c308eb93ea611cae5c480279a82fbc (patch) | |
tree | 245db115ec177c6c73b97f2cdeb2d12db61a2f6a /lib/Target/Sparc | |
parent | 2356f8612e2e7441d6c829b6886cc5c2a4a1671d (diff) |
Add some notes
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@18911 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Target/Sparc')
-rw-r--r-- | lib/Target/Sparc/README.txt | 22 |
1 files changed, 21 insertions, 1 deletions
diff --git a/lib/Target/Sparc/README.txt b/lib/Target/Sparc/README.txt index 1b25922438..d45a370e23 100644 --- a/lib/Target/Sparc/README.txt +++ b/lib/Target/Sparc/README.txt @@ -53,7 +53,27 @@ To-do * support shl on longs (fourinarow needs this) * support casting 64-bit integers to FP types (fhourstones needs this) -* support FP rem +* support FP rem (call fmod) + +* Eliminate srl/sll by zero bits like this: + sll %l0, 0, %l0 + srl %l0, 0, %o0 + + We think these are only used by V9 to clear off the top 32 bits of a reg, + so they are not needed. + +* Keep the address of the constant pool in a register instead of forming its + address all of the time. + +* Change code like this: + or %o0, %lo(.CPI_main_0), %o0 + ld [%o0+0], %o0 + into: + ld [%o0+%lo(.CPI_main_0)], %o0 + for constant pool access. + +* We can fold small constant offsets into the %hi/%lo references to constant + pool addresses as well. $Date$ |