|  | Commit message (Collapse) | Author | Age | Files | Lines | 
|---|
| ... |  | 
| | 
| 
| 
| | llvm-svn: 75046 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | of exception handling builtin sjlj targets in functions turns out not to 
be necessary. Marking the intrinsic implementation in the .td file as 
defining all registers is sufficient to get the context saved properly by 
the containing function.
llvm-svn: 71743 | 
| | 
| 
| 
| | llvm-svn: 71678 | 
| | 
| 
| 
| 
| 
| 
| | a supporting preliminary patch for GCC-compatible SjLJ exception handling. Note that these intrinsics are not designed to be invoked directly by the user, but
rather used by the front-end as target hooks for exception handling.
llvm-svn: 71610 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | - moved shrink wrapping code from PrologEpilogInserter.cpp to
  new file ShrinkWrapping.cpp.
- moved PEI pass definition into new shared header PEI.h.
llvm-svn: 71588 | 
| | 
| 
| 
| | llvm-svn: 71472 | 
| | 
| 
| 
| | llvm-svn: 71457 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | - reduces _static_ callee saved register spills
  and restores similar to Chow's original algorithm.
- iterative implementation with simple heuristic
  limits to mitigate compile time impact.
- handles placing spills/restores for multi-entry,
  multi-exit regions in the Machine CFG without
  splitting edges.
- passes test-suite in LLCBETA mode.
Added contains() method to ADT/SparseBitVector.
llvm-svn: 71438 | 
| | 
| 
| 
| 
| 
| | --shrink-wrap.
llvm-svn: 67828 | 
| | 
| 
| 
| | llvm-svn: 67649 | 
| | 
| 
| 
| | llvm-svn: 67364 | 
| | 
| 
| 
| 
| 
| | is the first in its block.  This is PR3842.
llvm-svn: 67304 | 
| | 
| 
| 
| | llvm-svn: 63198 | 
| | 
| 
| 
| | llvm-svn: 58829 | 
| | 
| 
| 
| | llvm-svn: 58815 | 
| | 
| 
| 
| 
| 
| 
| | - Get rid of "HasStackProtector" in MachineFrameInfo.
- Modify intrinsics to tell which are doing what with memory.
llvm-svn: 58799 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | - stackprotector_prologue creates a stack object and stores the guard there.
- stackprotector_epilogue reads the stack guard from the stack position created
  by stackprotector_prologue.
- The PrologEpilogInserter was changed to make sure that the stack guard is
  first on the stack frame.
llvm-svn: 58791 | 
| | 
| 
| 
| | llvm-svn: 58523 | 
| | 
| 
| 
| 
| 
| 
| | callee-saved restore code. It could skip over conditional jumps
accidentally. Instead, just skip the "return" instructions.
llvm-svn: 58489 | 
| | 
| 
| 
| 
| 
| | isReg, etc., from isRegister, etc.
llvm-svn: 57006 | 
| | 
| 
| 
| 
| 
| | machine dominators.
llvm-svn: 56475 | 
| | 
| 
| 
| | llvm-svn: 56469 | 
| | 
| 
| 
| | llvm-svn: 55779 | 
| | 
| 
| 
| | llvm-svn: 53681 | 
| | 
| 
| 
| 
| 
| | objects.  Fixes a couple of tests on Linux.
llvm-svn: 52921 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | <16 x float> is 64-byte aligned (for some reason),
which gets us into the stack realignment code.  The
computation changing FP-relative offsets to SP-relative
was broken, assiging a spill temp to a location
also used for parameter passing.  This
fixes it by rounding up the stack frame to a multiple
of the largest alignment (I concluded it wasn't fixable
without doing this, but I'm not very sure.)
llvm-svn: 52750 | 
| | 
| 
| 
| 
| 
| 
| | the solution commited is different from the previous patch to
avoid int and unsigned comparison
llvm-svn: 51899 | 
| | 
| 
| 
| | llvm-svn: 50164 | 
| | 
| 
| 
| | llvm-svn: 50160 | 
| | 
| 
| 
| | llvm-svn: 48577 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | - Cleaned up how the prologue-epilogue inserter loops over the instructions.
- Instead of restarting the processing of an instruction if we remove an
  implicit kill, just update the end iterator and make sure that the iterator
  isn't incremented.
llvm-svn: 47870 | 
| | 
| 
| 
| 
| 
| 
| | the register scavenger to process all of those new instructions instead of just
the last one inserted.
llvm-svn: 47860 | 
| | 
| 
| 
| 
| 
| | deleted later. Let PEI compute it.
llvm-svn: 47668 | 
| | 
| 
| 
| | llvm-svn: 47657 | 
| | 
| 
| 
| | llvm-svn: 47452 | 
| | 
| 
| 
| | llvm-svn: 46930 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | information descriptor and its corresponding stack frame index in MachineModuleInfo. This only works if the local variable is "homed" in the stack frame. It does not work for byval parameter, etc.
Added ISD::DECLARE node type to represent llvm.dbg.declare intrinsic. Now the intrinsic calls are lowered into a SDNode and lives on through out the codegen passes.
For now, since all the debugging information recording is done at isel time, when a ISD::DECLARE node is selected, it has the side effect of also recording the variable. This is a short term solution that should be fixed in time.
llvm-svn: 46659 | 
| | 
| 
| 
| 
| 
| | llvm.dbg.func.start implies a stoppoint is set. SelectionDAGISel records a new source line but does not create a ISD::LABEL node for this special stoppoint. Asm printer will magically print this label. This ensures nothing is emitted before.
llvm-svn: 46635 | 
| | 
| 
| 
| 
| 
| | or misc labels. This fixes the EH breakage. However I am not convinced this is *the* solution.
llvm-svn: 46609 | 
| | 
| 
| 
| | llvm-svn: 46586 | 
| | 
| 
| 
| 
| 
| 
| | Make MachineInstr::getDesc return a reference instead
of a pointer, since it can never be null.
llvm-svn: 45695 | 
| | 
| 
| 
| | llvm-svn: 45680 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | that it is cheap and efficient to get.
Move a variety of predicates from TargetInstrInfo into 
TargetInstrDescriptor, which makes it much easier to query a predicate
when you don't have TII around.  Now you can use MI->getDesc()->isBranch()
instead of going through TII, and this is much more efficient anyway. Not
all of the predicates have been moved over yet.
Update old code that used MI->getInstrDescriptor()->Flags to use the
new predicates in many places.
llvm-svn: 45674 | 
| | 
| 
| 
| | llvm-svn: 45655 | 
| | 
| 
| 
| | llvm-svn: 45608 | 
| | 
| 
| 
| | llvm-svn: 45484 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | that "machine" classes are used to represent the current state of
the code being compiled.  Given this expanded name, we can start 
moving other stuff into it.  For now, move the UsedPhysRegs and
LiveIn/LoveOuts vectors from MachineFunction into it.
Update all the clients to match.
This also reduces some needless #includes, such as MachineModuleInfo
from MachineFunction.
llvm-svn: 45467 | 
| | 
| 
| 
| | llvm-svn: 45454 | 
| | 
| 
| 
| | llvm-svn: 45418 | 
| | 
| 
| 
| 
| 
| | the stored register is killed.
llvm-svn: 44600 |