aboutsummaryrefslogtreecommitdiff
path: root/gcc/c-family
diff options
context:
space:
mode:
authorXi Ruoyao <xry111@xry111.site>2023-11-24 11:08:19 +0800
committerXi Ruoyao <xry111@xry111.site>2023-12-12 19:21:57 +0800
commit99182ea09f10beca8445396cbab491899536f5c3 (patch)
treed46fecc89e464b5287886d9c79fab280f0134d03 /gcc/c-family
parent0640bc76cd0937069bdeea71aa9e1076d633ed97 (diff)
downloadgcc-99182ea09f10beca8445396cbab491899536f5c3.zip
gcc-99182ea09f10beca8445396cbab491899536f5c3.tar.gz
gcc-99182ea09f10beca8445396cbab491899536f5c3.tar.bz2
Only allow (int)trunc(x) to (int)x simplification with -ffp-int-builtin-inexact [PR107723]
With -fno-fp-int-builtin-inexact, trunc is not allowed to raise FE_INEXACT and it should produce an integral result (if the input is not NaN or Inf). Thus FE_INEXACT should not be raised. But (int)x may raise FE_INEXACT when x is a non-integer, non-NaN, and non-Inf value. C23 recommends to do so in a footnote. Thus we should not simplify (int)trunc(x) to (int)x if -fno-fp-int-builtin-inexact is in-effect. gcc/ChangeLog: PR middle-end/107723 * convert.cc (convert_to_integer_1) [case BUILT_IN_TRUNC]: Break early if !flag_fp_int_builtin_inexact and flag_trapping_math. gcc/testsuite/ChangeLog: PR middle-end/107723 * gcc.dg/torture/builtin-fp-int-inexact-trunc.c: New test.
Diffstat (limited to 'gcc/c-family')
0 files changed, 0 insertions, 0 deletions