Let tblgen only generate fastisel routines, not the class definition. This makes...
[oota-llvm.git] / lib / Target / X86 / X86FastISel.cpp
1 //===-- X86FastISel.cpp - X86 FastISel implementation ---------------------===//
2 //
3 //                     The LLVM Compiler Infrastructure
4 //
5 // This file is distributed under the University of Illinois Open Source
6 // License. See LICENSE.TXT for details.
7 //
8 //===----------------------------------------------------------------------===//
9 //
10 // This file defines the X86-specific support for the FastISel class. Much
11 // of the target-specific code is generated by tablegen in the file
12 // X86GenFastISel.inc, which is #included here.
13 //
14 //===----------------------------------------------------------------------===//
15
16 #include "X86.h"
17 #include "X86RegisterInfo.h"
18 #include "X86ISelLowering.h"
19 #include "X86TargetMachine.h"
20 #include "llvm/CodeGen/FastISel.h"
21 #include "llvm/CodeGen/MachineRegisterInfo.h"
22
23 using namespace llvm;
24
25 class X86FastISel : public FastISel {
26   /// Subtarget - Keep a pointer to the X86Subtarget around so that we can
27   /// make the right decision when generating code for different targets.
28   const X86Subtarget *Subtarget;
29     
30  public:
31   explicit X86FastISel(MachineFunction &mf) : FastISel(mf) {}
32
33   virtual bool
34     TargetSelectInstruction(Instruction *I,
35                             DenseMap<const Value *, unsigned> &ValueMap,
36                       DenseMap<const BasicBlock *, MachineBasicBlock *> &MBBMap,
37                             MachineBasicBlock *MBB);
38
39 #include "X86GenFastISel.inc"
40 };
41
42 bool
43 X86FastISel::TargetSelectInstruction(Instruction *I,
44                                   DenseMap<const Value *, unsigned> &ValueMap,
45                       DenseMap<const BasicBlock *, MachineBasicBlock *> &MBBMap,
46                                   MachineBasicBlock *MBB)  {
47   switch (I->getOpcode()) {
48   default: break;
49   }
50
51   return false;
52 }
53
54 namespace llvm {
55   llvm::FastISel *X86::createFastISel(MachineFunction &mf) {
56     return new X86FastISel(mf);
57   }
58 }