diff options
Diffstat (limited to 'contrib/llvm/lib/Target/MSP430/MSP430TargetMachine.h')
-rw-r--r-- | contrib/llvm/lib/Target/MSP430/MSP430TargetMachine.h | 49 |
1 files changed, 49 insertions, 0 deletions
diff --git a/contrib/llvm/lib/Target/MSP430/MSP430TargetMachine.h b/contrib/llvm/lib/Target/MSP430/MSP430TargetMachine.h new file mode 100644 index 0000000..0e54ed6 --- /dev/null +++ b/contrib/llvm/lib/Target/MSP430/MSP430TargetMachine.h @@ -0,0 +1,49 @@ +//===-- MSP430TargetMachine.h - Define TargetMachine for MSP430 -*- C++ -*-===// +// +// The LLVM Compiler Infrastructure +// +// This file is distributed under the University of Illinois Open Source +// License. See LICENSE.TXT for details. +// +//===----------------------------------------------------------------------===// +// +// This file declares the MSP430 specific subclass of TargetMachine. +// +//===----------------------------------------------------------------------===// + + +#ifndef LLVM_LIB_TARGET_MSP430_MSP430TARGETMACHINE_H +#define LLVM_LIB_TARGET_MSP430_MSP430TARGETMACHINE_H + +#include "MSP430Subtarget.h" +#include "llvm/Target/TargetFrameLowering.h" +#include "llvm/Target/TargetMachine.h" + +namespace llvm { + +/// MSP430TargetMachine +/// +class MSP430TargetMachine : public LLVMTargetMachine { + std::unique_ptr<TargetLoweringObjectFile> TLOF; + MSP430Subtarget Subtarget; + +public: + MSP430TargetMachine(const Target &T, StringRef TT, + StringRef CPU, StringRef FS, const TargetOptions &Options, + Reloc::Model RM, CodeModel::Model CM, + CodeGenOpt::Level OL); + ~MSP430TargetMachine() override; + + const MSP430Subtarget *getSubtargetImpl() const override { + return &Subtarget; + } + TargetPassConfig *createPassConfig(PassManagerBase &PM) override; + + TargetLoweringObjectFile *getObjFileLowering() const override { + return TLOF.get(); + } +}; // MSP430TargetMachine. + +} // end namespace llvm + +#endif |