<div dir="ltr"><div class="gmail_extra">To be clear, TargetParser is about parsing subtarget CPUs and features, right?</div><div class="gmail_extra"><br></div><div class="gmail_extra">I'm not very familiar with how the current system works, but it would be a shame to run tablegen for all targets when the user just wants one backend.</div><div class="gmail_extra"><br>The subtarget feature flags aren't very much data. If I were doing this today, I would make one subtarget info library and put all the subtarget features in there. The subtarget information is far less than the instruction table information. For example:</div><div class="gmail_extra">lib/Target/Subtargets/X86Subtargets.td</div><div class="gmail_extra">lib/Target/Subtargets/ARMSubtargets.td<br></div><div class="gmail_extra">...</div><div class="gmail_extra"><br></div><div class="gmail_extra">Now that we have a lot of backends and lots of out of tree backends, this might be too disruptive. The answer might be that we have to live with duplicating the subtarget features in clang and building some kind of sanity checking mechanism to keep them in sync.</div><div class="gmail_extra"><br><div class="gmail_quote">On Mon, Mar 9, 2015 at 5:02 AM, Renato Golin <span dir="ltr"><<a href="mailto:renato.golin@linaro.org" target="_blank">renato.golin@linaro.org</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-color:rgb(204,204,204);border-left-style:solid;padding-left:1ex">Hi Folks,<br>
<br>
I'm back looking at the target parser that we discussed last year, and<br>
I have some questions.<br>
<br>
<a href="http://lists.cs.uiuc.edu/pipermail/cfe-dev/2014-August/038699.html" target="_blank">http://lists.cs.uiuc.edu/pipermail/cfe-dev/2014-August/038699.html</a><br>
<br>
There is no way I can create a target-independent parser in lib/Target<br>
without re-encoding all the information about the targets that we<br>
already have in the table-gen files on all targets' directories. Doing<br>
that would be folly.<br>
<br>
But building all targets by default goes against the current thinking,<br>
which I quite welcome and think we should not break it. We need to<br>
find a common ground.<br>
<br>
My idea is to build all table-gen files on all targets, but not build<br>
all targets' files and not include them in the final libraries /<br>
binaries. Since the table-gen'ed files don't end up there by<br>
themselves, only what we use from them (in the target parser) will be<br>
included in the final binaries.<br>
<br>
Does that sound like a good idea? If so, how would one go about doing<br>
that? I'm guessing it's a change solely in CMake files, and could be<br>
done independently of the target parser implementation, right?<br>
<br>
cheers,<br>
--renato<br>
_______________________________________________<br>
cfe-dev mailing list<br>
<a href="mailto:cfe-dev@cs.uiuc.edu">cfe-dev@cs.uiuc.edu</a><br>
<a href="http://lists.cs.uiuc.edu/mailman/listinfo/cfe-dev" target="_blank">http://lists.cs.uiuc.edu/mailman/listinfo/cfe-dev</a><br>
</blockquote></div><br></div></div>