Blame SOURCES/0031-netlink_delinearize-Sanitize-concat-data-element-dec.patch

b59ec1
From 05407602f79391e89e57ef5c4a1a0aea720855e2 Mon Sep 17 00:00:00 2001
b59ec1
From: Phil Sutter <psutter@redhat.com>
b59ec1
Date: Tue, 21 Feb 2023 19:50:41 +0100
b59ec1
Subject: [PATCH] netlink_delinearize: Sanitize concat data element decoding
b59ec1
b59ec1
Bugzilla: https://bugzilla.redhat.com/show_bug.cgi?id=2160049
b59ec1
Upstream Status: nftables commit 1344d9e53ba4d
b59ec1
b59ec1
commit 1344d9e53ba4d67cedd13a2c76a970fc7ce65683
b59ec1
Author: Phil Sutter <phil@nwl.cc>
b59ec1
Date:   Tue Feb 21 18:36:01 2023 +0100
b59ec1
b59ec1
    netlink_delinearize: Sanitize concat data element decoding
b59ec1
b59ec1
    The call to netlink_get_register() might return NULL, catch this before
b59ec1
    dereferencing the pointer.
b59ec1
b59ec1
    Fixes: db59a5c1204c9 ("netlink_delinearize: fix decoding of concat data element")
b59ec1
    Signed-off-by: Phil Sutter <phil@nwl.cc>
b59ec1
    Acked-by: Florian Westphal <fw@strlen.de>
b59ec1
b59ec1
Signed-off-by: Phil Sutter <psutter@redhat.com>
b59ec1
---
b59ec1
 src/netlink_delinearize.c | 2 +-
b59ec1
 1 file changed, 1 insertion(+), 1 deletion(-)
b59ec1
b59ec1
diff --git a/src/netlink_delinearize.c b/src/netlink_delinearize.c
b59ec1
index e9e0845..cadb8ec 100644
b59ec1
--- a/src/netlink_delinearize.c
b59ec1
+++ b/src/netlink_delinearize.c
b59ec1
@@ -1660,7 +1660,7 @@ static void netlink_parse_dynset(struct netlink_parse_ctx *ctx,
b59ec1
 		sreg_data = netlink_parse_register(nle, NFTNL_EXPR_DYNSET_SREG_DATA);
b59ec1
 		expr_data = netlink_get_register(ctx, loc, sreg_data);
b59ec1
 
b59ec1
-		if (expr_data->len < set->data->len) {
b59ec1
+		if (expr_data && expr_data->len < set->data->len) {
b59ec1
 			expr_free(expr_data);
b59ec1
 			expr_data = netlink_parse_concat_expr(ctx, loc, sreg_data, set->data->len);
b59ec1
 			if (expr_data == NULL)
b59ec1
-- 
b59ec1
2.39.2
b59ec1