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