From 3a98450308550e7c64fc39c1e21b0cf3f50d786f Mon Sep 17 00:00:00 2001 From: Pablo Neira Ayuso Date: Thu, 6 Jul 2023 10:26:39 +0200 Subject: [PATCH] netlink_linearize: use div_round_up in byteorder length commit 25e7b99cc450490c38becb03d8bddd0199cfd3f9 upstream. Use div_round_up() to calculate the byteorder length, otherwise fields that take % BITS_PER_BYTE != 0 are not considered by the byteorder expression. Reported-by: Florian Westphal Signed-off-by: Pablo Neira Ayuso --- src/netlink_linearize.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/netlink_linearize.c b/src/netlink_linearize.c index 527f3fc5..1aaa1284 100644 --- a/src/netlink_linearize.c +++ b/src/netlink_linearize.c @@ -740,7 +740,7 @@ static void netlink_gen_unary(struct netlink_linearize_ctx *ctx, netlink_put_register(nle, NFTNL_EXPR_BYTEORDER_SREG, dreg); netlink_put_register(nle, NFTNL_EXPR_BYTEORDER_DREG, dreg); nftnl_expr_set_u32(nle, NFTNL_EXPR_BYTEORDER_LEN, - expr->len / BITS_PER_BYTE); + div_round_up(expr->len, BITS_PER_BYTE)); nftnl_expr_set_u32(nle, NFTNL_EXPR_BYTEORDER_SIZE, byte_size); nftnl_expr_set_u32(nle, NFTNL_EXPR_BYTEORDER_OP, -- 2.47.3