|  | Commit message (Collapse) | Author | Age | Files | Lines | 
|---|
| | 
| 
| 
| | llvm-svn: 116018 | 
| | 
| 
| 
| | llvm-svn: 115005 | 
| | 
| 
| 
| | llvm-svn: 114999 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | passed the root of the match, even though only a few patterns
actually needed this (one in X86, several in ARM [which should
be refactored anyway], and some in CellSPU that I don't feel 
like detangling).   Instead of requiring all ComplexPatterns to
take the dead root, have targets opt into getting the root by
putting SDNPWantRoot on the ComplexPattern.
llvm-svn: 114471 | 
| | 
| 
| 
| | llvm-svn: 114461 | 
| | 
| 
| 
| 
| 
| | MachinePointerInfo around more.
llvm-svn: 114452 | 
| | 
| 
| 
| 
| 
| | SelectionDAG::getExtLoad overload, and eliminate it.
llvm-svn: 114446 | 
| | 
| 
| 
| | llvm-svn: 114410 | 
| | 
| 
| 
| 
| 
| 
| | instead of srcvalue/offset pairs.  This corrects SV info for mem 
operations whose size is > 32-bits.
llvm-svn: 114401 | 
| | 
| 
| 
| | llvm-svn: 114391 | 
| | 
| 
| 
| | llvm-svn: 114303 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | take multiple cycles to decode.
For the current if-converter clients (actually only ARM), the instructions that
are predicated on false are not nops. They would still take machine cycles to
decode. Micro-coded instructions such as LDM / STM can potentially take multiple
cycles to decode. If-converter should take treat them as non-micro-coded
simple instructions.
llvm-svn: 113570 | 
| | 
| 
| 
| | llvm-svn: 113073 | 
| | 
| 
| 
| 
| 
| | to try to re-use scavenged frame index reference registers. rdar://8277890
llvm-svn: 112241 | 
| | 
| 
| 
| | llvm-svn: 111835 | 
| | 
| 
| 
| | llvm-svn: 111241 | 
| | 
| 
| 
| | llvm-svn: 110460 | 
| | 
| 
| 
| | llvm-svn: 110410 | 
| | 
| 
| 
| 
| 
| 
| 
| | address of the static
ID member as the sole unique type identifier.  Clean up APIs related to this change.
llvm-svn: 110396 | 
| | 
| 
| 
| | llvm-svn: 110256 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | See PR5201. There is no way to know if direct calls will be within the allowed
range for BL. Hence emit all calls as indirect when in JIT mode.
Without this long-running applications will fail to JIT on PowerPC with a
relocation failure.
llvm-svn: 110246 | 
| | 
| 
| 
| | llvm-svn: 109998 | 
| | 
| 
| 
| 
| 
| 
| 
| | formerly rejected by the FE, so asserted in the BE; now the FE only
warns, so we treat it as a legitimate fatal error in PPC BE.
This means the test for the feature won't pass, so it's xfail'd.
llvm-svn: 109892 | 
| | 
| 
| 
| | llvm-svn: 109224 | 
| | 
| 
| 
| 
| 
| 
| 
| | ARM/PPC/MSP430-specific code (which are the only targets that
implement the hook) can directly reference their target-specific
instrinfo classes.
llvm-svn: 109171 | 
| | 
| 
| 
| | llvm-svn: 108567 | 
| | 
| 
| 
| 
| 
| | thus is a much more meaningful name.
llvm-svn: 108563 | 
| | 
| 
| 
| 
| 
| | PowerPC.
llvm-svn: 108555 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | operands.
Hopefully this fixes the llvm-gcc-powerpc-darwin9 buildbot. It really shouldn't
since missing memoperands should not affect correctness.
llvm-svn: 108540 | 
| | 
| 
| 
| 
| 
| 
| 
| | The only folding these load/store architectures can do is converting COPY into a
load or store, and the target independent part of foldMemoryOperand already
knows how to do that.
llvm-svn: 108099 | 
| | 
| 
| 
| | llvm-svn: 108083 | 
| | 
| 
| 
| 
| 
| | for consistency sake.
llvm-svn: 107820 | 
| | 
| 
| 
| 
| 
| | code can do calling-convention queries. This obviates OutputArgReg.
llvm-svn: 107786 | 
| | 
| 
| 
| | llvm-svn: 107710 | 
| | 
| 
| 
| 
| 
| 
| | the block before calling the expansion hook. And don't
put EFLAGS in a mbb's live-in list twice.
llvm-svn: 107691 | 
| | 
| 
| 
| | llvm-svn: 107668 | 
| | 
| 
| 
| 
| 
| | the pseudo instruction is not at the end of the block.
llvm-svn: 107655 | 
| | 
| 
| 
| 
| 
| | slots so it's always false.
llvm-svn: 107550 | 
| | 
| 
| 
| | llvm-svn: 107127 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | for an "i" constraint should get lowered; PR 6309.  While
this argument was passed around a lot, this is the only
place it was used, so it goes away from a lot of other
places.
llvm-svn: 106893 | 
| | 
| 
| 
| | llvm-svn: 106279 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | addresses a longstanding deficiency noted in many FIXMEs scattered
across all the targets.
This effectively moves the problem up one level, replacing eleven
FIXMEs in the targets with eight FIXMEs in CodeGen, plus one path
through FastISel where we actually supply a DebugLoc, fixing Radar
7421831.
llvm-svn: 106243 | 
| | 
| 
| 
| 
| 
| | immediates to avoid breaking the build.
llvm-svn: 105652 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | In file included from X86InstrInfo.cpp:16:
X86GenInstrInfo.inc:2789: error: integer constant is too large for 'long' type
X86GenInstrInfo.inc:2790: error: integer constant is too large for 'long' type
X86GenInstrInfo.inc:2792: error: integer constant is too large for 'long' type
X86GenInstrInfo.inc:2793: error: integer constant is too large for 'long' type
X86GenInstrInfo.inc:2808: error: integer constant is too large for 'long' type
X86GenInstrInfo.inc:2809: error: integer constant is too large for 'long' type
X86GenInstrInfo.inc:2816: error: integer constant is too large for 'long' type
X86GenInstrInfo.inc:2817: error: integer constant is too large for 'long' type
llvm-svn: 105524 | 
| | 
| 
| 
| 
| 
| | yet, only assembly encoding support.
llvm-svn: 105521 | 
| | 
| 
| 
| | llvm-svn: 105344 | 
| | 
| 
| 
| | llvm-svn: 105322 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | A Register with subregisters must also provide SubRegIndices for adressing the
subregisters. TableGen automatically inherits indices for sub-subregisters to
minimize typing.
CompositeIndices may be specified for the weirder cases such as the XMM sub_sd
index that returns the same register, and ARM NEON Q registers where both D
subregs have ssub_0 and ssub_1 sub-subregs.
It is now required that all subregisters are named by an index, and a future
patch will also require inherited subregisters to be named. This is necessary to
allow composite subregister indices to be reduced to a single index.
llvm-svn: 104704 | 
| | 
| 
| 
| 
| 
| | This reverts commit 104654.
llvm-svn: 104660 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | A Register with subregisters must also provide SubRegIndices for adressing the
subregisters. TableGen automatically inherits indices for sub-subregisters to
minimize typing.
CompositeIndices may be specified for the weirder cases such as the XMM sub_sd
index that returns the same register, and ARM NEON Q registers where both D
subregs have ssub_0 and ssub_1 sub-subregs.
It is now required that all subregisters are named by an index, and a future
patch will also require inherited subregisters to be named. This is necessary to
allow composite subregister indices to be reduced to a single index.
llvm-svn: 104654 |