X-Git-Url: http://git.archive.openwrt.org/?p=project%2Fnetifd.git;a=blobdiff_plain;f=iprule.c;h=a31db9929ef79e9dd37e390a4b6b20f794a976a6;hp=0ff02ded72f8691080d08ceb7b7c31beed9fe546;hb=ddbd2cc51b3db14f6a8bd46ceebaee9097a50b78;hpb=0b66ee22a3a339188ab2b8661c6af62883be93c2 diff --git a/iprule.c b/iprule.c index 0ff02de..a31db99 100644 --- a/iprule.c +++ b/iprule.c @@ -28,6 +28,7 @@ #include "system.h" struct vlist_tree iprules; +static bool iprules_flushed = false; static unsigned int iprules_counter[2]; enum { @@ -59,7 +60,7 @@ static const struct blobmsg_policy rule_attr[__RULE_MAX] = { [RULE_GOTO] = { .name = "goto", .type = BLOBMSG_TYPE_INT32 }, }; -const struct config_param_list rule_attr_list = { +const struct uci_blob_param_list rule_attr_list = { .n_params = __RULE_MAX, .params = rule_attr, }; @@ -208,6 +209,11 @@ error: void iprule_update_start(void) { + if (!iprules_flushed) { + system_flush_iprules(); + iprules_flushed = true; + } + iprules_counter[0] = 1; iprules_counter[1] = 1; vlist_update(&iprules); @@ -247,6 +253,5 @@ iprule_update_rule(struct vlist_tree *tree, static void __init iprule_init_list(void) { - system_flush_iprules(); vlist_init(&iprules, rule_cmp, iprule_update_rule); }