Blame SOURCES/0022-parser_json-Support-ranges-in-concat-expressions.patch

3e48d9
From 68392da523f43b9ae09f824fa68b04b20c9c88f5 Mon Sep 17 00:00:00 2001
3e48d9
From: Phil Sutter <psutter@redhat.com>
3e48d9
Date: Wed, 20 May 2020 11:12:37 +0200
3e48d9
Subject: [PATCH] parser_json: Support ranges in concat expressions
3e48d9
3e48d9
Bugzilla: https://bugzilla.redhat.com/show_bug.cgi?id=1805798
3e48d9
Upstream Status: nftables commit 9475ca305a993
3e48d9
3e48d9
commit 9475ca305a993751b05cf26ef8e785a00de98b94
3e48d9
Author: Phil Sutter <phil@nwl.cc>
3e48d9
Date:   Fri Mar 6 16:15:48 2020 +0100
3e48d9
3e48d9
    parser_json: Support ranges in concat expressions
3e48d9
3e48d9
    Duplicate commit 8ac2f3b2fca38's changes to bison parser into JSON
3e48d9
    parser by introducing a new context flag signalling we're parsing
3e48d9
    concatenated expressions.
3e48d9
3e48d9
    Fixes: 8ac2f3b2fca38 ("src: Add support for concatenated set ranges")
3e48d9
    Signed-off-by: Phil Sutter <phil@nwl.cc>
3e48d9
    Acked-by: Eric Garver <eric@garver.life>
3e48d9
---
252916
 src/parser_json.c | 51 +++++++++++++++++++++++++++--------------------
3e48d9
 1 file changed, 29 insertions(+), 22 deletions(-)
3e48d9
3e48d9
diff --git a/src/parser_json.c b/src/parser_json.c
3e48d9
index 031930e..c48faa8 100644
3e48d9
--- a/src/parser_json.c
3e48d9
+++ b/src/parser_json.c
3e48d9
@@ -40,6 +40,7 @@
3e48d9
 #define CTX_F_MANGLE	(1 << 5)
3e48d9
 #define CTX_F_SES	(1 << 6)	/* set_elem_expr_stmt */
3e48d9
 #define CTX_F_MAP	(1 << 7)	/* LHS of map_expr */
3e48d9
+#define CTX_F_CONCAT	(1 << 8)	/* inside concat_expr */
3e48d9
 
