//===- MipsAbiFlags.h -----------------------------------------------------===//
//
// The MCLinker Project
//
// This file is distributed under the University of Illinois Open Source
// License. See LICENSE.TXT for details.
//
//===----------------------------------------------------------------------===//
#ifndef TARGET_MIPS_MIPSABIFLAGS_H_
#define TARGET_MIPS_MIPSABIFLAGS_H_
#include "mcld/Support/MemoryRegion.h"
#include <llvm/ADT/Optional.h>
#include <llvm/Object/ELFTypes.h>
namespace mcld {
class Input;
class LDSection;
/** \class MipsAbiFlags
* \brief Representation of .MIPS.abiflags section.
*/
class MipsAbiFlags {
public:
/// size of underlaid ELF section structure
static uint64_t size();
/// write ELF section structure to the memory region
static uint64_t emit(const MipsAbiFlags& pInfo, MemoryRegion& pRegion);
/// fill the structure by the data from the input section
static bool fillBySection(const Input& pInput, const LDSection& pSection,
MipsAbiFlags& mipsAbi);
/// fill the structure by the data from ELF header flags
static bool fillByElfFlags(const Input& pInput, uint64_t elfFlags,
MipsAbiFlags& mipsAbi);
/// check compatibility between two structures
static bool isCompatible(const Input& pInput, const MipsAbiFlags& elf,
const MipsAbiFlags& abi);
/// merge new abi settings to the old structure
static bool merge(const Input& pInput, MipsAbiFlags& oldFlags,
const MipsAbiFlags& newFlags);
private:
uint32_t m_IsaLevel;
uint32_t m_IsaRev;
uint32_t m_IsaExt;
uint32_t m_GprSize;
uint32_t m_Cpr1Size;
uint32_t m_Cpr2Size;
uint32_t m_FpAbi;
uint32_t m_Ases;
uint32_t m_Flags1;
};
} // namespace mcld
#endif // TARGET_MIPS_MIPSABIFLAGS_H_