mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-19 20:34:38 +00:00
8a8d479214
change, now you need a TargetOptions object to create a TargetMachine. Clang patch to follow. One small functionality change in PTX. PTX had commented out the machine verifier parts in their copy of printAndVerify. That now calls the version in LLVMTargetMachine. Users of PTX who need verification disabled should rely on not passing the command-line flag to enable it. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@145714 91177308-0d34-0410-b5e6-96231b3b80d8
53 lines
1.9 KiB
C++
53 lines
1.9 KiB
C++
//===-- MSP430TargetMachine.cpp - Define TargetMachine for MSP430 ---------===//
|
|
//
|
|
// The LLVM Compiler Infrastructure
|
|
//
|
|
// This file is distributed under the University of Illinois Open Source
|
|
// License. See LICENSE.TXT for details.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
//
|
|
// Top-level implementation for the MSP430 target.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
#include "MSP430.h"
|
|
#include "MSP430TargetMachine.h"
|
|
#include "llvm/PassManager.h"
|
|
#include "llvm/CodeGen/Passes.h"
|
|
#include "llvm/MC/MCAsmInfo.h"
|
|
#include "llvm/Support/TargetRegistry.h"
|
|
using namespace llvm;
|
|
|
|
extern "C" void LLVMInitializeMSP430Target() {
|
|
// Register the target.
|
|
RegisterTargetMachine<MSP430TargetMachine> X(TheMSP430Target);
|
|
}
|
|
|
|
MSP430TargetMachine::MSP430TargetMachine(const Target &T,
|
|
StringRef TT,
|
|
StringRef CPU,
|
|
StringRef FS,
|
|
const TargetOptions &Options,
|
|
Reloc::Model RM, CodeModel::Model CM,
|
|
CodeGenOpt::Level OL)
|
|
: LLVMTargetMachine(T, TT, CPU, FS, Options, RM, CM, OL),
|
|
Subtarget(TT, CPU, FS),
|
|
// FIXME: Check TargetData string.
|
|
DataLayout("e-p:16:16:16-i8:8:8-i16:16:16-i32:16:32-n8:16"),
|
|
InstrInfo(*this), TLInfo(*this), TSInfo(*this),
|
|
FrameLowering(Subtarget) { }
|
|
|
|
|
|
bool MSP430TargetMachine::addInstSelector(PassManagerBase &PM) {
|
|
// Install an instruction selector.
|
|
PM.add(createMSP430ISelDag(*this, getOptLevel()));
|
|
return false;
|
|
}
|
|
|
|
bool MSP430TargetMachine::addPreEmitPass(PassManagerBase &PM) {
|
|
// Must run branch selection immediately preceding the asm printer.
|
|
PM.add(createMSP430BranchSelectionPass());
|
|
return false;
|
|
}
|