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