Received: by 2002:a25:8b91:0:0:0:0:0 with SMTP id j17csp8072605ybl; Thu, 16 Jan 2020 10:09:14 -0800 (PST) X-Google-Smtp-Source: APXvYqxQ6wfW41O9+eD9RWh/Tb3u82Q+VIgJJLTDK9r9JjVP9sHRFnj4efhiVoaoXGDoJ1IQoz2y X-Received: by 2002:aca:f456:: with SMTP id s83mr272074oih.12.1579198154301; Thu, 16 Jan 2020 10:09:14 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1579198154; cv=none; d=google.com; s=arc-20160816; b=0k9yfcXVLZy3fEcu6FUjGWajmDg5KomvDIvXqJVmdLcXAfaIZzL7PkhTQ/E3lhV1li ShbpldXC+JBvaMWLJuMMEES6zMeHoYbhcrHRAMdvEQU//mNM0GwIulSH6EGhxEb9ZhSP 37AbeCWmPVZSc4STZ9kMI3p37wkOOVuV7yK5rVUxhhlPjWsFTulj3fEmxnDrpce0rYGr sTKEFDQmRgRga7OItAszl6Fo/lbnauxTNMby3ciCF3A8MElHEHNDSEH5lWf79kR1eqSm ngD3HxYXGQIIOY+y+2NmD1UUyMR3ZteujsAQ0efyawIy7ZIAkOF4r4NQOQG1ln2Ny6/j 4w3g== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature; bh=vivu+Edxy3exxIH12pqILFRrvmMuE1BUSxGLW9bFw+s=; b=oGSRgJES9147C6OCjBaA/Wbs46nC/MHPJ2P1HFJem++fk8JCCM9dK+B8EdlqVbndQ5 Uq9cQF/vU39/vWXnvJ+9KKUeNwVI+AogBlwS3C851E7WVFSRI9+lszxo8X6o4Wqn5+Hk jFKLt4WHqRUSsxm9LzvlaYE9bQ66j/fHFSQP2kf/JW3pj1jr8bb7rPxAsj83rxebFZ8q 6igPMrqR03K2r6Hetz+pmeliz8S5gHmHNwsBhDKFnHaxcX7eD7DrSKP2NvoJmPxaV02R sOS6hZw5rhgaKO6oK6dYo/cRVdpxtnjZwUMEdy7nWM7oUO0WQ/PGw2uWBuDpzdg5lVMN BVbw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b="ayOwF/SN"; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id 9si10729454oiz.237.2020.01.16.10.09.02; Thu, 16 Jan 2020 10:09:14 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b="ayOwF/SN"; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2407100AbgAPSGs (ORCPT + 99 others); Thu, 16 Jan 2020 13:06:48 -0500 Received: from mail.kernel.org ([198.145.29.99]:55734 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2393470AbgAPRj0 (ORCPT ); Thu, 16 Jan 2020 12:39:26 -0500 Received: from sasha-vm.mshome.net (c-73-47-72-35.hsd1.nh.comcast.net [73.47.72.35]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id 2CCF1246F2; Thu, 16 Jan 2020 17:39:24 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1579196365; bh=yETDCHaS0GNumaF6qSl588yc42UN+5m/IRjtrw7dan4=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=ayOwF/SNsaSyUueFuUqOkUe3bn7fsEcbL8UZfxNWYQ+VMfPetAafnwQwpWF/0jTX4 UgUhSaZWtY89tr20ovI11lMSI1fE1gbBN54/CdXaENm06AIUjibsGb5bpQslsGwiyn MS/BtNkLThYnBr5UgPpGeF98JqcIM83bEMABvhxo= From: Sasha Levin To: linux-kernel@vger.kernel.org, stable@vger.kernel.org Cc: Jakub Kicinski , Dirk van der Merwe , Cong Wang , "David S . Miller" , Sasha Levin , netem@lists.linux-foundation.org, netdev@vger.kernel.org Subject: [PATCH AUTOSEL 4.9 154/251] net: netem: fix backlog accounting for corrupted GSO frames Date: Thu, 16 Jan 2020 12:35:03 -0500 Message-Id: <20200116173641.22137-114-sashal@kernel.org> X-Mailer: git-send-email 2.20.1 In-Reply-To: <20200116173641.22137-1-sashal@kernel.org> References: <20200116173641.22137-1-sashal@kernel.org> MIME-Version: 1.0 X-stable: review X-Patchwork-Hint: Ignore Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Jakub Kicinski [ Upstream commit 177b8007463c4f36c9a2c7ce7aa9875a4cad9bd5 ] When GSO frame has to be corrupted netem uses skb_gso_segment() to produce the list of frames, and re-enqueues the segments one by one. The backlog length has to be adjusted to account for new frames. The current calculation is incorrect, leading to wrong backlog lengths in the parent qdisc (both bytes and packets), and incorrect packet backlog count in netem itself. Parent backlog goes negative, netem's packet backlog counts all non-first segments twice (thus remaining non-zero even after qdisc is emptied). Move the variables used to count the adjustment into local scope to make 100% sure they aren't used at any stage in backports. Fixes: 6071bd1aa13e ("netem: Segment GSO packets on enqueue") Signed-off-by: Jakub Kicinski Reviewed-by: Dirk van der Merwe Acked-by: Cong Wang Signed-off-by: David S. Miller Signed-off-by: Sasha Levin --- net/sched/sch_netem.c | 13 ++++++++----- 1 file changed, 8 insertions(+), 5 deletions(-) diff --git a/net/sched/sch_netem.c b/net/sched/sch_netem.c index 95002e56fa48..308d92491757 100644 --- a/net/sched/sch_netem.c +++ b/net/sched/sch_netem.c @@ -437,8 +437,7 @@ static int netem_enqueue(struct sk_buff *skb, struct Qdisc *sch, struct netem_skb_cb *cb; struct sk_buff *skb2; struct sk_buff *segs = NULL; - unsigned int len = 0, last_len, prev_len = qdisc_pkt_len(skb); - int nb = 0; + unsigned int prev_len = qdisc_pkt_len(skb); int count = 1; int rc = NET_XMIT_SUCCESS; int rc_drop = NET_XMIT_DROP; @@ -495,6 +494,7 @@ static int netem_enqueue(struct sk_buff *skb, struct Qdisc *sch, segs = netem_segment(skb, sch, to_free); if (!segs) return rc_drop; + qdisc_skb_cb(segs)->pkt_len = segs->len; } else { segs = skb; } @@ -585,6 +585,11 @@ static int netem_enqueue(struct sk_buff *skb, struct Qdisc *sch, finish_segs: if (segs) { + unsigned int len, last_len; + int nb = 0; + + len = skb->len; + while (segs) { skb2 = segs->next; segs->next = NULL; @@ -600,9 +605,7 @@ static int netem_enqueue(struct sk_buff *skb, struct Qdisc *sch, } segs = skb2; } - sch->q.qlen += nb; - if (nb > 1) - qdisc_tree_reduce_backlog(sch, 1 - nb, prev_len - len); + qdisc_tree_reduce_backlog(sch, -nb, prev_len - len); } return NET_XMIT_SUCCESS; } -- 2.20.1