[PATCH] D34673: [ELF] - Do not set st_size field of SHT_UNDEF symbols

Rui Ueyama via Phabricator via llvm-commits llvm-commits at lists.llvm.org
Tue Jun 27 11:10:37 PDT 2017


ruiu added a comment.

LGTM with comment change.



================
Comment at: ELF/SyntheticSections.cpp:1388-1392
+    // Do not set size for undefined symbols. This size is unreliable for case
+    // when linking DSO which links to another DSO. In that case it is possible
+    // that low level DSO may be changed in the way that alters symbol size. In
+    // such case if high-level DSO is rebuilt, its CRC will change, what may be
+    // undesirable. It is possible to avoid if we set st_size to zero.
----------------
It seems this comment describes something too specific. The most important part is that the size field for the undefined symbol is not significant, so it can be any value. You didn't mention that. I'd write:

  // Copy symbol size if it is a defined symbol. st_size is not significant for undefined symbols,
  // so whether copying it or not is up to us if that's the case. We'll leave it as zero
  // because by not setting a value, we can get the exact same outputs for two sets of input files that
  // differ only in undefined symbol size in DSOs.
  if (ESym->st_shndx != SHN_UNDEF)
    ESym->st_size = Body->getSize<ELFT>();


https://reviews.llvm.org/D34673





More information about the llvm-commits mailing list