[lld] [AArch64][GCS][LLD] Introduce -zgcs-report-dynamic Command Line Option (PR #127787)
Jack Styles via llvm-commits
llvm-commits at lists.llvm.org
Thu Mar 6 03:55:42 PST 2025
================
@@ -1418,6 +1439,38 @@ std::vector<uint32_t> SharedFile::parseVerneed(const ELFFile<ELFT> &obj,
return verneeds;
}
+// To determine if a shared file can support any of the GNU Attributes,
+// the .note.gnu.properties section need to be read. The appropriate
+// location in memory is located then the GnuPropertyNote can be parsed.
+// This is the same process as is used for readGnuProperty, however we
+// do not pass the data variable as, without an InputSection, its value
+// is unknown in a SharedFile. This is ok as the information that would
+// be collected from this is irrelevant for a dynamic object.
+template <typename ELFT>
+void SharedFile::parseGnuAndFeatures(const uint8_t *base,
+ const typename ELFT::PhdrRange headers,
+ const typename ELFT::Shdr *sHeader) {
+ if (numElfPhdrs == 0 || sHeader == nullptr)
+ return;
+ uint32_t featureAndType = ctx.arg.emachine == EM_AARCH64
+ ? GNU_PROPERTY_AARCH64_FEATURE_1_AND
+ : GNU_PROPERTY_X86_FEATURE_1_AND;
+
+ for (unsigned i = 0; i < numElfPhdrs; i++) {
+ if (headers[i].p_type != PT_GNU_PROPERTY)
+ continue;
+ const typename ELFT::Note note(
+ *reinterpret_cast<const typename ELFT::Nhdr *>(base +
+ headers[i].p_vaddr));
----------------
Stylie777 wrote:
I will change to `p_offset`. It seems to be working for now not worth the risk. I modelled off the Android Linker which uses `p_vaddr` originally, but `p_offset` does make more sense on reflection.
https://github.com/llvm/llvm-project/pull/127787
More information about the llvm-commits
mailing list