diff options
author | Alexandre Oliva <oliva@adacore.com> | 2024-07-03 07:33:00 -0300 |
---|---|---|
committer | Alexandre Oliva <oliva@gnu.org> | 2024-07-03 07:44:33 -0300 |
commit | 113c4826f5e1ff88a9e1625980ff0b617583279c (patch) | |
tree | 9e9e504954cd255ac02c9b905d914c92947c66a9 /gcc/ada/gcc-interface/utils.cc | |
parent | bf2fc0a27b35de039c3d45e6d7ea9ad0a8a305ba (diff) | |
download | gcc-113c4826f5e1ff88a9e1625980ff0b617583279c.zip gcc-113c4826f5e1ff88a9e1625980ff0b617583279c.tar.gz gcc-113c4826f5e1ff88a9e1625980ff0b617583279c.tar.bz2 |
[debug] Avoid dropping bits from num/den in fixed-point types
We used to use an unsigned 128-bit type to hold the numerator and
denominator used to represent the delta of a fixed-point type in debug
information, but there are cases in which that was not enough, and
more significant bits silently overflowed and got omitted from debug
information.
Introduce a mode in which UI_to_gnu selects a wide-enough unsigned
type, and use that to convert numerator and denominator. While at
that, avoid exceeding the maximum precision for wide ints, and for
available int modes, when selecting a type to represent very wide
constants, falling back to 0/0 for unrepresentable fractions.
for gcc/ada/ChangeLog
* gcc-interface/cuintp.cc (UI_To_gnu): Add mode that selects a
wide enough unsigned type. Fail if the constant exceeds the
representable numbers.
* gcc-interface/decl.cc (gnat_to_gnu_entity): Use it for
numerator and denominator of fixed-point types. In case of
failure, fall back to an indeterminate fraction.
Diffstat (limited to 'gcc/ada/gcc-interface/utils.cc')
0 files changed, 0 insertions, 0 deletions