mirror of
https://github.com/ElementsProject/lightning.git
synced 2025-01-18 21:35:11 +01:00
2652cc9704
Use the same "child of tal object" trick to mark things "notleak". That simplifies things and means we don't have to track them being reallocated. Signed-off-by: Rusty Russell <rusty@rustcorp.com.au>
70 lines
2.2 KiB
C
70 lines
2.2 KiB
C
#ifndef LIGHTNING_COMMON_MEMLEAK_H
|
|
#define LIGHTNING_COMMON_MEMLEAK_H
|
|
#include "config.h"
|
|
#include <ccan/cast/cast.h>
|
|
#include <ccan/tal/tal.h>
|
|
#include <ccan/typesafe_cb/typesafe_cb.h>
|
|
#include <inttypes.h>
|
|
|
|
struct htable;
|
|
|
|
#if HAVE_TYPEOF
|
|
#define memleak_typeof(var) typeof(var)
|
|
#else
|
|
#define memleak_typeof(var) void *
|
|
#endif /* !HAVE_TYPEOF */
|
|
|
|
/* Mark a pointer as not being leaked. */
|
|
#define notleak(p) ((memleak_typeof(p))notleak_((p), false))
|
|
|
|
/* Mark a pointer and all its tal children as not being leaked. */
|
|
#define notleak_with_children(p) ((memleak_typeof(p))notleak_((p), true))
|
|
|
|
void *notleak_(const void *ptr, bool plus_children);
|
|
|
|
/* Mark a helper to be called to scan this structure for mem references */
|
|
/* For update-mock: memleak_add_helper_ mock empty */
|
|
void memleak_add_helper_(const tal_t *p, void (*cb)(struct htable *memtable,
|
|
const tal_t *));
|
|
|
|
#if DEVELOPER
|
|
#define memleak_add_helper(p, cb) \
|
|
memleak_add_helper_((p), \
|
|
typesafe_cb_preargs(void, const tal_t *, \
|
|
(cb), (p), \
|
|
struct htable *))
|
|
#else
|
|
/* Don't refer to cb at all if !DEVELOPER */
|
|
#define memleak_add_helper(p, cb)
|
|
#endif
|
|
|
|
/* Initialize memleak detection */
|
|
void memleak_init(void);
|
|
|
|
/* Allocate a htable with all the memory we've allocated. */
|
|
struct htable *memleak_enter_allocations(const tal_t *ctx,
|
|
const void *exclude1,
|
|
const void *exclude2);
|
|
|
|
/* Remove any pointers to memory under root */
|
|
void memleak_remove_referenced(struct htable *memtable, const void *root);
|
|
|
|
/* Remove any pointers inside this htable (which is opaque to memleak). */
|
|
void memleak_remove_htable(struct htable *memtable, const struct htable *ht);
|
|
|
|
/* Remove any pointers inside this uintmap (which is opaque to memleak). */
|
|
#define memleak_remove_uintmap(memtable, umap) \
|
|
memleak_remove_intmap_(memtable, uintmap_unwrap_(umap))
|
|
|
|
struct intmap;
|
|
void memleak_remove_intmap_(struct htable *memtable, const struct intmap *m);
|
|
|
|
/* Mark this pointer as being referenced, and search within for more. */
|
|
void memleak_scan_region(struct htable *memtable,
|
|
const void *p, size_t bytelen);
|
|
|
|
/* Get (and remove) a leak from memtable, or NULL */
|
|
const void *memleak_get(struct htable *memtable, const uintptr_t **backtrace);
|
|
|
|
#endif /* LIGHTNING_COMMON_MEMLEAK_H */
|