summaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/evaluate.c9
-rw-r--r--src/netlink.c11
-rw-r--r--src/rule.c23
3 files changed, 31 insertions, 12 deletions
diff --git a/src/evaluate.c b/src/evaluate.c
index 64e14b8b..0fad0913 100644
--- a/src/evaluate.c
+++ b/src/evaluate.c
@@ -2965,10 +2965,6 @@ static int cmd_evaluate_add(struct eval_ctx *ctx, struct cmd *cmd)
handle_merge(&cmd->set->handle, &cmd->handle);
return set_evaluate(ctx, cmd->set);
case CMD_OBJ_RULE:
- ret = cache_update(ctx->nf_sock, ctx->cache, cmd->op,
- ctx->msgs);
- if (ret < 0)
- return ret;
handle_merge(&cmd->rule->handle, &cmd->handle);
return rule_evaluate(ctx, cmd->rule);
case CMD_OBJ_CHAIN:
@@ -2983,11 +2979,6 @@ static int cmd_evaluate_add(struct eval_ctx *ctx, struct cmd *cmd)
case CMD_OBJ_COUNTER:
case CMD_OBJ_QUOTA:
case CMD_OBJ_CT_HELPER:
- ret = cache_update(ctx->nf_sock, ctx->cache, cmd->op,
- ctx->msgs);
- if (ret < 0)
- return ret;
-
return 0;
default:
BUG("invalid command object type %u\n", cmd->obj);
diff --git a/src/netlink.c b/src/netlink.c
index f631c26b..68f33625 100644
--- a/src/netlink.c
+++ b/src/netlink.c
@@ -464,7 +464,16 @@ int netlink_replace_rule_batch(struct netlink_ctx *ctx, const struct handle *h,
const struct location *loc)
{
struct nftnl_rule *nlr;
- int err, flags = ctx->octx->echo ? NLM_F_ECHO : 0;
+ int err, flags = 0;
+
+ if (ctx->octx->echo) {
+ err = cache_update(ctx->nf_sock, ctx->cache,
+ CMD_INVALID, ctx->msgs);
+ if (err < 0)
+ return err;
+
+ flags |= NLM_F_ECHO;
+ }
nlr = alloc_nftnl_rule(&rule->handle);
netlink_linearize_rule(ctx, nlr, rule);
diff --git a/src/rule.c b/src/rule.c
index 1bd5c801..38cd648e 100644
--- a/src/rule.c
+++ b/src/rule.c
@@ -1017,8 +1017,16 @@ static int do_command_add(struct netlink_ctx *ctx, struct cmd *cmd, bool excl)
{
uint32_t flags = excl ? NLM_F_EXCL : 0;
- if (ctx->octx->echo)
+ if (ctx->octx->echo) {
+ int ret;
+
+ ret = cache_update(ctx->nf_sock, ctx->cache,
+ cmd->obj, ctx->msgs);
+ if (ret < 0)
+ return ret;
+
flags |= NLM_F_ECHO;
+ }
switch (cmd->obj) {
case CMD_OBJ_TABLE:
@@ -1058,7 +1066,18 @@ static int do_command_replace(struct netlink_ctx *ctx, struct cmd *cmd)
static int do_command_insert(struct netlink_ctx *ctx, struct cmd *cmd)
{
- uint32_t flags = ctx->octx->echo ? NLM_F_ECHO : 0;
+ uint32_t flags = 0;
+
+ if (ctx->octx->echo) {
+ int ret;
+
+ ret = cache_update(ctx->nf_sock, ctx->cache,
+ cmd->obj, ctx->msgs);
+ if (ret < 0)
+ return ret;
+
+ flags |= NLM_F_ECHO;
+ }
switch (cmd->obj) {
case CMD_OBJ_RULE: