diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 1dc8252f2bd..aa98585688a 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 60c87fe9f9f..fb29f731b2a 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 00000000000..1c71b60c974 --- /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 1dcd1295930..fa4a364983a 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;