#include <isc/lang.h>
#include <isc/mutex.h>
#include <isc/result.h>
-#include <isc/strerr.h>
#include <isc/string.h>
#include <isc/types.h>
+#include <isc/util.h>
typedef pthread_cond_t isc_condition_t;
-#define isc_condition_init(cond) \
- if (pthread_cond_init(cond, NULL) != 0) { \
- char isc_condition_strbuf[ISC_STRERRORSIZE]; \
- strerror_r(errno, isc_condition_strbuf, \
- sizeof(isc_condition_strbuf)); \
- isc_error_fatal(__FILE__, __LINE__, \
- "pthread_cond_init failed: %s", \
- isc_condition_strbuf); \
+#define isc_condition_init(cond) \
+ { \
+ int _ret = pthread_cond_init(cond, NULL); \
+ ERRNO_CHECK(pthread_cond_init, _ret); \
}
#define isc_condition_wait(cp, mp) \
typedef pthread_mutex_t isc_mutex_t;
void
-isc__mutex_init(isc_mutex_t *mp, const char *file, unsigned int line);
+isc__mutex_init(isc_mutex_t *mp);
-#define isc_mutex_init(mp) isc__mutex_init((mp), __FILE__, __LINE__)
+#define isc_mutex_init(mp) isc__mutex_init((mp))
#define isc_mutex_lock(mp) \
((pthread_mutex_lock((mp)) == 0) ? ISC_R_SUCCESS : ISC_R_UNEXPECTED)
/*
* Errors
*/
-#include <isc/error.h> /* Contractual promise. */
+#include <errno.h> /* for errno */
+
+#include <isc/error.h> /* Contractual promise. */
+#include <isc/strerr.h> /* for ISC_STRERRORSIZE */
/*% Unexpected Error */
#define UNEXPECTED_ERROR isc_error_unexpected
#endif /* UNIT_TESTING */
+/*% Runtime check which logs the error string corresponding to errno */
+#define ERRNO_CHECK(func, ret) \
+ if ((ret) != 0) { \
+ char _strerrorbuf[ISC_STRERRORSIZE]; \
+ strerror_r(errno, _strerrorbuf, sizeof(_strerrorbuf)); \
+ isc_error_fatal(__FILE__, __LINE__, "%s() failed in %s(): %s", \
+ #func, __func__, _strerrorbuf); \
+ }
+
/*%
* Time
*/
#endif /* HAVE_PTHREAD_MUTEX_ADAPTIVE_NP */
void
-isc__mutex_init(isc_mutex_t *mp, const char *file, unsigned int line) {
+isc__mutex_init(isc_mutex_t *mp) {
int err;
#ifdef HAVE_PTHREAD_MUTEX_ADAPTIVE_NP
#else /* HAVE_PTHREAD_MUTEX_ADAPTIVE_NP */
err = pthread_mutex_init(mp, NULL);
#endif /* HAVE_PTHREAD_MUTEX_ADAPTIVE_NP */
- if (err != 0) {
- char strbuf[ISC_STRERRORSIZE];
- strerror_r(err, strbuf, sizeof(strbuf));
- isc_error_fatal(file, line, "pthread_mutex_init failed: %s",
- strbuf);
- }
+ ERRNO_CHECK(pthread_mutex_init, err);
}
#define THREAD_MINSTACKSIZE (1024U * 1024)
#endif /* ifndef THREAD_MINSTACKSIZE */
-#define _FATAL(r, f) \
- { \
- char strbuf[ISC_STRERRORSIZE]; \
- strerror_r(r, strbuf, sizeof(strbuf)); \
- isc_error_fatal(__FILE__, __LINE__, f " failed: %s", strbuf); \
- }
-
void
isc_thread_create(isc_threadfunc_t func, isc_threadarg_t arg,
isc_thread_t *thread) {
#if defined(HAVE_PTHREAD_ATTR_GETSTACKSIZE) && \
defined(HAVE_PTHREAD_ATTR_SETSTACKSIZE)
ret = pthread_attr_getstacksize(&attr, &stacksize);
- if (ret != 0) {
- _FATAL(ret, "pthread_attr_getstacksize()");
- }
+ ERRNO_CHECK(pthread_attr_getstacksize, ret);
if (stacksize < THREAD_MINSTACKSIZE) {
ret = pthread_attr_setstacksize(&attr, THREAD_MINSTACKSIZE);
- if (ret != 0) {
- _FATAL(ret, "pthread_attr_setstacksize()");
- }
+ ERRNO_CHECK(pthread_attr_setstacksize, ret);
}
#endif /* if defined(HAVE_PTHREAD_ATTR_GETSTACKSIZE) && \
* defined(HAVE_PTHREAD_ATTR_SETSTACKSIZE) */
ret = pthread_create(thread, &attr, isc__trampoline_run,
trampoline_arg);
- if (ret != 0) {
- _FATAL(ret, "pthread_create()");
- }
+ ERRNO_CHECK(pthread_create, ret);
pthread_attr_destroy(&attr);
void
isc_thread_join(isc_thread_t thread, isc_threadresult_t *result) {
int ret = pthread_join(thread, result);
- if (ret != 0) {
- _FATAL(ret, "pthread_join()");
- }
+
+ ERRNO_CHECK(pthread_join, ret);
}
void