aboutsummaryrefslogtreecommitdiff
path: root/gcc/tree-object-size.cc
diff options
context:
space:
mode:
authorEric Botcazou <ebotcazou@adacore.com>2023-06-30 18:05:34 +0200
committerEric Botcazou <ebotcazou@adacore.com>2023-06-30 18:12:21 +0200
commitdb5d70632a6cb59521e41df7745cacb08d00a3f4 (patch)
tree2b2d8019b85d7f5d2dddfc837a6e2def6fd26c38 /gcc/tree-object-size.cc
parentc3c0ba5436170e01499f4390b7b628a32943a9e2 (diff)
downloadgcc-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