Memory stats for DNSSEC.

This commit is contained in:
Simon Kelley
2014-01-08 18:04:20 +00:00
parent 98c098bfc7
commit c2207688c0
3 changed files with 23 additions and 5 deletions

View File

@@ -19,6 +19,13 @@
#ifdef HAVE_DNSSEC #ifdef HAVE_DNSSEC
static struct blockdata *keyblock_free = NULL; static struct blockdata *keyblock_free = NULL;
static unsigned int blockdata_count = 0, blockdata_hwm = 0;
void blockdata_report(void)
{
my_syslog(LOG_INFO, _("DNSSEC memory in use %u, max %u"),
blockdata_count * KEYBLOCK_LEN, blockdata_hwm * KEYBLOCK_LEN);
}
struct blockdata *blockdata_alloc(char *data, size_t len) struct blockdata *blockdata_alloc(char *data, size_t len)
{ {
@@ -32,9 +39,14 @@ struct blockdata *blockdata_alloc(char *data, size_t len)
{ {
block = keyblock_free; block = keyblock_free;
keyblock_free = block->next; keyblock_free = block->next;
blockdata_count++;
}
else if ((block = whine_malloc(sizeof(struct blockdata))))
{
blockdata_count++;
if (blockdata_hwm < blockdata_count)
blockdata_hwm = blockdata_count;
} }
else
block = whine_malloc(sizeof(struct blockdata));
if (!block) if (!block)
{ {
@@ -76,9 +88,11 @@ void blockdata_free(struct blockdata *blocks)
if (blocks) if (blocks)
{ {
for (tmp = blocks; tmp->next; tmp = tmp->next); for (tmp = blocks; tmp->next; tmp = tmp->next)
blockdata_count--;
tmp->next = keyblock_free; tmp->next = keyblock_free;
keyblock_free = blocks; keyblock_free = blocks;
blockdata_count--;
} }
} }

View File

@@ -1184,6 +1184,9 @@ void dump_cache(time_t now)
#ifdef HAVE_AUTH #ifdef HAVE_AUTH
my_syslog(LOG_INFO, _("queries for authoritative zones %u"), daemon->auth_answer); my_syslog(LOG_INFO, _("queries for authoritative zones %u"), daemon->auth_answer);
#endif #endif
#ifdef HAVE_DNSSEC
blockdata_report();
#endif
/* sum counts from different records for same server */ /* sum counts from different records for same server */
for (serv = daemon->servers; serv; serv = serv->next) for (serv = daemon->servers; serv; serv = serv->next)

View File

@@ -990,6 +990,7 @@ struct crec *cache_enumerate(int init);
/* blockdata.c */ /* blockdata.c */
#ifdef HAVE_DNSSEC #ifdef HAVE_DNSSEC
void blockdata_report(void);
struct blockdata *blockdata_alloc(char *data, size_t len); struct blockdata *blockdata_alloc(char *data, size_t len);
size_t blockdata_walk(struct blockdata **key, unsigned char **p, size_t cnt); size_t blockdata_walk(struct blockdata **key, unsigned char **p, size_t cnt);
void blockdata_retrieve(struct blockdata *block, size_t len, void *data); void blockdata_retrieve(struct blockdata *block, size_t len, void *data);