aboutsummaryrefslogtreecommitdiff
path: root/gcc/expr.c
diff options
context:
space:
mode:
authorJakub Jelinek <jakub@redhat.com>2019-05-06 23:50:14 +0200
committerJakub Jelinek <jakub@gcc.gnu.org>2019-05-06 23:50:14 +0200
commit3afd514bca6ea572e614b5289c4429ace693311b (patch)
tree6cf0ff6dfc80988456a14b05c7a9b0581f0a685d /gcc/expr.c
parent839c480a14f025bdcd73a53d14a19d4cc9a1aea5 (diff)
downloadgcc-3afd514bca6ea572e614b5289c4429ace693311b.zip
gcc-3afd514bca6ea572e614b5289c4429ace693311b.tar.gz
gcc-3afd514bca6ea572e614b5289c4429ace693311b.tar.bz2
re PR tree-optimization/88709 (Improve store-merging)
PR tree-optimization/88709 PR tree-optimization/90271 * params.def (PARAM_STORE_MERGING_MAX_SIZE): New parameter. * gimple-ssa-store-merging.c (encode_tree_to_bitpos): Handle non-clobber CONSTRUCTORs with no elts. Remove useless tmp_int variable. (imm_store_chain_info::coalesce_immediate_stores): Punt if the size of the store merging group is larger than PARAM_STORE_MERGING_MAX_SIZE parameter. (split_group): Add bzero_first argument. If set, always emit first the first store which must be = {} of the whole area and then for the rest of the stores consider all zero bytes as paddings. (imm_store_chain_info::output_merged_store): Check if first store is = {} of the whole area and if yes, determine which setting of bzero_first for split_group gives smaller number of stores. Adjust split_group callers. (lhs_valid_for_store_merging_p): Allow decls. (rhs_valid_for_store_merging_p): Allow non-clobber CONTRUCTORs with no elts. (pass_store_merging::process_store): Likewise. * gcc.dg/store_merging_26.c: New test. * gcc.dg/store_merging_27.c: New test. * gcc.dg/store_merging_28.c: New test. * gcc.dg/store_merging_29.c: New test. From-SVN: r270924
Diffstat (limited to 'gcc/expr.c')
0 files changed, 0 insertions, 0 deletions