Received: by 2002:a05:6602:2086:0:0:0:0 with SMTP id a6csp4457499ioa; Wed, 27 Apr 2022 04:25:48 -0700 (PDT) X-Google-Smtp-Source: ABdhPJz/v82fP+SbX3e/vJtbI/IOYEtmyUH31pB77YGNn5IK5ZaP15Fb3Rreqq1Bk6yMKikEAy51 X-Received: by 2002:a63:5d0a:0:b0:399:40fd:2012 with SMTP id r10-20020a635d0a000000b0039940fd2012mr24043063pgb.454.1651058748589; Wed, 27 Apr 2022 04:25:48 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1651058748; cv=none; d=google.com; s=arc-20160816; b=SuQT62EG1xYdFCxwzqlIZGHmi6mZFUKQVsLAAbOfiN11N61lr5zXMEDUgjKr2g0QDO h6MybsXt5J4qJh79773mnLeVQQd++6sFV9+kIHv87YDjwiXYLY+bJKAvPrtmfKeEwy8c Aq1wUYt+miSB/RbLJJ2Bs+lp8gFkOr7P/jCFPFlFyR3z5BLnCE8cheMQGR/E5F700dXO tzSw4/emrOsV5Cabkuth5a5oJ5+chQyG8gZ+9cNODQnKgJnybexHcsMjGsapmBegtHpc l9ZrGcnTLh9KqZQWwU6zUmiGStajftFkST67CCfCcrh13ODpy3cZOhghrEXygPWg0AOB kzDA== 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=fods+VHLPew9yDq597GCi7X2VJYH9jdyE+PlftMhkE4=; b=rkHiKLekGZ9ocg2+H6aNHPX6PgYo6RZu9IKK4kAUEYvMpGCv/0XN3OE9MM97ZNxtkO pSc1JAiY539+ih8zncarmLJYtqElkBMxLdISL+bJenoBD6FsIHu9XOId7FMsdO9MkBhD 39OzIYs+DeC0Bd4jFj4xks0c901hwQ3KP5TyRtnfSKfYJxTKJWCY4oeY6TSk05nNTzLJ +Epuq69El+9v+wIjed7yhWAN+bAXZ5o0EWPQvI01isQnR0AbCLFMgeHm0nXEyVDVSXa+ 2T16uqTrxRSLzKrIX2DhOnft4jQGuRM6uNN0VDPTgjSElIEcpApreMqPpdG+z3vYuRiy xDZw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=WmpSpAeK; spf=softfail (google.com: domain of transitioning linux-kernel-owner@vger.kernel.org does not designate 23.128.96.19 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 lindbergh.monkeyblade.net (lindbergh.monkeyblade.net. [23.128.96.19]) by mx.google.com with ESMTPS id w7-20020a628207000000b005058961217asi1117010pfd.216.2022.04.27.04.25.48 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Wed, 27 Apr 2022 04:25:48 -0700 (PDT) Received-SPF: softfail (google.com: domain of transitioning linux-kernel-owner@vger.kernel.org does not designate 23.128.96.19 as permitted sender) client-ip=23.128.96.19; Authentication-Results: mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=WmpSpAeK; spf=softfail (google.com: domain of transitioning linux-kernel-owner@vger.kernel.org does not designate 23.128.96.19 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by lindbergh.monkeyblade.net (Postfix) with ESMTP id 52103431D5C; Wed, 27 Apr 2022 03:22:28 -0700 (PDT) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1346635AbiDZIpP (ORCPT + 99 others); Tue, 26 Apr 2022 04:45:15 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:59638 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1345512AbiDZIjL (ORCPT ); Tue, 26 Apr 2022 04:39:11 -0400 Received: from ams.source.kernel.org (ams.source.kernel.org [145.40.68.75]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id E3D043FBD7; Tue, 26 Apr 2022 01:30:02 -0700 (PDT) Received: from smtp.kernel.org (relay.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by ams.source.kernel.org (Postfix) with ESMTPS id 80736B81CAF; Tue, 26 Apr 2022 08:30:01 +0000 (UTC) Received: by smtp.kernel.org (Postfix) with ESMTPSA id E3635C385A0; Tue, 26 Apr 2022 08:29:59 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1650961800; bh=GdhV+M7q++CPNc+w2fY6C6AGEQb4sYzOfXOJmXL+AZM=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=WmpSpAeKPnT/1Dyg7jtgepPjO46ObVgwHBKgfmFo+qoDCTHf/pGixKezmKBZ9dc1J MnmUl8N7ywU5jmbw3666FR1cvtzMSkFyeKlw8UJs0BKiRrH8Kvp9l/0KOHlvOyDQeh HBUyd04gu9E6d+Rp/eUgfPMwh4jIEEzyvzBDl5og= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Tomas Melin , Claudiu Beznea , Jakub Kicinski , Sasha Levin Subject: [PATCH 5.4 33/62] net: macb: Restart tx only if queue pointer is lagging Date: Tue, 26 Apr 2022 10:21:13 +0200 Message-Id: <20220426081738.175168427@linuxfoundation.org> X-Mailer: git-send-email 2.36.0 In-Reply-To: <20220426081737.209637816@linuxfoundation.org> References: <20220426081737.209637816@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-2.5 required=5.0 tests=BAYES_00,DKIMWL_WL_HIGH, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_AU,HEADER_FROM_DIFFERENT_DOMAINS, MAILING_LIST_MULTI,RDNS_NONE,SPF_HELO_NONE autolearn=unavailable autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Tomas Melin [ Upstream commit 5ad7f18cd82cee8e773d40cc7a1465a526f2615c ] commit 4298388574da ("net: macb: restart tx after tx used bit read") added support for restarting transmission. Restarting tx does not work in case controller asserts TXUBR interrupt and TQBP is already at the end of the tx queue. In that situation, restarting tx will immediately cause assertion of another TXUBR interrupt. The driver will end up in an infinite interrupt loop which it cannot break out of. For cases where TQBP is at the end of the tx queue, instead only clear TX_USED interrupt. As more data gets pushed to the queue, transmission will resume. This issue was observed on a Xilinx Zynq-7000 based board. During stress test of the network interface, driver would get stuck on interrupt loop within seconds or minutes causing CPU to stall. Signed-off-by: Tomas Melin Tested-by: Claudiu Beznea Reviewed-by: Claudiu Beznea Link: https://lore.kernel.org/r/20220407161659.14532-1-tomas.melin@vaisala.com Signed-off-by: Jakub Kicinski Signed-off-by: Sasha Levin --- drivers/net/ethernet/cadence/macb_main.c | 8 ++++++++ 1 file changed, 8 insertions(+) diff --git a/drivers/net/ethernet/cadence/macb_main.c b/drivers/net/ethernet/cadence/macb_main.c index 480d2ca369e6..002a374f197b 100644 --- a/drivers/net/ethernet/cadence/macb_main.c +++ b/drivers/net/ethernet/cadence/macb_main.c @@ -1378,6 +1378,7 @@ static void macb_tx_restart(struct macb_queue *queue) unsigned int head = queue->tx_head; unsigned int tail = queue->tx_tail; struct macb *bp = queue->bp; + unsigned int head_idx, tbqp; if (bp->caps & MACB_CAPS_ISR_CLEAR_ON_WRITE) queue_writel(queue, ISR, MACB_BIT(TXUBR)); @@ -1385,6 +1386,13 @@ static void macb_tx_restart(struct macb_queue *queue) if (head == tail) return; + tbqp = queue_readl(queue, TBQP) / macb_dma_desc_get_size(bp); + tbqp = macb_adj_dma_desc_idx(bp, macb_tx_ring_wrap(bp, tbqp)); + head_idx = macb_adj_dma_desc_idx(bp, macb_tx_ring_wrap(bp, head)); + + if (tbqp == head_idx) + return; + macb_writel(bp, NCR, macb_readl(bp, NCR) | MACB_BIT(TSTART)); } -- 2.35.1