mirror of
https://github.com/RPCS3/llvm.git
synced 2025-01-22 18:35:45 +00:00
Add an initial description of a new concept: trap values, and change
the definition of the nsw and nuw flags to make use of it. nsw was introduced to help optimizers answer yes to the following: // Can we change i from i32 to i64 to eliminate the cast inside the loop? for (int i = 0; i < n; ++i) A[i] *= 0.1; // Can we assume that this loop will eventually terminate? for (int i = 0; i <= n; ++i) A[i] *= 0.1; In its current form, it isn't truly sufficient for either. In the first case, if the increment overflows, it'll still have some valid i32 value; sign-extending it will produce a value which is 33 homogeneous sign bits trailed by 31 independent undef bits. If i is promoted to i64, it won't have those same values when it reaches that point. (The compiler could recover here by reasoning about how i is used by the load, but that's a lot more complicated and isn't always possible.) In the second case, there is no value for i which will be greater than n, so having the increment return undef on overflow doesn't help. Trap values are a formalization of some existing concepts that we have about LLVM IR, and give the optimizers a better basis for answering yes to both questions above. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@102140 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
60915146f4
commit
fff6c5332f
@ -89,6 +89,7 @@
|
||||
<li><a href="#complexconstants">Complex Constants</a></li>
|
||||
<li><a href="#globalconstants">Global Variable and Function Addresses</a></li>
|
||||
<li><a href="#undefvalues">Undefined Values</a></li>
|
||||
<li><a href="#trapvalues">Trap Values</a></li>
|
||||
<li><a href="#blockaddress">Addresses of Basic Blocks</a></li>
|
||||
<li><a href="#constantexprs">Constant Expressions</a></li>
|
||||
</ol>
|
||||
@ -2302,6 +2303,34 @@ has undefined behavior.</p>
|
||||
|
||||
</div>
|
||||
|
||||
<!-- ======================================================================= -->
|
||||
<div class="doc_subsection"><a name="trapvalues">Trap Values</a></div>
|
||||
<div class="doc_text">
|
||||
|
||||
<p>Trap values are similar to <a href="undefvalues">undef values</a>, however
|
||||
instead of representing an unspecified bit pattern, they represent the
|
||||
fact that an instruction or constant expression which cannot evoke side
|
||||
effects has nevertheless detected a condition which results in undefined
|
||||
behavior.<p>
|
||||
|
||||
<p>Any non-void instruction or constant expression other than non-intrinsic
|
||||
calls or invokes with a trap operand has trap as its result value.
|
||||
Any instruction with a trap operand which may have side effects emits
|
||||
those side effects as if it had an undef operand instead.</p>
|
||||
|
||||
<p>For example, an <a href="#i_and"><tt>and</tt></a> of a trap value with
|
||||
zero still has a trap value result. Using that value as an index in a
|
||||
<a href="#i_getelementptr"><tt>getelementptr</tt></a> yields a trap
|
||||
result. Using that result as the address of a
|
||||
<a href="#i_store"><tt>store</tt></a> produces undefined behavior.</p>
|
||||
|
||||
<p>There is currently no way of representing a trap constant in the IR; they
|
||||
only exist when produced by certain instructions, such as an
|
||||
<a href="#i_add"><tt>add</tt></a> with the <tt>nsw</tt> flag
|
||||
set, when overflow occurs.</p>
|
||||
|
||||
</div>
|
||||
|
||||
<!-- ======================================================================= -->
|
||||
<div class="doc_subsection"><a name="blockaddress">Addresses of Basic
|
||||
Blocks</a></div>
|
||||
@ -3104,7 +3133,8 @@ Instruction</a> </div>
|
||||
<p><tt>nuw</tt> and <tt>nsw</tt> stand for "No Unsigned Wrap"
|
||||
and "No Signed Wrap", respectively. If the <tt>nuw</tt> and/or
|
||||
<tt>nsw</tt> keywords are present, the result value of the <tt>add</tt>
|
||||
is undefined if unsigned and/or signed overflow, respectively, occurs.</p>
|
||||
is a <a href="#trapvalues">trap value</a> if unsigned and/or signed overflow,
|
||||
respectively, occurs.</p>
|
||||
|
||||
<h5>Example:</h5>
|
||||
<pre>
|
||||
@ -3184,7 +3214,8 @@ Instruction</a> </div>
|
||||
<p><tt>nuw</tt> and <tt>nsw</tt> stand for "No Unsigned Wrap"
|
||||
and "No Signed Wrap", respectively. If the <tt>nuw</tt> and/or
|
||||
<tt>nsw</tt> keywords are present, the result value of the <tt>sub</tt>
|
||||
is undefined if unsigned and/or signed overflow, respectively, occurs.</p>
|
||||
is a <a href="#trapvalues">trap value</a> if unsigned and/or signed overflow,
|
||||
respectively, occurs.</p>
|
||||
|
||||
<h5>Example:</h5>
|
||||
<pre>
|
||||
@ -3270,7 +3301,8 @@ Instruction</a> </div>
|
||||
<p><tt>nuw</tt> and <tt>nsw</tt> stand for "No Unsigned Wrap"
|
||||
and "No Signed Wrap", respectively. If the <tt>nuw</tt> and/or
|
||||
<tt>nsw</tt> keywords are present, the result value of the <tt>mul</tt>
|
||||
is undefined if unsigned and/or signed overflow, respectively, occurs.</p>
|
||||
is a <a href="#trapvalues">trap value</a> if unsigned and/or signed overflow,
|
||||
respectively, occurs.</p>
|
||||
|
||||
<h5>Example:</h5>
|
||||
<pre>
|
||||
|
Loading…
x
Reference in New Issue
Block a user