From: Ilya Enkovich Date: Thu, 28 Jan 2016 10:09:12 +0000 (+0000) Subject: tree-vect-stmts.c (vectorizable_comparison): Add NULL check for vectype. X-Git-Tag: basepoints/gcc-7~1259 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=30480bcd794f8a0d4e489b8eb3f043b2ab72e7e8;p=thirdparty%2Fgcc.git tree-vect-stmts.c (vectorizable_comparison): Add NULL check for vectype. gcc/ * tree-vect-stmts.c (vectorizable_comparison): Add NULL check for vectype. gcc/testsuite/ * gcc.dg/declare-simd.c: New test. From-SVN: r232917 --- diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 1dc8252f2bda..aa98585688a6 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,8 @@ +2016-01-28 Ilya Enkovich + + * tree-vect-stmts.c (vectorizable_comparison): Add + NULL check for vectype. + 2016-01-28 Richard Biener PR tree-optimization/69466 diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 60c87fe9f9f2..fb29f731b2a8 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,7 @@ +2016-01-28 Ilya Enkovich + + * gcc.dg/declare-simd.c: New test. + 2016-01-28 Richard Biener PR tree-optimization/69466 diff --git a/gcc/testsuite/gcc.dg/declare-simd.c b/gcc/testsuite/gcc.dg/declare-simd.c new file mode 100644 index 000000000000..1c71b60c9742 --- /dev/null +++ b/gcc/testsuite/gcc.dg/declare-simd.c @@ -0,0 +1,14 @@ +/* { dg-do compile } */ +/* { dg-options "-O3 -fopenmp-simd" } */ + +#pragma omp declare simd linear (p2, p3) +extern void fn2 (float p1, float *p2, float *p3); + +float *a, *b; +void fn1 (float *p1) +{ + int i; +#pragma omp simd + for (i = 0; i < 1000; i++) + fn2 (p1[i], a + i, b + i); +} diff --git a/gcc/tree-vect-stmts.c b/gcc/tree-vect-stmts.c index 1dcd12959307..fa4a364983a6 100644 --- a/gcc/tree-vect-stmts.c +++ b/gcc/tree-vect-stmts.c @@ -7764,7 +7764,7 @@ vectorizable_comparison (gimple *stmt, gimple_stmt_iterator *gsi, if (!STMT_VINFO_RELEVANT_P (stmt_info) && !bb_vinfo) return false; - if (!VECTOR_BOOLEAN_TYPE_P (vectype)) + if (!vectype || !VECTOR_BOOLEAN_TYPE_P (vectype)) return false; mask_type = vectype;