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
1716c29b5f285f375be53dabaa73e3e91107485fe4Anton Korobeynikov#include "XCoreFrameLowering.h"
18b25baef26f03b9909b65dd5f762b38f93000445dRichard Osborne#include "XCoreISelLowering.h"
19a1514e24cc24b050f53a12650e047799358833a1Chandler Carruth#include "XCoreInstrInfo.h"
20ff7a562751604a9fe13efc75bd59622244b54d35Dan Gohman#include "XCoreSelectionDAGInfo.h"
21a1514e24cc24b050f53a12650e047799358833a1Chandler Carruth#include "XCoreSubtarget.h"
220b8c9a80f20772c3793201ab5b251d3520b9cea3Chandler Carruth#include "llvm/IR/DataLayout.h"
2379aa3417eb6f58d668aadfedf075240a41d35a26Craig Topper#include "llvm/Target/TargetMachine.h"
24b25baef26f03b9909b65dd5f762b38f93000445dRichard Osborne
25b25baef26f03b9909b65dd5f762b38f93000445dRichard Osbornenamespace llvm {
26b25baef26f03b9909b65dd5f762b38f93000445dRichard Osborne
27b25baef26f03b9909b65dd5f762b38f93000445dRichard Osborneclass XCoreTargetMachine : public LLVMTargetMachine {
28b25baef26f03b9909b65dd5f762b38f93000445dRichard Osborne  XCoreSubtarget Subtarget;
293574eca1b02600bac4e625297f4ecf745f4c4f32Micah Villmow  const DataLayout DL;       // 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,
368a8d479214745c82ef00f08d4e4f1c173b5f9ce2Nick Lewycky                     StringRef CPU, StringRef FS, const TargetOptions &Options,
37b95fc31aa2e5a0a0b9ee1909d1cb949577c5aa16Evan Cheng                     Reloc::Model RM, CodeModel::Model CM,
38b95fc31aa2e5a0a0b9ee1909d1cb949577c5aa16Evan Cheng                     CodeGenOpt::Level OL);
39b25baef26f03b9909b65dd5f762b38f93000445dRichard Osborne
40b25baef26f03b9909b65dd5f762b38f93000445dRichard Osborne  virtual const XCoreInstrInfo *getInstrInfo() const { return &InstrInfo; }
4116c29b5f285f375be53dabaa73e3e91107485fe4Anton Korobeynikov  virtual const XCoreFrameLowering *getFrameLowering() const {
4216c29b5f285f375be53dabaa73e3e91107485fe4Anton Korobeynikov    return &FrameLowering;
4316c29b5f285f375be53dabaa73e3e91107485fe4Anton Korobeynikov  }
44b25baef26f03b9909b65dd5f762b38f93000445dRichard Osborne  virtual const XCoreSubtarget *getSubtargetImpl() const { return &Subtarget; }
45d858e90f039f5fcdc2fa93035e911a5a9505cc50Dan Gohman  virtual const XCoreTargetLowering *getTargetLowering() const {
46d858e90f039f5fcdc2fa93035e911a5a9505cc50Dan Gohman    return &TLInfo;
47b25baef26f03b9909b65dd5f762b38f93000445dRichard Osborne  }
48b25baef26f03b9909b65dd5f762b38f93000445dRichard Osborne
49ff7a562751604a9fe13efc75bd59622244b54d35Dan Gohman  virtual const XCoreSelectionDAGInfo* getSelectionDAGInfo() const {
50ff7a562751604a9fe13efc75bd59622244b54d35Dan Gohman    return &TSInfo;
51ff7a562751604a9fe13efc75bd59622244b54d35Dan Gohman  }
52ff7a562751604a9fe13efc75bd59622244b54d35Dan Gohman
53b25baef26f03b9909b65dd5f762b38f93000445dRichard Osborne  virtual const TargetRegisterInfo *getRegisterInfo() const {
54b25baef26f03b9909b65dd5f762b38f93000445dRichard Osborne    return &InstrInfo.getRegisterInfo();
55b25baef26f03b9909b65dd5f762b38f93000445dRichard Osborne  }
563574eca1b02600bac4e625297f4ecf745f4c4f32Micah Villmow  virtual const DataLayout       *getDataLayout() const { return &DL; }
57b25baef26f03b9909b65dd5f762b38f93000445dRichard Osborne
58b25baef26f03b9909b65dd5f762b38f93000445dRichard Osborne  // Pass Pipeline Configuration
59061efcfb3e79899493d857f49e50d09f29037e0aAndrew Trick  virtual TargetPassConfig *createPassConfig(PassManagerBase &PM);
60b25baef26f03b9909b65dd5f762b38f93000445dRichard Osborne};
61b25baef26f03b9909b65dd5f762b38f93000445dRichard Osborne
62b25baef26f03b9909b65dd5f762b38f93000445dRichard Osborne} // end namespace llvm
63b25baef26f03b9909b65dd5f762b38f93000445dRichard Osborne
64b25baef26f03b9909b65dd5f762b38f93000445dRichard Osborne#endif
65