[Openmp-commits] [openmp] [OpenMP][FIX] Ensure we do not read outside the device image (PR #74669)

Joseph Huber via Openmp-commits openmp-commits at lists.llvm.org
Wed Dec 6 14:47:41 PST 2023


================
@@ -53,9 +57,15 @@ Error GenericGlobalHandlerTy::getGlobalMetadataFromELF(
     const ELF64LE::Shdr &Section, GlobalTy &ImageGlobal) {
 
   // The global's address is computed as the image begin + the ELF section
-  // offset + the ELF symbol value.
-  ImageGlobal.setPtr(advanceVoidPtr(
-      Image.getStart(), Section.sh_offset - Section.sh_addr + Symbol.st_value));
+  // offset + the ELF symbol value except for NOBITS sections that, as the name
+  // suggests, have no bits in the image. We still record the size and use
+  // nullptr to indicate there is no location.
+  if (Section.sh_type == ELF::SHT_NOBITS)
----------------
jhuber6 wrote:

Not directly related, but could we remove this function from `GenericGlobalHandlerTy` and just make this a utility in `Elf.cpp` like `getSymbolAddr` that returns said void pointer?

https://github.com/llvm/llvm-project/pull/74669


More information about the Openmp-commits mailing list