OpenBSD manual page server

Manual Page Search Parameters
REFCNT_INIT(9) Kernel Developer's Manual REFCNT_INIT(9)

refcnt_init, refcnt_init_trace, refcnt_take, refcnt_rele, refcnt_rele_wake, refcnt_finalize, refcnt_shared, refcnt_read, REFCNT_INITIALIZERreference count API

#include <sys/refcnt.h>

void
refcnt_init(struct refcnt *r);

void
refcnt_init_trace(struct refcnt *r, int idx);

void
refcnt_take(struct refcnt *r);

int
refcnt_rele(struct refcnt *r);

void
refcnt_rele_wake(struct refcnt *r);

void
refcnt_finalize(struct refcnt *r, const char *wmesg);

int
refcnt_shared(struct refcnt *r);

unsigned int
refcnt_read(struct refcnt *r);

REFCNT_INITIALIZER();

The refcnt API provides simple reference counters that can be used to manage the lifetime of a shared object.

() sets the initial value of the counter to 1 to account for the caller's reference to the object. () additionally accepts a dt(4) static probe index.

() is used to acquire a new reference. It is the responsibility of the caller to guarantee that it holds a valid reference before taking a new reference.

() is used to release an existing reference.

() is used to release an existing reference and wakes up a process that is currently waiting in refcnt_finalize() for all the references to be released.

() releases the caller's reference and sleeps until all the other references to the relevant object have been released. There may only be one caller to refcnt_finalize() per refcnt r.

(), refcnt_rele_wake() and refcnt_finalize() order prior memory loads and stores before the release of the reference. The functions enforce control dependency so that after the final reference has been released, subsequent loads and stores happen after the release. These ensure that concurrent accesses cease before the object's destructor runs and that the destructor sees all updates done during the lifetime of the object.

() tests if the object has multiple references.

() returns a snapshot of the counter value. Its use is discouraged, code should use refcnt_shared() whenever possible.

() initialises a declaration of a refcnt to 1.

refcnt_init(), refcnt_init_trace(), refcnt_take(), refcnt_rele(), refcnt_rele_wake(), refcnt_shared() and refcnt_read() can be called during autoconf, from process context, or from interrupt context.

refcnt_finalize() can be called from process context.

refcnt_rele() returns a non-zero value if the last reference has been released, otherwise 0.

refcnt_shared() returns a non-zero value if the object has multiple references, otherwise 0.

refcnt_read() returns a snapshot of the counter value.

July 12, 2023 OpenBSD-current