<div dir="ltr"><div>The language requires both sides of the | need to be evaluated. The compiler can't remove the function call if it has side effects.</div><div><br></div><br clear="all"><div><div dir="ltr" class="gmail_signature" data-smartmail="gmail_signature">~Craig</div></div><br></div><br><div class="gmail_quote"><div dir="ltr">On Sun, Aug 19, 2018 at 10:15 PM Shoaib Meenai via llvm-dev <<a href="mailto:llvm-dev@lists.llvm.org">llvm-dev@lists.llvm.org</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">





<div lang="EN-US" link="blue" vlink="purple">
<div class="m_1238067471794601713WordSection1">
<p class="MsoNormal">This is better suited to llvm-dev, so I'm directing it there.<u></u><u></u></p>
<p class="MsoNormal"><u></u> <u></u></p>
<div style="border:none;border-top:solid #b5c4df 1.0pt;padding:3.0pt 0in 0in 0in">
<p class="MsoNormal" style="margin-left:.5in"><b><span style="font-size:12.0pt;color:black">From:
</span></b><span style="font-size:12.0pt;color:black">llvm-commits <<a href="mailto:llvm-commits-bounces@lists.llvm.org" target="_blank">llvm-commits-bounces@lists.llvm.org</a>> on behalf of Qing Shan Zhang via llvm-commits <<a href="mailto:llvm-commits@lists.llvm.org" target="_blank">llvm-commits@lists.llvm.org</a>><br>
<b>Reply-To: </b>Qing Shan Zhang <<a href="mailto:qshanz@cn.ibm.com" target="_blank">qshanz@cn.ibm.com</a>><br>
<b>Date: </b>Sunday, August 19, 2018 at 10:10 PM<br>
<b>To: </b>"<a href="mailto:llvm-commits@lists.llvm.org" target="_blank">llvm-commits@lists.llvm.org</a>" <<a href="mailto:llvm-commits@lists.llvm.org" target="_blank">llvm-commits@lists.llvm.org</a>><br>
<b>Subject: </b>A question about the widely used "xxx | true" inside llvm<u></u><u></u></span></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in"><u></u> <u></u></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in"><span style="font-size:10.0pt;font-family:"Verdana",serif">Hi, guys,<u></u><u></u></span></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in"><span style="font-size:10.0pt;font-family:"Verdana",serif"><u></u> <u></u></span></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in"><span style="font-size:10.0pt;font-family:"Verdana",serif">I notice that, we are widely using the statement "xxx | true" in llvm, such as "return SimplifyCFG(BB) | true;".  I have no idea if there is any downside
 to use the logic operator "||" here. Instead, I indeed see the potential problem to use bitwise operator "|". Because the bitwise operator do not short-circuit and the language std didn't specify the evaluation order for its lhs and rhs expression. That means,
 compiler is free to optimize this statement to "return true". <u></u><u></u></span></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in"><span style="font-size:10.0pt;font-family:"Verdana",serif"><u></u> <u></u></span></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in"><span style="font-size:10.0pt;font-family:"Verdana",serif">In shorts, IMO, it is legal to do the following optimization:<br>
bool bar() {<br>
  return foo() | true;<br>
}<br>
--><br>
bool bar() {<br>
  return true;  // the call to foo() is missing.<u></u><u></u></span></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in"><span style="font-size:10.0pt;font-family:"Verdana",serif">}<u></u><u></u></span></p>
</div>
<div>
<p class="MsoNormal" style="margin-left:.5in"><span style="font-size:10.0pt;font-family:"Verdana",serif"> <br>
Best regards<br>
<br>
steven.zhang(</span><span style="font-size:10.0pt;font-family:"PMingLiU",serif">张</span><span style="font-size:10.0pt;font-family:"MS Mincho"">青山</span><span style="font-size:10.0pt;font-family:"Verdana",serif">)<br>
XLC++ Compiler Frontend Developer<br>
<br>
IBM China Development Lab, Shanghai <br>
Tel: (8621)609-28454 Mobile: +8615900986116<br>
E-mail: <a href="mailto:qshanz@cn.ibm.com" target="_blank">qshanz@cn.ibm.com</a><br>
</span><span style="font-size:10.0pt;font-family:"MS Mincho"">关注</span><span style="font-size:10.0pt;font-family:"Verdana",serif">IBM</span><span style="font-size:10.0pt;font-family:"MS Mincho"">中国</span><span style="font-size:10.0pt;font-family:"PMingLiU",serif">编译</span><span style="font-size:10.0pt;font-family:"MS Mincho"">器开</span><span style="font-size:10.0pt;font-family:"PMingLiU",serif">发团队</span><span style="font-size:10.0pt;font-family:"Verdana",serif">
 - </span><span style="font-size:10.0pt;font-family:"MS Mincho"">新浪微博</span><span style="font-size:10.0pt;font-family:"Verdana",serif">:
<a href="https://urldefense.proofpoint.com/v2/url?u=http-3A__www.weibo.com_ibmcompiler&d=DwMFaQ&c=5VD0RTtNlTh3ycd41b3MUw&r=o3kDXzdBUE3ljQXKeTWOMw&m=Pq-hk0wEUZUsW1TCR5WSeKCTC9p-kFZHFQXEwhAc7-k&s=A_Y7Fzz24WHgMcnZjkQNCxix8GiaTORg0B7J-WtGp9c&e=" target="_blank">
http://www.weibo.com/ibmcompiler</a> | developerWorks: <a href="https://urldefense.proofpoint.com/v2/url?u=http-3A__t.cn_SPHWF4&d=DwMFaQ&c=5VD0RTtNlTh3ycd41b3MUw&r=o3kDXzdBUE3ljQXKeTWOMw&m=Pq-hk0wEUZUsW1TCR5WSeKCTC9p-kFZHFQXEwhAc7-k&s=EJ9ZnKu_kAhWtR9SgL-C_ooRh7TCL-EGc0wAotg4wb4&e=" target="_blank">
http://t.cn/SPHWF4</a><br>
<br>
"All things are difficult before they are easy."<u></u><u></u></span></p>
</div>
<p class="MsoNormal" style="margin-left:.5in"><br>
<br>
<u></u><u></u></p>
</div>
</div>

_______________________________________________<br>
LLVM Developers mailing list<br>
<a href="mailto:llvm-dev@lists.llvm.org" target="_blank">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/mailman/listinfo/llvm-dev</a><br>
</blockquote></div>