<html><head><meta http-equiv="Content-Type" content="text/html charset=utf-8"></head><body style="word-wrap: break-word; -webkit-nbsp-mode: space; -webkit-line-break: after-white-space;" class=""><br class=""><div><blockquote type="cite" class=""><div class="">On Jun 27, 2017, at 2:48 PM, Xinliang David Li <<a href="mailto:davidxl@google.com" class="">davidxl@google.com</a>> wrote:</div><br class="Apple-interchange-newline"><div class=""><div dir="ltr" class=""><br class=""><div class="gmail_extra"><br class=""><div class="gmail_quote">On Tue, Jun 27, 2017 at 2:41 PM, <span dir="ltr" class=""><<a href="mailto:vsk@apple.com" target="_blank" class="">vsk@apple.com</a>></span> wrote:<br class=""><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div style="word-wrap:break-word" class=""><div class="">With llc, the size of the names section can vary widely depending on the value of -DLLVM_TARGETS_TO_BUILD.</div><div class=""><br class=""></div></div></blockquote><div class=""><br class=""></div><div class="">Sure.</div><div class=""> </div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div style="word-wrap:break-word" class=""><div class=""></div><div class="">Enabling coverage shouldn't increase the name section size much. I only see one place where this happens, and it's relatively cold:</div><div class=""><a href="http://lab.llvm.org:8080/coverage/coverage-reports/llvm/coverage/Users/buildslave/jenkins/sharedspace/clang-stage2-coverage-R@2/llvm/lib/Transforms/Instrumentation/InstrProfiling.cpp.html#L512" target="_blank" class="">http://lab.llvm.org:8080/<wbr class="">coverage/coverage-reports/<wbr class="">llvm/coverage/Users/<wbr class="">buildslave/jenkins/<wbr class="">sharedspace/clang-stage2-<wbr class="">coverage-R@2/llvm/lib/<wbr class="">Transforms/Instrumentation/<wbr class="">InstrProfiling.cpp.html#L512</a></div><div class=""><br class=""></div></div></blockquote><div class=""><br class=""></div><div class=""><br class=""></div><div class="">What is the data set used to create the coverage data there? Looks like the lower Coverage function is called 6 times (aka only 6 modules have coverage data) and on average, each coverage data only references ~2 names. This does not seem typical.</div></div></div></div></div></blockquote><div><br class=""></div>It's check-llvm, check-clang, plus the test suite. lowerCoverageData doesn't get called unless we need to emit empty counter mappings, for things like functions with empty bodies.</div><div><br class=""></div><div>vedant</div><div><br class=""><blockquote type="cite" class=""><div class=""><div dir="ltr" class=""><div class="gmail_extra"><div class="gmail_quote"><div class=""><br class=""></div><div class=""> <br class=""></div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div style="word-wrap:break-word" class=""><div class=""></div><div class=""><br class=""></div><div class=""><span class=""><blockquote type="cite" class=""><div class="">On Jun 27, 2017, at 2:40 PM, Friedman, Eli <<a href="mailto:efriedma@codeaurora.org" target="_blank" class="">efriedma@codeaurora.org</a>> wrote:</div><br class="m_4509745092729201675Apple-interchange-newline"><div class="">
<div text="#000000" bgcolor="#FFFFFF" class="">
<div class="m_4509745092729201675moz-cite-prefix">I get a bunch of unreadable binary.
Output piped to "less":<br class="">
<br class="">
String dump of section '__llvm_prf_names':<br class="">
[ 2]
#<CA>^Ex<DA><D4>is<E3>(^Z<EF>^<wbr class="">O<DD>^P<A9><D5><F7><9B><CB><<wbr class="">FB><A8>d<97>^U<96>O<9F><89><<wbr class="">FB><85>AQ<B4>M<B5><B6>&)Wy~<<wbr class="">FD>C^B\<B0>/$<A5><EA>s<E3><CE><wbr class="">L<97>E$^R<89>Dn<C8>L<84><FF><br class="">
<EF><C7>h<B7><FB><DC>ߊ,=<BC><<wbr class="">BF>$ow~<B0>\<C4><FF>_X<FE><E0><wbr class=""><C7><D1>&<C9>c<F4><E7>^_<AB><<wbr class="">B0><F9>,`<BE>H^Oi1G<BF>{<E3><<wbr class="">D7>({O<8A><E7>S<91>^^^O<B9>7<<wbr class="">BB><CD><F7><F3>C^d<E7>}r("<F8><wbr class="">c^P
P<83><br class="">
<D0><F3>`T^Z<ED><D2><FF>M<B2><<wbr class="">F9>k^X^D/<8B><D5>8<A4><E1>N><<wbr class="">A3><DD>9<C9><E7><DF><F1><F7>c^<wbr class="">B38<9C><F7>^<BF><C2>ߕ^_<D6><<wbr class="">F0>_<F2><BB>]<94><E7><C1><FD><<wbr class="">E9><95>^A3<<9E>^\<B0>{\^O0<CC><wbr class=""><C9>)<CA>r<84><D9>j^H<B3><DC><<wbr class="">F9><F3><EF><B7><FE>
<8C><E1>'L^Q<C9>"<F0><A7>"><<wbr class="">E8><FF><DD>^^V^R<A4><D6><FC>d<<wbr class="">EB>j*oHO<D5>^F<C2>p<D0>^U<82><<wbr class="">EF>^Y!<90><9D>O5;:^TgL<F9>^Y<<wbr class="">D3>z<D5>#=<81><E1><C3>6<C4>^\<wbr class="">u%<85>7<EE>^Jaf^D0C<8B><8C>r^<wbr class="">D^E<9D><B5>^W^L<A3>dx<FA><A3><wbr class="">1<FE><88>l^OO<AB>^Z<80>^\~^I<<wbr class="">EE><DE>^O>]V~c<C9>^D<B7><88>[<wbr class="">4|0^R<89><B5>ʳ<96><D7>Ӽ<E7><<wbr class="">F9>^D<EB>^<BF><A5><9B>Mr^Ht<<wbr class="">CC>A^PP<EF><br class="">
<8D>n<BA><89>q<91><DE><br class=""></div></div></div></blockquote><div class=""><br class=""></div></span><div class="">This looks compressed to me.</div><span class="HOEnZb"><font color="#888888" class=""><div class=""><br class=""></div></font></span></div></div></blockquote><div class=""><br class=""></div><div class="">Yes.</div><div class=""><br class=""></div><div class="">David</div><div class=""> </div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div style="word-wrap:break-word" class=""><div class=""><span class="HOEnZb"><font color="#888888" class=""><div class=""></div><div class="">vedant</div></font></span><div class=""><div class="h5"><div class=""><br class=""></div><br class=""><blockquote type="cite" class=""><div class=""><div text="#000000" bgcolor="#FFFFFF" class=""><div class="m_4509745092729201675moz-cite-prefix">
<br class="">
-Eli<br class="">
<br class="">
On 6/27/2017 2:32 PM, Xinliang David Li wrote:<br class="">
</div>
<blockquote type="cite" class="">
<div dir="ltr" class="">I had an old build of llc with FE instrumentation,
the name section size is about 5MB. Using coverage is likely to
cause the name section to be larger as there are more references
to dead/unused function names.
<div class=""><br class="">
</div>
<div class="">What do you see when </div>
<div class=""><br class="">
</div>
<div class="">readelf --string-dump=__llvm_prf_names llc</div>
<div class=""><br class="">
</div>
<div class="">David</div>
</div>
<div class="gmail_extra"><br class="">
<div class="gmail_quote">On Tue, Jun 27, 2017 at 2:23 PM,
Xinliang David Li <span dir="ltr" class=""><<a href="mailto:davidxl@google.com" target="_blank" class="">davidxl@google.com</a>></span>
wrote:<br class="">
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
<div dir="ltr" class=""><br class="">
<div class="gmail_extra"><br class="">
<div class="gmail_quote"><span class="">On Tue, Jun 27,
2017 at 2:09 PM, Friedman, Eli <span dir="ltr" class=""><<a href="mailto:efriedma@codeaurora.org" target="_blank" class="">efriedma@codeaurora.org</a>></span>
wrote:<br class="">
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
<div text="#000000" bgcolor="#FFFFFF" class=""><span class="">
<div class="m_4509745092729201675m_-8320681835050143414m_-4689985255915253797moz-cite-prefix">On
6/27/2017 1:47 PM, Xinliang David Li wrote:<br class="">
</div>
<blockquote type="cite" class="">
<div dir="ltr" class=""><br class="">
<div class="gmail_extra"><br class="">
<div class="gmail_quote">On Mon, Jun 26,
2017 at 7:24 PM, Friedman, Eli <span dir="ltr" class=""><<a href="mailto:efriedma@codeaurora.org" target="_blank" class="">efriedma@codeaurora.org</a>></span>
wrote:<br class="">
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
<div text="#000000" bgcolor="#FFFFFF" class=""><span class="">
<div class="m_4509745092729201675m_-8320681835050143414m_-4689985255915253797m_-8178743545387745684moz-cite-prefix">On
6/19/2017 7:29 PM, Vedant
Kumar wrote:<br class="">
</div>
<blockquote type="cite" class=""><br class="">
<div class="">
<blockquote type="cite" class="">
<div class="">
<div text="#000000" bgcolor="#FFFFFF" class="">
<blockquote type="cite" class="">
<div class="">
<div class="">
<div class="">We can
reduce testing
time by *not*
instrumented
basic tools
like count,
not, FileCheck
etc. I filed:
<a href="http://llvm.org/PR33501" target="_blank" class="">llvm.org/PR33501</a>.</div>
<div class=""><br class="">
</div>
<blockquote type="cite" class="">
<div class="">
<div class="">3. The
generated
profile
information
takes up a lot
of space: llc
generates a
90MB profraw
file.<br class="">
</div>
</div>
</blockquote>
<div class=""><br class="">
</div>
<div class="">I don't
have any ideas
about how to
fix this. You
can decrease
the space
overhead for
raw profiles
by altering <span class="">LLVM_PROFILE_</span><span class="">MERGE_P</span><span class="">O<wbr class="">OL_SIZE
from 4 to a
lower value.</span></div>
</div>
</div>
</blockquote>
<br class="">
Disk space is cheap,
but the I/O takes a
long time. I guess
it's specifically bad
for LLVM's "make
check", maybe not so
bad for other cases.<br class="">
</div>
</div>
</blockquote>
<div class=""><br class="">
</div>
<div class="">You can speed up "make
check" a bit by using
non-instrumented versions
of count, not, FileCheck,
etc.</div>
</div>
</blockquote>
<br class="">
</span> I tried looking into this
a bit more. It looks like the
profile data file generated by llc
contains approximately 5MB of
counters (__llvm_prf_cnts), 10MB
of "data" (__llvm_prf_data), and
70MB of __llvm_prf_names.
__llvm_prf_data and
__llvm_prf_names contain which can
be read from the original binary,
as far as I can tell. The 80MB of
data wouldn't be a big deal if it
were just sitting on disk... but
we also erase the whole file and
rewrite it from scratch after we
merge profile counters.<br class="">
<br class="">
</div>
</blockquote>
<div class=""><br class="">
</div>
<div class="">Can you check if name compression
is turned on in your build? </div>
<div class=""><br class="">
</div>
<div class="">David</div>
<br class="">
</div>
</div>
</div>
</blockquote>
<br class="">
</span> I think it is. At least, I didn't
intentionally turn it off, and examining the
file with objdump I don't see any uncompressed
strings. Not sure if there's any easy way to
confirm that.</div>
</blockquote>
<div class=""><br class="">
</div>
<div class=""><br class="">
</div>
</span>
<div class="">Just a little surprised at the size of
__llvm_prf_names section. The llc I built with IR
PGO has a __llvm_prf_names section with size
~1.4MB. I expect FE instrumentation to produce
larger name section size, but not so much bigger.</div>
<span class="m_4509745092729201675HOEnZb"><font color="#888888" class="">
<div class=""><br class="">
</div>
<div class="">David</div>
</font></span><span class="">
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
<div text="#000000" bgcolor="#FFFFFF" class=""><span class=""><br class=""><p class="">-Eli<br class="">
</p>
<pre class="m_4509745092729201675m_-8320681835050143414m_-4689985255915253797moz-signature" cols="72">--
Employee of Qualcomm Innovation Center, Inc.
Qualcomm Innovation Center, Inc. is a member of Code Aurora Forum, a Linux Foundation Collaborative Project</pre>
</span></div>
</blockquote>
</span></div>
<br class="">
</div>
</div>
</blockquote>
</div>
<br class="">
</div>
</blockquote><p class=""><br class="">
</p>
<pre class="m_4509745092729201675moz-signature" cols="72">--
Employee of Qualcomm Innovation Center, Inc.
Qualcomm Innovation Center, Inc. is a member of Code Aurora Forum, a Linux Foundation Collaborative Project</pre>
</div>
</div></blockquote></div></div></div><br class=""></div></blockquote></div><br class=""></div></div>
</div></blockquote></div><br class=""></body></html>