diff options
author | Brian Gaeke <gaeke@uiuc.edu> | 2003-06-18 21:43:21 +0000 |
---|---|---|
committer | Brian Gaeke <gaeke@uiuc.edu> | 2003-06-18 21:43:21 +0000 |
commit | de3aa4f77f511ace5b9fc1e3a777b0c3ec5ffa27 (patch) | |
tree | 53b30b34a061fba3e53f364a17913c226b9f1fff /lib/Target/X86/X86TargetMachine.cpp | |
parent | 8c6bb90b8ef7acad87d3fb7424dce02ee81fedd1 (diff) |
lib/Target/X86/X86TargetMachine.{cpp,h}: Add initial version
(non-working) of llc guts for X86, and add a prototype for it.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@6779 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Target/X86/X86TargetMachine.cpp')
-rw-r--r-- | lib/Target/X86/X86TargetMachine.cpp | 13 |
1 files changed, 13 insertions, 0 deletions
diff --git a/lib/Target/X86/X86TargetMachine.cpp b/lib/Target/X86/X86TargetMachine.cpp index d5a628cb67..1673fffd0c 100644 --- a/lib/Target/X86/X86TargetMachine.cpp +++ b/lib/Target/X86/X86TargetMachine.cpp @@ -41,6 +41,19 @@ X86TargetMachine::X86TargetMachine(unsigned Config) FrameInfo(TargetFrameInfo::StackGrowsDown, 8/*16 for SSE*/, 4) { } +// llc backend for x86 +bool X86TargetMachine::addPassesToEmitAssembly(PassManager &PM, + std::ostream &Out) { + PM.add(createLowerSwitchPass()); + PM.add(createSimpleX86InstructionSelector(*this)); + PM.add(createLocalRegisterAllocator()); + PM.add(createX86FloatingPointStackifierPass()); + PM.add(createPrologEpilogCodeInserter()); + PM.add(createX86PeepholeOptimizerPass()); + PM.add(createX86CodePrinterPass(Out)); + return false; // success! +} + /// addPassesToJITCompile - Add passes to the specified pass manager to /// implement a fast dynamic compiler for this target. Return true if this is /// not supported for this target. |