<div class="gmail_extra"><div class="gmail_quote">On Fri, Apr 27, 2012 at 3:10 PM, Jakob Stoklund Olesen <span dir="ltr"><<a href="mailto:stoklund@2pi.dk" target="_blank">stoklund@2pi.dk</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
<div style="word-wrap:break-word"><br><div><div><div class="h5"><div>On Apr 27, 2012, at 2:31 PM, Andrew Trick wrote:</div><br><blockquote type="cite"><div style="word-wrap:break-word"><br><div><div>On Apr 26, 2012, at 10:48 PM, Evan Cheng <<a href="mailto:evan.cheng@apple.com" target="_blank">evan.cheng@apple.com</a>> wrote:</div>
<br><blockquote type="cite"><span style="font-family:Helvetica;font-size:medium;font-style:normal;font-variant:normal;font-weight:normal;letter-spacing:normal;line-height:normal;text-align:-webkit-auto;text-indent:0px;text-transform:none;white-space:normal;word-spacing:0px;display:inline!important;float:none">That seems like a BranchProbabilityInfo deficiency. Andy, what do you think? Benjamin, can you point us to examples of long select chains? Are they in real world benchmarks?</span></blockquote>
</div><div><br></div><div>Rhetorical question: If we have profile data or simple static heuristics that suggest a biased branch, should we really have turned it into a select?</div><div>Obvious answer: the front end doesn't want to know about condition probabilities.</div>
<div><br></div><div>...but handling this in any branch profiler won't be clean.</div><div><br></div><div>We'll probably have to plop metadata on the select if we really care that much. When we convert back to control flow, it will be easy to move the metadata to the branch's MD_prof and update BranchProbability if needed. It doesn't seem too hard to add support to LowerExpectIntrinsic.</div>
</div></blockquote><div><br></div></div></div><div>It is not obvious to me that there is a strong correlation between branch bias and branch predictability.</div><div><br></div><div>Branch predictors are much better than 'take the most probable direction'. A 50/50 branch can be perfectly predictable, and conversely a 10/90 branch can be very difficult to predict.</div>
<div><br></div><div>Using branch bias to estimate predictability only makes sense for strongly biased branches.</div></div></div></blockquote><div><br></div><div>Agreed. However, the bias would be useful to reconstitute on any branches formed to represent the select, so that the subsequent codegen passes can make the appropriate decisions...</div>
</div></div>