|  | Commit message (Collapse) | Author | Age | Files | Lines | 
|---|
| ... |  | 
| | 
| 
| 
| 
| 
| | Respond to some feedback asking for a name change.
llvm-svn: 134921 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Manage Inits in a FoldingSet.  This provides several benefits:
- Memory for Inits is properly managed
- Duplicate Inits are folded into Flyweights, saving memory
- It enforces const-correctness, protecting against certain classes
  of bugs
The above benefits allow Inits to be used in more contexts, which in
turn provides more dynamism to TableGen.  This enhanced capability
will be used by the AVX code generator to a fold common patterns
together.
llvm-svn: 134907 | 
| | 
| 
| 
| | llvm-svn: 134563 | 
| | 
| 
| 
| 
| 
| 
| 
| | operands are logically equivalent to existing registers, but happen to be printed specially.  For example, an instruciton that prints d0[0] instead of s0.
Patch by Jim Grosbach.
llvm-svn: 133940 | 
| | 
| 
| 
| 
| 
| 
| | TableGen had diagnostic printers sprinkled about in a few places. Pull them
together into a single location in Error.cpp.
llvm-svn: 133568 | 
| | 
| 
| 
| 
| 
| | matching code.
llvm-svn: 129677 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | kind of predicate: one that is specific to imm nodes.  The predicate function
specified here just checks an int64_t directly instead of messing around with
SDNode's.  The virtue of this is that it means that fastisel and other things
can reason about these predicates.
llvm-svn: 129675 | 
| | 
| 
| 
| 
| 
| 
| 
| | structure and fix some fixmes.  We now have a TreePredicateFn class
that handles all of the decoding of these things.  This is an internal
cleanup that has no impact on the code generated by tblgen.
llvm-svn: 129670 | 
| | 
| 
| 
| 
| 
| 
| | nothing more than a bitcast.
- Teach tablegen to automatically infer "Bitcast" property.
llvm-svn: 127667 | 
| | 
| 
| 
| | llvm-svn: 124869 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | makes type checking for extract_subvector and insert_subvector more
robust and will allow stricter typechecking of more patterns in the
future.
This change handles int and fp as disjoint sets so that it will
enforce integer types to be smaller than the largest integer type and
fp types to be smaller than the largest fp type.  There is no attempt
to check type sizes across the int/fp sets.
llvm-svn: 124672 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | This will be used to check patterns referencing a forthcoming
INSERT_SUBVECTOR SDNode.  INSERT_SUBVECTOR in turn is very useful for
matching to VINSERTF128 instructions and complements the already
existing EXTRACT_SUBVECTOR SDNode.
llvm-svn: 124145 | 
| | 
| 
| 
| | llvm-svn: 122513 | 
| | 
| 
| 
| | llvm-svn: 122337 | 
| | 
| 
| 
| | llvm-svn: 121659 | 
| | 
| 
| 
| | llvm-svn: 121196 | 
| | 
| 
| 
| 
| 
| | CodeGenInstruction into its own helper class.  No functionality change.
llvm-svn: 117893 | 
| | 
| 
| 
| | llvm-svn: 116069 | 
| | 
| 
| 
| | llvm-svn: 116030 | 
| | 
| 
| 
| 
| 
| | to IntrReadWriteArgMem, as it's for reading as well as writing.
llvm-svn: 110395 | 
| | 
| 
| 
| 
| 
| 
| | This is the beginning of purely symbolic subregister indices, but we need a bit
of jiggling before the explicit numeric indices can be completely removed.
llvm-svn: 104492 | 
| | 
| 
| 
| | llvm-svn: 101881 | 
| | 
| 
| 
| | llvm-svn: 101880 | 
| | 
| 
| 
| 
| 
| | comment in the generated table.
llvm-svn: 99794 | 
| | 
| 
| 
| 
| 
| 
| | where an incorrect number of operands is provided to an sdnode instead
of just a few cases.
llvm-svn: 99761 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | and those derived from them.  These are obnoxious because
they were written as: PatLeaf<(bitconvert).  Not having an
argument was foiling adding better type checking for operand
count matching up with what was required (in this case,
bitconvert always requires an operand!)
llvm-svn: 99759 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | transforming it into (add (i32 GPR), 4).  This allows us to write type
generic multi patterns and have tblgen automatically drop the bitconvert
in the case when the types align.  This allows us to fold an extra load
in the changed testcase.
llvm-svn: 99756 | 
| | 
| 
| 
| | llvm-svn: 99747 | 
| | 
| 
| 
| 
| 
| | by rotating it.
llvm-svn: 99746 | 
| | 
| 
| 
| | llvm-svn: 99744 | 
| | 
| 
| 
| 
| 
| 
| 
| | same vt multiple times for a register.  For example,
ECX is in 5 different i32 reg classes, just return 
1 i32 instead of 5.
llvm-svn: 99727 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | from two places in CodeGenDAGPatterns.cpp, and
use it in DAGISelMatcherGen.cpp instead of using
an incorrect predicate that happened to get lucky
on our current targets.
llvm-svn: 99726 | 
| | 
| 
| 
| 
| 
| 
| 
| | results forward.  We can now handle an instruction that 
produces one implicit def and one result instead of one or
the other when not at the root of the pattern.
llvm-svn: 99725 | 
| | 
| 
| 
| | llvm-svn: 99703 | 
| | 
| 
| 
| 
| 
| | in some more places.
llvm-svn: 99366 | 
| | 
| 
| 
| 
| 
| | instead of reimplementing it wrong and poorly.
llvm-svn: 99357 | 
| | 
| 
| 
| | llvm-svn: 99354 | 
| | 
| 
| 
| | llvm-svn: 99353 | 
| | 
| 
| 
| 
| 
| 
| | instead of as a single element list with VoidTy.  Now with a fix
for the verifier.
llvm-svn: 99206 | 
| | 
| 
| 
| | llvm-svn: 99111 | 
| | 
| 
| 
| | llvm-svn: 99011 | 
| | 
| 
| 
| 
| 
| | instead of as a single element list with VoidTy.
llvm-svn: 99009 | 
| | 
| 
| 
| 
| 
| | ApplyTypeConstraint) and make it handle multiple result nodes.
llvm-svn: 99003 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | to maintain a list of types (one for each result of
the node) instead of a single type.  There are liberal
hacks added to emulate the old behavior in various
situations, but they can start disolving now.
llvm-svn: 98999 | 
| | 
| 
| 
| 
| 
| | we don't blow the smallvector as often.  No functionality change.
llvm-svn: 98968 | 
| | 
| 
| 
| 
| 
| | from the pattern if present, and we use it instead of the bit.
llvm-svn: 98938 | 
| | 
| 
| 
| 
| 
| 
| 
| | dag isel gen instead of instruction properties.  This
allows the oh-so-useful behavior of matching a variadic
non-root node.
llvm-svn: 98934 | 
| | 
| 
| 
| | llvm-svn: 98933 | 
| | 
| 
| 
| | llvm-svn: 98927 | 
| | 
| 
| 
| | llvm-svn: 98918 |