#include "MCTargetDesc/MipsMCTargetDesc.h"
#include "MipsTargetMachine.h"
#include "llvm/Pass.h"
#include "llvm/Target/TargetMachine.h"
#ifndef MIPS16HARDFLOAT_H
#define MIPS16HARDFLOAT_H
using namespace llvm;
namespace llvm {
class Mips16HardFloat : public ModulePass {
public:
static char ID;
Mips16HardFloat(MipsTargetMachine &TM_) : ModulePass(ID),
TM(TM_), Subtarget(TM.getSubtarget<MipsSubtarget>()) {
}
virtual const char *getPassName() const {
return "MIPS16 Hard Float Pass";
}
virtual bool runOnModule(Module &M);
protected:
const TargetMachine &TM;
const MipsSubtarget &Subtarget;
};
ModulePass *createMips16HardFloat(MipsTargetMachine &TM);
}
#endif