mirror of
				https://github.com/c64scene-ar/llvm-6502.git
				synced 2025-10-26 02:22:29 +00:00 
			
		
		
		
	MC: Add MCSectionData::AddressSize, which is the size of the address space consumed by the section. This can differ from both the section logical size, and the section size on disk (although the current code handles this without making an explicit distinction).
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@103689 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
		| @@ -91,10 +91,18 @@ public: | |||||||
|   /// \brief Set the data size of the given section. |   /// \brief Set the data size of the given section. | ||||||
|   void setSectionFileSize(MCSectionData *SD, uint64_t Value); |   void setSectionFileSize(MCSectionData *SD, uint64_t Value); | ||||||
|  |  | ||||||
|   /// \brief Get the actual data size of the given section. |   /// \brief Get the address space size of the given section, as it effects | ||||||
|  |   /// layout. This may differ from the size reported by \see getSectionSize() by | ||||||
|  |   /// not including section tail padding. | ||||||
|  |   uint64_t getSectionAddressSize(const MCSectionData *SD) const; | ||||||
|  |  | ||||||
|  |   /// \brief Set the address space size of the given section. | ||||||
|  |   void setSectionAddressSize(MCSectionData *SD, uint64_t Value); | ||||||
|  |  | ||||||
|  |   /// \brief Get the logical data size of the given section. | ||||||
|   uint64_t getSectionSize(const MCSectionData *SD) const; |   uint64_t getSectionSize(const MCSectionData *SD) const; | ||||||
|  |  | ||||||
|   /// \brief Set the actual data size of the given section. |   /// \brief Set the logical data size of the given section. | ||||||
|   void setSectionSize(MCSectionData *SD, uint64_t Value); |   void setSectionSize(MCSectionData *SD, uint64_t Value); | ||||||
|  |  | ||||||
|   /// @} |   /// @} | ||||||
|   | |||||||
| @@ -394,9 +394,13 @@ private: | |||||||
|   /// initialized. |   /// initialized. | ||||||
|   uint64_t Address; |   uint64_t Address; | ||||||
|  |  | ||||||
|   /// Size - The content size of this section. This is ~0 until initialized. |   /// Size - The logical size of this section. This is ~0 until initialized. | ||||||
|   uint64_t Size; |   uint64_t Size; | ||||||
|  |  | ||||||
|  |   /// AddressSize - The address space size used by this section. This is ~0 | ||||||
|  |   /// until initialized. | ||||||
|  |   uint64_t AddressSize; | ||||||
|  |  | ||||||
|   /// FileSize - The size of this section in the object file. This is ~0 until |   /// FileSize - The size of this section in the object file. This is ~0 until | ||||||
|   /// initialized. |   /// initialized. | ||||||
|   uint64_t FileSize; |   uint64_t FileSize; | ||||||
|   | |||||||
| @@ -126,6 +126,14 @@ void MCAsmLayout::setSectionFileSize(MCSectionData *SD, uint64_t Value) { | |||||||
|   SD->FileSize = Value; |   SD->FileSize = Value; | ||||||
| } | } | ||||||
|  |  | ||||||
|  | uint64_t MCAsmLayout::getSectionAddressSize(const MCSectionData *SD) const { | ||||||
|  |   assert(SD->AddressSize != ~UINT64_C(0) && "Address size not set!"); | ||||||
|  |   return SD->AddressSize; | ||||||
|  | } | ||||||
|  | void MCAsmLayout::setSectionAddressSize(MCSectionData *SD, uint64_t Value) { | ||||||
|  |   SD->AddressSize = Value; | ||||||
|  | } | ||||||
|  |  | ||||||
| /* *** */ | /* *** */ | ||||||
|  |  | ||||||
| MCFragment::MCFragment() : Kind(FragmentType(~0)) { | MCFragment::MCFragment() : Kind(FragmentType(~0)) { | ||||||
| @@ -150,6 +158,7 @@ MCSectionData::MCSectionData(const MCSection &_Section, MCAssembler *A) | |||||||
|     Alignment(1), |     Alignment(1), | ||||||
|     Address(~UINT64_C(0)), |     Address(~UINT64_C(0)), | ||||||
|     Size(~UINT64_C(0)), |     Size(~UINT64_C(0)), | ||||||
|  |     AddressSize(~UINT64_C(0)), | ||||||
|     FileSize(~UINT64_C(0)), |     FileSize(~UINT64_C(0)), | ||||||
|     HasInstructions(false) |     HasInstructions(false) | ||||||
| { | { | ||||||
| @@ -434,7 +443,8 @@ void MCAssembler::LayoutSection(MCAsmLayout &Layout, | |||||||
|   uint64_t StartAddress = 0; |   uint64_t StartAddress = 0; | ||||||
|   if (SectionOrderIndex) { |   if (SectionOrderIndex) { | ||||||
|     MCSectionData *Prev = Layout.getSectionOrder()[SectionOrderIndex - 1]; |     MCSectionData *Prev = Layout.getSectionOrder()[SectionOrderIndex - 1]; | ||||||
|     StartAddress = Layout.getSectionAddress(Prev) + Layout.getSectionSize(Prev); |     StartAddress = (Layout.getSectionAddress(Prev) + | ||||||
|  |                     Layout.getSectionAddressSize(Prev)); | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   // Align this section if necessary by adding padding bytes to the previous |   // Align this section if necessary by adding padding bytes to the previous | ||||||
| @@ -465,6 +475,7 @@ void MCAssembler::LayoutSection(MCAsmLayout &Layout, | |||||||
|     Size = Layout.getFragmentOffset(F) + Layout.getFragmentEffectiveSize(F); |     Size = Layout.getFragmentOffset(F) + Layout.getFragmentEffectiveSize(F); | ||||||
|   } |   } | ||||||
|   Layout.setSectionSize(&SD, Size); |   Layout.setSectionSize(&SD, Size); | ||||||
|  |   Layout.setSectionAddressSize(&SD, Size); | ||||||
|   Layout.setSectionFileSize(&SD, IsVirtual ? 0 : Size); |   Layout.setSectionFileSize(&SD, IsVirtual ? 0 : Size); | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -837,9 +848,7 @@ void MCFragment::dump() { | |||||||
|   raw_ostream &OS = llvm::errs(); |   raw_ostream &OS = llvm::errs(); | ||||||
|  |  | ||||||
|   OS << "<MCFragment " << (void*) this << " Offset:" << Offset |   OS << "<MCFragment " << (void*) this << " Offset:" << Offset | ||||||
|      << " EffectiveSize:" << EffectiveSize; |      << " EffectiveSize:" << EffectiveSize << ">"; | ||||||
|  |  | ||||||
|   OS << ">"; |  | ||||||
| } | } | ||||||
|  |  | ||||||
| void MCAlignFragment::dump() { | void MCAlignFragment::dump() { | ||||||
| @@ -914,8 +923,8 @@ void MCSectionData::dump() { | |||||||
|  |  | ||||||
|   OS << "<MCSectionData"; |   OS << "<MCSectionData"; | ||||||
|   OS << " Alignment:" << getAlignment() << " Address:" << Address |   OS << " Alignment:" << getAlignment() << " Address:" << Address | ||||||
|      << " Size:" << Size << " FileSize:" << FileSize |      << " Size:" << Size << " AddressSize:" << AddressSize | ||||||
|      << " Fragments:[\n      "; |      << " FileSize:" << FileSize << " Fragments:[\n      "; | ||||||
|   for (iterator it = begin(), ie = end(); it != ie; ++it) { |   for (iterator it = begin(), ie = end(); it != ie; ++it) { | ||||||
|     if (it != begin()) OS << ",\n      "; |     if (it != begin()) OS << ",\n      "; | ||||||
|     it->dump(); |     it->dump(); | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user