Received: by 2002:ab2:5c0e:0:b0:1ef:a325:1205 with SMTP id i14csp43165lqk; Wed, 13 Mar 2024 15:52:15 -0700 (PDT) X-Forwarded-Encrypted: i=3; AJvYcCUalw8O7Vxn8jfKzu7tDW/FzLOG6o7TM8YZvyA2drE5lUy0zrShY47kF9BAL35bKiZxJhJKmPYDc0cr4bPqrNvsxL9qmhpHWaF54Ahgmg== X-Google-Smtp-Source: AGHT+IElAz/FWwtCbz6HezzLjx+Z1MSvIgrbZV8l+vijQ2rv4CUhvCnICFN4M7AS1t/yA8QUQAJS X-Received: by 2002:a17:90b:fcb:b0:29b:c31:1fe1 with SMTP id gd11-20020a17090b0fcb00b0029b0c311fe1mr293052pjb.10.1710370335547; Wed, 13 Mar 2024 15:52:15 -0700 (PDT) ARC-Seal: i=2; a=rsa-sha256; t=1710370335; cv=pass; d=google.com; s=arc-20160816; b=Um/m3VvQz7LHpGRfXHJBbWhvtxETc2toGI2h224/ttt9L0yEBY4S2TUkmkUBv6hniF OvEdUJtiy8xm0N4kx0rRD1IbgbF8zPNYL8rLDLOGBdVLiKGBn10MHpTkn22GwTUIL2RU HDVXP6cKiM5s94FCN1rr6bSgFzw2ipl/9Jw9s7Dgluey6bidIMsJBwE1r6jqwVdF9SG0 fYujqBR93cxQytjjuYCrS83KMz0Uwrv5YraZbrGToYHRSnJaSClWDGIoo0xVXa/bODAv 9pl8U3oIFomG3UNbNOeAuTrF91A73xaHPCrGGnU513gPOLMx1aTXEMbIsGTpre3ZHXrR P+ig== ARC-Message-Signature: i=2; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=in-reply-to:content-disposition:mime-version:list-unsubscribe :list-subscribe:list-id:precedence:references:message-id:subject:cc :to:from:date; bh=odSyffoOi5zlU5841SIXYWTujBrltUe6RwuClRfOD2Q=; fh=VuyS3liYuCLtfMk16iHL4UtOsnMFwVURAxxdY2tDDAQ=; b=SrQndwMgkc2wChXqx3s93ArwoMCxIt4O0g5yEAmDLLLCgVmFqGIkTUivnFu/lsR35N JnJMcR+A2b4MXv5nnyhhgd9nrNOr59XgpQvHpFC49aR52wt8B305m4IdqNRxuXXG8gE1 9Dy9DCxSPqK4Y+AhjyXmPPjbyEPm4Cgjj5sJGHRqwORh7PHhq53GM80F9e60j5lO4jFs k/HrI1sHuttlQ3g9ceJ6sNYcVA25oNtKNx52hie8RLC4dG2BuBQ/kFU2VExdSZFoCNfW sXRWjFiRpF8wShFD2R52I+SXR4JR2kYMkCXyeNoENrqALsPnwsEKtii/oPVutCPnXXB6 IIJw==; dara=google.com ARC-Authentication-Results: i=2; mx.google.com; arc=pass (i=1 spf=pass spfdomain=makrotopia.org); spf=pass (google.com: domain of linux-kernel+bounces-102618-linux.lists.archive=gmail.com@vger.kernel.org designates 147.75.48.161 as permitted sender) smtp.mailfrom="linux-kernel+bounces-102618-linux.lists.archive=gmail.com@vger.kernel.org" Return-Path: Received: from sy.mirrors.kernel.org (sy.mirrors.kernel.org. [147.75.48.161]) by mx.google.com with ESMTPS id gw15-20020a17090b0a4f00b0029613ad55a4si271835pjb.103.2024.03.13.15.52.15 for (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Wed, 13 Mar 2024 15:52:15 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel+bounces-102618-linux.lists.archive=gmail.com@vger.kernel.org designates 147.75.48.161 as permitted sender) client-ip=147.75.48.161; Authentication-Results: mx.google.com; arc=pass (i=1 spf=pass spfdomain=makrotopia.org); spf=pass (google.com: domain of linux-kernel+bounces-102618-linux.lists.archive=gmail.com@vger.kernel.org designates 147.75.48.161 as permitted sender) smtp.mailfrom="linux-kernel+bounces-102618-linux.lists.archive=gmail.com@vger.kernel.org" Received: from smtp.subspace.kernel.org (wormhole.subspace.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by sy.mirrors.kernel.org (Postfix) with ESMTPS id F2176B22509 for ; Wed, 13 Mar 2024 22:51:06 +0000 (UTC) Received: from localhost.localdomain (localhost.localdomain [127.0.0.1]) by smtp.subspace.kernel.org (Postfix) with ESMTP id 8157F5CDF3; Wed, 13 Mar 2024 22:50:57 +0000 (UTC) Received: from pidgin.makrotopia.org (pidgin.makrotopia.org [185.142.180.65]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id 4A0075A10A; Wed, 13 Mar 2024 22:50:53 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=185.142.180.65 ARC-Seal:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1710370257; cv=none; b=UKV/zAVMFDV/GZsOcjG8ftNenJM4xBZJ9jtWvYPuUTKJiJp9dIqXSinXogjdFmUnWtl+nZ5iYi2aD3Cs/5x0ZEE3uTHMa3B3SeEtv3TFsz5/xMp8PBg8hTRimSd2HRHWLJUw2gy3xrAvrtSo/npaTYzMDPb6ovfiGAkZ1awcZlM= ARC-Message-Signature:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1710370257; c=relaxed/simple; bh=LzUMRu+d7NikfjMCKwk8dTKXUjge8nRIf7hSNqMRLIM=; h=Date:From:To:Cc:Subject:Message-ID:References:MIME-Version: Content-Type:Content-Disposition:In-Reply-To; b=nP8d2GEwL23lW9TCCtdsfDgTGlnzVRjo/9n/kIN3R3zn6wkwzR83grxPWuZNxUwO76L9j5gZz9JJtleIqXbrvZDXAu604vSkCTf+IYWceGpxpRd1lHFZR3gbEz0OtjL93uFaMviPYiAalCmjoKU4/2NhvHYiRdzdqZPhnf4cYeA= ARC-Authentication-Results:i=1; smtp.subspace.kernel.org; dmarc=none (p=none dis=none) header.from=makrotopia.org; spf=pass smtp.mailfrom=makrotopia.org; arc=none smtp.client-ip=185.142.180.65 Authentication-Results: smtp.subspace.kernel.org; dmarc=none (p=none dis=none) header.from=makrotopia.org Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=makrotopia.org Received: from local by pidgin.makrotopia.org with esmtpsa (TLS1.3:TLS_AES_256_GCM_SHA384:256) (Exim 4.96.2) (envelope-from ) id 1rkXQp-0003yg-2i; Wed, 13 Mar 2024 22:50:43 +0000 Date: Wed, 13 Mar 2024 22:50:40 +0000 From: Daniel Golle To: Felix Fietkau , Sean Wang , Mark Lee , Lorenzo Bianconi , "David S. Miller" , Eric Dumazet , Jakub Kicinski , Paolo Abeni , Matthias Brugger , AngeloGioacchino Del Regno , =?iso-8859-1?Q?Ren=E9?= van Dorst , netdev@vger.kernel.org, linux-kernel@vger.kernel.org, linux-arm-kernel@lists.infradead.org, linux-mediatek@lists.infradead.org Cc: Chad Monroe , Steven Liu , John Crispin Subject: [PATCH net 2/2] net: ethernet: mtk_eth_soc: fix PPE hanging issue Message-ID: <82fd25be48f869969b22ef439b8ea403f7e188a0.1710367570.git.daniel@makrotopia.org> References: <7205ca7d3c5433214256df4672f7c1a49815a5a5.1710367570.git.daniel@makrotopia.org> Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <7205ca7d3c5433214256df4672f7c1a49815a5a5.1710367570.git.daniel@makrotopia.org> A patch to resolve an issue was found in MediaTek's GPL-licensed SDK: In the mtk_ppe_stop() function, the PPE scan mode is not disabled before disabling the PPE. This can potentially lead to a hang during the process of disabling the PPE. Without this patch, the PPE may experience a hang during the reboot test. Link: https://git01.mediatek.com/plugins/gitiles/openwrt/feeds/mtk-openwrt-feeds/+/b40da332dfe763932a82f9f62a4709457a15dd6c Fixes: ba37b7caf1ed ("net: ethernet: mtk_eth_soc: add support for initializing the PPE") Suggested-by: Bc-bocun Chen Signed-off-by: Daniel Golle --- drivers/net/ethernet/mediatek/mtk_ppe.c | 18 +++++++++++------- 1 file changed, 11 insertions(+), 7 deletions(-) diff --git a/drivers/net/ethernet/mediatek/mtk_ppe.c b/drivers/net/ethernet/mediatek/mtk_ppe.c index b2a5d9c3733d4..6ce0db3a1a920 100644 --- a/drivers/net/ethernet/mediatek/mtk_ppe.c +++ b/drivers/net/ethernet/mediatek/mtk_ppe.c @@ -994,7 +994,7 @@ void mtk_ppe_start(struct mtk_ppe *ppe) MTK_PPE_KEEPALIVE_DISABLE) | FIELD_PREP(MTK_PPE_TB_CFG_HASH_MODE, 1) | FIELD_PREP(MTK_PPE_TB_CFG_SCAN_MODE, - MTK_PPE_SCAN_MODE_KEEPALIVE_AGE) | + MTK_PPE_SCAN_MODE_CHECK_AGE) | FIELD_PREP(MTK_PPE_TB_CFG_ENTRY_NUM, MTK_PPE_ENTRIES_SHIFT); if (mtk_is_netsys_v2_or_greater(ppe->eth)) @@ -1090,17 +1090,21 @@ int mtk_ppe_stop(struct mtk_ppe *ppe) mtk_ppe_cache_enable(ppe, false); - /* disable offload engine */ - ppe_clear(ppe, MTK_PPE_GLO_CFG, MTK_PPE_GLO_CFG_EN); - ppe_w32(ppe, MTK_PPE_FLOW_CFG, 0); - /* disable aging */ val = MTK_PPE_TB_CFG_AGE_NON_L4 | MTK_PPE_TB_CFG_AGE_UNBIND | MTK_PPE_TB_CFG_AGE_TCP | MTK_PPE_TB_CFG_AGE_UDP | - MTK_PPE_TB_CFG_AGE_TCP_FIN; + MTK_PPE_TB_CFG_AGE_TCP_FIN | + MTK_PPE_TB_CFG_SCAN_MODE; ppe_clear(ppe, MTK_PPE_TB_CFG, val); - return mtk_ppe_wait_busy(ppe); + if (mtk_ppe_wait_busy(ppe)) + return -ETIMEDOUT; + + /* disable offload engine */ + ppe_clear(ppe, MTK_PPE_GLO_CFG, MTK_PPE_GLO_CFG_EN); + ppe_w32(ppe, MTK_PPE_FLOW_CFG, 0); + + return 0; } -- 2.44.0