//===- TargetOptions.h ----------------------------------------------------===//
//
// The MCLinker Project
//
// This file is distributed under the University of Illinois Open Source
// License. See LICENSE.TXT for details.
//
//===----------------------------------------------------------------------===//
#ifndef MCLD_TARGETOPTIONS_H_
#define MCLD_TARGETOPTIONS_H_
#include <llvm/ADT/Triple.h>
#include <string>
namespace mcld {
/** \class TargetOptions
* \brief TargetOptions collects the options that dependent on a target
* backend.
*/
class TargetOptions {
public:
enum Endian { Little, Big, Unknown };
public:
TargetOptions();
explicit TargetOptions(const std::string& pTriple);
~TargetOptions();
const llvm::Triple& triple() const { return m_Triple; }
void setTriple(const std::string& pTriple);
void setTriple(const llvm::Triple& pTriple);
const std::string& getArch() const { return m_ArchName; }
void setArch(const std::string& pArchName);
const std::string& getTargetCPU() const { return m_TargetCPU; }
void setTargetCPU(const std::string& pCPU);
Endian endian() const { return m_Endian; }
void setEndian(Endian pEndian) { m_Endian = pEndian; }
bool isLittleEndian() const { return (Little == m_Endian); }
bool isBigEndian() const { return (Big == m_Endian); }
unsigned int bitclass() const { return m_BitClass; }
void setBitClass(unsigned int pBitClass) { m_BitClass = pBitClass; }
bool is32Bits() const { return (32 == m_BitClass); }
bool is64Bits() const { return (64 == m_BitClass); }
// -G, max GP size option
void setGPSize(unsigned pGPSize) { m_GPSize = pGPSize; }
unsigned getGPSize() const { return m_GPSize; }
void setStubGroupSize(unsigned pSize) { m_StubGroupSize = pSize; }
unsigned getStubGroupSize() const { return m_StubGroupSize; }
void setFixCA53Erratum835769(bool pEnable = true) {
m_FixCA53Erratum835769 = pEnable;
}
bool fixCA53Erratum835769() const { return m_FixCA53Erratum835769; }
void setFixCA53Erratum843419(bool pEnable = true) {
m_FixCA53Erratum843419 = pEnable;
}
bool fixCA53Erratum843419() const { return m_FixCA53Erratum843419; }
private:
llvm::Triple m_Triple;
std::string m_ArchName;
std::string m_TargetCPU;
Endian m_Endian;
unsigned int m_BitClass;
unsigned m_GPSize; // -G, --gpsize
unsigned m_StubGroupSize;
bool m_FixCA53Erratum835769 : 1;
bool m_FixCA53Erratum843419 : 1;
};
} // namespace mcld
#endif // MCLD_TARGETOPTIONS_H_