summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJoe Holden <jwh@zorins.co.uk>2018-07-13 16:44:39 +0100
committerJo-Philipp Wich <jo@mein.io>2018-08-07 22:27:55 +0200
commit06fa692c80fb2beb69d23d0a2c5cf667aa12f4ad (patch)
treeb942d2e38e9bd87e404c2c181ac810d4a775dda6
parent12a7cf9db1f902f359038d9f52851da83c153407 (diff)
downloadfirewall3-06fa692c80fb2beb69d23d0a2c5cf667aa12f4ad.tar.gz
defaults: use a generic check_kmod() function
Rather than having functions for check_offloading() et al, replace it with a generic function. Signed-off-by: Joe Holden <jwh@zorins.co.uk>
-rw-r--r--defaults.c15
1 files changed, 9 insertions, 6 deletions
diff --git a/defaults.c b/defaults.c
index f42eed6..44fe629 100644
--- a/defaults.c
+++ b/defaults.c
@@ -85,14 +85,17 @@ check_policy(struct uci_element *e, enum fw3_flag *pol, const char *name)
}
static void
-check_offloading(struct uci_element *e, bool *offloading)
+check_kmod(struct uci_element *e, bool *module, const char *name)
{
FILE *f;
+ char buf[128];
- if (!*offloading)
+ if (!*module)
return;
- f = fopen("/sys/module/xt_FLOWOFFLOAD/refcnt", "r");
+ snprintf(buf, sizeof(buf), "/sys/module/%s/refcnt", name);
+
+ f = fopen(buf, "r");
if (f)
{
@@ -100,8 +103,8 @@ check_offloading(struct uci_element *e, bool *offloading)
return;
}
- warn_elem(e, "enables offloading but missing kernel support, disabling");
- *offloading = false;
+ warn_elem(e, sprintf("requires module %s but missing kernel support, disabling", name));
+ *module = false;
}
static void
@@ -168,7 +171,7 @@ fw3_load_defaults(struct fw3_state *state, struct uci_package *p)
check_any_reject_code(e, &defs->any_reject_code);
- check_offloading(e, &defs->flow_offloading);
+ check_kmod(e, &defs->flow_offloading, "xt_FLOWOFFLOAD");
}
}