|  | Commit message (Collapse) | Author | Age | Files | Lines | 
|---|
| ... |  | 
| | 
| 
| 
| 
| 
| | the current function on its own, rather than relying on the SelectionDAG.
llvm-svn: 59277 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | to carry a SmallVector of flagged nodes, just calculate the flagged nodes
dynamically when they are needed.
The local-liveness change is due to a trivial scheduling change where
the scheduler arbitrary decision differently.
llvm-svn: 59273 | 
| | 
| 
| 
| | llvm-svn: 59264 | 
| | 
| 
| 
| 
| 
| | for the possibility of scheduling without a SelectionDAG being present.
llvm-svn: 59263 | 
| | 
| 
| 
| 
| 
| | instead.
llvm-svn: 58290 | 
| | 
| 
| 
| 
| 
| | will be used to support debug features in TableGen.
llvm-svn: 58257 | 
| | 
| 
| 
| | llvm-svn: 57770 | 
| | 
| 
| 
| | llvm-svn: 56399 | 
| | 
| 
| 
| 
| 
| | Apologies for the thrashing.
llvm-svn: 56251 | 
| | 
| 
| 
| | llvm-svn: 56250 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | - Add linkage to SymbolSDNode (default to external).
- Change ISD::ExternalSymbol to ISD::Symbol.
- Change ISD::TargetExternalSymbol to ISD::TargetSymbol
These changes pave the way to allowing SymbolSDNodes with non-external linkage.
llvm-svn: 56249 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Currently it just holds the calling convention and flags
for isVarArgs and isTailCall.
And it has several utility methods, which eliminate magic
5+2*i and similar index computations in several places.
CallSDNodes are not CSE'd. Teach UpdateNodeOperands to handle
nodes that are not CSE'd gracefully.
llvm-svn: 56183 | 
| | 
| 
| 
| 
| 
| 
| | with ConstantInt. This led to fixing a bug in TargetLowering.cpp
using getValue instead of getAPIntValue.
llvm-svn: 56159 | 
| | 
| 
| 
| 
| 
| | Node to reflect semantics
llvm-svn: 55504 | 
| | 
| 
| 
| | llvm-svn: 55394 | 
| | 
| 
| 
| 
| 
| | really nice if someone converted MachineFunction::print to raw_ostream.
llvm-svn: 55268 | 
| | 
| 
| 
| 
| 
| | it isn't always visible to gdb.
llvm-svn: 54228 | 
| | 
| 
| 
| 
| 
| | the SelectionDAG's.
llvm-svn: 54129 | 
| | 
| 
| 
| | llvm-svn: 54128 | 
| | 
| 
| 
| 
| 
| 
| | and use the right result number, in the off chance that the graph root
has multiple result values.
llvm-svn: 53923 | 
| | 
| 
| 
| 
| 
| 
| 
| | SelectionDAG graph writer to make use of them. Now, nodes with multiple
values are displayed as such, with incoming edges pointing to the
specific value they use.
llvm-svn: 53875 | 
| | 
| 
| 
| 
| 
| 
| | that include useful information like the name of the
block being viewed and the current phase of compilation.
llvm-svn: 53872 | 
| | 
| 
| 
| | llvm-svn: 53772 | 
| | 
| 
| 
| 
| 
| 
| 
| | PseudoSourceValue values, which never have names. Use getName()
for all other values, because we want to print just a short summary
of the value, not the entire instruction.
llvm-svn: 53738 | 
| | 
| 
| 
| 
| 
| 
| | don't have value names, so use print instead of getName() to get a
useful string.
llvm-svn: 53563 | 
| | 
| 
| 
| 
| 
| | slow the compiler down at -O0 some 30% or more. Ooops.
llvm-svn: 53120 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | the need for a flavor operand, and add a new SDNode subclass,
LabelSDNode, for use with them to eliminate the need for a label id
operand.
Change instruction selection to let these label nodes through
unmodified instead of creating copies of them. Teach the MachineInstr
emitter how to emit a MachineInstr directly from an ISD label node.
This avoids the need for allocating SDNodes for the label id and
flavor value, as well as SDNodes for each of the post-isel label,
label id, and label flavor.
llvm-svn: 52943 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | purpose, and give it a custom SDNode subclass so that it doesn't
need to have line number, column number, filename string, and
directory string, all existing as individual SDNodes to be the
operands.
This was the only user of ISD::STRING, StringSDNode, etc., so
remove those and some associated code.
This makes stop-points considerably easier to read in
-view-legalize-dags output, and reduces overhead (creating new
nodes and copying std::strings into them) on code containing
debugging information.
llvm-svn: 52924 | 
| | 
| 
| 
| 
| 
| 
| | field, which is otherwise unused after instruction selection, as an index
into the SUnit array.
llvm-svn: 52583 | 
| | 
| 
| 
| 
| 
| 
| 
| | to DenseMap<SDNode*, SUnit*>, and adjust the way cloned SUnit nodes are
handled so that only the original node needs to be in the map.
This speeds up llc on 447.dealII.llvm.bc by about 2%.
llvm-svn: 52576 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | and better control the abstraction.  Rename the type
to MVT.  To update out-of-tree patches, the main
thing to do is to rename MVT::ValueType to MVT, and
rewrite expressions like MVT::getSizeInBits(VT) in
the form VT.getSizeInBits().  Use VT.getSimpleVT()
to extract a MVT::SimpleValueType for use in switch
statements (you will get an assert failure if VT is
an extended value type - these shouldn't exist after
type legalization).
This results in a small speedup of codegen and no
new testsuite failures (x86-64 linux).
llvm-svn: 52044 | 
| | 
| 
| 
| 
| 
| | empty ScheduleDAG.
llvm-svn: 50054 | 
| | 
| 
| 
| 
| 
| | instead of blue to distinguish them from regular dependencies.
llvm-svn: 49696 | 
| | 
| 
| 
| | llvm-svn: 48664 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | flags.  This is needed by the new legalize types
infrastructure which wants to expand the 64 bit
constants previously used to hold the flags on
32 bit machines.  There are two functional changes:
(1) in LowerArguments, if a parameter has the zext
attribute set then that is marked in the flags;
before it was being ignored; (2) PPC had some bogus
code for handling two word arguments when using the
ELF 32 ABI, which was hard to convert because of
the bogusness.  As suggested by the original author
(Nicolas Geoffray), I've disabled it for the moment.
Tested with "make check" and the Ada ACATS testsuite.
llvm-svn: 48640 | 
| | 
| 
| 
| | llvm-svn: 47663 | 
| | 
| 
| 
| | llvm-svn: 47629 | 
| | 
| 
| 
| 
| 
| | would have been a Godsend here!
llvm-svn: 47625 | 
| | 
| 
| 
| | llvm-svn: 46930 | 
| | 
| 
| 
| 
| 
| 
| 
| | initializer problem, a minor tweak to the way the
DAGISelEmitter finds load/store nodes, and a renaming of the
new PseudoSourceValue objects.
llvm-svn: 46827 | 
| | 
| 
| 
| 
| 
| | re-commit.
llvm-svn: 46623 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | in the backend. Introduce a new SDNode type, MemOperandSDNode, for
holding a MemOperand in the SelectionDAG IR, and add a MemOperand
list to MachineInstr, and code to manage them. Remove the offset
field from SrcValueSDNode; uses of SrcValueSDNode that were using
it are all all using MemOperandSDNode now.
Also, begin updating some getLoad and getStore calls to use the
PseudoSourceValue objects.
Most of this was written by Florian Brander, some
reorganization and updating to TOT by me.
llvm-svn: 46585 | 
| | 
| 
| 
| 
| 
| 
| 
| | and StoreSDNode into their common base class LSBaseSDNode. Member
functions getLoadedVT and getStoredVT are replaced with the common
getMemoryVT to simplify code that will handle both loads and stores.
llvm-svn: 46538 | 
| | 
| 
| 
| | llvm-svn: 46347 | 
| | 
| 
| 
| | llvm-svn: 45418 | 
| | 
| 
| 
| | llvm-svn: 42978 | 
| | 
| 
| 
| 
| 
| | physical register dependency. The BURR scheduler can now backtrace and duplicate instructions in order to avoid "expensive / impossible to copy" values (e.g. status flag EFLAGS for x86) from being clobbered.
llvm-svn: 42284 | 
| | 
| 
| 
| 
| 
| | in tracking physical register output dependencies.
llvm-svn: 42125 | 
| | 
| 
| 
| 
| 
| 
| | Use APFloat interfaces for more references, mostly
of ConstantFPSDNode.
llvm-svn: 41632 | 
| | 
| 
| 
| 
| 
| | scheduling.
llvm-svn: 41556 |