diff options
author | Richard Biener <rguenther@suse.de> | 2017-07-28 11:27:45 +0000 |
---|---|---|
committer | Richard Biener <rguenth@gcc.gnu.org> | 2017-07-28 11:27:45 +0000 |
commit | 92e29a5e86c8adc88ee17a483d7284d7bb9e090c (patch) | |
tree | 7c89972072bd6357aef834097b5e62e1378d814d /gcc/gimple-fold.c | |
parent | c9b39a4955f56fe609ef54784f7bf48c4cba6b1a (diff) | |
download | gcc-92e29a5e86c8adc88ee17a483d7284d7bb9e090c.zip gcc-92e29a5e86c8adc88ee17a483d7284d7bb9e090c.tar.gz gcc-92e29a5e86c8adc88ee17a483d7284d7bb9e090c.tar.bz2 |
re PR middle-end/81502 (In some cases the data is moved to memory unnecessarily [partial regression])
2017-07-28 Richard Biener <rguenther@suse.de>
PR tree-optimization/81502
* match.pd: Add pattern combining BIT_INSERT_EXPR with
BIT_FIELD_REF.
* tree-cfg.c (verify_expr): Verify types of BIT_FIELD_REF
size/pos operands.
(verify_gimple_assign_ternary): Likewise for BIT_INSERT_EXPR pos.
* gimple-fold.c (maybe_canonicalize_mem_ref_addr): Use bitsizetype
for BIT_FIELD_REF args.
* fold-const.c (make_bit_field_ref): Likewise.
* tree-vect-stmts.c (vectorizable_simd_clone_call): Likewise.
* gcc.target/i386/pr81502.c: New testcase.
From-SVN: r250659
Diffstat (limited to 'gcc/gimple-fold.c')
-rw-r--r-- | gcc/gimple-fold.c | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/gcc/gimple-fold.c b/gcc/gimple-fold.c index d94dc9c..d82d060 100644 --- a/gcc/gimple-fold.c +++ b/gcc/gimple-fold.c @@ -4245,7 +4245,7 @@ maybe_canonicalize_mem_ref_addr (tree *t) TREE_TYPE (*t), TREE_OPERAND (TREE_OPERAND (*t, 0), 0), TYPE_SIZE (TREE_TYPE (*t)), - wide_int_to_tree (sizetype, idx)); + wide_int_to_tree (bitsizetype, idx)); res = true; } } |