|  | Commit message (Collapse) | Author | Age | Files | Lines | 
|---|
| ... |  | 
| | 
| 
| 
| | llvm-svn: 104463 | 
| | 
| 
| 
| | llvm-svn: 104029 | 
| | 
| 
| 
| 
| 
| 
| | -filetype=obj test, and -filetype=obj leaks a few objects. Added a FIXME, we
need to sort out the ownership model for the various MC objects.
llvm-svn: 103769 | 
| | 
| 
| 
| 
| 
| | than just getting one through a TargetLowering.
llvm-svn: 101802 | 
| | 
| 
| 
| | llvm-svn: 101622 | 
| | 
| 
| 
| | llvm-svn: 101023 | 
| | 
| 
| 
| 
| 
| | It is not ready for public yet.
llvm-svn: 100673 | 
| | 
| 
| 
| | llvm-svn: 100640 | 
| | 
| 
| 
| | llvm-svn: 100592 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | "asm printering" happens through MCStreamer.  This also 
Streamerizes PIC16 debug info, which escaped my attention.
This removes a leak from LLVMTargetMachine of the 'legacy'
output stream.
llvm-svn: 100327 | 
| | 
| 
| 
| 
| 
| 
| 
| | raw_ostream to print an instruction to had to be specified
at MCInstPrinter construction time instead of being able
to pick at each call to printInstruction.
llvm-svn: 100307 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | and passing off ownership to AsmPrinter.  Now MachineModuleInfo
creates it and owns it by value.  This allows us to use MCSymbols
more consistently throughout the rest of the code generator, and
simplifies a bit of code.  This also allows MachineFunction to 
keep an MCContext reference handy, and cleans up the TargetRegistry
interfaces for AsmPrinters.
llvm-svn: 98450 | 
| | 
| 
| 
| 
| 
| | No functionality change.
llvm-svn: 98363 | 
| | 
| 
| 
| 
| 
| | can get it from the context now.
llvm-svn: 98361 | 
| | 
| 
| 
| | llvm-svn: 98293 | 
| | 
| 
| 
| | llvm-svn: 98222 | 
| | 
| 
| 
| | llvm-svn: 98132 | 
| | 
| 
| 
| | llvm-svn: 98045 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | coalescer) handle sub-register classes.
- Add heuristics to avoid non-profitable cse. Given the current lack of live
  range splitting, avoid cse when an expression has PHI use and the would be
  new use is in a BB where the expression wasn't already being used.
llvm-svn: 98043 | 
| | 
| 
| 
| 
| 
| | post-ra scheduler has run. Disable the verifier checks that late in the game.
llvm-svn: 97837 | 
| | 
| 
| 
| | llvm-svn: 97752 | 
| | 
| 
| 
| | llvm-svn: 97713 | 
| | 
| 
| 
| | llvm-svn: 97627 | 
| | 
| 
| 
| 
| 
| | after LSR, so that clients can opt in.
llvm-svn: 97357 | 
| | 
| 
| 
| | llvm-svn: 97235 | 
| | 
| 
| 
| 
| 
| 
| 
| | phi cycles.  Adjust a few tests to keep dead instructions from being optimized
away.  This (together with my previous change for phi cycles) fixes Apple
radar 7627077.
llvm-svn: 96057 | 
| | 
| 
| 
| | llvm-svn: 96038 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | bug fixes, and with improved heuristics for analyzing foreign-loop
addrecs.
This change also flattens IVUsers, eliminating the stride-oriented
groupings, which makes it easier to work with.
llvm-svn: 95975 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | reduce down to a single value.  InstCombine already does this transformation
but DAG legalization may introduce new opportunities.  This has turned out to
be important for ARM where 64-bit values are split up during type legalization:
InstCombine is not able to remove the PHI cycles on the 64-bit values but
the separate 32-bit values can be optimized.  I measured the compile time 
impact of this (running llc on 176.gcc) and it was not significant.
llvm-svn: 95951 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | only run for x86 with fastisel. I've found it being very effective in
eliminating some obvious dead code as result of formal parameter lowering
especially when tail call optimization eliminated the need for some of the loads
from fixed frame objects. It also shrinks a number of the tests. A couple of
tests no longer make sense and are now eliminated.
llvm-svn: 95493 | 
| | 
| 
| 
| 
| 
| 
| | add -filetype=null for performance testing and remove -filetype=dynlib,
which isn't planned to be implemented.
llvm-svn: 95202 | 
| | 
| 
| 
| | llvm-svn: 95168 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | stderr if in filetype=obj mode.  This is a hack, and will
live until dwarf emission and other random stuff that is
not yet going through MCStreamer is upgraded.  It only
impacts filetype=obj mode.
llvm-svn: 95166 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | $ cat t.ll 
@g = global i32 42
$ llc t.ll -o t.o -filetype=obj
$ nm t.o
00000000 D _g
There is still a ton of work left.  Instructions are not being encoded
yet apparently.
llvm-svn: 95162 | 
| | 
| 
| 
| | llvm-svn: 95156 | 
| | 
| 
| 
| 
| 
| 
| | mccontext instead of having AsmPrinter do it.  This allows other 
types of MCStreamer's to be passed in.
llvm-svn: 95155 | 
| | 
| 
| 
| | llvm-svn: 95153 | 
| | 
| 
| 
| 
| 
| | LLVMTargetMachine.cpp with the rest of the command line options.
llvm-svn: 95152 | 
| | 
| 
| 
| 
| 
| 
| | Now the only use of the ELF writer is the JIT, which won't be
easy to fix in the short term. :( :(
llvm-svn: 95148 | 
| | 
| 
| 
| 
| 
| 
| | of the code generator shouldn't care what object format a target
uses.
llvm-svn: 95124 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | the one used by the JIT.  Remove all forms of
addPassesToEmitFileFinish except the one used by the static
code generator.  Inline the remaining version of
addPassesToEmitFileFinish into its only caller.
llvm-svn: 95109 | 
| | 
| 
| 
| 
| 
| 
| | the -print-emitted-asm option.  The JIT shouldn't have to pull
in the asmprinter.
llvm-svn: 95100 | 
| | 
| 
| 
| 
| 
| | The MCStreamer based assemblers will take over for this functionality.
llvm-svn: 95033 | 
| | 
| 
| 
| 
| 
| 
| | LoopStrengthReduce, as it's causing too much trouble (even with the
old LoopStrengthReduce code).
llvm-svn: 94172 | 
| | 
| 
| 
| 
| 
| | they reach codegen.
llvm-svn: 94066 | 
| | 
| 
| 
| 
| 
| 
| | the -pre-regalloc-taildup command-line option, and add a new
-disable-early-taildup option.
llvm-svn: 93597 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | Remove most of old Mach-O Writer support, it has been replaced by MCMachOStreamer
Further refactoring to completely remove MachOWriter and drive the object file
writer with the AsmPrinter MCInst/MCSection logic is forthcoming.
llvm-svn: 93527 | 
| | 
| 
| 
| | llvm-svn: 93459 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | catch info can get misplaced when a selector ends up more than one block
removed from the parent invoke(s). This could happen when a landing pad is
shared by multiple invokes and is also a target of a normal edge from
elsewhere.
llvm-svn: 93456 | 
| | 
| 
| 
| | llvm-svn: 93313 |