From: David Malcolm Date: Thu, 23 Jan 2020 22:46:12 +0000 (-0500) Subject: analyzer: avoid relying on system in testsuite (PR 93367) X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=a0b935ac66bc9804b0864151e5f1bfde5ac1ddeb;p=gcc.git analyzer: avoid relying on system in testsuite (PR 93367) PR analyzer/93367 reports a testsuite failure in abort.c on hppa64-hp-hpux11.11 when detecting if the analyzer "knows" that the condition holds after the assert. The root cause is that the assertion failure function in that configuration's is not marked with __attribute__ ((__noreturn__)). This patch reworks the test to avoid in favor of a custom implementation of assert, so that the test demonstrates the idea without relying on properties of . gcc/testsuite/ChangeLog: PR analyzer/93367 * gcc.dg/analyzer/abort.c: Remove include of . Replace use of assert with a custom assertion implementation. --- diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 85e2fbbb645..df547bcc2ae 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 ea1756e47cb..9497ae30b46 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" } */ }