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