https://gcc.gnu.org/bugzilla/show_bug.cgi?id=93081

            Bug ID: 93081
           Summary: insertation followed by another inseration to the same
                    location is not optimized away
           Product: gcc
           Version: 10.0
            Status: UNCONFIRMED
          Keywords: missed-optimization, TREE
          Severity: enhancement
          Priority: P3
         Component: tree-optimization
          Assignee: pinskia at gcc dot gnu.org
          Reporter: pinskia at gcc dot gnu.org
  Target Milestone: ---

Testcase:
/* { dg-do compile } */
/* { dg-options "-O2 -fdump-tree-optimized" } */


#define vector __attribute__((__vector_size__(16) ))

vector int f(vector int a, int b, int c)
{
  a[0] = b;
  a[0] = c;
  return a;
}


/* { dg-final { scan-tree-dump-times "BIT_INSERT_EXPR" 1 "optimized" } } */

--- CUT ---
Code added to match.pd which will fix it:
/* Inserting into the same location as previously just over writes the
location. */
(simplify
 (bit_insert (bit_insert @0 @1 @2) @3 @2)
 (bit_insert @0 @3 @2))

Reply via email to