From: Jez Ng Date: Wed, 20 Jul 2022 01:22:27 +0000 (-0400) Subject: [lld-macho] Read in new addrsig format X-Git-Tag: upstream/15.0.7~1141 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=2d889a87fb1c557f67adf9bc6dce90ddef7c7836;p=platform%2Fupstream%2Fllvm.git [lld-macho] Read in new addrsig format The new format uses symbol relocations, as described in {D127637}. Reviewed By: #lld-macho, alx32 Differential Revision: https://reviews.llvm.org/D128938 --- diff --git a/lld/MachO/ICF.cpp b/lld/MachO/ICF.cpp index 2a927b1..34ffd05 100644 --- a/lld/MachO/ICF.cpp +++ b/lld/MachO/ICF.cpp @@ -384,18 +384,13 @@ void macho::markAddrSigSymbols() { continue; assert(addrSigSection->subsections.size() == 1); - Subsection *subSection = &addrSigSection->subsections[0]; - ArrayRef &contents = subSection->isec->data; - - const uint8_t *pData = contents.begin(); - while (pData != contents.end()) { - unsigned size; - const char *err; - uint32_t symIndex = decodeULEB128(pData, &size, contents.end(), &err); - if (err) - fatal(toString(file) + ": could not decode addrsig section: " + err); - markSymAsAddrSig(obj->symbols[symIndex]); - pData += size; + const InputSection *isec = addrSigSection->subsections[0].isec; + + for (const Reloc &r : isec->relocs) { + if (auto *sym = r.referent.dyn_cast()) + markSymAsAddrSig(sym); + else + error(toString(isec) + ": unexpected section relocation"); } } }