<div dir="ltr"><div class="gmail_quote"><div dir="ltr">On Wed, Jan 20, 2016 at 7:30 AM Rafael Espíndola <<a href="mailto:llvm-dev@lists.llvm.org">llvm-dev@lists.llvm.org</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">Sorry for being late on this thread.<br>
<br>
I just wanted to say I am strongly on Rui's side on this one.<br>
<br>
There current design is for lld *not* not be a library and I think<br>
that is important. That has saved us a tremendous amount of work for<br>
doing library like code and a lot of design for library interfaces.<br>
The comparison of old and new ELF code is night and day as far as<br>
productivity and performance are concerned. Designing right now would<br>
be premature because it is not clear what commonalities there will be<br>
on how to refactor them.<br>
<br>
For example, both MCJIT and lld apply relocations, but there are<br>
tremendously different options on how to factor this<br>
<br>
* Have MC produce position dependent code and MCJIT would be a bit<br>
more like other jits and not need relocations.<br>
* Move relocation processing to LLVM somewhere and have lld and MCJIT use it.<br>
* Have MC produce shared objects directly, saving MCJIT the<br>
complication of using relocatable objects.<br>
* Have MCJIT use lld as trivial library that implements "ld foo.o -o<br>
foo.so -shared".<br>
<br>
The situation is even less clear for the other parts we are missing in<br>
llvm: objcopy, readelf, etc.<br>
<br>
We have to discuss and prototype these before we can make a decision.<br>
Committing now would be premature design and stall the progress on one<br>
thing we are sure we need: A high quality, bsd  license linker. Lets<br>
get that implemented. While that MCJIT will move along and we will be<br>
in a position to productively discuss what can be shared and at what<br>
cost (complexity and performance).<br>
<br>
Last but not least, anything that is not needed in two different areas<br>
should remain application code. The only point of paying the<br>
complexity of writing a library is if it is used.<br></blockquote><div><br></div><div>I strongly disagree about some of this, but agree about other aspects. I feel like there are two issues conflated here:</div><div><br></div><div>1) Having a fundamentally library-oriented structure of code and design philosophy.</div><div><br></div><div>2) Having general APIs for a library of code that allows it to be reused in different ways by different clients.</div><div><br></div><div>For #1, let me indicate the kinds of things I'm thinking about here:</div><div>- Cannot rely on global state</div><div>- Cannot directly call "exit" (but can call "abort" for *programmer* errors like asserts)</div><div>- Cannot leak memory</div><div><br></div><div>There are probably others, but this is the gist of it. Now, you could still design everything with the simplest imaginable API, that is incredibly narrow and specialized for a *single* user. But there are still fundamentals of the style of code that are absolutely necessary to build a library. And the only way to make sure we get this right, is to have the single user of the code use it as a library and keep all the business logic inside the library.</div><div><br></div><div>This pattern is fundamental to literally every part of LLVM, including Clang, LLDB, and thus far LLD. I think it is a core principle of the project as a whole. I think that unless LLD continues to follow this principle, it doesn't really fit in the LLVM project at all.</div><div><br></div><div><br></div><div>But for #2, I actually completely agree with you. We will never guess the *right* general purpose API for different users to share logic until we actually have those different users. I very much like lazy design of APIs as users for those APIs arrive. It's one of the reasons I'm so strongly in favor of the lack of API stability in LLVM -- it *allows* us to figure these APIs out as the actual use cases emerge and we learn what they need to do.</div><div><br></div><div>One of the nice things about changing APIs though is that there tends to be a clear incremental path to evolve the API. But if your code doesn't use basic memory management techniques, or if even reportable errors (as opposed to asserted programmer errors) are inherently fatal, fixing that can be incredibly hard and present a huge barrier to adoption of the library.</div><div><br></div><div><br></div><div>So, I encourage LLD to keep its interfaces highly specialized for the users it actually has -- and indeed today that may be exactly one user, the command line linker.</div><div><br></div><div>But when a new user for the libraries arrives, it needs to adapt to support an API that they can use, provided the use case is reasonable for the LLD code to support.</div><div><br></div><div>And most importantly, it needs to be engineered as at least a fundamentally library oriented body of code.</div><div><br></div><div><br></div><div>Finally, I will directly state that we (Google) have a specific interest in both linking LLD libraries into the Clang executable rather than having separate binaries, and in invoking LLD to link many different executables from a single process. So there is at least one concrete user here today. Now, the API we would need for both of these is *exactly* the API that the existing command line linker would need. But the functionality would have to be reasonable to access via a library call.</div><div><br></div><div>-Chandler</div><div><br></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>
_______________________________________________<br>
LLVM Developers mailing list<br>
<a href="mailto:llvm-dev@lists.llvm.org" target="_blank">llvm-dev@lists.llvm.org</a><br>
<a href="http://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-dev" rel="noreferrer" target="_blank">http://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-dev</a><br>
</blockquote></div></div>