Received: by 2002:a05:6a10:206:0:0:0:0 with SMTP id 6csp3936276pxj; Mon, 21 Jun 2021 09:44:11 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzJYnddAwCALTAqipQo3pjBh1XlUj6oriAA8Hcja6XwweqS+2Hm6vjUUEdp+zDlMlYTuC0k X-Received: by 2002:aa7:db94:: with SMTP id u20mr22841571edt.381.1624293851312; Mon, 21 Jun 2021 09:44:11 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1624293851; cv=none; d=google.com; s=arc-20160816; b=hR25VzYnATJga79AaluSHszhpHxY0ofZ//Ll5BqHjngmHHoNVmNN8ReN6InQQsI53+ euMK1lSG58ZxG513fFlnpuPbQSNvHXUgu1gEggskLAYOhCQDfrJuC1lyhhYvGLumB7/k zOX76HYsazKXHtElNAKFJQhX1fbg18sgMDvksG5xF1WookbzcdXkCBlC/hMPit5AMGkJ gg1DyqvzeBATPhmrJxle0e/ad3aHSMozttDRF/+dKsuHCjz4498Hyx6pRUe0SvkR9NLe bEW9ckR4CWTqGn17+UiDUK54yUeGh5Tu3AarRCvyWEd3NMNcRotgNiLHbUh1ZuV3kQXR Xxpg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=pihJTDCDlo3KJeLepGXvgGQK9gIIeOjDhwxzG05S8TU=; b=Kje4fA53ZsNtBl33xHdE72pj/5/ozoloRUqqbmMEhNM5OSFgi3af2pNXf65s9VWlOP oJxjHSTAVoR2RUeMwgcP/oKjISbDPAZK4lBGm+9ml0w2o+3ejj3HM7vVheKHpEQXBvB8 mksZfnLOo8WXxPjh/hh1LqCDvORUF/ns+jkqhdv5eWoXNyPbTFbE/J5CdLX9UiWH1GOC FleidNfw7jPddzvIs4d8oPNF3TWwOn9eZt1bRMRLln4glOMWwYzRy9LKbaGxEAwdmIWa 4MBuJapd9zrvrUQ4N6ENeYmOgH0PhxUo1axqRnuuiKw349NvUvucoGZWjXTdSuxAC8yw 1yIw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=NnXneVDx; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id s23si10635118ejc.642.2021.06.21.09.43.48; Mon, 21 Jun 2021 09:44:11 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=NnXneVDx; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S231899AbhFUQm2 (ORCPT + 99 others); Mon, 21 Jun 2021 12:42:28 -0400 Received: from mail.kernel.org ([198.145.29.99]:56118 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S232814AbhFUQhr (ORCPT ); Mon, 21 Jun 2021 12:37:47 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id 94BC66115B; Mon, 21 Jun 2021 16:29:06 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1624292947; bh=0mKJ3fkAyYjKKBmwW1OD3wt7IeExMJxJozSgLde2vJE=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=NnXneVDxW/j2ATftj4I/uww3dIgU9KKuKqi/Mr02k7aeI28apm+SJI34tYSHEVBGN PHnTklsUnViL5N5Y7EizS9iNoR+1Yzh+p92df3j/rkVj5+ESJpr+hPE4hSPF3hqasJ CI/Kox4BLNxWNjZw5zMJIGGI3/M99qN6QtCDlnYQ= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Young Xiao <92siuyang@gmail.com>, Maxim Mikityanskiy , =?UTF-8?q?Toke=20H=C3=B8iland-J=C3=B8rgensen?= , "David S. Miller" , Sasha Levin Subject: [PATCH 5.12 043/178] sch_cake: Fix out of bounds when parsing TCP options and header Date: Mon, 21 Jun 2021 18:14:17 +0200 Message-Id: <20210621154923.651802582@linuxfoundation.org> X-Mailer: git-send-email 2.32.0 In-Reply-To: <20210621154921.212599475@linuxfoundation.org> References: <20210621154921.212599475@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Maxim Mikityanskiy [ Upstream commit ba91c49dedbde758ba0b72f57ac90b06ddf8e548 ] The TCP option parser in cake qdisc (cake_get_tcpopt and cake_tcph_may_drop) could read one byte out of bounds. When the length is 1, the execution flow gets into the loop, reads one byte of the opcode, and if the opcode is neither TCPOPT_EOL nor TCPOPT_NOP, it reads one more byte, which exceeds the length of 1. This fix is inspired by commit 9609dad263f8 ("ipv4: tcp_input: fix stack out of bounds when parsing TCP options."). v2 changes: Added doff validation in cake_get_tcphdr to avoid parsing garbage as TCP header. Although it wasn't strictly an out-of-bounds access (memory was allocated), garbage values could be read where CAKE expected the TCP header if doff was smaller than 5. Cc: Young Xiao <92siuyang@gmail.com> Fixes: 8b7138814f29 ("sch_cake: Add optional ACK filter") Signed-off-by: Maxim Mikityanskiy Acked-by: Toke Høiland-Jørgensen Signed-off-by: David S. Miller Signed-off-by: Sasha Levin --- net/sched/sch_cake.c | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) diff --git a/net/sched/sch_cake.c b/net/sched/sch_cake.c index 7d37638ee1c7..5c15968b5155 100644 --- a/net/sched/sch_cake.c +++ b/net/sched/sch_cake.c @@ -943,7 +943,7 @@ static struct tcphdr *cake_get_tcphdr(const struct sk_buff *skb, } tcph = skb_header_pointer(skb, offset, sizeof(_tcph), &_tcph); - if (!tcph) + if (!tcph || tcph->doff < 5) return NULL; return skb_header_pointer(skb, offset, @@ -967,6 +967,8 @@ static const void *cake_get_tcpopt(const struct tcphdr *tcph, length--; continue; } + if (length < 2) + break; opsize = *ptr++; if (opsize < 2 || opsize > length) break; @@ -1104,6 +1106,8 @@ static bool cake_tcph_may_drop(const struct tcphdr *tcph, length--; continue; } + if (length < 2) + break; opsize = *ptr++; if (opsize < 2 || opsize > length) break; -- 2.30.2