dblaikie added a comment.

> And another problem here is, without LTO, the function definitions in other 
> TU can't be inlined. But now, the function definitions in the module 
> interface can be imported to the importee as AvaialableExternally linkage 
> with optimization. The AvaialableExternally linkage is a special linkage 
> which aims for the IPO. And the AvaialableExternally entities would be 
> removed in the middle end after inlining. (I know there are arguments to 
> remove the function definition in the module file.) So if we move not 
> directly used things in .cpp files, the performance will be hurt. But it is 
> not the case for modules (at least for now).

Yeah, I think if we're planning to minimize pcms to the point where they can't 
do code generation I guess we'll probably remove the indirect function 
definitions/not use available externally, and rely on (Thin)LTO to provide 
whole program optimization - so the guidance that modules reduces link time 
wouldn't be true in that case.

I think it's probably best to abandon this patch/not document/suggest that this 
is a benefit people should expect from modules if it's one that'd go away in 
the future anyway.


Repository:
  rG LLVM Github Monorepo

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

https://reviews.llvm.org/D138552

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

Reply via email to