From e35693fd13de771e1e047ffa4f799f72f1446e8d Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Carlos=20Falgueras=20Garc=C3=ADa?= Date: Wed, 17 Aug 2016 16:07:09 +0200 Subject: src: Implement rule comparison MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit This patch implements the function: bool nftnl_rule_cmp(const struct nftnl_rule *r1, const struct nftnl_rule *r2) for rule comparison. Expressions within rules need to be compared, so also has been created the function: bool nftnl_expr_cmp(const struct nftnl_expr *e1, const struct nftnl_expr *e2); Also includes all expression comparators. Signed-off-by: Carlos Falgueras GarcĂ­a Signed-off-by: Pablo Neira Ayuso --- src/expr/redir.c | 18 ++++++++++++++++++ 1 file changed, 18 insertions(+) (limited to 'src/expr/redir.c') diff --git a/src/expr/redir.c b/src/expr/redir.c index c6eedfb..d9dba00 100644 --- a/src/expr/redir.c +++ b/src/expr/redir.c @@ -242,10 +242,28 @@ nftnl_expr_redir_snprintf(char *buf, size_t len, uint32_t type, return -1; } +static bool nftnl_expr_redir_cmp(const struct nftnl_expr *e1, + const struct nftnl_expr *e2) +{ + struct nftnl_expr_redir *r1 = nftnl_expr_data(e1); + struct nftnl_expr_redir *r2 = nftnl_expr_data(e2); + bool eq = true; + + if (e1->flags & (1 << NFTNL_EXPR_REDIR_REG_PROTO_MIN)) + eq &= (r1->sreg_proto_min== r2->sreg_proto_min); + if (e1->flags & (1 << NFTNL_EXPR_REDIR_REG_PROTO_MAX)) + eq &= (r1->sreg_proto_max== r2->sreg_proto_max); + if (e1->flags & (1 << NFTNL_EXPR_REDIR_FLAGS)) + eq &= (r1->flags== r2->flags); + + return eq; +} + struct expr_ops expr_ops_redir = { .name = "redir", .alloc_len = sizeof(struct nftnl_expr_redir), .max_attr = NFTA_REDIR_MAX, + .cmp = nftnl_expr_redir_cmp, .set = nftnl_expr_redir_set, .get = nftnl_expr_redir_get, .parse = nftnl_expr_redir_parse, -- cgit v1.2.3