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.
#include <sys/types.h>
#include <unistd.h>
#include <sys/types.h>
#include <unistd.h>
getstats(int *total, int *used)
{
struct swapent *sep, *fsep;
int rnswap, nswap, i;
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':");
warn("swaptctl 'SWAP_NSWAP':");
-
- fsep = sep = calloc(nswap, sizeof(*sep));
- if (!sep) {
+ if (!(fsep = sep = calloc(nswap, sizeof(*sep)))) {
-
- rnswap = swapctl(SWAP_STATS, (void *)sep, nswap);
- if (rnswap < 0) {
+ if ((rnswap = swapctl(SWAP_STATS, (void *)sep, nswap)) < 0) {
warn("swapctl 'SWAP_STATA':");
warn("swapctl 'SWAP_STATA':");
if (nswap != rnswap) {
warn("getstats: SWAP_STATS != SWAP_NSWAP");
if (nswap != rnswap) {
warn("getstats: SWAP_STATS != SWAP_NSWAP");
- getstats(&total, &used);
+ if (getstats(&total, &used)) {
+ return NULL;
+ }
return fmt_human((total - used) * 1024, 1024);
}
return fmt_human((total - used) * 1024, 1024);
}
- getstats(&total, &used);
+ if (getstats(&total, &used)) {
+ return NULL;
+ }
if (total == 0) {
return NULL;
if (total == 0) {
return NULL;
- getstats(&total, &used);
+ if (getstats(&total, &used)) {
+ return NULL;
+ }
return fmt_human(total * 1024, 1024);
}
return fmt_human(total * 1024, 1024);
}
- getstats(&total, &used);
+ if (getstats(&total, &used)) {
+ return NULL;
+ }
return fmt_human(used * 1024, 1024);
}
return fmt_human(used * 1024, 1024);
}