2
0
mirror of https://gitlab.isc.org/isc-projects/bind9 synced 2025-08-30 22:15:20 +00:00

Enhance the isc_loop unit to allow reference count tracking

Use ISC_REFCOUNT_TRACE_{IMPL,DECL} to allow better isc_loop reference
tracking - use `#define ISC_LOOP_TRACE 1` in <isc/loop.h> to enable.
This commit is contained in:
Ondřej Surý
2023-01-02 13:26:41 +01:00
parent 5e956d3cba
commit 6613f89c62
2 changed files with 18 additions and 0 deletions

View File

@@ -22,6 +22,8 @@
typedef void (*isc_job_cb)(void *); typedef void (*isc_job_cb)(void *);
#undef ISC_LOOP_TRACE
ISC_LANG_BEGINDECLS ISC_LANG_BEGINDECLS
void void
@@ -169,7 +171,19 @@ isc_loop_get(isc_loopmgr_t *loopmgr, uint32_t tid);
*\li 'tid' is smaller than number of initialized loops *\li 'tid' is smaller than number of initialized loops
*/ */
#
#if ISC_LOOP_TRACE
#define isc_loop_ref(ptr) isc_loop__ref(ptr, __func__, __FILE__, __LINE__)
#define isc_loop_unref(ptr) isc_loop__unref(ptr, __func__, __FILE__, __LINE__)
#define isc_loop_attach(ptr, ptrp) \
isc_loop__attach(ptr, ptrp, __func__, __FILE__, __LINE__)
#define isc_loop_detach(ptrp) \
isc_loop__detach(ptrp, __func__, __FILE__, __LINE__)
ISC_REFCOUNT_TRACE_DECL(isc_loop);
#else
ISC_REFCOUNT_DECL(isc_loop); ISC_REFCOUNT_DECL(isc_loop);
#endif
/*%< /*%<
* Reference counting functions for isc_loop * Reference counting functions for isc_loop
*/ */

View File

@@ -330,7 +330,11 @@ loop_destroy(isc_loop_t *loop) {
UV_RUNTIME_CHECK(uv_async_send, r); UV_RUNTIME_CHECK(uv_async_send, r);
} }
#if ISC_LOOP_TRACE
ISC_REFCOUNT_TRACE_IMPL(isc_loop, loop_destroy)
#else
ISC_REFCOUNT_IMPL(isc_loop, loop_destroy); ISC_REFCOUNT_IMPL(isc_loop, loop_destroy);
#endif
void void
isc_loopmgr_create(isc_mem_t *mctx, uint32_t nloops, isc_loopmgr_t **loopmgrp) { isc_loopmgr_create(isc_mem_t *mctx, uint32_t nloops, isc_loopmgr_t **loopmgrp) {