summaryrefslogtreecommitdiff
path: root/components/swap.c
diff options
context:
space:
mode:
authorLaslo Hunhold <dev@frign.de>2018-05-21 23:03:34 +0200
committerAaron Marcher <me@drkhsh.at>2018-05-21 23:05:39 +0200
commit7f91ce265ea456b3096ccba7fdbb890bcf00e225 (patch)
treed0541afb0ae5f7cc215b9db91d066f7db54f71da /components/swap.c
parentceb13206a4d9f410ab49c3824c487658c341d8c8 (diff)
swap.c: Refactor getstats() and its usage
Add a return value so we are able to check any errors and actually fail when there has been a critical error instead of carrying on uselessly.
Diffstat (limited to 'components/swap.c')
-rw-r--r--components/swap.c36
1 files changed, 22 insertions, 14 deletions
diff --git a/components/swap.c b/components/swap.c
index c9bb920..37ee85c 100644
--- a/components/swap.c
+++ b/components/swap.c
@@ -135,29 +135,27 @@
#include <sys/types.h>
#include <unistd.h>
- static void
+ static int
getstats(int *total, int *used)
{
struct swapent *sep, *fsep;
int rnswap, nswap, i;
- nswap = swapctl(SWAP_NSWAP, 0, 0);
- if (nswap < 1) {
+ if ((nswap = swapctl(SWAP_NSWAP, 0, 0)) < 1) {
warn("swaptctl 'SWAP_NSWAP':");
+ return 1;
}
-
- fsep = sep = calloc(nswap, sizeof(*sep));
- if (!sep) {
+ if (!(fsep = sep = calloc(nswap, sizeof(*sep)))) {
warn("calloc 'nswap':");
+ return 1;
}
-
- rnswap = swapctl(SWAP_STATS, (void *)sep, nswap);
- if (rnswap < 0) {
+ if ((rnswap = swapctl(SWAP_STATS, (void *)sep, nswap)) < 0) {
warn("swapctl 'SWAP_STATA':");
+ return 1;
}
-
if (nswap != rnswap) {
warn("getstats: SWAP_STATS != SWAP_NSWAP");
+ return 1;
}
*total = 0;
@@ -169,6 +167,8 @@
}
free(fsep);
+
+ return 0;
}
const char *
@@ -176,7 +176,9 @@
{
int total, used;
- getstats(&total, &used);
+ if (getstats(&total, &used)) {
+ return NULL;
+ }
return fmt_human((total - used) * 1024, 1024);
}
@@ -186,7 +188,9 @@
{
int total, used;
- getstats(&total, &used);
+ if (getstats(&total, &used)) {
+ return NULL;
+ }
if (total == 0) {
return NULL;
@@ -200,7 +204,9 @@
{
int total, used;
- getstats(&total, &used);
+ if (getstats(&total, &used)) {
+ return NULL;
+ }
return fmt_human(total * 1024, 1024);
}
@@ -210,7 +216,9 @@
{
int total, used;
- getstats(&total, &used);
+ if (getstats(&total, &used)) {
+ return NULL;
+ }
return fmt_human(used * 1024, 1024);
}