<div dir="ltr"><br><div class="gmail_extra"><br><div class="gmail_quote">On Sun, May 7, 2017 at 6:43 AM, Perry E. Metzger via llvm-dev <span dir="ltr"><<a href="mailto:llvm-dev@lists.llvm.org" target="_blank">llvm-dev@lists.llvm.org</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex"><span class="gmail-">On Sat, 6 May 2017 21:38:50 -0700 Sanjoy Das<br>
<<a href="mailto:sanjoy@playingwithpointers.com">sanjoy@playingwithpointers.<wbr>com</a>> wrote:<br>
> Hi Perry,<br>
><br>
> On Sat, May 6, 2017 at 2:55 PM, Perry E. Metzger<br>
> <<a href="mailto:perry@piermont.com">perry@piermont.com</a>> wrote:<br>
> >> Let me put it this way -- I'm pretty sure if you take it on<br>
> >> yourself to answer beginner questions on llvm-dev promptly,<br>
> >> nobody will *complain*.  In fact, you're going to make some<br>
> >> folks happy. :)<br>
> ><br>
> > Sure, but who will answer mine? Part of the reason I asked about<br>
> > this was selfish, as I'd like access to other people in the same<br>
> > situation as me who might know answers. (I don't think the people<br>
> > here now will want to answer more questions, and many of my<br>
> > questions doubtless border on inanely stupid but for the fact<br>
> > that it is hard to find answers in the docs.)<br>
><br>
> I don't see how people who don't have time to answer on llvm-dev<br>
> will find time to answer on some other mailing list.<br>
<br>
</span>My belief was they would be different populations. That is why there<br>
would be a separate list. The other list would attract mostly front<br>
end devs. I would expect front end devs would be both more interested<br>
in a list that discusses mostly things they care about (including IR<br>
changes they need to be aware of) and more interested in mutual<br>
assistance.<br>
<br>
But never mind, it seems that I'm the only person who likes that idea,<br>
so we're ignoring that possibility for the moment.<br>
<span class="gmail-"><br>
> > That said, I'm willing to give it a try, as an experiment. How<br>
> > long should we attempt it for? If that's reasonably agreed to,<br>
> > I'll<br>
><br>
> Depends on how much time you have -- that's the limiting resource<br>
> here.<br>
<br>
</span>By time I meant the question of how long one tries a strategy before<br>
deciding to look for new strategies. :) Given that few questions about<br>
front end things arrive on the -dev list, trying to help answering<br>
them, for the moment, will only require that I attend more closely to<br>
the postings, and that other people make a bit of an effort to answer<br>
"dumb questions" as well.<br>
<br>
Hopefully that will simply work. My skepticism comes from the feeling<br>
that if it was really going to work, it would have already, but<br>
there's no reason not to give it a good faith try.<br>
<br>
On the wider issue:<br>
<br>
LLVM has been transformative. There are now a lot more people<br>
experimenting with compiling languages than ever before (including<br>
me!) because LLVM removes a lot of the pain from constructing<br>
everything past the IR.<br>
<br>
However, until I started working with it personally, I didn't<br>
understand how much work it was to learn how to use it, and much of<br>
that work is because there is a very big gap between the programmers<br>
guide + the tutorial (which makes it all look like you can learn the<br>
whole thing in an afternoon) and what you actually need to figure out<br>
to get things done. Much of what you need you have to puzzle out<br>
painstakingly on your own, trying to make sense of the doxygen docs<br>
and reading code, because there's less written down than one would<br>
hope. Even the IR language reference, which is seemingly complete at<br>
first glance, has some big gaps in it.<br>
<br>
Given good enough resources, though, even more people could be using<br>
LLVM to create compilers, which would be a great thing. And,<br>
selfishly, given better resources, my own work would be easier. :)<br>
Thus my overall interest.<br></blockquote><div><br></div><div>I'm still unclear about what sorts of questions/discussion this audience is interested in. Can you provide a few examples of questions that might be asked, or links to discussions/blog posts on the net that exemplify the type of thing that you would want to happen in the "frontend authors using LLVM" medium you are thinking of?</div><div><br></div><div>For example, looking at the post you linked (<a href="http://lists.llvm.org/pipermail/llvm-dev/2017-March/111526.html">http://lists.llvm.org/pipermail/llvm-dev/2017-March/111526.html</a> the author of which is in this thread I think, hi!), there's not much LLVM-specific about it. In order to generate LLVM IR, it is necessary to understand its semantics. The semantics are mostly C-like, and so the answer to questions like those in the post:</div><div><br></div><div>- How to assign a text to a string variable?</div><div>- How to access for example the 4th element in a heap-allocated array?</div><div>- How to create local variables which are not part of the global scope?</div><div>- How to create complex structures like classes and objects? </div><div><br></div><div>is basically "how would you do it in C"? For example, to assign text to a "string variable", you first have to have a struct that represents you string type, then you do some C-level code to manipulate that data structure. For a class with inheritance, you would put a vptr in your structs and emit vtables. Etc. Then it's just a matter of writing some C code and running it through Clang to see how Clang lowers it to LLVM IR. It shouldn't be too hard to then trace back from the textual IR to the API's (at worst, requiring a small amount of trial and error, at worst looking at small parts of Clang's source code after grepping for AllocaInst or whatever).</div><div><br></div><div>Something like <a href="https://f0rki.gitbooks.io/mapping-high-level-constructs-to-llvm-ir/content/">https://f0rki.gitbooks.io/mapping-high-level-constructs-to-llvm-ir/content/</a> might be useful too, though you could get mostly the same effect by looking at Clang's output.</div><div><br></div><div>For some of the specifics of LLVM IR's SSA form (like phi nodes) working through the Kaleidoscope tutorial should give a feel for how to do it. (for an intro, a video like <a href="https://www.youtube.com/watch?v=haQ2cijhvhE">https://www.youtube.com/watch?v=haQ2cijhvhE</a> by our own Chandler Carruth might be useful).</div><div>  <br></div><div><br></div><div><br></div><div><br></div><div><br></div><div><br></div><div>However, from your other posts, you say something like:</div><div>"People working on front ends typically don't really know everything</div><div>about the innards of LLVM, and thanks to LLVM's very nicely designed</div><div>architecture, we don't need to, we mostly need to know how to</div><div>generate IR and hook up to the rest of the system."</div><div><br></div><div>So it sounds like you're more interested in API usage like IRBuilder, setting up codegen, setting up MC, configuring pass pipelines, etc.? I.e. you have a clear idea about the "big picture" and what you are trying to do, but want to know how that is done in LLVM (e.g. "how do I create a phi node?"). This is a very different kind of question from the ones above.</div><div><br></div><div>On the other hand, "hook it up to the rest of the system" might be referring to general toolchain knowledge (which is again not LLVM specifc). For example object file semantics (i.e. the semantics of what comes out the LLVM backends; there's a lot more to it than just a single blob of machine code) and how that interacts with the rest of the system (e.g. how a malloc declaration in LLVM IR gets actually resolved and called at runtime).</div><div><br></div><div><br></div><div><br></div><div>I'd really like to hear your feedback. I think that historically, Clang has been the dominant frontend and so there hasn't been much impetus for providing certain kinds of documention, but as you mention upthread, there is now a quite large tail of other frontends that are developed outside of the LLVM community, so that might have to change.</div><div><br></div><div>-- Sean Silva</div><div> </div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">
<span class="gmail-"><br>
> However, I liked your idea of maintaining a wiki-like thing.  Both<br>
> <a href="http://llvm.org/docs/Frontend/PerformanceTips.html" rel="noreferrer" target="_blank">http://llvm.org/docs/Frontend/<wbr>PerformanceTips.html</a> and<br>
> <a href="http://llvm.org/docs/tutorial/" rel="noreferrer" target="_blank">http://llvm.org/docs/tutorial/</a> will be good additions there.<br>
<br>
</span>Parts of the programmer's manual<br>
<a href="http://llvm.org/docs/ProgrammersManual.html" rel="noreferrer" target="_blank">http://llvm.org/docs/<wbr>ProgrammersManual.html</a> are also essential, though<br>
for a front end developer, especially one using the C API, not<br>
everything is something you want to know, and it isn't initially<br>
obvious when you need to read closely.<br>
<br>
Anyway, given that you would prefer for it not to be an actual wiki,<br>
what would be lower barrier to entry and Wiki-ish?<br>
<br>
(A big issue with the current workflow, I think, is that for outsiders<br>
submitting documentation updates the process is very heavyweight. Even<br>
the use of svn vs. git increases the amount of work for casual users.<br>
It's just not worth it as it stands for someone to say "hey, please<br>
fix just this one sentence", especially if you've never contributed to<br>
LLVM before. However, often even single sentence edits improve<br>
comprehension. Having a low barrier for small fixes is one of the<br>
reasons Wikipedia grew so fast. Of course, it is also the reason that<br>
policing Wikipedia takes huge effort, so there's a tradeoff.)<br>
<span class="gmail-im gmail-HOEnZb"><br>
<br>
Perry<br>
--<br>
Perry E. Metzger                <a href="mailto:perry@piermont.com">perry@piermont.com</a><br>
</span><div class="gmail-HOEnZb"><div class="gmail-h5">______________________________<wbr>_________________<br>
LLVM Developers mailing list<br>
<a href="mailto:llvm-dev@lists.llvm.org">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/<wbr>mailman/listinfo/llvm-dev</a><br>
</div></div></blockquote></div><br></div></div>