mirror of
https://github.com/RPCS3/llvm.git
synced 2025-01-15 06:18:50 +00:00
c4cc40c001
- Add TSFlags for the instruction formats. The idea here is to use as much encoding as possible from getBinaryCodeForInstr, and having TSFLags formats for that would make it easier to encode most part of the instructions (since Mips encodings are pretty straightforward) - Improve the mips mechanism for compilation callback - Add Mips specific code for invalidating the instruction cache - Next patch will address wrong tablegen encoding Commit msg added by my own but the patch is from Sasa Stankovic. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@139688 91177308-0d34-0410-b5e6-96231b3b80d8
95 lines
3.0 KiB
C++
95 lines
3.0 KiB
C++
//===-- MipsTargetMachine.h - Define TargetMachine for Mips -00--*- 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 Mips specific subclass of TargetMachine.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
#ifndef MIPSTARGETMACHINE_H
|
|
#define MIPSTARGETMACHINE_H
|
|
|
|
#include "MipsSubtarget.h"
|
|
#include "MipsInstrInfo.h"
|
|
#include "MipsISelLowering.h"
|
|
#include "MipsFrameLowering.h"
|
|
#include "MipsSelectionDAGInfo.h"
|
|
#include "llvm/Target/TargetMachine.h"
|
|
#include "llvm/Target/TargetData.h"
|
|
#include "llvm/Target/TargetFrameLowering.h"
|
|
#include "MipsJITInfo.h"
|
|
|
|
namespace llvm {
|
|
class formatted_raw_ostream;
|
|
|
|
class MipsTargetMachine : public LLVMTargetMachine {
|
|
MipsSubtarget Subtarget;
|
|
const TargetData DataLayout; // Calculates type size & alignment
|
|
MipsInstrInfo InstrInfo;
|
|
MipsFrameLowering FrameLowering;
|
|
MipsTargetLowering TLInfo;
|
|
MipsSelectionDAGInfo TSInfo;
|
|
MipsJITInfo JITInfo;
|
|
|
|
public:
|
|
MipsTargetMachine(const Target &T, StringRef TT,
|
|
StringRef CPU, StringRef FS,
|
|
Reloc::Model RM, CodeModel::Model CM,
|
|
bool isLittle);
|
|
|
|
virtual const MipsInstrInfo *getInstrInfo() const
|
|
{ return &InstrInfo; }
|
|
virtual const TargetFrameLowering *getFrameLowering() const
|
|
{ return &FrameLowering; }
|
|
virtual const MipsSubtarget *getSubtargetImpl() const
|
|
{ return &Subtarget; }
|
|
virtual const TargetData *getTargetData() const
|
|
{ return &DataLayout;}
|
|
virtual MipsJITInfo *getJITInfo()
|
|
{ return &JITInfo; }
|
|
|
|
|
|
virtual const MipsRegisterInfo *getRegisterInfo() const {
|
|
return &InstrInfo.getRegisterInfo();
|
|
}
|
|
|
|
virtual const MipsTargetLowering *getTargetLowering() const {
|
|
return &TLInfo;
|
|
}
|
|
|
|
virtual const MipsSelectionDAGInfo* getSelectionDAGInfo() const {
|
|
return &TSInfo;
|
|
}
|
|
|
|
// Pass Pipeline Configuration
|
|
virtual bool addInstSelector(PassManagerBase &PM,
|
|
CodeGenOpt::Level OptLevel);
|
|
virtual bool addPreEmitPass(PassManagerBase &PM,
|
|
CodeGenOpt::Level OptLevel);
|
|
virtual bool addPreRegAlloc(PassManagerBase &PM,
|
|
CodeGenOpt::Level OptLevel);
|
|
virtual bool addPostRegAlloc(PassManagerBase &, CodeGenOpt::Level);
|
|
virtual bool addCodeEmitter(PassManagerBase &PM,
|
|
CodeGenOpt::Level OptLevel,
|
|
JITCodeEmitter &JCE);
|
|
|
|
};
|
|
|
|
/// MipselTargetMachine - Mipsel target machine.
|
|
///
|
|
class MipselTargetMachine : public MipsTargetMachine {
|
|
public:
|
|
MipselTargetMachine(const Target &T, StringRef TT,
|
|
StringRef CPU, StringRef FS,
|
|
Reloc::Model RM, CodeModel::Model CM);
|
|
};
|
|
|
|
} // End llvm namespace
|
|
|
|
#endif
|