diff options
author | Eric Botcazou <ebotcazou@adacore.com> | 2023-06-30 18:05:34 +0200 |
---|---|---|
committer | Eric Botcazou <ebotcazou@adacore.com> | 2023-06-30 18:12:21 +0200 |
commit | db5d70632a6cb59521e41df7745cacb08d00a3f4 (patch) | |
tree | 2b2d8019b85d7f5d2dddfc837a6e2def6fd26c38 /gcc/tree-object-size.cc | |
parent | c3c0ba5436170e01499f4390b7b628a32943a9e2 (diff) | |
download | gcc-db5d70632a6cb59521e41df7745cacb08d00a3f4.zip gcc-db5d70632a6cb59521e41df7745cacb08d00a3f4.tar.gz gcc-db5d70632a6cb59521e41df7745cacb08d00a3f4.tar.bz2 |
Fix couple of endianness issues in fold_ctor_reference
fold_ctor_reference attempts to use a recursive local processing in order
to call native_encode_expr on the leaf nodes of the constructor, before
falling back to calling native_encode_initializer if this fails.
There are a couple of issues related to endianness present in it:
1) it does not specifically handle integral bit-fields; now these are left
justified on big-endian platforms so cannot be treated like ordinary fields.
2) it does not check that the constructor uses the native storage order.
gcc/
* gimple-fold.cc (fold_array_ctor_reference): Fix head comment.
(fold_nonarray_ctor_reference): Likewise. Specifically deal
with integral bit-fields.
(fold_ctor_reference): Make sure that the constructor uses the
native storage order.
gcc/testsuite/
* gcc.c-torture/execute/20230630-1.c: New test.
* gcc.c-torture/execute/20230630-2.c: Likewise.
* gcc.c-torture/execute/20230630-3.c: Likewise
* gcc.c-torture/execute/20230630-4.c: Likewise
Diffstat (limited to 'gcc/tree-object-size.cc')
0 files changed, 0 insertions, 0 deletions