Received: by 2002:ac0:950c:0:0:0:0:0 with SMTP id f12csp2269739imc; Tue, 12 Mar 2019 10:16:40 -0700 (PDT) X-Google-Smtp-Source: APXvYqzMbNIMHg+Ms/SirdKxwo8bjDkTmMFLJyKPE+MwqhOTBXuyJGkHU4PYMOxV7SadLIB47dgQ X-Received: by 2002:a63:7e0e:: with SMTP id z14mr36109665pgc.436.1552411000242; Tue, 12 Mar 2019 10:16:40 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1552411000; cv=none; d=google.com; s=arc-20160816; b=kQrVjpDM0HJNrqACGJWJFFlDDLvKXH0JUpIWuQzlIOvNFh3PS+u5H4hVwYN+6GABcC zWXJgsPSEvfWUW4ISh5DwP+mXy8veZalSdV2dzPlhLs7XJh8g/EreZ/8C9HfTCbalP+U MJa4RjUkVRc+PwxOhQDvwq+w5f5O8/XasvCz8EcbJci0vuPDT+L/NFDtUDCP54unJFel p25MUH598HJtMB2JjUYEHWPXuboJAXBMcG6kFaUwZTpleYxkelhTfa0JrpHlvN/XcL5e N00GRi5zOo2W3xS3mkP061/IgQMb+iLbu0suVkSVsDvC1EYvUoSeIEnWkf6clywUl0XH m1pg== 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 :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=cYPK+DhBNYWghdLXHerme4XdWPtziRzV0IsQ9m5BDow=; b=zQx4x1brdZGoYYuLsF/al09ZRIu6hjl2MV5vLXzccTULAiVw2D3NK6v5MLg4870Y6A Drrhf85og9y+TgXb5uMxzsRkDe2+GD+U1rBBa2i+zLGzDYdvqwoHfwjc9gdj49lhRozX +BnfPiKuWHtrci08QQNNx4oObu9cyPnSY1RG+RbUph+X4+XoLz6mocaBYs4ybJkLjrZz XWMusK7MariAkuzKxSeDG2jfYYq2r7ubyn4hEljr2Wmk3rneBVOEO6tFJm1WpGDqLVM2 M6aOBQbCO5WvLxVpK/I9PB+hfM/pkKf+fxNE/xJfl3jOGgsBFXPiq0AQ6X2Zr5imvWmN qyzg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=zI4UETDt; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id l7si7920935pgp.513.2019.03.12.10.16.24; Tue, 12 Mar 2019 10:16:40 -0700 (PDT) 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=zI4UETDt; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1728659AbfCLRPQ (ORCPT + 99 others); Tue, 12 Mar 2019 13:15:16 -0400 Received: from mail.kernel.org ([198.145.29.99]:53336 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728388AbfCLROc (ORCPT ); Tue, 12 Mar 2019 13:14:32 -0400 Received: from localhost (unknown [104.133.8.98]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id 1254B2173C; Tue, 12 Mar 2019 17:14:31 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1552410871; bh=kKRXxVlhedt0LxUb7F9TwIv2Jc8pRKwQk5/lvBoImxU=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=zI4UETDtQsr9gt+bm4nDRImpVx+FFy3qeUaiwTpeuQNjE6R4HdKmwFCHaPf6OEBCH DKmH++Yru4dButDcKSEa9uLi9lW/x234KFrE7sznHW/86MHzxyhd2eB7FsPnTTho1F lk2IH3XeGunKdsYxH8uk6EAphOQCvmAzJuUDC7Y8= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Ulf Hansson , Tony Lindgren , Anders Roxell , Kalle Valo , Sasha Levin Subject: [PATCH 4.19 073/149] wlcore: sdio: Fixup power on/off sequence Date: Tue, 12 Mar 2019 10:08:11 -0700 Message-Id: <20190312170355.754717265@linuxfoundation.org> X-Mailer: git-send-email 2.21.0 In-Reply-To: <20190312170349.421581206@linuxfoundation.org> References: <20190312170349.421581206@linuxfoundation.org> User-Agent: quilt/0.65 X-stable: review X-Patchwork-Hint: ignore MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org 4.19-stable review patch. If anyone has any objections, please let me know. ------------------ [ Upstream commit 13e62626c578d9889ebbda7c521be5adff9bef8e ] During "wlan-up", we are programming the FW into the WiFi-chip. However, re-programming the FW doesn't work, unless a power cycle of the WiFi-chip is made in-between the programmings. To conform to this requirement and to fix the regression in a simple way, let's start by allowing that the SDIO card (WiFi-chip) may stay powered on (runtime resumed) when wl12xx_sdio_power_off() returns. The intent with the current code is to treat this scenario as an error, but unfortunate this doesn't work as expected, so let's fix this. The other part is to guarantee that a power cycle of the SDIO card has been completed when wl12xx_sdio_power_on() returns, as to allow the FW programming to succeed. However, relying solely on runtime PM to deal with this isn't sufficient. For example, userspace may prevent runtime suspend via sysfs for the device that represents the SDIO card, leading to that the mmc core also keeps it powered on. For this reason, let's instead do a brute force power cycle in wl12xx_sdio_power_on(). Fixes: 728a9dc61f13 ("wlcore: sdio: Fix flakey SDIO runtime PM handling") Signed-off-by: Ulf Hansson Tested-by: Tony Lindgren Tested-by: Anders Roxell Signed-off-by: Ulf Hansson Signed-off-by: Kalle Valo Signed-off-by: Sasha Levin --- drivers/net/wireless/ti/wlcore/sdio.c | 15 +++++++-------- 1 file changed, 7 insertions(+), 8 deletions(-) diff --git a/drivers/net/wireless/ti/wlcore/sdio.c b/drivers/net/wireless/ti/wlcore/sdio.c index 750bea3574ee..627df164b7b6 100644 --- a/drivers/net/wireless/ti/wlcore/sdio.c +++ b/drivers/net/wireless/ti/wlcore/sdio.c @@ -164,6 +164,12 @@ static int wl12xx_sdio_power_on(struct wl12xx_sdio_glue *glue) } sdio_claim_host(func); + /* + * To guarantee that the SDIO card is power cycled, as required to make + * the FW programming to succeed, let's do a brute force HW reset. + */ + mmc_hw_reset(card->host); + sdio_enable_func(func); sdio_release_host(func); @@ -174,20 +180,13 @@ static int wl12xx_sdio_power_off(struct wl12xx_sdio_glue *glue) { struct sdio_func *func = dev_to_sdio_func(glue->dev); struct mmc_card *card = func->card; - int error; sdio_claim_host(func); sdio_disable_func(func); sdio_release_host(func); /* Let runtime PM know the card is powered off */ - error = pm_runtime_put(&card->dev); - if (error < 0 && error != -EBUSY) { - dev_err(&card->dev, "%s failed: %i\n", __func__, error); - - return error; - } - + pm_runtime_put(&card->dev); return 0; } -- 2.19.1