<div dir="ltr"><br><div class="gmail_extra"><br><br><div class="gmail_quote">On Wed, Nov 13, 2013 at 7:58 PM, Rafael Espíndola <span dir="ltr"><<a href="mailto:rafael.espindola@gmail.com" target="_blank">rafael.espindola@gmail.com</a>></span> wrote:<br>
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div class="im">> It sounds like the linker could call lto_module_dispose() right after<br>
> lto_codegen_add_module() to help reduce the memory footprint.  That would be<br>
> a simple linker change.  A slightly larger linker change would be to<br>
> immediately call lto_codegen_add_module() right after<br>
> lto_module_create_from_memory(), then lto_module_dispose().  That is, never<br>
> have any unmerged modules laying around.<br>
><br>
> I have no idea is these sort of changes work for the gold plugin.<br>
<br>
</div>The gold plugin calls lto_codegen_add_module/lto_module_dispose early.<br>
So it looks like Chandler's idea would be a win for gold but a loss<br>
for ld64 right now.<br></blockquote><div><br></div><div>Letting the module own MDNodes may not be a win for gold since it is going to create multiple copies of MDNodes that could be shared with Context owning MDNodes.</div>
<div><br></div><div>For example, with debug info type uniquing, the type nodes can be shared across modules, but with module owning MDNodes, each module will create its own copy of the type nodes. The advantage is that the MDNodes can be deleted easily by deleting the module. It is not clearly a win to me.</div>
<div><br></div><div>Manman</div><div> </div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
<br>
Cheers,<br>
Rafael<br>
</blockquote></div><br></div></div>