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

--- Comment #2 from GCC Commits <cvs-commit at gcc dot gnu.org> ---
The master branch has been updated by Jakub Jelinek <ja...@gcc.gnu.org>:

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

commit r14-6306-gb5cfbb8f4cceb621d6812eec3e0fb876b648241c
Author: Jakub Jelinek <ja...@redhat.com>
Date:   Fri Dec 8 09:02:15 2023 +0100

    vr-values: Avoid ICEs on large _BitInt cast to floating point [PR112901]

    For casts from integers to floating point,
    simplify_float_conversion_using_ranges uses SCALAR_INT_TYPE_MODE
    and queries optabs on the optimization it wants to make.

    That doesn't really work for large/huge BITINT_TYPE, those have BLKmode
    which is not scalar int mode.  Querying an optab is not useful for that
    either.

    I think it is best to just skip this optimization for those bitints,
    after all, bitint lowering uses ranges already to determine minimum
    precision for bitint operands of the integer to float casts.

    2023-12-08  Jakub Jelinek  <ja...@redhat.com>

            PR tree-optimization/112901
            * vr-values.cc
            (simplify_using_ranges::simplify_float_conversion_using_ranges):
            Return false if rhs1 has BITINT_TYPE type with BLKmode TYPE_MODE.

            * gcc.dg/bitint-51.c: New test.

Reply via email to