0
0
mirror of https://gitlab.nic.cz/labs/bird.git synced 2025-01-05 00:21:54 +00:00

Table exporter journal dumping and memsize

The show-memory command wasn't showing the consumed memory
properly because it ignored the journal size. Now it does.
This commit is contained in:
Maria Matejka 2024-12-16 10:59:59 +01:00
parent b67db7c97d
commit 056659c94e
5 changed files with 86 additions and 15 deletions

View File

@ -604,3 +604,45 @@ lfjour_init(struct lfjour *j, struct settle_config *scf)
}; };
j->max_tokens = 20; j->max_tokens = 20;
} }
void
lfjour_dump(struct dump_request *dreq, struct lfjour *j)
{
RDUMP("item_size=%u, item_count=%u\n", j->item_size, j->item_count);
struct lfjour_item *first = atomic_load_explicit(&j->first, memory_order_relaxed);
RDUMP("first=%p", first);
if (first)
RDUMP(" (seq %lu)", first->seq);
RDUMP(", next_seq=%lu", j->next_seq);
RDUMP("max_tokens=%lu, issued_tokens=%lu",
j->max_tokens, atomic_load_explicit(&j->issued_tokens, memory_order_relaxed));
RDUMP("Blocks:\n");
dreq->indent += 3;
WALK_TLIST(lfjour_block, block, &j->pending)
RDUMP("%p: end=%u, not_last=%u\n", block,
atomic_load_explicit(&block->end, memory_order_relaxed),
atomic_load_explicit(&block->not_last, memory_order_relaxed)
);
dreq->indent -= 3;
}
struct resmem lfjour_memsize(struct lfjour *j)
{
u64 blocks = 0;
WALK_TLIST(lfjour_block, block, &j->pending)
blocks++;
struct lfjour_item *first = atomic_load_explicit(&j->first, memory_order_relaxed);
if (!first)
return (struct resmem) { .overhead = blocks * page_size, };
struct resmem out;
out.effective = (j->next_seq - first->seq) * j->item_size;
out.overhead = blocks * page_size - out.effective;
return out;
}

View File

@ -277,7 +277,8 @@ static inline uint lfjour_count_recipients(struct lfjour *j)
{ return TLIST_LENGTH(lfjour_recipient, &j->recipients); } { return TLIST_LENGTH(lfjour_recipient, &j->recipients); }
void lfjour_init(struct lfjour *, struct settle_config *); void lfjour_init(struct lfjour *, struct settle_config *);
void lfjour_dump(struct dump_request *, struct lfjour *);
struct resmem lfjour_memsize(struct lfjour *);
static inline struct lfjour *lfjour_of_recipient(struct lfjour_recipient *r) static inline struct lfjour *lfjour_of_recipient(struct lfjour_recipient *r)
{ {

View File

@ -164,11 +164,6 @@ struct rt_export_request {
struct rt_feeding_request *next; /* Next in request chain */ struct rt_feeding_request *next; /* Next in request chain */
void (*done)(struct rt_feeding_request *);/* Called when this refeed finishes */ void (*done)(struct rt_feeding_request *);/* Called when this refeed finishes */
struct rt_prefilter prefilter; /* Reload only matching nets */ struct rt_prefilter prefilter; /* Reload only matching nets */
PACKED enum {
RFRS_INACTIVE = 0, /* Inactive request */
RFRS_PENDING, /* Request enqueued, do not touch */
RFRS_RUNNING, /* Request active, do not touch */
} state;
} *feeding, *feed_pending; } *feeding, *feed_pending;
TLIST_DEFAULT_NODE; TLIST_DEFAULT_NODE;
u8 trace_routes; u8 trace_routes;
@ -239,6 +234,10 @@ struct rt_export_item *rt_exporter_push(struct rt_exporter *, const struct rt_ex
struct rt_export_feed *rt_alloc_feed(uint routes, uint exports); struct rt_export_feed *rt_alloc_feed(uint routes, uint exports);
void rt_exporter_shutdown(struct rt_exporter *, void (*stopped)(struct rt_exporter *)); void rt_exporter_shutdown(struct rt_exporter *, void (*stopped)(struct rt_exporter *));
void rt_exporter_dump(struct dump_request *, struct rt_exporter *);
static inline struct resmem rt_exporter_memsize(struct rt_exporter *e)
{ return lfjour_memsize(&e->journal); }
/* Standalone feeds */ /* Standalone feeds */
void rt_feeder_subscribe(struct rt_exporter *, struct rt_export_feeder *); void rt_feeder_subscribe(struct rt_exporter *, struct rt_export_feeder *);
void rt_feeder_unsubscribe(struct rt_export_feeder *); void rt_feeder_unsubscribe(struct rt_export_feeder *);

View File

@ -573,3 +573,19 @@ rt_exporter_shutdown(struct rt_exporter *e, void (*stopped)(struct rt_exporter *
// e->stopped = stopped; // e->stopped = stopped;
bug("not implemented yet"); bug("not implemented yet");
} }
void
rt_exporter_dump(struct dump_request *dreq, struct rt_exporter *e)
{
RDUMP("Feeders (max_feed_index=%u):\n",
atomic_load_explicit(&e->max_feed_index, memory_order_relaxed));
dreq->indent += 3;
WALK_TLIST(rt_export_feeder, f, &e->feeders)
RDUMP("%p (%s), index %u\n");
dreq->indent -= 3;
RDUMP("Journal:\n");
dreq->indent += 3;
lfjour_dump(dreq, &e->journal);
dreq->indent -= 3;
}

View File

@ -3243,15 +3243,28 @@ rt_res_dump(struct dump_request *dreq, resource *_r)
RDUMP("name \"%s\", addr_type=%s, rt_count=%u, use_count=%d\n", RDUMP("name \"%s\", addr_type=%s, rt_count=%u, use_count=%d\n",
r->name, net_label[r->addr_type], r->rt_count, r->use_count); r->name, net_label[r->addr_type], r->rt_count, r->use_count);
#if 0 RDUMP("Exporter ALL:\n");
/* TODO: rethink this completely */ dreq->indent += 3;
/* TODO: move this to lfjour */ rt_exporter_dump(dreq, &r->export_all);
char x[32]; dreq->indent -= 3;
bsprintf(x, "%%%dspending export %%p\n", indent + 2); RDUMP("Exporter BEST:\n");
dreq->indent += 3;
rt_exporter_dump(dreq, &r->export_best);
dreq->indent -= 3;
}
WALK_TLIST(lfjour_block, n, &r->journal.pending) static struct resmem
debug(x, "", n); rt_res_memsize(resource *_r)
#endif {
SKIP_BACK_DECLARE(struct rtable_private, r, r, _r);
struct resmem amem = rt_exporter_memsize(&r->export_all);
struct resmem bmem = rt_exporter_memsize(&r->export_best);
return (struct resmem) {
.effective = amem.effective + bmem.effective,
.overhead = amem.overhead + bmem.overhead,
};
} }
static struct resclass rt_class = { static struct resclass rt_class = {
@ -3260,7 +3273,7 @@ static struct resclass rt_class = {
.free = rt_free, .free = rt_free,
.dump = rt_res_dump, .dump = rt_res_dump,
.lookup = NULL, .lookup = NULL,
.memsize = NULL, .memsize = rt_res_memsize,
}; };
static struct idm rtable_idm; static struct idm rtable_idm;