//===- AlignFragment.h ----------------------------------------------------===// // // The MCLinker Project // // This file is distributed under the University of Illinois Open Source // License. See LICENSE.TXT for details. // //===----------------------------------------------------------------------===// #ifndef MCLD_FRAGMENT_ALIGNFRAGMENT_H_ #define MCLD_FRAGMENT_ALIGNFRAGMENT_H_ #include "mcld/Fragment/Fragment.h" namespace mcld { class SectionData; class AlignFragment : public Fragment { public: AlignFragment(unsigned int pAlignment, int64_t pValue, unsigned int pValueSize, unsigned int pMaxBytesToEmit, SectionData* pSD = NULL); unsigned int getAlignment() const { return m_Alignment; } int64_t getValue() const { return m_Value; } unsigned int getValueSize() const { return m_ValueSize; } unsigned int getMaxBytesToEmit() const { return m_MaxBytesToEmit; } bool hasEmitNops() const { return m_bEmitNops; } void setEmitNops(bool pValue) { m_bEmitNops = pValue; } static bool classof(const Fragment* F) { return F->getKind() == Fragment::Alignment; } static bool classof(const AlignFragment*) { return true; } size_t size() const; private: /// Alignment - The alignment to ensure, in bytes. unsigned int m_Alignment; /// Value - Value to use for filling padding bytes. int64_t m_Value; /// ValueSize - The size of the integer (in bytes) of \arg Value. unsigned int m_ValueSize; /// MaxBytesToEmit - The maximum number of bytes to emit; if the alignment /// cannot be satisfied in this width then this fragment is ignored. unsigned int m_MaxBytesToEmit; /// EmitNops - Flag to indicate that (optimal) NOPs should be emitted instead /// of using the provided value. The exact interpretation of this flag is /// target dependent. bool m_bEmitNops : 1; }; } // namespace mcld #endif // MCLD_FRAGMENT_ALIGNFRAGMENT_H_