2004-07-23 22:37:22 +00:00
|
|
|
Currently unimplemented:
|
|
|
|
* cast fp to bool
|
2004-07-26 16:23:55 +00:00
|
|
|
* signed right shift of long by reg
|
2004-07-23 22:37:22 +00:00
|
|
|
|
|
|
|
Current bugs:
|
2004-07-28 19:16:10 +00:00
|
|
|
* ulong to double. ahhh, here's the problem:
|
|
|
|
floatdidf assumes signed longs. so if the high but of a ulong
|
|
|
|
just happens to be set, you get the wrong sign. The fix for this
|
|
|
|
is to call cmpdi2 to compare against zero, if so shift right by one,
|
|
|
|
convert to fp, and multiply by (add to itself). the sequence would
|
|
|
|
look like:
|
|
|
|
{r3:r4} holds ulong a;
|
|
|
|
li r5, 0
|
|
|
|
li r6, 0 (set r5:r6 to ulong 0)
|
|
|
|
call cmpdi2 ==> sets r3 <, =, > 0
|
|
|
|
if r3 > 0
|
|
|
|
call floatdidf as usual
|
|
|
|
else
|
|
|
|
shift right ulong a, 1 (we could use emitShift)
|
|
|
|
call floatdidf
|
|
|
|
fadd f1, f1, f1 (fp left shift by 1)
|
|
|
|
* linking llvmg++ .s files with gcc instead of g++
|
2004-07-26 16:23:55 +00:00
|
|
|
|
|
|
|
Codegen improvements needed:
|
2004-08-06 06:58:50 +00:00
|
|
|
* PowerPCPEI.cpp needs to save/restore regs in the opposite order
|
2004-07-26 16:23:55 +00:00
|
|
|
* setCondInst needs to know branchless versions of seteq/setne/etc
|
|
|
|
* cast elimination pass (uint -> sbyte -> short, kill the byte -> short)
|
2004-07-27 18:43:04 +00:00
|
|
|
* should hint to the branch select pass that it doesn't need to print the
|
|
|
|
second unconditional branch, so we don't end up with things like:
|
|
|
|
b .LBBl42__2E_expand_function_8_674 ; loopentry.24
|
|
|
|
b .LBBl42__2E_expand_function_8_42 ; NewDefault
|
|
|
|
b .LBBl42__2E_expand_function_8_42 ; NewDefault
|
2004-07-26 16:23:55 +00:00
|
|
|
|
|
|
|
Current hacks:
|
|
|
|
* lazy insert of GlobalBaseReg definition at front of first MBB
|
|
|
|
A prime candidate for sabre's "slightly above ISel" passes.
|
|
|
|
* cast code is huge, unwieldy. Should probably be broken up into
|
|
|
|
smaller pieces.
|
|
|
|
* visitLoadInst is getting awfully cluttered as well.
|
2004-07-23 22:37:22 +00:00
|
|
|
|
|
|
|
Currently failing tests:
|
|
|
|
* SingleSource
|
2004-07-28 00:55:12 +00:00
|
|
|
`- Regression
|
2004-07-30 15:53:09 +00:00
|
|
|
| `- casts (ulong to fp failure)
|
2004-07-23 22:37:22 +00:00
|
|
|
`- Benchmarks
|
|
|
|
| `- Shootout-C++ : most programs fail, miscompilations
|
|
|
|
`- UnitTests
|
2004-07-30 15:53:09 +00:00
|
|
|
| `- C++Catch
|
|
|
|
| `- SimpleC++Test
|
|
|
|
| `- ConditionalExpr (also C++)
|
2004-07-23 22:37:22 +00:00
|
|
|
* MultiSource
|
|
|
|
|- Applications
|
|
|
|
| `- burg: miscompilation
|
|
|
|
| `- siod: llc bus error
|
|
|
|
| `- hbd: miscompilation
|
|
|
|
| `- d (make_dparser): miscompilation
|
|
|
|
`- Benchmarks
|
2004-07-30 15:53:09 +00:00
|
|
|
`- MallocBench/make: miscompilation
|