Received: by 2002:a05:6a10:1d13:0:0:0:0 with SMTP id pp19csp735614pxb; Wed, 1 Sep 2021 08:52:13 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxmGmR09Wo5WBEabrwhO5aBJjwXEms7sJpn8yYZMz6oz/i2tU4wzvFO4yzb7zR+uRjNQMyC X-Received: by 2002:a6b:e70f:: with SMTP id b15mr250858ioh.140.1630511532819; Wed, 01 Sep 2021 08:52:12 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1630511532; cv=none; d=google.com; s=arc-20160816; b=lPwqMGb1GoCEYdoMxbRGHKKyWj4jmjQIQjX7qqxPsVkZDpj0HkEFB169AWrfmqdVZO WzbBQdSQHpGdEazDrWTfkwGnwfRskJWFub8aHUoCCYprpM0ZSHvbtEZ+QwGM/FKFPBCb 9JTfklhioKn1S274wpaboBbbBlTPyhY4d4HTqrwTzLy82eiYlmkWrQLnMSJpbITDz9Dt AkJWXc7XA8U4fAs5oga7WFdcJMOI5+dBcH3w93O+vd4Tj4+whU06kByG4K1yaUlk9XpT hl0TW9kJo2jGnXFaNNeicgZIwfiqy+gYVZ+nL4rTbGmnKF/aQTlPvQ6d+lPZwbAO0dIB PcTA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:user-agent:in-reply-to:content-transfer-encoding :content-disposition:mime-version:references:message-id:subject:cc :to:from:date:dkim-signature; bh=ENEObPVZurtI1M4oVscHA4Z/BCaqlVjz1nVdkAKQYzI=; b=QSJ+qmi5JwIUbML2X2Glhmp8IEvBldY/5I/je4gqwe6OP9m+4/3xrwMJrAVrbsWM3J iZmDWE6KiLEiZFpHeyH7B+3fHDC4vVe468cR7F6JDZVOVI4yZAyKE+C24xvBlIC7N/3Y SelRW1EB/c3TtHB2rvS2v8zTzVVRmv/sf9Q5OQ0YQ80PP3DlMwAGP7uz2N8o1JoO1Rv9 9l4pkrNxliOyzKR5yHPbsqiat0sHw95wHMmZqnqp9j0a5DWsc6HJamTmL00+KOv2WI+W XDdEehOZXrpNjrqH01M/sT4wJLRiGsgHmNXk/vvHoS1Hx1WCiGx0RMn50bwf9n20a2wS g3Wg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=fvIGRMsT; spf=pass (google.com: domain of linux-wireless-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-wireless-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. [23.128.96.18]) by mx.google.com with ESMTP id q20si168296ilj.61.2021.09.01.08.51.52; Wed, 01 Sep 2021 08:52:12 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-wireless-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=@kernel.org header.s=k20201202 header.b=fvIGRMsT; spf=pass (google.com: domain of linux-wireless-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-wireless-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 S1343815AbhIAPwK (ORCPT + 99 others); Wed, 1 Sep 2021 11:52:10 -0400 Received: from mail.kernel.org ([198.145.29.99]:33802 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S244935AbhIAPwK (ORCPT ); Wed, 1 Sep 2021 11:52:10 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id EBA2C61027; Wed, 1 Sep 2021 15:51:12 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1630511473; bh=3lBDzHMwRFHFzEmJ5m7CdDmivd2al3khol396gFXMyY=; h=Date:From:To:Cc:Subject:References:In-Reply-To:From; b=fvIGRMsTiSiSONENP3ZgDmxoqbkwAc6KIqfKGMz3d+ei/XaH860hQWNfVYMuHelb0 YYIrId3XUgflrGPMo1SZ/uZSH3RXhLgxIDWIn6qfXcloKX7Ac0YnX2J1u+9OmyNYiV A9pL6c7BhgW3/U2KGWt48/lihL7dJ2lMhhH+fdfJnvK03LGjPBhmVBi/whPR9420Sh g8En/1AJYqej3EPhLOHFfNmB0BSaNn5jBCrWPiJ9bz4uaPeHA5aGOmcq5N2awjJNTX 77nGfF01hYcrD5OHM7F2a7x9yQ1bkKnxAa9XHlvpaRORXQwv76d8WQJeH9x4a1KQv5 tDyhwQ9PIKO/A== Received: by pali.im (Postfix) id 9E7AEA46; Wed, 1 Sep 2021 17:51:10 +0200 (CEST) Date: Wed, 1 Sep 2021 17:51:10 +0200 From: Pali =?utf-8?B?Um9ow6Fy?= To: Jonas =?utf-8?Q?Dre=C3=9Fler?= Cc: Andy Shevchenko , Amitkumar Karwar , Ganapathi Bhat , Xinming Hu , Kalle Valo , "David S. Miller" , Jakub Kicinski , Tsuchiya Yuto , "open list:TI WILINK WIRELES..." , netdev , Linux Kernel Mailing List , linux-pci , Maximilian Luz , Andy Shevchenko , Bjorn Helgaas Subject: Re: [PATCH 1/2] mwifiex: Use non-posted PCI register writes Message-ID: <20210901155110.xgje2qrtq65loawh@pali> References: <20210830123704.221494-1-verdre@v0yd.nl> <20210830123704.221494-2-verdre@v0yd.nl> <7e38931e-2f1c-066e-088e-b27b56c1245c@v0yd.nl> MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Disposition: inline Content-Transfer-Encoding: 8bit In-Reply-To: <7e38931e-2f1c-066e-088e-b27b56c1245c@v0yd.nl> User-Agent: NeoMutt/20180716 Precedence: bulk List-ID: X-Mailing-List: linux-wireless@vger.kernel.org On Wednesday 01 September 2021 16:01:54 Jonas Dreßler wrote: > On 8/30/21 2:49 PM, Andy Shevchenko wrote: > > On Mon, Aug 30, 2021 at 3:38 PM Jonas Dreßler wrote: > >> > >> On the 88W8897 card it's very important the TX ring write pointer is > >> updated correctly to its new value before setting the TX ready > >> interrupt, otherwise the firmware appears to crash (probably because > >> it's trying to DMA-read from the wrong place). > >> > >> Since PCI uses "posted writes" when writing to a register, it's not > >> guaranteed that a write will happen immediately. That means the pointer > >> might be outdated when setting the TX ready interrupt, leading to > >> firmware crashes especially when ASPM L1 and L1 substates are enabled > >> (because of the higher link latency, the write will probably take > >> longer). > >> > >> So fix those firmware crashes by always forcing non-posted writes. We do > >> that by simply reading back the register after writing it, just as a lot > >> of other drivers do. > >> > >> There are two reproducers that are fixed with this patch: > >> > >> 1) During rx/tx traffic and with ASPM L1 substates enabled (the enabled > >> substates are platform dependent), the firmware crashes and eventually a > >> command timeout appears in the logs. That crash is fixed by using a > >> non-posted write in mwifiex_pcie_send_data(). > >> > >> 2) When sending lots of commands to the card, waking it up from sleep in > >> very quick intervals, the firmware eventually crashes. That crash > >> appears to be fixed by some other non-posted write included here. > > > > Thanks for all this work! > > > > Nevertheless, do we have any commits that may be a good candidate to > > be in the Fixes tag here? > > > > I don't think there's any commit we could point to, given that the bug is > probably somewhere in the firmware code. Then please add Cc: stable@vger.kernel.org tag into commit message. Such bugfix is a good candidate for backporting into stable releases. > >> Signed-off-by: Jonas Dreßler