https://gcc.gnu.org/bugzilla/show_bug.cgi?id=122296

--- Comment #7 from GCC Commits <cvs-commit at gcc dot gnu.org> ---
The trunk branch has been updated by Andrew Pinski <[email protected]>:

https://gcc.gnu.org/g:eb717a8f4ea9f5eebb3d5add0ca4a33d74febd1a

commit r16-4463-geb717a8f4ea9f5eebb3d5add0ca4a33d74febd1a
Author: Andrew Pinski <[email protected]>
Date:   Thu Oct 16 17:02:52 2025 -0700

    match: Fix (a != b) | ((a|b) != 0) and (a == b) & ((a|b) == 0) match
pattern [PR122296]

    There are 2 fixes for these 2 patterns.
    1) Reuse the (a|b) expression instead of recreating it
       Fixed by capturing the bit_ior expression and using that instead
       of a new expression.
    2) Use the correct 0. Fixed by capturing the integer_zerop and using that
       instead of integer_zero_node.

    2) could be fuxed by using `build_cst_zero (TREE_TYPE (@0))` But since
    we already have the correct 0, capturing it would be faster.

    Pushed as obvious after a bootstrap/test on x86_64-linux-gnu.

            PR tree-optimization/122296

    gcc/ChangeLog:

            * match.pd (`(a != b) | ((a|b) != 0)`): Reuse both
            the ior and zero instead of recreating them.
            (`(a == b) & ((a|b) == 0)`): Likewise

    gcc/testsuite/ChangeLog:

            * gcc.dg/torture/int-bwise-opt-1.c: New test.

    Signed-off-by: Andrew Pinski <[email protected]>

Reply via email to