]> git.ipfire.org Git - thirdparty/linux.git/commitdiff
net: garp: fix unsigned integer underflow in garp_pdu_parse_attr
authorYizhou Zhao <zhaoyz24@mails.tsinghua.edu.cn>
Wed, 27 May 2026 08:31:58 +0000 (16:31 +0800)
committerJakub Kicinski <kuba@kernel.org>
Tue, 2 Jun 2026 19:16:53 +0000 (12:16 -0700)
The receive-side GARP attribute parser computes dlen with reversed
operands:

        dlen = sizeof(*ga) - ga->len;

ga->len is the on-wire attribute length and includes the GARP attribute
header. For normal attributes with data, ga->len is larger than
sizeof(*ga), so the subtraction underflows in unsigned arithmetic.

The resulting value is later passed to garp_attr_lookup(), whose length
argument is u8. After truncation, the parsed data length usually no
longer matches the length stored for locally registered attributes, so
received Join/Leave events are ignored. This breaks the GARP receive path
for common attributes, such as GVRP VLAN registration attributes.

Compute the data length as the attribute length minus the header length.

Fixes: eca9ebac651f ("net: Add GARP applicant-only participant")
Reported-by: Yizhou Zhao <zhaoyz24@mails.tsinghua.edu.cn>
Reported-by: Yuxiang Yang <yangyx22@mails.tsinghua.edu.cn>
Reported-by: Ao Wang <wangao@seu.edu.cn>
Reported-by: Xuewei Feng <fengxw06@126.com>
Reported-by: Qi Li <qli01@tsinghua.edu.cn>
Reported-by: Ke Xu <xuke@tsinghua.edu.cn>
Signed-off-by: Yizhou Zhao <zhaoyz24@mails.tsinghua.edu.cn>
Reviewed-by: Simon Horman <horms@kernel.org>
Link: https://patch.msgid.link/20260527083200.42861-1-zhaoyz24@mails.tsinghua.edu.cn
Signed-off-by: Jakub Kicinski <kuba@kernel.org>
net/802/garp.c

index 6f563b6797d99e9eeb6c0251437e5d3f192ad685..c7a39f298ad6edf689c1119535b5aabb8083f8cf 100644 (file)
@@ -453,7 +453,7 @@ static int garp_pdu_parse_attr(struct garp_applicant *app, struct sk_buff *skb,
        if (!pskb_may_pull(skb, ga->len))
                return -1;
        skb_pull(skb, ga->len);
-       dlen = sizeof(*ga) - ga->len;
+       dlen = ga->len - sizeof(*ga);
 
        if (attrtype > app->app->maxattr)
                return 0;