- Apr 02, 2004
-
-
Alkis Evlogimenos authored
llvm-svn: 12610
-
Alkis Evlogimenos authored
llvm-svn: 12607
-
- Apr 01, 2004
-
-
Chris Lattner authored
llvm-svn: 12589
-
Chris Lattner authored
Implement a small optimization. In test/Regression/CodeGen/X86/select.ll, we now generate this for foldSel3: foldSel3: mov %AL, BYTE PTR [%ESP + 4] fld DWORD PTR [%ESP + 8] fld DWORD PTR [%ESP + 12] mov %EAX, DWORD PTR [%ESP + 16] mov %ECX, DWORD PTR [%ESP + 20] cmp %EAX, %ECX fxch %ST(1) fcmovae %ST(0), %ST(1) *** fstp %ST(1) ret Instead of: foldSel3: mov %AL, BYTE PTR [%ESP + 4] fld DWORD PTR [%ESP + 8] fld DWORD PTR [%ESP + 12] mov %EAX, DWORD PTR [%ESP + 16] mov %ECX, DWORD PTR [%ESP + 20] cmp %EAX, %ECX fxch %ST(1) fcmovae %ST(0), %ST(1) *** fxch %ST(1) *** fstp %ST(0) ret In practice, this only effects code size: performance should be basically unaffected. llvm-svn: 12588
-
Chris Lattner authored
llvm-svn: 12587
-
Chris Lattner authored
llvm-svn: 12579
-
Chris Lattner authored
llvm-svn: 12578
-
Chris Lattner authored
the X86 does not support a full set of fp cmove instructions, so we can't always fold the condition into the select. :( Yuck. llvm-svn: 12577
-
Chris Lattner authored
llvm-svn: 12576
-
Chris Lattner authored
llvm-svn: 12575
-
Chris Lattner authored
that require the asmwriter to be extended (printing implicit uses before the explicit operands) llvm-svn: 12574
-
- Mar 31, 2004
-
-
Chris Lattner authored
llvm-svn: 12572
-
Brian Gaeke authored
easily steal it for a separate use in the reoptimizer. llvm-svn: 12568
-
Chris Lattner authored
using our broad selection of movcc instructions. :) llvm-svn: 12560
-
- Mar 30, 2004
-
-
Chris Lattner authored
llvm-svn: 12554
-
Chris Lattner authored
folding compares into the select yet. llvm-svn: 12553
-
Chris Lattner authored
we never generated them Make indentation a bit more consistent llvm-svn: 12549
-
Chris Lattner authored
an incoming value from a block, the selector would evaluate the constant at the TOP of the block instead of at the end of the block. This made the live range for the constant span the entire block, increasing register pressure needlessly. llvm-svn: 12542
-
Chris Lattner authored
llvm-svn: 12541
-
- Mar 29, 2004
-
-
Brian Gaeke authored
Otherwise, if you're in debugging mode, you get warnings for (apparently) every immediate constant in the function during reg. allocation. llvm-svn: 12538
-
- Mar 19, 2004
-
-
Chris Lattner authored
llvm-svn: 12504
-
- Mar 18, 2004
-
-
Chris Lattner authored
llvm-svn: 12500
-
Chris Lattner authored
folding load instructions into other instructions across free instruction boundaries. Perhaps this will also fix the other strange failures? llvm-svn: 12494
-
- Mar 16, 2004
-
-
Brian Gaeke authored
llvm-svn: 12454
-
Brian Gaeke authored
llvm-svn: 12453
-
Brian Gaeke authored
llvm-svn: 12452
-
Brian Gaeke authored
llvm-svn: 12451
-
Brian Gaeke authored
Add handling for Mul instruction. llvm-svn: 12450
-
- Mar 15, 2004
-
-
Alkis Evlogimenos authored
llvm-svn: 12424
-
- Mar 14, 2004
-
-
Alkis Evlogimenos authored
MachineBasicBlock::iterator take a MachineInstr*. llvm-svn: 12392
-
Alkis Evlogimenos authored
instruction to make the API more flexible. llvm-svn: 12386
-
- Mar 13, 2004
-
-
Chris Lattner authored
llvm-svn: 12357
-
Chris Lattner authored
Intrinsic::va*. This avoid conflicting with macros in the stdlib.h file. llvm-svn: 12356
-
- Mar 12, 2004
-
-
Brian Gaeke authored
llvm-svn: 12344
-
Alkis Evlogimenos authored
llvm-svn: 12336
-
Chris Lattner authored
llvm-svn: 12316
-
Misha Brukman authored
header file and all those who #include it. llvm-svn: 12297
-
- Mar 11, 2004
-
-
Brian Gaeke authored
Make an explicit call to it from runOnFunction() if we know we're supposed to write into the global. This is lame (esp. the const_cast), but it solves the problem. llvm-svn: 12291
-
Brian Gaeke authored
llvm-svn: 12290
-
Misha Brukman authored
llvm-svn: 12289
-