1//===- AlignFragment.h ----------------------------------------------------===// 2// 3// The MCLinker Project 4// 5// This file is distributed under the University of Illinois Open Source 6// License. See LICENSE.TXT for details. 7// 8//===----------------------------------------------------------------------===// 9#ifndef MCLD_FRAGMENT_ALIGNFRAGMENT_H 10#define MCLD_FRAGMENT_ALIGNFRAGMENT_H 11 12#include <mcld/Fragment/Fragment.h> 13 14namespace mcld { 15 16class SectionData; 17 18class AlignFragment : public Fragment 19{ 20public: 21 AlignFragment(unsigned int pAlignment, int64_t pValue, unsigned int pValueSize, 22 unsigned int pMaxBytesToEmit, SectionData *pSD = NULL); 23 24 unsigned int getAlignment() const { return m_Alignment; } 25 26 int64_t getValue() const { return m_Value; } 27 28 unsigned int getValueSize() const { return m_ValueSize; } 29 30 unsigned int getMaxBytesToEmit() const { return m_MaxBytesToEmit; } 31 32 bool hasEmitNops() const { return m_bEmitNops; } 33 34 void setEmitNops(bool pValue) { m_bEmitNops = pValue; } 35 36 static bool classof(const Fragment *F) 37 { return F->getKind() == Fragment::Alignment; } 38 static bool classof(const AlignFragment *) { return true; } 39 40 size_t size() const; 41 42private: 43 /// Alignment - The alignment to ensure, in bytes. 44 unsigned int m_Alignment; 45 46 /// Value - Value to use for filling padding bytes. 47 int64_t m_Value; 48 49 /// ValueSize - The size of the integer (in bytes) of \arg Value. 50 unsigned int m_ValueSize; 51 52 /// MaxBytesToEmit - The maximum number of bytes to emit; if the alignment 53 /// cannot be satisfied in this width then this fragment is ignored. 54 unsigned int m_MaxBytesToEmit; 55 56 /// EmitNops - Flag to indicate that (optimal) NOPs should be emitted instead 57 /// of using the provided value. The exact interpretation of this flag is 58 /// target dependent. 59 bool m_bEmitNops : 1; 60 61}; 62 63} // namespace of mcld 64 65#endif 66 67