| //===- 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_ |