|  | Commit message (Collapse) | Author | Age | Files | Lines | 
|---|
| | 
| 
| 
| 
| 
| 
| | This centralizes the handling of O_BINARY and opens the way for hiding more
differences (like how open behaves with directories).
llvm-svn: 186447 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | 1> on every path through the CFG, a FrameSetup <n> is always followed by a
   FrameDestroy <n> and a FrameDestroy is always followed by a FrameSetup.
2> stack adjustments are identical on all CFG edges to a merge point.
3> frame is destroyed at end of a return block.
PR16393
llvm-svn: 186350 | 
| | 
| 
| 
| | llvm-svn: 182531 | 
| | 
| 
| 
| 
| 
| 
| | This checks the sanity of the register use lists in the MI intermediate
representation.
llvm-svn: 179895 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | into their new header subdirectory: include/llvm/IR. This matches the
directory structure of lib, and begins to correct a long standing point
of file layout clutter in LLVM.
There are still more header files to move here, but I wanted to handle
them in separate commits to make tracking what files make sense at each
layer easier.
The only really questionable files here are the target intrinsic
tablegen files. But that's a battle I'd rather not fight today.
I've updated both CMake and Makefile build systems (I think, and my
tests think, but I may have missed something).
I've also re-sorted the includes throughout the project. I'll be
committing updates to Clang, DragonEgg, and Polly momentarily.
llvm-svn: 171366 | 
| | 
| 
| 
| 
| 
| | No testcase because it is apparently not so trivial to construct.
llvm-svn: 170595 | 
| | 
| 
| 
| 
| 
| 
| | The new bidirectional bundle flags are redundant, so inadvertent bundle
tearing can be detected in the machine code verifier.
llvm-svn: 170463 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Sooooo many of these had incorrect or strange main module includes.
I have manually inspected all of these, and fixed the main module
include to be the nearest plausible thing I could find. If you own or
care about any of these source files, I encourage you to take some time
and check that these edits were sensible. I can't have broken anything
(I strictly added headers, and reordered them, never removed), but they
may not be the headers you'd really like to identify as containing the
API being implemented.
Many forward declarations and missing includes were added to a header
files to allow them to parse cleanly when included first. The main
module rule does in fact have its merits. =]
llvm-svn: 169131 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | the MachineInstr MayLoad/MayLoad flags are based on the tablegen implementation.
For inline assembly, however, we need to compute these based on the constraints.
Revert r166929 as this is no longer needed, but leave the test case in place. 
rdar://12033048 and PR13504
llvm-svn: 167040 | 
| | 
| 
| 
| | llvm-svn: 165999 | 
| | 
| 
| 
| 
| 
| 
| | Using the cached bit vector in MRI avoids comstantly allocating and
recomputing the reserved register bit vector.
llvm-svn: 165983 | 
| | 
| 
| 
| | llvm-svn: 163258 | 
| | 
| 
| 
| | llvm-svn: 163152 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | The operands on an INLINEASM machine instruction are divided into groups
headed by immediate flag operands. Verify this structure.
Extract verifyTiedOperands(), and only call it for non-inlineasm
instructions.
llvm-svn: 162849 | 
| | 
| 
| 
| 
| 
| 
| 
| | WHen running with -verify-machineinstrs, check that tied operands come
in matching use/def pairs, and that they are consistent with MCInstrDesc
when it applies.
llvm-svn: 162816 | 
| | 
| 
| 
| 
| 
| | did getFunction()->getName(). Remove includes of Function.h that are no longer needed.
llvm-svn: 162347 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | IR that hasn't been through SimplifyCFG can look like this:
  br i1 %b, label %r, label %r
