| Commit message (Collapse) | Author | Age | Files | Lines | |
|---|---|---|---|---|---|
| * | Silence VC++ redeclaration warnings. | Jeff Cohen | 2005-09-29 | 1 | -4/+6 |
| | | | | | llvm-svn: 23516 | ||||
| * | Never rely on ReplaceAllUsesWith when selecting, use CodeGenMap instead. | Chris Lattner | 2005-09-29 | 1 | -34/+29 |
| | | | | | | | | ReplaceAllUsesWith does not replace scalars SDOperand floating around on the stack, permitting things to be selected multiple times. llvm-svn: 23515 | ||||
| * | Codegen ADD X, IMM -> addis/addi if needed. | Chris Lattner | 2005-09-28 | 1 | -2/+12 |
| | | | | | | | This implements PowerPC/fold-li.ll llvm-svn: 23514 | ||||
| * | Autogen MUL, move FP cases together | Chris Lattner | 2005-09-28 | 1 | -24/+12 |
| | | | | | llvm-svn: 23512 | ||||
| * | disentangle FP from INT versions of div/mul | Chris Lattner | 2005-09-28 | 1 | -18/+16 |
| | | | | | llvm-svn: 23511 | ||||
| * | Use the autogenerated matcher for ADD/SUB | Chris Lattner | 2005-09-28 | 1 | -30/+0 |
| | | | | | llvm-svn: 23510 | ||||
| * | add a patter for SUBFIC | Chris Lattner | 2005-09-28 | 1 | -1/+1 |
| | | | | | llvm-svn: 23509 | ||||
| * | Mark int binops as int-only, add FP binops. Mark FADD/FMUL as commutative but | Chris Lattner | 2005-09-28 | 1 | -15/+23 |
| | | | | | | | not associative. Add [SU]REM. llvm-svn: 23508 | ||||
| * | wrap a long line | Chris Lattner | 2005-09-28 | 1 | -1/+2 |
| | | | | | llvm-svn: 23507 | ||||
| * | Add FP versions of the binary operators, keeping the int and fp worlds seperate. | Chris Lattner | 2005-09-28 | 3 | -114/+120 |
| | | | | | llvm-svn: 23506 | ||||
| * | Add FP versions of the binary operators, keeping the int and fp worlds seperate. | Chris Lattner | 2005-09-28 | 4 | -97/+108 |
| | | | | | | | | | Though I have done extensive testing, it is possible that this will break things in configs I can't test. Please let me know if this causes a problem and I'll fix it ASAP. llvm-svn: 23505 | ||||
| * | Add FP versions of the binary operators, keeping the int and fp worlds seperate. | Chris Lattner | 2005-09-28 | 4 | -87/+209 |
| | | | | | | | | | Though I have done extensive testing, it is possible that this will break things in configs I can't test. Please let me know if this causes a problem and I'll fix it ASAP. llvm-svn: 23504 | ||||
| * | Mark associative nodes as associative | Chris Lattner | 2005-09-28 | 1 | -6/+12 |
| | | | | | llvm-svn: 23503 | ||||
| * | Nate pointed out that mulh[us] are commutative as well. Thanks! | Chris Lattner | 2005-09-28 | 1 | -2/+2 |
| | | | | | llvm-svn: 23500 | ||||
| * | expose commutativity information | Chris Lattner | 2005-09-28 | 1 | -8/+17 |
| | | | | | llvm-svn: 23498 | ||||
| * | All (xor *) cases are autogenerated now | Chris Lattner | 2005-09-28 | 1 | -43/+0 |
| | | | | | llvm-svn: 23497 | ||||
| * | add support for missed eqv tests | Chris Lattner | 2005-09-28 | 1 | -0/+9 |
| | | | | | llvm-svn: 23496 | ||||
| * | Implement PowerPC/eqv-andc-orc-nor.ll:EQV3 | Chris Lattner | 2005-09-28 | 1 | -1/+5 |
| | | | | | llvm-svn: 23494 | ||||
| * | learn to codegen not as NOR instead of xoris/xori | Chris Lattner | 2005-09-28 | 1 | -1/+5 |
| | | | | | llvm-svn: 23490 | ||||
| * | These nodes are all autogenerated | Chris Lattner | 2005-09-28 | 1 | -44/+0 |
| | | | | | llvm-svn: 23489 | ||||
| * | Constant fold llvm.sqrt | Chris Lattner | 2005-09-28 | 1 | -1/+9 |
| | | | | | llvm-svn: 23487 | ||||
| * | add a note about a way to improve this code further, that I won't be getting | Chris Lattner | 2005-09-27 | 1 | -0/+8 |
| | | | | | | | to right now. llvm-svn: 23485 | ||||
| * | Fix a regression in my previous patch, fixing GlobalOpt/2005-09-27-Crash.ll | Chris Lattner | 2005-09-27 | 1 | -1/+1 |
| | | | | | | | and PR632. llvm-svn: 23484 | ||||
| * | Darwin, like many BSD systems, has a setjmp/longjmp which saves the signal mask | Chris Lattner | 2005-09-27 | 1 | -0/+3 |
| | | | | | | | | | | on setjmp calls and restores it on longjmp calls (both of which require syscalls). This makes the calls REALLY slow. Use _setjmp/_longjmp instead. This speeds up hexxagon from 120.31s to 15.68s: from 5.53x slower than GCC to 28% faster than GCC. llvm-svn: 23482 | ||||
| * | If the target prefers it, use _setjmp/_longjmp should be used instead of ↵ | Chris Lattner | 2005-09-27 | 1 | -2/+6 |
| | | | | | | | setjmp/longjmp for llvm.setjmp/llvm.longjmp. llvm-svn: 23481 | ||||
| * | initialize new flag | Chris Lattner | 2005-09-27 | 1 | -0/+1 |
| | | | | | llvm-svn: 23480 | ||||
| * | Avoid spilling stack slots... to stack slots. | Chris Lattner | 2005-09-27 | 1 | -0/+6 |
| | | | | | llvm-svn: 23478 | ||||
| * | Completely rewrite 'correct' eh support. This changes how setjmp insertion | Chris Lattner | 2005-09-27 | 1 | -140/+301 |
| | | | | | | | | | | | | | | | | | | is performed so it is only at most once per function that contains an invoke instead of once per invoke in the function. This patch has the following perks: 1. It fixes PR631, which complains about slowness. 2. If fixes PR240, which complains about non-volatile vars being live across setjmp/longjmps. 3. It improves (but does not fix) the jmpbuf alignment issue on itanium by not forcing the jmpbufs to always be 8-bytes off the alignment of the structure. 4. It speeds up 253.perlbmk from 338s to 13.70s (a 25x improvement!), making us now about 4% faster than GCC. Further improvements are also possible. llvm-svn: 23477 | ||||
| * | Make the pass name simpler | Chris Lattner | 2005-09-27 | 1 | -1/+1 |
| | | | | | llvm-svn: 23476 | ||||
| * | fix CBackend/2005-09-27-VolatileFuncPtr.ll | Chris Lattner | 2005-09-27 | 1 | -4/+4 |
| | | | | | llvm-svn: 23475 | ||||
| * | allow demotion to volatile values, add support for invoke | Chris Lattner | 2005-09-27 | 1 | -12/+15 |
| | | | | | llvm-svn: 23473 | ||||
| * | Make sure to clear the CodeGenMap after each basic block is selected to avoid | Chris Lattner | 2005-09-27 | 1 | -0/+1 |
| | | | | | | | cross MBB pollution. llvm-svn: 23470 | ||||
| * | Remove some redundancies. | Jim Laskey | 2005-09-27 | 1 | -10/+10 |
| | | | | | llvm-svn: 23469 | ||||
| * | Split SimpleConstantVal up into its components, so each Constant subclass ↵ | Chris Lattner | 2005-09-27 | 1 | -10/+14 |
| | | | | | | | | | | | getsa different enum value. This allows 'classof' for these to be really simple,not needing to call getType() anymore. This speeds up isa/dyncast/etc for constants, and also makes them smaller. For example, the text section of a release build of InstCombine.cpp shrinks from 230037 bytes to 216363 bytes, a 6% reduction. llvm-svn: 23467 | ||||
| * | Add support for external calls that we know how to constant fold. This ↵ | Chris Lattner | 2005-09-27 | 1 | -11/+20 |
| | | | | | | | | | implements ctor-list-opt.ll:CTOR8 llvm-svn: 23465 | ||||
| * | Fix a bug where we would evaluate stores into linkonce objects which could be | Chris Lattner | 2005-09-27 | 1 | -1/+6 |
| | | | | | | | potentially replaced at link-time. llvm-svn: 23463 | ||||
| * | Implement support for static constructors with calls in them. This is useful | Chris Lattner | 2005-09-27 | 1 | -23/+54 |
| | | | | | | | | | because gccas runs globalopt before inlining. This implements ctor-list-opt.ll:CTOR7 llvm-svn: 23462 | ||||
| * | Refactor this code a bit, no functionality changes. | Chris Lattner | 2005-09-27 | 1 | -22/+40 |
| | | | | | llvm-svn: 23460 | ||||
| * | Move the post-lsr simplify cfg pass after lowereh, so it can clean up after | Chris Lattner | 2005-09-27 | 1 | -2/+6 |
| | | | | | | | eh lowering as well. llvm-svn: 23459 | ||||
| * | minor pattern shuffling | Chris Lattner | 2005-09-26 | 1 | -8/+3 |
| | | | | | llvm-svn: 23458 | ||||
| * | Addition of a simple two pass scheduler. This version is currently hacked up | Jim Laskey | 2005-09-26 | 1 | -80/+771 |
| | | | | | | | | | for testing and will require target machine info to do a proper scheduling. The simple scheduler can be turned on using -sched=simple (defaults to -sched=none) llvm-svn: 23455 | ||||
| * | Remove some dead code. ctor evaluation subsumes empty ctor elim | Chris Lattner | 2005-09-26 | 1 | -12/+0 |
| | | | | | llvm-svn: 23453 | ||||
| * | Add support for alloca, implementing ctor-list-opt.ll:CTOR6 | Chris Lattner | 2005-09-26 | 1 | -17/+48 |
| | | | | | llvm-svn: 23452 | ||||
| * | Add a debug printout, fix a crash on kc++ | Chris Lattner | 2005-09-26 | 1 | -1/+6 |
| | | | | | llvm-svn: 23450 | ||||
| * | Implement loads/stores through GEP's of globals. This implements | Chris Lattner | 2005-09-26 | 1 | -6/+98 |
| | | | | | | | ctor-list-opt.ll:CTOR5. llvm-svn: 23449 | ||||
| * | Replace TraverseGEPInitializer with ConstantFoldLoadThroughGEPConstantExpr | Chris Lattner | 2005-09-26 | 1 | -17/+5 |
| | | | | | llvm-svn: 23447 | ||||
| * | Eliminate GetGEPGlobalInitializer in favor of the more powerful | Chris Lattner | 2005-09-26 | 1 | -27/+1 |
| | | | | | | | ConstantFoldLoadThroughGEPConstantExpr function in the utils lib. llvm-svn: 23446 | ||||
| * | Factor the GetGEPGlobalInitializer out of this pass and into Transforms/Utils | Chris Lattner | 2005-09-26 | 1 | -44/+2 |
| | | | | | | | as ConstantFoldLoadThroughGEPConstantExpr. llvm-svn: 23445 | ||||
| * | Move the ConstantFoldLoadThroughGEPConstantExpr function out of the InstCombine | Chris Lattner | 2005-09-26 | 1 | -1/+45 |
| | | | | | | | pass. llvm-svn: 23444 | ||||
| * | add a comment | Chris Lattner | 2005-09-26 | 1 | -0/+3 |
| | | | | | llvm-svn: 23442 | ||||

