Received: by 2002:a05:6a10:6744:0:0:0:0 with SMTP id w4csp3835950pxu; Tue, 20 Oct 2020 01:31:15 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxFLjwAiRPyaXWaBLhIRrYgKTh01Y9tmlXJL5SCvx14JOlvuMg0HCBc0XD4rztY+9DpTApR X-Received: by 2002:a17:906:a454:: with SMTP id cb20mr2048481ejb.137.1603182675125; Tue, 20 Oct 2020 01:31:15 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1603182675; cv=none; d=google.com; s=arc-20160816; b=c/Dj0WmGJym7kHabJK1oiJfIvwk15fzNFh9av0Zk8uCKheBVSfXuvPiBJR1CPG7vfj kZdyehS17Mzb62R3c5gtG5qN1eMHUpaV5BnExgrgun1PlGUwEg2R+pRsbmUMh4fxKup7 xk1qVo+l/XBNHVnnu1Yiqocfd6nMJypHZ8pu6VA/L2ByLMOYjw2l2qvIOZFyrEoAl7Ph eIqrvWBtGj2SXSlWXNWCgGjlOuuWbBp20mZYzg8fWH0/xSNoFGRuzvjlTEgVvtSbU5D9 ETSu0FWRze2YQfXdhNNGAZKLXPUIwK7J25IhzDi3DV1RBJfWDDSbHeT6usb0XRvzTUTr LmoQ== 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 :references:in-reply-to:date:cc:to:from:subject:message-id; bh=VGQ9N4RhocW7P7q8lnFpLU2kl+cZeVaeyy2IbUEjGnw=; b=SvEeVKiGLdQx7PAhrjMP+YO8gQd+lgTGnlVEn6w8LaR85IJCyvoRZOWEy0F9uIyInk ZnxsCXZ+PYkfz/ICEeVdMgOrgKqvr7WN47Ce+aSnpD6eRFoU2moxVkXzHagj6DS0QcFl FysCYNsdS6AAvNiD1IWbE6CevPCL8Zq/cCESGUkgk9hGcT+nVk4wi06lmNJ1wxObiUPH w7eeGqRf7EA+y+vhR4XlE/egFkzqg9+ykF/RQJymklCAy6ZeP8SEgMIrLvGxC/1pLHgg CpEluxQfse7rHqeEVJzm8Fdcd3WSmZc19kCKS1Vw547UcLSlsjUXgOqIqggPtrJXjlhE dE1Q== ARC-Authentication-Results: i=1; mx.google.com; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id l19si793863ejz.222.2020.10.20.01.30.52; Tue, 20 Oct 2020 01:31:15 -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; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2389072AbgJSXaR (ORCPT + 99 others); Mon, 19 Oct 2020 19:30:17 -0400 Received: from kernel.crashing.org ([76.164.61.194]:42630 "EHLO kernel.crashing.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2389063AbgJSXaO (ORCPT ); Mon, 19 Oct 2020 19:30:14 -0400 Received: from localhost (gate.crashing.org [63.228.1.57]) (authenticated bits=0) by kernel.crashing.org (8.14.7/8.14.7) with ESMTP id 09JNJQN2024225 (version=TLSv1/SSLv3 cipher=ECDHE-RSA-AES256-GCM-SHA384 bits=256 verify=NO); Mon, 19 Oct 2020 18:19:37 -0500 Message-ID: Subject: Re: [PATCH 1/4] ftgmac100: Fix race issue on TX descriptor[0] From: Benjamin Herrenschmidt To: Dylan Hung , davem@davemloft.net, kuba@kernel.org, netdev@vger.kernel.org, linux-kernel@vger.kernel.org, ratbert@faraday-tech.com, linux-aspeed@lists.ozlabs.org, openbmc@lists.ozlabs.org Cc: BMC-SW@aspeedtech.com, Joel Stanley Date: Tue, 20 Oct 2020 10:19:25 +1100 In-Reply-To: <20201019085717.32413-2-dylan_hung@aspeedtech.com> References: <20201019085717.32413-1-dylan_hung@aspeedtech.com> <20201019085717.32413-2-dylan_hung@aspeedtech.com> Content-Type: text/plain; charset="UTF-8" X-Mailer: Evolution 3.28.5-0ubuntu0.18.04.2 Mime-Version: 1.0 Content-Transfer-Encoding: 7bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Mon, 2020-10-19 at 16:57 +0800, Dylan Hung wrote: > These rules must be followed when accessing the TX descriptor: > > 1. A TX descriptor is "cleanable" only when its value is non-zero > and the owner bit is set to "software" Can you elaborate ? What is the point of that change ? The owner bit should be sufficient, why do we need to check other fields ? > 2. A TX descriptor is "writable" only when its value is zero > regardless the edotr mask. Again, why is that ? Can you elaborate ? What race are you trying to address here ? Cheers, Ben. > Fixes: 52c0cae87465 ("ftgmac100: Remove tx descriptor accessors") > Signed-off-by: Dylan Hung > Signed-off-by: Joel Stanley > --- > drivers/net/ethernet/faraday/ftgmac100.c | 10 ++++++++++ > 1 file changed, 10 insertions(+) > > diff --git a/drivers/net/ethernet/faraday/ftgmac100.c > b/drivers/net/ethernet/faraday/ftgmac100.c > index 00024dd41147..7cacbe4aecb7 100644 > --- a/drivers/net/ethernet/faraday/ftgmac100.c > +++ b/drivers/net/ethernet/faraday/ftgmac100.c > @@ -647,6 +647,9 @@ static bool ftgmac100_tx_complete_packet(struct > ftgmac100 *priv) > if (ctl_stat & FTGMAC100_TXDES0_TXDMA_OWN) > return false; > > + if ((ctl_stat & ~(priv->txdes0_edotr_mask)) == 0) > + return false; > + > skb = priv->tx_skbs[pointer]; > netdev->stats.tx_packets++; > netdev->stats.tx_bytes += skb->len; > @@ -756,6 +759,9 @@ static netdev_tx_t > ftgmac100_hard_start_xmit(struct sk_buff *skb, > pointer = priv->tx_pointer; > txdes = first = &priv->txdes[pointer]; > > + if (le32_to_cpu(txdes->txdes0) & ~priv->txdes0_edotr_mask) > + goto drop; > + > /* Setup it up with the packet head. Don't write the head to > the > * ring just yet > */ > @@ -787,6 +793,10 @@ static netdev_tx_t > ftgmac100_hard_start_xmit(struct sk_buff *skb, > /* Setup descriptor */ > priv->tx_skbs[pointer] = skb; > txdes = &priv->txdes[pointer]; > + > + if (le32_to_cpu(txdes->txdes0) & ~priv- > >txdes0_edotr_mask) > + goto dma_err; > + > ctl_stat = ftgmac100_base_tx_ctlstat(priv, pointer); > ctl_stat |= FTGMAC100_TXDES0_TXDMA_OWN; > ctl_stat |= FTGMAC100_TXDES0_TXBUF_SIZE(len);