diff options
author | Yang Yujie <yangyujie@loongson.cn> | 2025-08-06 12:03:39 +0200 |
---|---|---|
committer | Jakub Jelinek <jakub@gcc.gnu.org> | 2025-08-06 12:03:39 +0200 |
commit | 94d2bc6d08caad947a8897a538f2a9b64e16a11a (patch) | |
tree | 415710c9994d02a32c4ee1ce493fec1457909861 /libjava/classpath | |
parent | 88f638e276c25e216b3d01c0d7aa25a0d17921d9 (diff) | |
download | gcc-94d2bc6d08caad947a8897a538f2a9b64e16a11a.zip gcc-94d2bc6d08caad947a8897a538f2a9b64e16a11a.tar.gz gcc-94d2bc6d08caad947a8897a538f2a9b64e16a11a.tar.bz2 |
bitint: Zero-extend the result of a signed->unsigned widening cast
A widening cast from a signed _BitInt operand to an unsigned _BitInt
type involves filling the extra limb(s) with sign extension.
On a target that wants _BitInts extended in memory, if this unsigned
type has a partial limb, the unused part of it should be zeroed.
e.g. Assuming limb_mode == E_DImode, at the end of
void
test (unsigned _BitInt(519) *t, _BitInt(512) x)
{
*t = -x;
}
the most significant limb of *t should be masked with 0x7f.
This patch also fixes gcc.dg/torture/bitint-16.c, which aborts at -O2
when the extension on load is optimized away.
* gimple-lower-bitint.cc (bitint_large_huge::lower_mergeable_stmt):
Zero-extend the partial limb of any unsigned _BitInt LHS assigned
with a widening sign-extension.
* gcc.dg/torture/bitint-83.c: New test.
Diffstat (limited to 'libjava/classpath')
0 files changed, 0 insertions, 0 deletions