On Wed, Aug 30, 2017 at 2:32 PM, Martin Liška <mli...@suse.cz> wrote: > On 08/30/2017 02:28 PM, Richard Biener wrote: >> On Wed, Aug 30, 2017 at 1:13 PM, Martin Liška <mli...@suse.cz> wrote: >>> Hi. >>> >>> Simple transformation of switch statements where degenerated switch can be >>> interpreted >>> as gimple condition (or removed if having any non-default case). I >>> originally though >>> that we don't have switch statements without non-default cases, but PR82032 >>> shows we >>> can see it. >>> >>> Patch can bootstrap on ppc64le-redhat-linux and survives regression tests. >>> >>> Ready to be installed? >> >> While I guess this case is ok to handle here it would be nice if CFG cleanup >> would do the same. I suppose find_taken_edge somehow doesn't work for >> this case even after my last enhancement? Or is CFG cleanup for some reason >> not run? > > Do you mean both with # of non-default edges equal to 0 and 1? > Let me take a look.
First and foremost 0. The case of 1 non-default and a default would need extra code. Richard. > Martin > >> >> Richard. >> >>> Martin >>> >>> gcc/ChangeLog: >>> >>> 2017-08-25 Martin Liska <mli...@suse.cz> >>> >>> PR tree-optimization/82032 >>> * tree-switch-conversion.c (generate_high_low_equality): New >>> function. >>> (expand_degenerated_switch): Likewise. >>> (process_switch): Call expand_degenerated_switch. >>> (try_switch_expansion): Likewise. >>> (emit_case_nodes): Use generate_high_low_equality. >>> >>> gcc/testsuite/ChangeLog: >>> >>> 2017-08-25 Martin Liska <mli...@suse.cz> >>> >>> PR tree-optimization/82032 >>> * gcc.dg/tree-ssa/pr68198.c: Update jump threading expectations. >>> * gcc.dg/tree-ssa/switch-expansion.c: New test. >>> * gcc.dg/tree-ssa/vrp34.c: Update scanned pattern. >>> * g++.dg/other/pr82032.C: New test. >>> --- >>> gcc/testsuite/g++.dg/other/pr82032.C | 36 +++++++ >>> gcc/testsuite/gcc.dg/tree-ssa/pr68198.c | 6 +- >>> gcc/testsuite/gcc.dg/tree-ssa/switch-expansion.c | 14 +++ >>> gcc/testsuite/gcc.dg/tree-ssa/vrp34.c | 5 +- >>> gcc/tree-switch-conversion.c | 123 >>> ++++++++++++++++++----- >>> 5 files changed, 152 insertions(+), 32 deletions(-) >>> create mode 100644 gcc/testsuite/g++.dg/other/pr82032.C >>> create mode 100644 gcc/testsuite/gcc.dg/tree-ssa/switch-expansion.c >>> >>> >