/* PR tree-optimization/80933 - redundant bzero/bcopy calls not eliminated { dg-do compile } { dg-options "-O2 -fdump-tree-dse1" } */ void sink (void*); void test_bcopy (const void *s) { char d[33]; /* Bcopy is transformed into memmove before DSE runs, so this test doesn't actually verify that DSE does its job. */ __builtin_bcopy (s, d, sizeof d); __builtin_bcopy (s, d, sizeof d); sink (d); } void test_bzero (void) { char d[33]; __builtin_bzero (d, sizeof d); __builtin_bzero (d, sizeof d); sink (d); } /* { dg-final { scan-tree-dump-times "builtin_memset" 1 "dse1" } } */ /* Merging the evrp folder into substitute_and_fold_engine shuffled the order of gimple_fold a bit, so evrp is no longer folding the memmove inline. This folding is instead done by forwprop. Thus, I have remmoved the |memmove in the test below as this is not done until after dse. What happened was that the propagator engine only called gimple fold if replace_uses_in() was successful. On the other hand, EVRP called gimple fold regardless. If we really care about previous behavior, we could put a call to gimple ::fold_stmt into evrp_folder::fold_stmt(). */ /* { dg-final { scan-tree-dump-not "builtin_(bcopy|bzero|memcpy)" "dse1" } } */