diff --git a/docs/LangRef.html b/docs/LangRef.html index 1b94ab5a9a7..8c52a2118eb 100644 --- a/docs/LangRef.html +++ b/docs/LangRef.html @@ -89,6 +89,7 @@
Trap values are similar to undef values, 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.
+ +
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.
+ +For example, an and of a trap value with + zero still has a trap value result. Using that value as an index in a + getelementptr yields a trap + result. Using that result as the address of a + store produces undefined behavior.
+ +There is currently no way of representing a trap constant in the IR; they + only exist when produced by certain instructions, such as an + add with the nsw flag + set, when overflow occurs.
+ +nuw and nsw stand for "No Unsigned Wrap" and "No Signed Wrap", respectively. If the nuw and/or nsw keywords are present, the result value of the add - is undefined if unsigned and/or signed overflow, respectively, occurs.
+ is a trap value if unsigned and/or signed overflow, + respectively, occurs.@@ -3184,7 +3214,8 @@ Instructionnuw and nsw stand for "No Unsigned Wrap" and "No Signed Wrap", respectively. If the nuw and/or nsw keywords are present, the result value of the sub - is undefined if unsigned and/or signed overflow, respectively, occurs.
+ is a trap value if unsigned and/or signed overflow, + respectively, occurs.Example:
@@ -3270,7 +3301,8 @@ Instructionnuw and nsw stand for "No Unsigned Wrap" and "No Signed Wrap", respectively. If the nuw and/or nsw keywords are present, the result value of the mul - is undefined if unsigned and/or signed overflow, respectively, occurs.
+ is a trap value if unsigned and/or signed overflow, + respectively, occurs.Example: