|  | Commit message (Collapse) | Author | Age | Files | Lines | 
|---|
| | 
| 
| 
| | llvm-svn: 112571 | 
| | 
| 
| 
| 
| 
| 
| 
| | Fixes potential ambiguity problems on VS 2010.
Patch by nobled!
llvm-svn: 110029 | 
| | 
| 
| 
| | llvm-svn: 109234 | 
| | 
| 
| 
| | llvm-svn: 109122 | 
| | 
| 
| 
| 
| 
| | -enable-no-nans-fp-math and -enable-no-infs-fp-math. All of the current codegen fp math optimizations only care whether the fp arithmetics arguments and results can never be NaN.
llvm-svn: 108465 | 
| | 
| 
| 
| 
| 
| | for consistency sake.
llvm-svn: 107820 | 
| | 
| 
| 
| | llvm-svn: 107710 | 
| | 
| 
| 
| 
| 
| | ensures remat'ed loads from fixed slots have the right alignments.
llvm-svn: 107591 | 
| | 
| 
| 
| 
| 
| | This produces terrible but correct code.
llvm-svn: 106952 | 
| | 
| 
| 
| 
| 
| | is not used.  Spotted by gcc-4.6.
llvm-svn: 106854 | 
| | 
| 
| 
| 
| 
| | as many tests as possible.
llvm-svn: 106749 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | when the condition is constant. This optimization shouldn't be
necessary, because codegen shouldn't be able to find dead control
paths that the IR-level optimizer can't find. And it's undesirable,
because it encourages bugpoint to leave "br i1 false" branches
in its output. And it wasn't updating the CFG.
I updated all the tests I could, but some tests are too reduced
and I wasn't able to meaningfully preserve them.
llvm-svn: 106748 | 
| | 
| 
| 
| | llvm-svn: 106746 | 
| | 
| 
| 
| 
| 
| | DAGCombiner pass,"... it was causing both 'file' (with clang) and 176.gcc (with llvm-gcc) to be miscompiled.
llvm-svn: 106634 | 
| | 
| 
| 
| 
| 
| | SmallVector, and other SmallVector simplifications.
llvm-svn: 106452 | 
| | 
| 
| 
| 
| 
| | the old one.
llvm-svn: 106284 | 
| | 
| 
| 
| 
| 
| 
| | Don't replace the old DbgInfo with a new one when clear() on the
old one is sufficient.
llvm-svn: 106283 | 
| | 
| 
| 
| 
| 
| | SDNode *, since it doesn't care about the ResNo value.
llvm-svn: 106282 | 
| | 
| 
| 
| 
| 
| | which is faster, simpler, and less surprising.
llvm-svn: 106263 | 
| | 
| 
| 
| | llvm-svn: 106256 | 
| | 
| 
| 
| | llvm-svn: 105283 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | that are too large.  This causes the freebsd bootloader to be too
large apparently.
It's unclear if this should be an -Os or -Oz thing.  Thoughts welcome.
llvm-svn: 105228 | 
| | 
| 
| 
| | llvm-svn: 105226 | 
| | 
| 
| 
| 
| 
| 
| | shouldn't have a TargetLoweringInfo member. And FunctionLoweringInfo::set
doesn't needs its EnableFastISel argument.
llvm-svn: 105101 | 
| | 
| 
| 
| 
| 
| | ISD::. No functional change.
llvm-svn: 104734 | 
| | 
| 
| 
| | llvm-svn: 103882 | 
| | 
| 
| 
| 
| 
| 
| 
| | Move EmitTargetCodeForMemcpy, EmitTargetCodeForMemset, and
EmitTargetCodeForMemmove out of TargetLowering and into
SelectionDAGInfo to exercise this.
llvm-svn: 103481 | 
| | 
| 
| 
| 
| 
| | Based on a patch by Javier Martinez.
llvm-svn: 103391 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | getConstantFP to accept the two supported long double
target types.  This was not the original intent, but
there are other places that assume this works and it's
easy enough to do.
llvm-svn: 103299 | 
| | 
| 
| 
| | llvm-svn: 103227 | 
| | 
| 
| 
| 
| 
| 
| 
| | indexes could be of a different value type. Or not even using the same SDNode
for the constant (weird, I know). Compare the actual values instead of the
pointers.
llvm-svn: 102791 | 
| | 
| 
| 
| 
| 
| 
| | produces a comment on targets that support it, but
the Dwarf writer is not hooked up yet.
llvm-svn: 102372 | 
| | 
| 
| 
| 
| 
| 
| | CodeGen's ComputeMaskedBits was being over-conservative when computing
bits for an ADD.
llvm-svn: 101963 | 
| | 
| 
| 
| 
| 
| | fetch one from the MachineFunction.
llvm-svn: 101807 | 
| | 
| 
| 
| | llvm-svn: 101637 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | const_casts, and it reinforces the design of the Target classes being
immutable.
SelectionDAGISel::IsLegalToFold is now a static member function, because
PIC16 uses it in an unconventional way. There is more room for API
cleanup here.
And PIC16's AsmPrinter no longer uses TargetLowering.
llvm-svn: 101635 | 
| | 
| 
| 
| | llvm-svn: 101532 | 
| | 
| 
| 
| | llvm-svn: 101334 | 
| | 
| 
| 
| | llvm-svn: 101010 | 
| | 
| 
| 
| 
| 
| | i32 store of immediates.
llvm-svn: 100751 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | 1. Introduce some enums and accessors in the InlineAsm class
   that eliminate a ton of magic numbers when handling inline
   asm SDNode.
2. Add a new MDNodeSDNode selection dag node type that holds
   a MDNode (shocking!)
3. Add a new argument to ISD::INLINEASM nodes that hold !srcloc
   metadata, propagating it to the instruction emitter, which
   drops it.
No functionality change.
llvm-svn: 100605 | 
| | 
| 
| 
| | llvm-svn: 100521 | 
| | 
| 
| 
| | llvm-svn: 100494 | 
| | 
| 
| 
| | llvm-svn: 100459 | 
| | 
| 
| 
| 
| 
| | PR6779
llvm-svn: 100457 | 
| | 
| 
| 
| | llvm-svn: 100419 | 
| | 
| 
| 
| | llvm-svn: 100417 | 
| | 
| 
| 
| | llvm-svn: 100382 | 
| | 
| 
| 
| 
| 
| 
| | Added support for address spaces and added a isVolatile field to memcpy, memmove, and memset,
e.g., llvm.memcpy.i32(i8*, i8*, i32, i32) -> llvm.memcpy.p0i8.p0i8.i32(i8*, i8*, i32, i32, i1)
llvm-svn: 100304 | 
| | 
| 
| 
| | llvm-svn: 100215 |