diff options
author | Kewen Lin <linkw@linux.ibm.com> | 2022-12-20 21:04:54 -0600 |
---|---|---|
committer | Kewen Lin <linkw@linux.ibm.com> | 2022-12-20 21:04:54 -0600 |
commit | 94cf7a2d95bf6db873cdcc4085a697ad40057957 (patch) | |
tree | 37ca3926fd5fcbb1e8d9ba22b476cbcc2dafb897 | |
parent | 282462b39584ae49eaaa6f53bd44b6cfdc4ccbcb (diff) | |
download | gcc-94cf7a2d95bf6db873cdcc4085a697ad40057957.zip gcc-94cf7a2d95bf6db873cdcc4085a697ad40057957.tar.gz gcc-94cf7a2d95bf6db873cdcc4085a697ad40057957.tar.bz2 |
fold-const: Treat fp conversion to a type with same mode as copy
In function fold_convert_const_real_from_real, when the modes of
two types involved in fp conversion are the same, we can simply
take it as copy, rebuild with the exactly same TREE_REAL_CST and
the target type. It is more efficient and helps to avoid possible
unexpected signalling bit clearing in [1].
[1] https://gcc.gnu.org/pipermail/gcc-patches/2022-December/608533.html
gcc/ChangeLog:
* fold-const.cc (fold_convert_const_real_from_real): Treat floating
point conversion to a type with same mode as copy instead of normal
convertFormat.
-rw-r--r-- | gcc/fold-const.cc | 9 |
1 files changed, 9 insertions, 0 deletions
diff --git a/gcc/fold-const.cc b/gcc/fold-const.cc index 00e2af0..d4ee3b3 100644 --- a/gcc/fold-const.cc +++ b/gcc/fold-const.cc @@ -2178,6 +2178,15 @@ fold_convert_const_real_from_real (tree type, const_tree arg1) REAL_VALUE_TYPE value; tree t; + /* If the underlying modes are the same, simply treat it as + copy and rebuild with TREE_REAL_CST information and the + given type. */ + if (TYPE_MODE (type) == TYPE_MODE (TREE_TYPE (arg1))) + { + t = build_real (type, TREE_REAL_CST (arg1)); + return t; + } + /* Don't perform the operation if flag_signaling_nans is on and the operand is a signaling NaN. */ if (HONOR_SNANS (arg1) |