aboutsummaryrefslogtreecommitdiff
path: root/libgo/go/encoding/json/encode.go
diff options
context:
space:
mode:
authorRichard Sandiford <richard.sandiford@arm.com>2020-07-10 19:06:46 +0100
committerRichard Sandiford <richard.sandiford@arm.com>2020-07-10 19:06:46 +0100
commit510125d2272175f47b26227fbe9b8c8c5abfd988 (patch)
treec728707640fde946dd6dc9c70d7b624799a1f2ec /libgo/go/encoding/json/encode.go
parentefe99cca78215e339ba79f0a900a896b4c0a3d36 (diff)
downloadgcc-510125d2272175f47b26227fbe9b8c8c5abfd988.zip
gcc-510125d2272175f47b26227fbe9b8c8c5abfd988.tar.gz
gcc-510125d2272175f47b26227fbe9b8c8c5abfd988.tar.bz2
expr: Move reduce_bit_field target mode check [PR96151]
In some cases, expand_expr_real_2 prefers to use the mode of the caller-suggested target instead of the mode of the expression when passing values to reduce_to_bit_field_precision. E.g.: else if (target == 0) op0 = convert_to_mode (mode, op0, TYPE_UNSIGNED (TREE_TYPE (treeop0))); else { convert_move (target, op0, TYPE_UNSIGNED (TREE_TYPE (treeop0))); op0 = target; } where “op0” might not have “mode” for the “else” branch, but does for all the others. reduce_to_bit_field_precision discards the suggested target if it has the wrong mode. This patch moves that to expand_expr_real_2 instead (conditional on reduce_bit_field). gcc/ PR middle-end/96151 * expr.c (expand_expr_real_2): When reducing bit fields, clear the target if it has a different mode from the expression. (reduce_to_bit_field_precision): Don't do that here. Instead assert that the target already has the correct mode.
Diffstat (limited to 'libgo/go/encoding/json/encode.go')
0 files changed, 0 insertions, 0 deletions