3e48d9
 struct json_ctx {
3e48d9
 	struct input_descriptor indesc;
3e48d9
@@ -99,6 +100,7 @@ static struct expr *json_parse_primary_expr(struct json_ctx *ctx, json_t *root);
3e48d9
 static struct expr *json_parse_set_rhs_expr(struct json_ctx *ctx, json_t *root);
3e48d9
 static struct expr *json_parse_set_elem_expr_stmt(struct json_ctx *ctx, json_t *root);
3e48d9
 static struct expr *json_parse_map_lhs_expr(struct json_ctx *ctx, json_t *root);
3e48d9
+static struct expr *json_parse_concat_elem_expr(struct json_ctx *ctx, json_t *root);
3e48d9
 static struct stmt *json_parse_stmt(struct json_ctx *ctx, json_t *root);
3e48d9
 
3e48d9
 /* parsing helpers */
3e48d9
@@ -1058,7 +1060,7 @@ static struct expr *json_parse_concat_expr(struct json_ctx *ctx,
3e48d9
 	}
3e48d9
 
3e48d9
 	json_array_foreach(root, index, value) {
3e48d9
-		tmp = json_parse_primary_expr(ctx, value);
3e48d9
+		tmp = json_parse_concat_elem_expr(ctx, value);
3e48d9
 		if (!tmp) {
3e48d9
 			json_error(ctx, "Parsing expr at index %zd failed.", index);
3e48d9
 			expr_free(expr);
3e48d9
@@ -1354,28 +1356,28 @@ static struct expr *json_parse_expr(struct json_ctx *ctx, json_t *root)
3e48d9
 		{ "set", json_parse_set_expr, CTX_F_RHS | CTX_F_STMT }, /* allow this as stmt expr because that allows set references */
3e48d9
 		{ "map", json_parse_map_expr, CTX_F_STMT | CTX_F_PRIMARY | CTX_F_SET_RHS },
3e48d9
 		/* below three are multiton_rhs_expr */
3e48d9
-		{ "prefix", json_parse_prefix_expr, CTX_F_RHS | CTX_F_STMT },
3e48d9
-		{ "range", json_parse_range_expr, CTX_F_RHS | CTX_F_STMT },
3e48d9
-		{ "payload", json_parse_payload_expr, CTX_F_STMT | CTX_F_PRIMARY | CTX_F_SET_RHS | CTX_F_MANGLE | CTX_F_SES | CTX_F_MAP },
3e48d9
-		{ "exthdr", json_parse_exthdr_expr, CTX_F_PRIMARY | CTX_F_SET_RHS | CTX_F_SES | CTX_F_MAP },
3e48d9
-		{ "tcp option", json_parse_tcp_option_expr, CTX_F_PRIMARY | CTX_F_SET_RHS | CTX_F_MANGLE | CTX_F_SES },
3e48d9
-		{ "ip option", json_parse_ip_option_expr, CTX_F_PRIMARY | CTX_F_SET_RHS | CTX_F_MANGLE | CTX_F_SES },
3e48d9
-		{ "meta", json_parse_meta_expr, CTX_F_STMT | CTX_F_PRIMARY | CTX_F_SET_RHS | CTX_F_MANGLE | CTX_F_SES | CTX_F_MAP },
3e48d9
-		{ "osf", json_parse_osf_expr, CTX_F_STMT | CTX_F_PRIMARY | CTX_F_MAP },
3e48d9
-		{ "ipsec", json_parse_xfrm_expr, CTX_F_PRIMARY | CTX_F_MAP },
3e48d9
-		{ "socket", json_parse_socket_expr, CTX_F_PRIMARY },
3e48d9
-		{ "rt", json_parse_rt_expr, CTX_F_STMT | CTX_F_PRIMARY | CTX_F_SET_RHS | CTX_F_SES | CTX_F_MAP },
3e48d9
-		{ "ct", json_parse_ct_expr, CTX_F_STMT | CTX_F_PRIMARY | CTX_F_SET_RHS | CTX_F_MANGLE | CTX_F_SES | CTX_F_MAP },
3e48d9
-		{ "numgen", json_parse_numgen_expr, CTX_F_STMT | CTX_F_PRIMARY | CTX_F_SET_RHS | CTX_F_SES | CTX_F_MAP },
3e48d9
+		{ "prefix", json_parse_prefix_expr, CTX_F_RHS | CTX_F_STMT | CTX_F_CONCAT },
3e48d9
+		{ "range", json_parse_range_expr, CTX_F_RHS | CTX_F_STMT | CTX_F_CONCAT },
3e48d9
+		{ "payload", json_parse_payload_expr, CTX_F_STMT | CTX_F_PRIMARY | CTX_F_SET_RHS | CTX_F_MANGLE | CTX_F_SES | CTX_F_MAP | CTX_F_CONCAT },
3e48d9
+		{ "exthdr", json_parse_exthdr_expr, CTX_F_PRIMARY | CTX_F_SET_RHS | CTX_F_SES | CTX_F_MAP | CTX_F_CONCAT },
3e48d9
+		{ "tcp option", json_parse_tcp_option_expr, CTX_F_PRIMARY | CTX_F_SET_RHS | CTX_F_MANGLE | CTX_F_SES | CTX_F_CONCAT },
3e48d9
+		{ "ip option", json_parse_ip_option_expr, CTX_F_PRIMARY | CTX_F_SET_RHS | CTX_F_MANGLE | CTX_F_SES | CTX_F_CONCAT },
3e48d9
+		{ "meta", json_parse_meta_expr, CTX_F_STMT | CTX_F_PRIMARY | CTX_F_SET_RHS | CTX_F_MANGLE | CTX_F_SES | CTX_F_MAP | CTX_F_CONCAT },
3e48d9
+		{ "osf", json_parse_osf_expr, CTX_F_STMT | CTX_F_PRIMARY | CTX_F_MAP | CTX_F_CONCAT },
3e48d9
+		{ "ipsec", json_parse_xfrm_expr, CTX_F_PRIMARY | CTX_F_MAP | CTX_F_CONCAT },
3e48d9
+		{ "socket", json_parse_socket_expr, CTX_F_PRIMARY | CTX_F_CONCAT },
3e48d9
+		{ "rt", json_parse_rt_expr, CTX_F_STMT | CTX_F_PRIMARY | CTX_F_SET_RHS | CTX_F_SES | CTX_F_MAP | CTX_F_CONCAT },
3e48d9
+		{ "ct", json_parse_ct_expr, CTX_F_STMT | CTX_F_PRIMARY | CTX_F_SET_RHS | CTX_F_MANGLE | CTX_F_SES | CTX_F_MAP | CTX_F_CONCAT },
3e48d9
+		{ "numgen", json_parse_numgen_expr, CTX_F_STMT | CTX_F_PRIMARY | CTX_F_SET_RHS | CTX_F_SES | CTX_F_MAP | CTX_F_CONCAT },
3e48d9
 		/* below two are hash expr */
3e48d9
-		{ "jhash", json_parse_hash_expr, CTX_F_STMT | CTX_F_PRIMARY | CTX_F_SET_RHS | CTX_F_SES | CTX_F_MAP },
3e48d9
-		{ "symhash", json_parse_hash_expr, CTX_F_STMT | CTX_F_PRIMARY | CTX_F_SET_RHS | CTX_F_SES | CTX_F_MAP },
3e48d9
-		{ "fib", json_parse_fib_expr, CTX_F_PRIMARY | CTX_F_SET_RHS | CTX_F_SES | CTX_F_MAP },
3e48d9
-		{ "|", json_parse_binop_expr, CTX_F_RHS | CTX_F_STMT | CTX_F_PRIMARY | CTX_F_SET_RHS | CTX_F_SES | CTX_F_MAP },
3e48d9
-		{ "^", json_parse_binop_expr, CTX_F_RHS | CTX_F_STMT | CTX_F_PRIMARY | CTX_F_SET_RHS | CTX_F_SES | CTX_F_MAP },
3e48d9
-		{ "&", json_parse_binop_expr, CTX_F_RHS | CTX_F_STMT | CTX_F_PRIMARY | CTX_F_SET_RHS | CTX_F_SES | CTX_F_MAP },
3e48d9
-		{ ">>", json_parse_binop_expr, CTX_F_RHS | CTX_F_STMT | CTX_F_PRIMARY | CTX_F_SET_RHS | CTX_F_SES | CTX_F_MAP },
3e48d9
-		{ "<<", json_parse_binop_expr, CTX_F_RHS | CTX_F_STMT | CTX_F_PRIMARY | CTX_F_SET_RHS | CTX_F_SES | CTX_F_MAP },
3e48d9
+		{ "jhash", json_parse_hash_expr, CTX_F_STMT | CTX_F_PRIMARY | CTX_F_SET_RHS | CTX_F_SES | CTX_F_MAP | CTX_F_CONCAT },
3e48d9
+		{ "symhash", json_parse_hash_expr, CTX_F_STMT | CTX_F_PRIMARY | CTX_F_SET_RHS | CTX_F_SES | CTX_F_MAP | CTX_F_CONCAT },
3e48d9
+		{ "fib", json_parse_fib_expr, CTX_F_PRIMARY | CTX_F_SET_RHS | CTX_F_SES | CTX_F_MAP | CTX_F_CONCAT },
3e48d9
+		{ "|", json_parse_binop_expr, CTX_F_RHS | CTX_F_STMT | CTX_F_PRIMARY | CTX_F_SET_RHS | CTX_F_SES | CTX_F_MAP | CTX_F_CONCAT },
3e48d9
+		{ "^", json_parse_binop_expr, CTX_F_RHS | CTX_F_STMT | CTX_F_PRIMARY | CTX_F_SET_RHS | CTX_F_SES | CTX_F_MAP | CTX_F_CONCAT },
3e48d9
+		{ "&", json_parse_binop_expr, CTX_F_RHS | CTX_F_STMT | CTX_F_PRIMARY | CTX_F_SET_RHS | CTX_F_SES | CTX_F_MAP | CTX_F_CONCAT },
3e48d9
+		{ ">>", json_parse_binop_expr, CTX_F_RHS | CTX_F_STMT | CTX_F_PRIMARY | CTX_F_SET_RHS | CTX_F_SES | CTX_F_MAP | CTX_F_CONCAT },
3e48d9
+		{ "<<", json_parse_binop_expr, CTX_F_RHS | CTX_F_STMT | CTX_F_PRIMARY | CTX_F_SET_RHS | CTX_F_SES | CTX_F_MAP | CTX_F_CONCAT },
3e48d9
 		{ "accept", json_parse_verdict_expr, CTX_F_RHS | CTX_F_SET_RHS },
3e48d9
 		{ "drop", json_parse_verdict_expr, CTX_F_RHS | CTX_F_SET_RHS },
3e48d9
 		{ "continue", json_parse_verdict_expr, CTX_F_RHS | CTX_F_SET_RHS },
3e48d9
@@ -1500,6 +1502,11 @@ static struct expr *json_parse_map_lhs_expr(struct json_ctx *ctx, json_t *root)
3e48d9
 	return json_parse_flagged_expr(ctx, CTX_F_MAP, root);
3e48d9
 }
3e48d9
 
3e48d9
+static struct expr *json_parse_concat_elem_expr(struct json_ctx *ctx, json_t *root)
3e48d9
+{
3e48d9
+	return json_parse_flagged_expr(ctx, CTX_F_CONCAT, root);
3e48d9
+}
3e48d9
+
3e48d9
 static struct expr *json_parse_dtype_expr(struct json_ctx *ctx, json_t *root)
3e48d9
 {
3e48d9
 	if (json_is_string(root)) {
3e48d9
-- 
252916
2.31.1
3e48d9