XCoreTargetMachine.h revision 439661395fd2a2a832dba01c65bc88718528313c
1b25baef26f03b9909b65dd5f762b38f93000445dRichard Osborne//===-- XCoreTargetMachine.h - Define TargetMachine for XCore ---*- C++ -*-===//
2b25baef26f03b9909b65dd5f762b38f93000445dRichard Osborne//
3b25baef26f03b9909b65dd5f762b38f93000445dRichard Osborne//                     The LLVM Compiler Infrastructure
4b25baef26f03b9909b65dd5f762b38f93000445dRichard Osborne//
5b25baef26f03b9909b65dd5f762b38f93000445dRichard Osborne// This file is distributed under the University of Illinois Open Source
6b25baef26f03b9909b65dd5f762b38f93000445dRichard Osborne// License. See LICENSE.TXT for details.
7b25baef26f03b9909b65dd5f762b38f93000445dRichard Osborne//
8b25baef26f03b9909b65dd5f762b38f93000445dRichard Osborne//===----------------------------------------------------------------------===//
9b25baef26f03b9909b65dd5f762b38f93000445dRichard Osborne//
10b25baef26f03b9909b65dd5f762b38f93000445dRichard Osborne// This file declares the XCore specific subclass of TargetMachine.
11b25baef26f03b9909b65dd5f762b38f93000445dRichard Osborne//
12b25baef26f03b9909b65dd5f762b38f93000445dRichard Osborne//===----------------------------------------------------------------------===//
13b25baef26f03b9909b65dd5f762b38f93000445dRichard Osborne
14b25baef26f03b9909b65dd5f762b38f93000445dRichard Osborne#ifndef XCORETARGETMACHINE_H
15b25baef26f03b9909b65dd5f762b38f93000445dRichard Osborne#define XCORETARGETMACHINE_H
16b25baef26f03b9909b65dd5f762b38f93000445dRichard Osborne
17b25baef26f03b9909b65dd5f762b38f93000445dRichard Osborne#include "llvm/Target/TargetMachine.h"
18b25baef26f03b9909b65dd5f762b38f93000445dRichard Osborne#include "llvm/Target/TargetData.h"
1916c29b5f285f375be53dabaa73e3e91107485fe4Anton Korobeynikov#include "XCoreFrameLowering.h"
20b25baef26f03b9909b65dd5f762b38f93000445dRichard Osborne#include "XCoreSubtarget.h"
21b25baef26f03b9909b65dd5f762b38f93000445dRichard Osborne#include "XCoreInstrInfo.h"
22b25baef26f03b9909b65dd5f762b38f93000445dRichard Osborne#include "XCoreISelLowering.h"
23ff7a562751604a9fe13efc75bd59622244b54d35Dan Gohman#include "XCoreSelectionDAGInfo.h"
24b25baef26f03b9909b65dd5f762b38f93000445dRichard Osborne
25b25baef26f03b9909b65dd5f762b38f93000445dRichard Osbornenamespace llvm {
26b25baef26f03b9909b65dd5f762b38f93000445dRichard Osborne
27b25baef26f03b9909b65dd5f762b38f93000445dRichard Osborneclass XCoreTargetMachine : public LLVMTargetMachine {
28b25baef26f03b9909b65dd5f762b38f93000445dRichard Osborne  XCoreSubtarget Subtarget;
29b25baef26f03b9909b65dd5f762b38f93000445dRichard Osborne  const TargetData DataLayout;       // Calculates type size & alignment
30b25baef26f03b9909b65dd5f762b38f93000445dRichard Osborne  XCoreInstrInfo InstrInfo;
3116c29b5f285f375be53dabaa73e3e91107485fe4Anton Korobeynikov  XCoreFrameLowering FrameLowering;
32b25baef26f03b9909b65dd5f762b38f93000445dRichard Osborne  XCoreTargetLowering TLInfo;
33ff7a562751604a9fe13efc75bd59622244b54d35Dan Gohman  XCoreSelectionDAGInfo TSInfo;
34b25baef26f03b9909b65dd5f762b38f93000445dRichard Osbornepublic:
35439661395fd2a2a832dba01c65bc88718528313cEvan Cheng  XCoreTargetMachine(const Target &T, StringRef TT,
36439661395fd2a2a832dba01c65bc88718528313cEvan Cheng                     StringRef CPU, StringRef FS, Reloc::Model RM);
37b25baef26f03b9909b65dd5f762b38f93000445dRichard Osborne
38b25baef26f03b9909b65dd5f762b38f93000445dRichard Osborne  virtual const XCoreInstrInfo *getInstrInfo() const { return &InstrInfo; }
3916c29b5f285f375be53dabaa73e3e91107485fe4Anton Korobeynikov  virtual const XCoreFrameLowering *getFrameLowering() const {
4016c29b5f285f375be53dabaa73e3e91107485fe4Anton Korobeynikov    return &FrameLowering;
4116c29b5f285f375be53dabaa73e3e91107485fe4Anton Korobeynikov  }
42b25baef26f03b9909b65dd5f762b38f93000445dRichard Osborne  virtual const XCoreSubtarget *getSubtargetImpl() const { return &Subtarget; }
43d858e90f039f5fcdc2fa93035e911a5a9505cc50Dan Gohman  virtual const XCoreTargetLowering *getTargetLowering() const {
44d858e90f039f5fcdc2fa93035e911a5a9505cc50Dan Gohman    return &TLInfo;
45b25baef26f03b9909b65dd5f762b38f93000445dRichard Osborne  }
46b25baef26f03b9909b65dd5f762b38f93000445dRichard Osborne
47ff7a562751604a9fe13efc75bd59622244b54d35Dan Gohman  virtual const XCoreSelectionDAGInfo* getSelectionDAGInfo() const {
48ff7a562751604a9fe13efc75bd59622244b54d35Dan Gohman    return &TSInfo;
49ff7a562751604a9fe13efc75bd59622244b54d35Dan Gohman  }
50ff7a562751604a9fe13efc75bd59622244b54d35Dan Gohman
51b25baef26f03b9909b65dd5f762b38f93000445dRichard Osborne  virtual const TargetRegisterInfo *getRegisterInfo() const {
52b25baef26f03b9909b65dd5f762b38f93000445dRichard Osborne    return &InstrInfo.getRegisterInfo();
53b25baef26f03b9909b65dd5f762b38f93000445dRichard Osborne  }
54b25baef26f03b9909b65dd5f762b38f93000445dRichard Osborne  virtual const TargetData       *getTargetData() const { return &DataLayout; }
55b25baef26f03b9909b65dd5f762b38f93000445dRichard Osborne
56b25baef26f03b9909b65dd5f762b38f93000445dRichard Osborne  // Pass Pipeline Configuration
5798a366d547772010e94609e4584489b3e5ce0043Bill Wendling  virtual bool addInstSelector(PassManagerBase &PM, CodeGenOpt::Level OptLevel);
58b25baef26f03b9909b65dd5f762b38f93000445dRichard Osborne};
59b25baef26f03b9909b65dd5f762b38f93000445dRichard Osborne
60b25baef26f03b9909b65dd5f762b38f93000445dRichard Osborne} // end namespace llvm
61b25baef26f03b9909b65dd5f762b38f93000445dRichard Osborne
62b25baef26f03b9909b65dd5f762b38f93000445dRichard Osborne#endif
63