From: Craig Small Date: Sun, 1 May 2016 06:18:10 +0000 (+1000) Subject: vmstat: Various resource_leak fixes X-Git-Tag: v4.0.0~930 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=6151b794c6a4f1958dee81fb17bad83b65166c8f;p=procps-ng vmstat: Various resource_leak fixes Using *_unref to free up the memory. Most of these are one-shot so not terribly important anyhow. --- diff --git a/vmstat.c b/vmstat.c index 85c28a25..53677628 100644 --- a/vmstat.c +++ b/vmstat.c @@ -399,6 +399,10 @@ static void new_format(void) printf("\n"); } + /* Cleanup */ + procps_stat_unref(&sys_info); + procps_vmstat_unref(&vm_info); + procps_meminfo_unref(&mem_info); } static void diskpartition_header(const char *partition_name) @@ -461,6 +465,7 @@ static int diskpartition_format(const char *partition_name) sleep(sleep_time); } return 0; + procps_diskstat_unref(&disk_stat); } static void diskheader(void) @@ -583,6 +588,7 @@ static void diskformat(void) sleep(sleep_time); } #undef DSTAT + procps_diskstat_unref(&disk_stat); } static void slabheader(void) @@ -710,6 +716,7 @@ static void disksum_format(void) printf(_("%13lu milli spent IO\n"), milli_spent_IO); printf(_("%13lu milli weighted IO\n"), weighted_milli_spent_IO); #undef DSTAT + procps_diskstat_unref(&disk_stat); } static void sum_format(void) @@ -774,6 +781,11 @@ static void sum_format(void) printf(_("%13u CPU context switches\n"), procps_stat_sys_get(sys_info, PROCPS_STAT_CTXT)); printf(_("%13u boot time\n"), procps_stat_sys_get(sys_info, PROCPS_STAT_BTIME)); printf(_("%13u forks\n"), procps_stat_sys_get(sys_info, PROCPS_STAT_PROCS)); + + /* Cleanup */ + procps_stat_unref(&sys_info); + procps_vmstat_unref(&vm_info); + procps_meminfo_unref(&mem_info); } static void fork_format(void) @@ -788,6 +800,8 @@ static void fork_format(void) _("Unable to read system stat information")); printf(_("%13u forks\n"), procps_stat_sys_get(sys_info, PROCPS_STAT_PROCS)); + /* Cleanup */ + procps_stat_unref(&sys_info); } static int winhi(void)