diff options
author | Daniel Dunbar <daniel@zuster.org> | 2010-03-25 02:00:07 +0000 |
---|---|---|
committer | Daniel Dunbar <daniel@zuster.org> | 2010-03-25 02:00:07 +0000 |
commit | 5d428511ca9607d52a09d3483d0738f483e09934 (patch) | |
tree | 8962b6cf6868e23e127512634022c006ce0cf3ff /include/llvm | |
parent | 432cd5fd9b4c97f1e4a53fcf45e16f7dd6bc085e (diff) | |
download | external_llvm-5d428511ca9607d52a09d3483d0738f483e09934.zip external_llvm-5d428511ca9607d52a09d3483d0738f483e09934.tar.gz external_llvm-5d428511ca9607d52a09d3483d0738f483e09934.tar.bz2 |
MC: Route access to SectionData offset and file size through MCAsmLayout.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@99474 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'include/llvm')
-rw-r--r-- | include/llvm/MC/MCAsmLayout.h | 43 | ||||
-rw-r--r-- | include/llvm/MC/MCAssembler.h | 26 |
2 files changed, 44 insertions, 25 deletions
diff --git a/include/llvm/MC/MCAsmLayout.h b/include/llvm/MC/MCAsmLayout.h index 9b9cdf2..f7f32ae 100644 --- a/include/llvm/MC/MCAsmLayout.h +++ b/include/llvm/MC/MCAsmLayout.h @@ -33,19 +33,58 @@ public: /// Get the assembler object this is a layout for. MCAssembler &getAssembler() const { return Assembler; } - uint64_t getFragmentAddress(const MCFragment *F) const; + /// @name Fragment Layout Data + /// @{ + /// \brief Get the effective size of the given fragment, as computed in the + /// current layout. uint64_t getFragmentEffectiveSize(const MCFragment *F) const; + + /// \brief Set the effective size of the given fragment. void setFragmentEffectiveSize(MCFragment *F, uint64_t Value); + /// \brief Get the offset of the given fragment inside its containing section. uint64_t getFragmentOffset(const MCFragment *F) const; + + /// \brief Set the offset of the given fragment inside its containing section. void setFragmentOffset(MCFragment *F, uint64_t Value); + /// @} + /// @name Section Layout Data + /// @{ + + /// \brief Get the computed address of the given section. uint64_t getSectionAddress(const MCSectionData *SD) const; + /// \brief Set the computed address of the given section. + void setSectionAddress(MCSectionData *SD, uint64_t Value); + + /// \brief Get the data size of the given section, as emitted to the object + /// file. This may include additional padding, or be 0 for virtual sections. + uint64_t getSectionFileSize(const MCSectionData *SD) const; + + /// \brief Set the data size of the given section. + void setSectionFileSize(MCSectionData *SD, uint64_t Value); + + /// \brief Get the actual data size of the given section. + uint64_t getSectionSize(const MCSectionData *SD) const; + + /// \brief Set the actual data size of the given section. + void setSectionSize(MCSectionData *SD, uint64_t Value); + + /// @} + /// @name Utility Functions + /// @{ + + /// \brief Get the address of the given fragment, as computed in the current + /// layout. + uint64_t getFragmentAddress(const MCFragment *F) const; + + /// \brief Get the address of the given symbol, as computed in the current + /// layout. uint64_t getSymbolAddress(const MCSymbolData *SD) const; - void setSectionAddress(MCSectionData *SD, uint64_t Value); + /// @} }; } // end namespace llvm diff --git a/include/llvm/MC/MCAssembler.h b/include/llvm/MC/MCAssembler.h index 327b0b8..19cec1c 100644 --- a/include/llvm/MC/MCAssembler.h +++ b/include/llvm/MC/MCAssembler.h @@ -425,6 +425,9 @@ public: unsigned getAlignment() const { return Alignment; } void setAlignment(unsigned Value) { Alignment = Value; } + bool hasInstructions() const { return HasInstructions; } + void setHasInstructions(bool Value) { HasInstructions = Value; } + /// @name Fragment Access /// @{ @@ -447,29 +450,6 @@ public: bool empty() const { return Fragments.empty(); } - /// @} - /// @name Assembler Backend Support - /// @{ - // - // FIXME: This could all be kept private to the assembler implementation. - - uint64_t getSize() const { - assert(Size != ~UINT64_C(0) && "File size not set!"); - return Size; - } - void setSize(uint64_t Value) { Size = Value; } - - uint64_t getFileSize() const { - assert(FileSize != ~UINT64_C(0) && "File size not set!"); - return FileSize; - } - void setFileSize(uint64_t Value) { FileSize = Value; } - - bool hasInstructions() const { return HasInstructions; } - void setHasInstructions(bool Value) { HasInstructions = Value; } - - /// @} - void dump(); }; |