2012-02-18 20:03:15 +08:00
|
|
|
//===-- SparcSubtarget.h - Define Subtarget for the SPARC -------*- C++ -*-===//
|
2006-02-05 13:50:24 +08:00
|
|
|
//
|
|
|
|
// The LLVM Compiler Infrastructure
|
|
|
|
//
|
2007-12-30 04:36:04 +08:00
|
|
|
// This file is distributed under the University of Illinois Open Source
|
|
|
|
// License. See LICENSE.TXT for details.
|
2006-02-05 13:50:24 +08:00
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
//
|
2011-07-02 05:01:15 +08:00
|
|
|
// This file declares the SPARC specific subclass of TargetSubtargetInfo.
|
2006-02-05 13:50:24 +08:00
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
|
2014-08-14 00:26:38 +08:00
|
|
|
#ifndef LLVM_LIB_TARGET_SPARC_SPARCSUBTARGET_H
|
|
|
|
#define LLVM_LIB_TARGET_SPARC_SPARCSUBTARGET_H
|
2006-02-05 13:50:24 +08:00
|
|
|
|
2014-06-27 06:33:55 +08:00
|
|
|
#include "SparcFrameLowering.h"
|
|
|
|
#include "SparcISelLowering.h"
|
2016-01-28 00:32:26 +08:00
|
|
|
#include "SparcInstrInfo.h"
|
|
|
|
#include "llvm/CodeGen/SelectionDAGTargetInfo.h"
|
2014-06-27 06:33:55 +08:00
|
|
|
#include "llvm/IR/DataLayout.h"
|
|
|
|
#include "llvm/Target/TargetFrameLowering.h"
|
2011-07-02 05:01:15 +08:00
|
|
|
#include "llvm/Target/TargetSubtargetInfo.h"
|
2006-02-05 13:50:24 +08:00
|
|
|
#include <string>
|
|
|
|
|
2011-07-02 04:45:01 +08:00
|
|
|
#define GET_SUBTARGETINFO_HEADER
|
2011-07-02 06:36:09 +08:00
|
|
|
#include "SparcGenSubtargetInfo.inc"
|
2011-07-02 04:45:01 +08:00
|
|
|
|
2006-02-05 13:50:24 +08:00
|
|
|
namespace llvm {
|
2011-07-07 15:07:08 +08:00
|
|
|
class StringRef;
|
2009-08-03 06:11:08 +08:00
|
|
|
|
2011-07-02 04:45:01 +08:00
|
|
|
class SparcSubtarget : public SparcGenSubtargetInfo {
|
2016-04-26 18:37:14 +08:00
|
|
|
Triple TargetTriple;
|
2011-12-20 10:50:00 +08:00
|
|
|
virtual void anchor();
|
2006-02-05 13:50:24 +08:00
|
|
|
bool IsV9;
|
[Sparc] This provides support for itineraries on Sparc.
Specifically, itineraries for LEON processors has been added, along with several LEON processor Subtargets. Although currently all these targets are pretty much identical, support for features that will differ among these processors will be added in the very near future.
The different Instruction Itinerary Classes (IICs) added are sufficient to differentiate between the instruction timings used by LEON and, quite probably, by generic Sparc processors too, but the focus of the exercise has been for LEON processors, as the requirement of my project. If the IICs are not sufficient for other Sparc processor types and you want to add a new itinerary for one of those, it should be relatively trivial to adapt this.
As none of the LEON processors has Quad Floats, or is a Version 9 processor, none of those instructions have itinerary classes defined and revert to the default "NoItinerary" instruction itinerary.
Phabricator Review: http://reviews.llvm.org/D19359
llvm-svn: 267121
2016-04-22 16:17:17 +08:00
|
|
|
bool IsLeon;
|
2006-02-05 13:50:24 +08:00
|
|
|
bool V8DeprecatedInsts;
|
2014-03-03 03:31:21 +08:00
|
|
|
bool IsVIS, IsVIS2, IsVIS3;
|
2010-02-04 14:34:01 +08:00
|
|
|
bool Is64Bit;
|
2013-08-26 02:30:06 +08:00
|
|
|
bool HasHardQuad;
|
2014-01-26 14:09:59 +08:00
|
|
|
bool UsePopc;
|
2016-05-18 17:14:13 +08:00
|
|
|
bool UseSoftFloat;
|
2016-05-16 19:02:00 +08:00
|
|
|
|
|
|
|
// LEON features
|
|
|
|
bool HasUmacSmac;
|
|
|
|
bool HasLeonCasa;
|
2016-05-23 18:56:36 +08:00
|
|
|
bool InsertNOPLoad;
|
2016-06-19 19:03:28 +08:00
|
|
|
bool FixFSMULD;
|
|
|
|
bool ReplaceFMULS;
|
|
|
|
bool FixAllFDIVSQRT;
|
2016-10-19 22:01:06 +08:00
|
|
|
bool DetectRoundChange;
|
2016-10-10 16:53:06 +08:00
|
|
|
bool PerformSDIVReplace;
|
2016-05-16 19:02:00 +08:00
|
|
|
|
2014-06-27 06:33:55 +08:00
|
|
|
SparcInstrInfo InstrInfo;
|
|
|
|
SparcTargetLowering TLInfo;
|
2016-01-28 00:32:26 +08:00
|
|
|
SelectionDAGTargetInfo TSInfo;
|
2014-06-27 06:33:55 +08:00
|
|
|
SparcFrameLowering FrameLowering;
|
2013-06-05 02:33:25 +08:00
|
|
|
|
2006-02-05 13:50:24 +08:00
|
|
|
public:
|
2015-06-10 20:11:26 +08:00
|
|
|
SparcSubtarget(const Triple &TT, const std::string &CPU,
|
2016-05-03 22:57:18 +08:00
|
|
|
const std::string &FS, const TargetMachine &TM, bool is64bit);
|
2014-06-27 06:33:55 +08:00
|
|
|
|
2014-08-05 05:25:23 +08:00
|
|
|
const SparcInstrInfo *getInstrInfo() const override { return &InstrInfo; }
|
|
|
|
const TargetFrameLowering *getFrameLowering() const override {
|
|
|
|
return &FrameLowering;
|
|
|
|
}
|
|
|
|
const SparcRegisterInfo *getRegisterInfo() const override {
|
2014-06-27 06:33:55 +08:00
|
|
|
return &InstrInfo.getRegisterInfo();
|
|
|
|
}
|
2014-08-05 05:25:23 +08:00
|
|
|
const SparcTargetLowering *getTargetLowering() const override {
|
|
|
|
return &TLInfo;
|
|
|
|
}
|
2016-01-28 00:32:26 +08:00
|
|
|
const SelectionDAGTargetInfo *getSelectionDAGInfo() const override {
|
2014-08-05 05:25:23 +08:00
|
|
|
return &TSInfo;
|
|
|
|
}
|
2006-02-05 13:50:24 +08:00
|
|
|
|
2015-09-11 05:49:06 +08:00
|
|
|
bool enableMachineScheduler() const override;
|
|
|
|
|
2006-02-05 13:50:24 +08:00
|
|
|
bool isV9() const { return IsV9; }
|
[Sparc] This provides support for itineraries on Sparc.
Specifically, itineraries for LEON processors has been added, along with several LEON processor Subtargets. Although currently all these targets are pretty much identical, support for features that will differ among these processors will be added in the very near future.
The different Instruction Itinerary Classes (IICs) added are sufficient to differentiate between the instruction timings used by LEON and, quite probably, by generic Sparc processors too, but the focus of the exercise has been for LEON processors, as the requirement of my project. If the IICs are not sufficient for other Sparc processor types and you want to add a new itinerary for one of those, it should be relatively trivial to adapt this.
As none of the LEON processors has Quad Floats, or is a Version 9 processor, none of those instructions have itinerary classes defined and revert to the default "NoItinerary" instruction itinerary.
Phabricator Review: http://reviews.llvm.org/D19359
llvm-svn: 267121
2016-04-22 16:17:17 +08:00
|
|
|
bool isLeon() const { return IsLeon; }
|
2006-02-05 13:50:24 +08:00
|
|
|
bool isVIS() const { return IsVIS; }
|
2014-03-03 03:31:21 +08:00
|
|
|
bool isVIS2() const { return IsVIS2; }
|
|
|
|
bool isVIS3() const { return IsVIS3; }
|
2006-02-05 13:50:24 +08:00
|
|
|
bool useDeprecatedV8Instructions() const { return V8DeprecatedInsts; }
|
2013-08-26 02:30:06 +08:00
|
|
|
bool hasHardQuad() const { return HasHardQuad; }
|
2014-01-26 14:09:59 +08:00
|
|
|
bool usePopc() const { return UsePopc; }
|
2016-05-18 17:14:13 +08:00
|
|
|
bool useSoftFloat() const { return UseSoftFloat; }
|
2013-06-05 02:33:25 +08:00
|
|
|
|
2016-05-16 19:02:00 +08:00
|
|
|
// Leon options
|
2016-07-08 23:33:56 +08:00
|
|
|
bool hasUmacSmac() const { return HasUmacSmac; }
|
2016-10-10 16:53:06 +08:00
|
|
|
bool performSDIVReplace() const { return PerformSDIVReplace; }
|
2016-08-12 22:48:09 +08:00
|
|
|
bool hasLeonCasa() const { return HasLeonCasa; }
|
|
|
|
bool insertNOPLoad() const { return InsertNOPLoad; }
|
2016-06-19 19:03:28 +08:00
|
|
|
bool fixFSMULD() const { return FixFSMULD; }
|
|
|
|
bool replaceFMULS() const { return ReplaceFMULS; }
|
|
|
|
bool fixAllFDIVSQRT() const { return FixAllFDIVSQRT; }
|
2016-10-19 22:01:06 +08:00
|
|
|
bool detectRoundChange() const { return DetectRoundChange; }
|
2016-05-16 19:02:00 +08:00
|
|
|
|
2013-06-05 02:33:25 +08:00
|
|
|
/// ParseSubtargetFeatures - Parses features string setting specified
|
2006-02-05 13:50:24 +08:00
|
|
|
/// subtarget options. Definition of function is auto generated by tblgen.
|
2011-07-07 15:07:08 +08:00
|
|
|
void ParseSubtargetFeatures(StringRef CPU, StringRef FS);
|
2014-06-27 06:33:55 +08:00
|
|
|
SparcSubtarget &initializeSubtargetDependencies(StringRef CPU, StringRef FS);
|
2013-06-05 02:33:25 +08:00
|
|
|
|
2010-02-04 14:34:01 +08:00
|
|
|
bool is64Bit() const { return Is64Bit; }
|
2013-04-07 05:38:57 +08:00
|
|
|
|
|
|
|
/// The 64-bit ABI uses biased stack and frame pointers, so the stack frame
|
|
|
|
/// of the current function is the area from [%sp+BIAS] to [%fp+BIAS].
|
|
|
|
int64_t getStackPointerBias() const {
|
|
|
|
return is64Bit() ? 2047 : 0;
|
|
|
|
}
|
2013-06-01 12:51:18 +08:00
|
|
|
|
|
|
|
/// Given a actual stack size as determined by FrameInfo, this function
|
|
|
|
/// returns adjusted framesize which includes space for register window
|
|
|
|
/// spills and arguments.
|
|
|
|
int getAdjustedFrameSize(int stackSize) const;
|
2016-04-26 18:37:14 +08:00
|
|
|
|
|
|
|
bool isTargetLinux() const { return TargetTriple.isOSLinux(); }
|
2006-02-05 13:50:24 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
} // end namespace llvm
|
|
|
|
|
|
|
|
#endif
|