From: Florian Weimer Date: Mon, 23 Dec 2024 12:57:55 +0000 (+0100) Subject: support: Add support_record_failure_barrier X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=59273e870f126febcb5cc69e53ab81bcdf72aed8;p=thirdparty%2Fglibc.git support: Add support_record_failure_barrier This can be used to stop execution after a TEST_COMPARE_BLOB failure, for example. (cherry picked from commit d0b8aa6de4529231fadfe604ac2c434e559c2d9e) --- diff --git a/support/check.h b/support/check.h index 43f4208a0a..dac6f04b56 100644 --- a/support/check.h +++ b/support/check.h @@ -207,6 +207,9 @@ void support_record_failure_reset (void); failures or not. */ int support_record_failure_is_failed (void); +/* Terminate the process if any failures have been encountered so far. */ +void support_record_failure_barrier (void); + __END_DECLS #endif /* SUPPORT_CHECK_H */ diff --git a/support/support_record_failure.c b/support/support_record_failure.c index 7e57fe97fb..b00387ff80 100644 --- a/support/support_record_failure.c +++ b/support/support_record_failure.c @@ -112,3 +112,13 @@ support_record_failure_is_failed (void) synchronization for reliable test error reporting anyway. */ return __atomic_load_n (&state->failed, __ATOMIC_RELAXED); } + +void +support_record_failure_barrier (void) +{ + if (__atomic_load_n (&state->failed, __ATOMIC_RELAXED)) + { + puts ("error: exiting due to previous errors"); + exit (1); + } +}