Make sure we don't create duplicate Machine CFG edges in this case.
Fix the machine code verifier to accept conditional branches with a
single CFG edge.
llvm-svn: 162230 | 
| | 
| 
| 
| 
| 
| 
| | Verify that the predecessor and successor lists are consistent and free
of duplicates.
llvm-svn: 162223 | 
| | 
| 
| 
| 
| 
| | pointer.
llvm-svn: 161919 | 
| | 
| 
| 
| 
| 
| 
| | Don't cause regunit intervals to be computed just to verify them. Only
check the already cached intervals.
llvm-svn: 161183 | 
| | 
| 
| 
| | llvm-svn: 161178 | 
| | 
| 
| 
| 
| 
| | No functional change.
llvm-svn: 161149 | 
| | 
| 
| 
| | llvm-svn: 161147 | 
| | 
| 
| 
| 
| 
| | Include <undef> operands and virtual registers after leaving SSA form.
llvm-svn: 160734 | 
| | 
| 
| 
| 
| 
| | which has no def
llvm-svn: 160531 | 
| | 
| 
| 
| | llvm-svn: 160475 | 
| | 
| 
| 
| 
| 
| 
| | This would previously get reported as the misleading "Virtual register
def doesn't dominate all uses."
llvm-svn: 159460 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Verify that all paths from the entry block to a virtual register read
pass through a def. Enable this check even when MRI->isSSA() is false.
Verify that the live range of a virtual register is live out of all
predecessor blocks, even for PHI-values.
This requires that PHIElimination sometimes inserts IMPLICIT_DEF
instruction in predecessor blocks.
llvm-svn: 159150 | 
| | 
| 
| 
| | llvm-svn: 159039 | 
| | 
| 
| 
| 
| 
| | Deterministically enumerate the virtual registers instead.
llvm-svn: 158872 | 
| | 
| 
| 
| 
| 
| | the last instruction of a basic block.
llvm-svn: 158468 | 
| | 
| 
| 
| 
| 
| | MachineBasicBlock::instr_iterator instead of MBB::iterator
llvm-svn: 158154 | 
| | 
| 
| 
| 
| 
| 
| 
| | Bundles should be treated as one atomic transaction when checking
liveness. That is how the register allocator (and VLIW targets) treats
bundles.
llvm-svn: 158116 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | No functional change intended.
Sorry for the churn. The iterator classes are supposed to help avoid
giant commits like this one in the future. The TableGen-produced
register lists are getting quite large, and it may be necessary to
change the table representation.
This makes it possible to do so without changing all clients (again).
llvm-svn: 157854 | 
| | 
| 
| 
| | llvm-svn: 157640 | 
| | 
| 
| 
| 
| 
| | Make sure useless (def-only) intervals also get verified.
llvm-svn: 157000 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | The getPointerRegClass() hook can return register classes that depend on
the calling convention of the current function (ptr_rc_tailcall).
So far, we have been able to infer the calling convention from the
subtarget alone, but as we add support for multiple calling conventions
per target, that no longer works.
Patch by Yiannis Tsiouris!
llvm-svn: 156328 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | The late scheduler depends on accurate liveness information if it is
breaking anti-dependencies, so we should be able to verify it.
Relax the terminator checking in the machine code verifier so it can
handle the basic blocks created by if conversion.
llvm-svn: 153614 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | Extract the liveness verification into its own method.
This makes it possible to run the machine code verifier after liveness
information is no longer required to be valid.
llvm-svn: 153596 | 
| | 
| 
| 
| | llvm-svn: 152460 | 
| | 
| 
| 
| 
| 
| | Somehow we never verified SSA dominance before.
llvm-svn: 152458 | 
| | 
| 
| 
| | llvm-svn: 152457 | 
| | 
| 
| 
| 
| 
| | static data size.
llvm-svn: 152016 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | Extract a base class and provide four specific sub-classes for iterating
over const/non-const bundles/instructions.
This eliminates the mystery bool constructor argument.
llvm-svn: 151684 | 
| | 
| 
| 
| | llvm-svn: 151607 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | After the SlotIndex slot names were updated, it is possible to apply
stricter checks to live intervals.
Also treat bundles as bags of operands when checking live intervals.
llvm-svn: 151531 | 
| | 
| 
| 
| | llvm-svn: 150496 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | to finalize MI bundles (i.e. add BUNDLE instruction and computing register def
  and use lists of the BUNDLE instruction) and a pass to unpack bundles.
- Teach more of MachineBasic and MachineInstr methods to be bundle aware.
- Switch Thumb2 IT block to MI bundles and delete the hazard recognizer hack to
  prevent IT blocks from being broken apart.
llvm-svn: 146542 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | generator to it. For non-bundle instructions, these behave exactly the same
as the MC layer API.
For properties like mayLoad / mayStore, look into the bundle and if any of the
bundled instructions has the property it would return true.
For properties like isPredicable, only return true if *all* of the bundled
instructions have the property.
For properties like canFoldAsLoad, isCompare, conservatively return false for
bundles.
llvm-svn: 146026 | 
| | 
| 
| 
| | llvm-svn: 144648 |