rocallahan added a comment.

Sorry for the delayed reply. I just discovered that Phabricator nofications 
were being buried by my mail filters.

In D54747#1312161 <https://reviews.llvm.org/D54747#1312161>, @ruiu wrote:

> What you are doing in this patch is not too complicated and makes sense to 
> me. That said, if actual size saving is not significant as you said in 
> https://github.com/rust-lang/rust/issues/56068#issuecomment-440160568, it may 
> not be worth doing. It seems to me that if debug info is already 2.4GB, 
> shrinking it to 2GB doesn't make much difference.


17% saving for a pretty small and conservative patch seems good to me, but I 
guess it's subjective.

In D54747#1315241 <https://reviews.llvm.org/D54747#1315241>, @ruiu wrote:

> rocallahan, can I ask why Rust passes all object files to the linker and use 
> `-gc-sections` to eliminate unused part of these files?


I'm not a Rust compiler contributor, but my guess is developer ergonomics. Once 
upon a time users manually divided code into translation units, each producing 
an object, file and garbage collection occurred only at the granularity of 
object files. Later `--gc-sections` and `-ffunction-sections` let compilers 
automatically subdivide object files into smaller units and GC with a 
granularity of functions. In Rust each translation unit is a whole module 
(crate); users aren't expected to subdivide libraries into smaller units for GC 
purposes, and in fact aren't able to. Emitting one section per function mostly 
means they don't need to ... except it breaks down with DWARF here.

> One possible way to fix it is to pass `--start-lib` to the linker before any 
> object file paths in the command line. That option gives archive file 
> semantics to object files, so if you option, each object file is treated as 
> if that were in an archive file containing that the single object file. (Note 
> that `--start-lib` is a positional option just like `--start-group`, so all 
> files between `--start-lib` and `--end-lib` get that special treament.)

I will try that and follow up but I don't see how it would make any difference.


Repository:
  rLLD LLVM Linker

CHANGES SINCE LAST ACTION
  https://reviews.llvm.org/D54747/new/

https://reviews.llvm.org/D54747



_______________________________________________
lldb-commits mailing list
lldb-commits@lists.llvm.org
http://lists.llvm.org/cgi-bin/mailman/listinfo/lldb-commits

Reply via email to