aboutsummaryrefslogtreecommitdiff
path: root/lib/Target/Sparc
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2004-12-13 20:13:10 +0000
committerChris Lattner <sabre@nondot.org>2004-12-13 20:13:10 +0000
commite171d5c812c308eb93ea611cae5c480279a82fbc (patch)
tree245db115ec177c6c73b97f2cdeb2d12db61a2f6a /lib/Target/Sparc
parent2356f8612e2e7441d6c829b6886cc5c2a4a1671d (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.txt22
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$