diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 85e2fbbb6452..df547bcc2ae6 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,9 @@ +2020-01-23 David Malcolm + + PR analyzer/93367 + * gcc.dg/analyzer/abort.c: Remove include of . + Replace use of assert with a custom assertion implementation. + 2020-01-23 Jakub Jelinek PR inline-asm/93027 diff --git a/gcc/testsuite/gcc.dg/analyzer/abort.c b/gcc/testsuite/gcc.dg/analyzer/abort.c index ea1756e47cb0..9497ae30b469 100644 --- a/gcc/testsuite/gcc.dg/analyzer/abort.c +++ b/gcc/testsuite/gcc.dg/analyzer/abort.c @@ -1,4 +1,3 @@ -#include #include #include #include "analyzer-decls.h" @@ -62,11 +61,20 @@ void test_4 (void *ptr) /**************************************************************************/ +/* Verify that we discover conditions from assertions if the assert macro + isn't disabled, and that it has its failure-handler labelled with + __attribute__ ((__noreturn__)). + This attribute isn't present for all implementations of , so + we have to test the idea using our own assert macro. */ + +extern void my_assert_fail (const char *expr, const char *file, int line) + __attribute__ ((__noreturn__)); + +#define MY_ASSERT(EXPR) \ + do { if (!(EXPR)) my_assert_fail (#EXPR, __FILE__, __LINE__); } while (0) + void test_5 (int i) { - assert (i < 10); - - /* We have not defined NDEBUG, so this will call __assert_fail if - i >= 10, which is labelled with __attribute__ ((__noreturn__)). */ + MY_ASSERT (i < 10); __analyzer_eval (i < 10); /* { dg-warning "TRUE" } */ }