|  | Commit message (Collapse) | Author | Age | Files | Lines | 
|---|
| ... |  | 
| | 
| 
| 
| | llvm-svn: 102657 | 
| | 
| 
| 
| 
| 
| | the rest of CodeGen.
llvm-svn: 101146 | 
| | 
| 
| 
| | llvm-svn: 100415 | 
| | 
| 
| 
| | llvm-svn: 98109 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | is preparatory to having PEI's scavenged frame index value reuse logic
properly distinguish types of frame values (e.g., whether the value is
stack-pointer relative or frame-pointer relative).
No functionality change.
llvm-svn: 98086 | 
| | 
| 
| 
| 
| 
| 
| 
| | 126.gcc nightly tests. These failures uncovered latent bugs that machine DCE
could remove one half of a stack adjust down/up pair, causing PEI to assert.
This update fixes that, and the tests now pass.
llvm-svn: 96822 | 
| | 
| 
| 
| 
| 
| | the armv6 nightly tests.
llvm-svn: 96691 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | for ARM to just check if a function has a FP to determine if it's safe
to simplify the stack adjustment pseudo ops prior to eliminating frame
indices. Allow targets to override the default behavior and does so for ARM
and Thumb2.
llvm-svn: 96634 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | created. This ensures it's updated at all time. It means targets which perform
dynamic stack alignment would know whether it is required and whether frame
pointer register cannot be made available register allocation.
This is a fix for rdar://7625239. Sorry, I can't create a reasonably sized test
case.
llvm-svn: 96069 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | into TargetOpcodes.h.  #include the new TargetOpcodes.h
into MachineInstr.  Add new inline accessors (like isPHI())
to MachineInstr, and start using them throughout the 
codebase.
llvm-svn: 95687 | 
| | 
| 
| 
| | llvm-svn: 92187 | 
| | 
| 
| 
| 
| 
| 
| | This is used in some weird cases like general dynamic TLS model.
This fixes PR5723
llvm-svn: 91144 | 
| | 
| 
| 
| 
| 
| | Patch by Howard Hinnant!
llvm-svn: 90365 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | slots.  The AsmPrinter will use this information to determine whether to
print a spill/reload comment.
Remove default argument values.  It's too easy to pass a wrong argument
value when multiple arguments have default values.  Make everything
explicit to trap bugs early.
Update all targets to adhere to the new interfaces..
llvm-svn: 87022 | 
| | 
| 
| 
| 
| 
| 
| 
| | indexed via the stack pointer, even if a frame pointer is present. Update the
heuristic to place it nearest the stack pointer in that case, rather than
nearest the frame pointer.
llvm-svn: 85474 | 
| | 
| 
| 
| 
| 
| | handles T2 and ARM use cases.
llvm-svn: 84761 | 
| | 
| 
| 
| | llvm-svn: 84657 | 
| | 
| 
| 
| 
| 
| | of the register in the instruction which kills the scavenged value.
llvm-svn: 84641 | 
| | 
| 
| 
| | llvm-svn: 84585 | 
| | 
| 
| 
| 
| 
| | get FixedStack PseudoSourceValues.
llvm-svn: 84326 | 
| | 
| 
| 
| | llvm-svn: 84138 | 
| | 
| 
| 
| | llvm-svn: 84133 | 
| | 
| 
| 
| | llvm-svn: 83653 | 
| | 
| 
| 
| | llvm-svn: 83521 | 
| | 
| 
| 
| 
| 
| | but are allocated by the scavenger. The re-use algorithm needs to watch for that.
llvm-svn: 83519 | 
| | 
| 
| 
| 
| 
| | what's up.
llvm-svn: 83501 | 
| | 
| 
| 
| | llvm-svn: 83496 | 
| | 
| 
| 
| | llvm-svn: 83483 | 
| | 
| 
| 
| | llvm-svn: 83481 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | a virtual register to eliminate a frame index, it can return that register
and the constant stored there to PEI to track. When scavenging to allocate
for those registers, PEI then tracks the last-used register and value, and
if it is still available and matches the value for the next index, reuses
the existing value rather and removes the re-materialization instructions.
Fancier tracking and adjustment of scavenger allocations to keep more
values live for longer is possible, but not yet implemented and would likely
be better done via a different, less special-purpose, approach to the
problem.
eliminateFrameIndex() is modified so the target implementations can return
the registers they wish to be tracked for reuse.
ARM Thumb1 implements and utilizes the new mechanism. All other targets are
simply modified to adjust for the changed eliminateFrameIndex() prototype.
llvm-svn: 83467 | 
| | 
| 
| 
| | llvm-svn: 83163 | 
| | 
| 
| 
| 
| 
| | per customary usage
llvm-svn: 83137 | 
| | 
| 
| 
| | llvm-svn: 83132 | 
| | 
| 
| 
| 
| 
| 
| | so a simple "current register" will suffice. Also add some additional
sanity-checking assertions to make sure things are as we expect.
llvm-svn: 83081 | 
| | 
| 
| 
| 
| 
| | slots.
llvm-svn: 82909 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | For the AAPCS ABI, SP must always be 4-byte aligned, and at any "public
interface" it must be 8-byte aligned.  For the older ARM APCS ABI, the stack
alignment is just always 4 bytes.  For X86, we currently align SP at
entry to a function (e.g., to 16 bytes for Darwin), but no stack alignment
is needed at other times, such as for a leaf function.
After discussing this with Dan, I decided to go with the approach of adding
a new "TransientStackAlignment" field to TargetFrameInfo.  This value
specifies the stack alignment that must be maintained even in between calls.
It defaults to 1 except for ARM, where it is 4.  (Some other targets may
also want to set this if they have similar stack requirements. It's not
currently required for PPC because it sets targetHandlesStackFrameRounding
and handles the alignment in target-specific code.) The existing StackAlignment
value specifies the alignment upon entry to a function, which is how we've
been using it anyway.
llvm-svn: 82767 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | interest for this, as it currently reserves a register rather than using
the scavenger for matierializing constants as needed.
Instead of scavenging registers on the fly while eliminating frame indices,
new virtual registers are created, and then a scavenged collectively in a
post-pass over the function. This isolates the bits that need to interact
with the scavenger, and sets the stage for more intelligent use, and reuse,
of scavenged registers.
For the time being, this is disabled by default. Once the bugs are worked out,
the current scavenging calls in replaceFrameIndices() will be removed and
the post-pass scavenging will be the default. Until then,
-enable-frame-index-scavenging enables the new code. Currently, only the
Thumb1 back end is set up to use it.
llvm-svn: 82734 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | LocalAreaOffset.  (We don't have any of those right now.)
PEI::calculateFrameObjectOffsets includes the absolute value of the
LocalAreaOffset in the cumulative offset value used to calculate the
stack frame size.  It then adds the raw value of the LocalAreaOffset
to the stack size.  For a StackGrowsDown target, that raw value is negative
and has the effect of cancelling out the absolute value that was added
earlier, but that obviously won't work for a StackGrowsUp target.  Change
to subtract the absolute value of the LocalAreaOffset.
llvm-svn: 82693 | 
| | 
| 
| 
| | llvm-svn: 82641 | 
| | 
| 
| 
| | llvm-svn: 82285 | 
| | 
| 
| 
| | llvm-svn: 79742 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | In a naked function, the flag is never set and getPristineRegs() returns an
empty list. That means naked functions are able to clobber callee saved
registers, but that is the whole point of naked functions.
This fixes PR4716.
llvm-svn: 79096 | 
| | 
| 
| 
| | llvm-svn: 78911 | 
| | 
| 
| 
| | llvm-svn: 77754 | 
| | 
| 
| 
| 
| 
| 
| 
| | shouldn't do AU.setPreservesCFG(), because even though CodeGen passes
don't modify the LLVM IR CFG, they may modify the MachineFunction CFG,
and passes like MachineLoop are registered with isCFGOnly set to true.
llvm-svn: 77691 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | failures when building assorted projects with clang.
--- Reverse-merging r77654 into '.':
U    include/llvm/CodeGen/Passes.h
U    include/llvm/CodeGen/MachineFunctionPass.h
U    include/llvm/CodeGen/MachineFunction.h
U    include/llvm/CodeGen/LazyLiveness.h
U    include/llvm/CodeGen/SelectionDAGISel.h
D    include/llvm/CodeGen/MachineFunctionAnalysis.h
U    include/llvm/Function.h
U    lib/Target/CellSPU/SPUISelDAGToDAG.cpp
U    lib/Target/PowerPC/PPCISelDAGToDAG.cpp
U    lib/CodeGen/LLVMTargetMachine.cpp
U    lib/CodeGen/MachineVerifier.cpp
U    lib/CodeGen/MachineFunction.cpp
U    lib/CodeGen/PrologEpilogInserter.cpp
U    lib/CodeGen/MachineLoopInfo.cpp
U    lib/CodeGen/SelectionDAG/SelectionDAGISel.cpp
D    lib/CodeGen/MachineFunctionAnalysis.cpp
D    lib/CodeGen/MachineFunctionPass.cpp
U    lib/CodeGen/LiveVariables.cpp
llvm-svn: 77661 | 
| | 
| 
| 
| 
| 
| 
| | mechanism. To support this, make MachineFunctionPass a little more
complete.
llvm-svn: 77654 | 
| | 
| 
| 
| | llvm-svn: 76198 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | stack alignment right when it is.  This is not
ideal but conservatively correct.  Adjust a test
to compensate for changed stack offset value.
gcc.apple/asm-block-57.c
llvm-svn: 76120 | 
| | 
| 
| 
| 
| 
| | ProcessFunctionBeforeCalleeSaveScan() use this information
llvm-svn: 75942 |