summaryrefslogtreecommitdiff
path: root/gcc/doc/match-and-simplify.texi
diff options
context:
space:
mode:
authorrguenth <rguenth@138bc75d-0d04-0410-961f-82ee72b054a4>2015-09-14 09:40:17 +0000
committerrguenth <rguenth@138bc75d-0d04-0410-961f-82ee72b054a4>2015-09-14 09:40:17 +0000
commita6b9137e4b11feb3150ae0addf5533755201d210 (patch)
tree0c1dd8f5b516a50f05e46cddd6b3b039265277ae /gcc/doc/match-and-simplify.texi
parent546e705f38aa5c125cc29469d3c8f1b789cf788a (diff)
downloadgcc-a6b9137e4b11feb3150ae0addf5533755201d210.tar.gz
2015-09-14 Richard Biener <rguenther@suse.de>
* doc/match-and-simplify.texi: Update for changed syntax of inner ifs and the new switch expression. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@227741 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'gcc/doc/match-and-simplify.texi')
-rw-r--r--gcc/doc/match-and-simplify.texi52
1 files changed, 47 insertions, 5 deletions
diff --git a/gcc/doc/match-and-simplify.texi b/gcc/doc/match-and-simplify.texi
index 2591ed835cd..2bf23204151 100644
--- a/gcc/doc/match-and-simplify.texi
+++ b/gcc/doc/match-and-simplify.texi
@@ -118,8 +118,8 @@ be a valid GIMPLE operand (so you cannot generate expressions in C code).
@smallexample
(simplify
(trunc_mod integer_zerop@@0 @@1)
- (if (!integer_zerop (@@1)))
- @@0)
+ (if (!integer_zerop (@@1))
+ @@0))
@end smallexample
Here @code{@@0} captures the first operand of the trunc_mod expression
@@ -130,9 +130,11 @@ can be unconstrained or capture expresions or predicates.
This example introduces an optional operand of simplify,
the if-expression. This condition is evaluated after the
expression matched in the IL and is required to evaluate to true
-to enable the replacement expression. The expression operand
-of the @code{if} is a standard C expression which may contain references
-to captures.
+to enable the replacement expression in the second operand
+position. The expression operand of the @code{if} is a standard C
+expression which may contain references to captures. The @code{if}
+has an optional third operand which may contain the replacement
+expression that is enabled when the condition evaluates to false.
A @code{if} expression can be used to specify a common condition
for multiple simplify patterns, avoiding the need
@@ -149,8 +151,48 @@ to repeat that multiple times:
(negate @@1)))
@end smallexample
+Note that @code{if}s in outer position do not have the optional
+else clause but instead have multiple then clauses.
+
Ifs can be nested.
+There exists a @code{switch} expression which can be used to
+chain conditions avoiding nesting @code{if}s too much:
+
+@smallexample
+(simplify
+ (simple_comparison @@0 REAL_CST@@1)
+ (switch
+ /* a CMP (-0) -> a CMP 0 */
+ (if (REAL_VALUE_MINUS_ZERO (TREE_REAL_CST (@@1)))
+ (cmp @@0 @{ build_real (TREE_TYPE (@@1), dconst0); @}))
+ /* x != NaN is always true, other ops are always false. */
+ (if (REAL_VALUE_ISNAN (TREE_REAL_CST (@@1))
+ && ! HONOR_SNANS (@@1))
+ @{ constant_boolean_node (cmp == NE_EXPR, type); @})))
+@end smallexample
+
+Is equal to
+
+@smallexample
+(simplify
+ (simple_comparison @@0 REAL_CST@@1)
+ (switch
+ /* a CMP (-0) -> a CMP 0 */
+ (if (REAL_VALUE_MINUS_ZERO (TREE_REAL_CST (@@1)))
+ (cmp @@0 @{ build_real (TREE_TYPE (@@1), dconst0); @})
+ /* x != NaN is always true, other ops are always false. */
+ (if (REAL_VALUE_ISNAN (TREE_REAL_CST (@@1))
+ && ! HONOR_SNANS (@@1))
+ @{ constant_boolean_node (cmp == NE_EXPR, type); @}))))
+@end smallexample
+
+which has the second @code{if} in the else operand of the first.
+The @code{switch} expression takes @code{if} expressions as
+operands (which may not have else clauses) and as a last operand
+a replacement expression which should be enabled by default if
+no other condition evaluated to true.
+
Captures can also be used for capturing results of sub-expressions.
@smallexample