+2017-01-14 Jeff Law <law@redhat.com>
+
+ PR tree-optimization/79090
+ * tree-ssa-dse.c (valid_ao_ref_for_dse): Reject zero length and
+ variable length stores.
+ (compute_trims): Delete dead assignment to *trim_tail.
+ (dse_dom_walker::dse_optimize_stmt): Optimize mem* calls with
+ zero length.
+
2017-01-14 Bernd Schmidt <bschmidt@redhat.com>
PR rtl-optimization/78626
{
return (ao_ref_base (ref)
&& ref->max_size != -1
+ && ref->size != 0
+ && ref->max_size == ref->size
&& (ref->offset % BITS_PER_UNIT) == 0
&& (ref->size % BITS_PER_UNIT) == 0
&& (ref->size != -1));
the REF to compute the trims. */
/* Now identify how much, if any of the tail we can chop off. */
- *trim_tail = 0;
int last_orig = (ref->size / BITS_PER_UNIT) - 1;
int last_live = bitmap_last_set_bit (live);
*trim_tail = (last_orig - last_live) & ~0x1;
case BUILT_IN_MEMMOVE:
case BUILT_IN_MEMSET:
{
+ /* Occasionally calls with an explicit length of zero
+ show up in the IL. It's pointless to do analysis
+ on them, they're trivially dead. */
+ tree size = gimple_call_arg (stmt, 2);
+ if (integer_zerop (size))
+ {
+ delete_dead_call (gsi);
+ return;
+ }
+
gimple *use_stmt;
enum dse_store_status store_status;
m_byte_tracking_enabled