Home | History | Annotate | Download | only in Fragment
      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 
     14 namespace mcld {
     15 
     16 class SectionData;
     17 
     18 class AlignFragment : public Fragment
     19 {
     20 public:
     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 
     42 private:
     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