From: Andre Vieira Date: Fri, 8 Nov 2019 11:30:50 +0000 (+0000) Subject: [vect] Disable vectorization of epilogues for loops with SIMDUID set X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=b602712b3ea2a0729a2eda61bd9ee795aba6138f;p=gcc.git [vect] Disable vectorization of epilogues for loops with SIMDUID set gcc/ChangeLog: 2019-11-08 Andre Vieira * tree-vect-loop.c (vect_analyze_loop): Disable epilogue vectorization for loops with SIMDUID set. Enable epilogue vectorization for loops with SIMDLEN set after finding a main loop with a VF that matches it. From-SVN: r277964 --- diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 277c21c9e83..c6c7daa2987 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,9 @@ +2019-11-08 Andre Vieira + + * tree-vect-loop.c (vect_analyze_loop): Disable epilogue vectorization + for loops with SIMDUID set. Enable epilogue vectorization for loops + with SIMDLEN set after finding a main loop with a VF that matches it. + 2019-11-08 Jakub Jelinek PR target/92038 diff --git a/gcc/tree-vect-loop.c b/gcc/tree-vect-loop.c index a2847ef6eb3..f25260c35b6 100644 --- a/gcc/tree-vect-loop.c +++ b/gcc/tree-vect-loop.c @@ -2455,11 +2455,15 @@ vect_analyze_loop (class loop *loop, vec_info_shared *shared) delete loop_vinfo; /* Only vectorize epilogues if PARAM_VECT_EPILOGUES_NOMASK is - enabled, this is not a simd loop and it is the innermost loop. */ - vect_epilogues = (!loop->simdlen + enabled, SIMDUID is not set, it is the innermost loop and we have + either already found the loop's SIMDLEN or there was no SIMDLEN to + begin with. + TODO: Enable epilogue vectorization for loops with SIMDUID set. */ + vect_epilogues = (!simdlen && loop->inner == NULL && PARAM_VALUE (PARAM_VECT_EPILOGUES_NOMASK) && LOOP_VINFO_PEELING_FOR_NITER (first_loop_vinfo) + && !loop->simduid /* For now only allow one epilogue loop. */ && first_loop_vinfo->epilogue_vinfos.is_empty ());