summaryrefslogtreecommitdiffstats
path: root/lib/libmemstat/memstat.c
diff options
context:
space:
mode:
authorrwatson <rwatson@FreeBSD.org>2005-07-20 09:17:40 +0000
committerrwatson <rwatson@FreeBSD.org>2005-07-20 09:17:40 +0000
commit7a523e19dbdf32db124098a41f93e706e585050b (patch)
treed3758da9b6587221ae0e6860dda2621e94ec4663 /lib/libmemstat/memstat.c
parentb8e17ef7630a3906fbab49d7daa80ccb9bab26a8 (diff)
downloadFreeBSD-src-7a523e19dbdf32db124098a41f93e706e585050b.zip
FreeBSD-src-7a523e19dbdf32db124098a41f93e706e585050b.tar.gz
UMA supports "secondary" zones, in which a second zone can be layered
on top of a primary zone, sharing the same allocation "keg". When reporting statistics for zones, do not report the free items in the keg as part of the free items in the zone, or those free items will be reported more than once: for the primary zone, and then any secondary zones off the primary zone. Separately record and maintain a kegfree statistic, and export via memstat_get_kegfree(), which is available for use if needed. Since items free'd back to the keg are not fully initialized, and hence may not actually be available (since secondary zone ctor-time initialization can fail), this makes some amount of sense. This change corrects a bug made visible in the libmemstat(3) modifications to netstat: mbufs freed back to the keg from the packet zone would be counted twice, resulting in negative values being printed in the mbuf free count. Some further refinement of reporting relating to secondary zones may still be required. Reported by: ssouhlal MFC after: 3 days
Diffstat (limited to 'lib/libmemstat/memstat.c')
-rw-r--r--lib/libmemstat/memstat.c8
1 files changed, 8 insertions, 0 deletions
diff --git a/lib/libmemstat/memstat.c b/lib/libmemstat/memstat.c
index f2764ff..cbab40a 100644
--- a/lib/libmemstat/memstat.c
+++ b/lib/libmemstat/memstat.c
@@ -143,6 +143,7 @@ memstat_mt_reset_stats(struct memory_type *mtp)
mtp->mt_failures = 0;
mtp->mt_zonefree = 0;
+ mtp->mt_kegfree = 0;
for (i = 0; i < MEMSTAT_MAXCPU; i++) {
mtp->mt_percpu_alloc[i].mtp_memalloced = 0;
@@ -292,6 +293,13 @@ memstat_get_zonefree(const struct memory_type *mtp)
}
uint64_t
+memstat_get_kegfree(const struct memory_type *mtp)
+{
+
+ return (mtp->mt_kegfree);
+}
+
+uint64_t
memstat_get_percpu_memalloced(const struct memory_type *mtp, int cpu)
{
OpenPOWER on IntegriCloud