|  | Commit message (Collapse) | Author | Age | Files | Lines | 
|---|
| | 
| 
| 
| 
| 
| | This reverts commit 494f7ac3e8d2ab3d94e52317abf9c42a949fe1f3.
llvm-svn: 142455 | 
| | 
| 
| 
| 
| 
| | I'll remove/rename the option in a few days.
llvm-svn: 142439 | 
| | 
| 
| 
| | llvm-svn: 141988 | 
| | 
| 
| 
| | llvm-svn: 141616 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | promoting allocas to preferred alignments that exceed the natural
alignment. This avoids some potentially expensive dynamic stack realignments.
The natural stack alignment is set in target data strings via the "S<size>"
option. Size is in bits and must be a multiple of 8. The natural stack alignment
defaults to "unspecified" (represented by a zero value), and the "unspecified"
value does not prevent any alignment promotions. Target maintainers that care
about avoiding promotions should explicitly add the "S<size>" option to their
target data strings.
llvm-svn: 141599 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | This also enables domain swizzling for AVX code which required a few
trivial test changes.
The pass will be moved to lib/CodeGen shortly.
llvm-svn: 140659 | 
| | 
| 
| 
| | llvm-svn: 139816 | 
| | 
| 
| 
| | llvm-svn: 139079 | 
| | 
| 
| 
| 
| 
| | These are strictly utilities for registering targets and components.
llvm-svn: 138450 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | SSE transition penalty. The pass is enabled through the "x86-use-vzeroupper"
llc command line option. This is only the first step (very naive and
conservative one) to sketch out the idea, but proper DFA is coming next
to allow smarter decisions. Comments and ideas now and in further commits
will be very appreciated.
llvm-svn: 138317 | 
| | 
| 
| 
| | llvm-svn: 135939 | 
| | 
| 
| 
| 
| 
| 
| 
| | - Introduce JITDefault code model. This tells targets to set different default
  code model for JIT. This eliminates the ugly hack in TargetMachine where
  code model is changed after construction.
llvm-svn: 135580 | 
| | 
| 
| 
| 
| 
| 
| | (including compilation, assembly). Move relocation model Reloc::Model from
TargetMachine to MCCodeGenInfo so it's accessible even without TargetMachine.
llvm-svn: 135468 | 
| | 
| 
| 
| 
| 
| | MCTargetDesc to prepare for next round of changes.
llvm-svn: 135219 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | and MCSubtargetInfo.
- Added methods to update subtarget features (used when targets automatically
  detect subtarget features or switch modes).
- Teach X86Subtarget to update MCSubtargetInfo features bits since the
  MCSubtargetInfo layer can be shared with other modules.
- These fixes .code 16 / .code 32 support since mode switch is updated in
  MCSubtargetInfo so MC code emitter can do the right thing.
llvm-svn: 134884 | 
| | 
| 
| 
| 
| 
| | specified.
llvm-svn: 134757 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | - Each target asm parser now creates its own MCSubtatgetInfo (if needed).
- Changed AssemblerPredicate to take subtarget features which tablegen uses
  to generate asm matcher subtarget feature queries. e.g.
  "ModeThumb,FeatureThumb2" is translated to
  "(Bits & ModeThumb) != 0 && (Bits & FeatureThumb2) != 0".
llvm-svn: 134678 | 
| | 
| 
| 
| | llvm-svn: 134641 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | be the first encoded as the first feature. It then uses the CPU name to look up
features / scheduling itineray even though clients know full well the CPU name
being used to query these properties.
The fix is to just have the clients explictly pass the CPU name!
llvm-svn: 134127 | 
| | 
| 
| 
| | llvm-svn: 133739 | 
| | 
| 
| 
| | llvm-svn: 133726 | 
| | 
| 
| 
| 
| 
| | converting the symbol passed to .cfi_personality into bytes is the file.
llvm-svn: 130400 | 
| | 
| 
| 
| 
| 
| | predicates.
llvm-svn: 129816 | 
| | 
| 
| 
| | llvm-svn: 126780 | 
| | 
| 
| 
| 
| 
| | No one uses *-mingw64. mingw-w64 is represented as {i686|x86_64}-w64-mingw32. In llvm side, i686 and x64 can be treated as similar way.
llvm-svn: 125747 | 
| | 
| 
| 
| | llvm-svn: 125746 | 
| | 
| 
| 
| | llvm-svn: 124639 | 
| | 
| 
| 
| | llvm-svn: 124077 | 
| | 
| 
| 
| 
| 
| | and fixes here and there.
llvm-svn: 123170 | 
| | 
| 
| 
| | llvm-svn: 119754 | 
| | 
| 
| 
| 
| 
| | out of TargetRegisterInfo to TargetFrameInfo, which is definitely much better suitable place
llvm-svn: 119097 | 
| | 
| 
| 
| | llvm-svn: 116083 | 
| | 
| 
| 
| 
| 
| | Patch by Cameron!
llvm-svn: 115480 | 
| | 
| 
| 
| 
| 
| 
| 
| | so and also change X86 for consistency.
Investigating if this can be improved a bit.
llvm-svn: 115469 | 
| | 
| 
| 
| 
| 
| | defaults to small pic code model.
llvm-svn: 111741 | 
| | 
| 
| 
| | llvm-svn: 111173 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | target.
- The COFF backend doesn't support MingW/Cygwin at the moment, it'll report an
  error, but it's still much better than random assertions from the MachO backend.
- We want to make ELF the default eventually, it's what the majority of targets use.
llvm-svn: 110197 | 
| | 
| 
| 
| | llvm-svn: 109947 | 
| | 
| 
| 
| | llvm-svn: 109494 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | pass that inserted it.
It is no longer necessary to limit the live ranges of FP registers to a single
basic block.
llvm-svn: 108536 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | FP_REG_KILL instructions are still inserted, but can be disabled by passing
-live-x87 to llc. The X87FPRegKillInserterPass is going to be removed shortly.
CFG edges are partioned into bundles where the x87 stack must be allocated
identically. Code is insertad at the end of each basic block that shuffles the
live FP registers to match the outgoing bundles expectations.
This fix is in preparation for some upcoming register allocator improvements
that may extend the live range of registers beyond a basic block, similar to
LICM. It also provides a nice runtime speedup if you are building with
-mfpmath=387.
llvm-svn: 108529 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | - Check getBytesToPopOnReturn().
 - Eschew ST0 and ST1 for return values.
 - Fix the PIC base register initialization so that it doesn't ever
   fail to end up the top of the entry block.
llvm-svn: 108039 | 
| | 
| 
| 
| 
| 
| 
| | 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 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | isn't ideal if we want to be able to use another object file format.
Add a createObjectStreamer() factory method so that the correct object
file streamer can be instantiated for a given target triple.
llvm-svn: 104318 | 
| | 
| 
| 
| 
| 
| 
| 
| | Move EmitTargetCodeForMemcpy, EmitTargetCodeForMemset, and
EmitTargetCodeForMemmove out of TargetLowering and into
SelectionDAGInfo to exercise this.
llvm-svn: 103481 | 
| | 
| 
| 
| 
| 
| | hack the code to turn it off when debugging.
llvm-svn: 103083 | 
| | 
| 
| 
| | llvm-svn: 102941 | 
| | 
| 
| 
| | llvm-svn: 101978 |