<div dir="ltr"><br><div class="gmail_extra"><br><div class="gmail_quote">On Tue, Jan 24, 2017 at 10:58 AM, Xinliang David Li <span dir="ltr"><<a href="mailto:davidxl@google.com" target="_blank">davidxl@google.com</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div dir="ltr"><br><div class="gmail_extra"><br><div class="gmail_quote"><span class="">On Tue, Jan 24, 2017 at 10:49 AM, Rong Xu <span dir="ltr"><<a href="mailto:xur@google.com" target="_blank">xur@google.com</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div dir="ltr"><br><div class="gmail_extra"><br><div class="gmail_quote"><span>On Mon, Jan 23, 2017 at 10:22 AM, David Li via Phabricator <span dir="ltr"><<a href="mailto:reviews@reviews.llvm.org" target="_blank">reviews@reviews.llvm.org</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">davidxl added a comment.<br>
<br>
A general comment.<br>
<br>
The range profiling should not be limited to just memory intrinsics.  It should be designed to be a more general interval profiler. Interval profiler is also useful for other value profiling transformations such as mod operation for integer values (x%y). The value profiler can do interval profiling for division x/y and track resulting values in interval [0, 1].<br></blockquote><div><br></div></span><div>why do we need to track the result? I think usually we profile the divisor. Current code can track the range of divisor. The only issue is that I assume the type to be unsigned.</div></div></div></div></blockquote><div><br></div></span><div>There are two types of value profiling related to div/mod. The one I mentioned is for 'mod' operation: </div><div><br></div><div>if the value of x/y is mostly 0,</div><div><br></div><div>x%y can be transformed into</div><div><br></div><div> if (x < y)</div><div>    return x;</div><div> ..</div><div><br></div><div>if 1 is also one of the hot target value of x/y, x%y can be transformed like</div><div>  if (y > x - y)</div><div>     return x-y;</div><div><br></div><div>In other words, we only care about values in range [0,1].</div></div></div></div></blockquote><div><br></div><div>OK. this can be handled in current implementation. </div><div><br></div><div>I thought we also wanted to do power of 2 value profiling to convert operation to bit operation. </div><div>but anyway, that's another instrumentation.  </div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div dir="ltr"><div class="gmail_extra"><div class="gmail_quote"><span class=""><div><br></div><div> </div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div dir="ltr"><div class="gmail_extra"><div class="gmail_quote"><span><div><br></div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
<br>
In a more general form, an interval profiler API should specify the following things<br>
<br>
1. counter index<br>
2. interval start and end (inclusive) : [S, E]<br>
3. optionally specify the start value of a large value range [SL, inf)<br>
<br>
3 + (E-S+1)  values will be tracked:<br>
(-inf, S) one value<br>
[S,E] one for each in the range<br>
[E, SL) one value<br>
[SL, inf) for one.<br>
<br>
The client (instrumentor) decides the the interval boundaries depending on the value profile kind.<br>
<div class="m_1855822334681437843m_-2477187068210679613HOEnZb"><div class="m_1855822334681437843m_-2477187068210679613h5"><br></div></div></blockquote><div><br></div></span><div>Index is obtained incrementally in the instrumentation. I don't think it's necessary to expose it to the API.</div><div>right now, there is options to control the intervals. it's universal to all range profiles.</div><div>I can have the client choose the intervals by including it into the instrumentation intrinsic. </div><span><div><br></div></span></div></div></div></blockquote><div><br></div></span><div>See my later comments about eliminating this change.</div><span class="HOEnZb"><font color="#888888"><div><br></div><div>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 dir="ltr"><div class="gmail_extra"><div class="gmail_quote"><span><div></div><div> </div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div class="m_1855822334681437843m_-2477187068210679613HOEnZb"><div class="m_1855822334681437843m_-2477187068210679613h5">
<br>
Repository:<br>
  rL LLVM<br>
<br>
<a href="https://reviews.llvm.org/D28964" rel="noreferrer" target="_blank">https://reviews.llvm.org/D2896<wbr>4</a><br>
<br>
<br>
<br>
</div></div></blockquote></span></div><br></div></div>
</blockquote></span></div><br></div></div>
</blockquote></div><br></div></div>