diff options
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$ |