Received: by 2002:a05:6a10:9848:0:0:0:0 with SMTP id x8csp2583669pxf; Sat, 27 Mar 2021 17:12:12 -0700 (PDT) X-Google-Smtp-Source: ABdhPJx4xwPdy9h4YphCabKvtPBajVpFjKlEFkwDzkJWDUm/6qIOuPKtBGjcjK4xACR6oBH8CWon X-Received: by 2002:a17:906:94ca:: with SMTP id d10mr21754553ejy.107.1616890331890; Sat, 27 Mar 2021 17:12:11 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1616890331; cv=none; d=google.com; s=arc-20160816; b=cvYkzCxx5/32GUVN1P0UuiyF1WVkziog2i4H0XNnXr97tCx7Kw5hu6lH1P8Ng1jkBw E7jNvOa+iX3iZDlmMd5P1seRI6UMHe2jE0Kc4sxONE+mykbF5qvtME9gWIse9WfFDG9F ChqWJq+56N6LtJpTmZwjqxGJrqrG1VWHaHcRqXVIkXGglfAbwwNtusOzFUtA8SQCOn7H JI57WMCFGsqxndjQsQtEdsS0jzJErdWuTFCAkVejZwSGKeMftZTLiVFWZQgYDBWC9ct8 xM05967z+lrlIlc5dfAr8D0+UlieA4kvcPRzCsarYIlEa58XCi0Dy88/ZKEvfMGKJX6I LRBA== 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 :message-id:date:subject:cc:to:from; bh=ebdTQ9EahV4jhL8scVvn/EZcOrnzvgJjTzTU26aabGE=; b=tODRmMFYXoA4JmQiBksBODM7P09feqErlPlfD2pAd+DqIr0VvmXDtCJl0VKc9TO2mt aCmYUZtzU8wPMe5kbVEPVNaknv7xV5KF8SZjmBEtMhojTO/XT3uHfWHMB1wgg5dDLy+O Js1NsCnOyNSyHDBLbFN9DffInZXJ3Io2mg3AlaJPAe0f7NCMEKoN0YMdvyAOEvBpN9Q1 fBRxirVh05FHHeeYYKzUlcaGNOoH0XnSY7+OkZkv+Dk6l469An9ZnQKbbER+PhrWlI+k x8LsmCSZLnepWYn3iAMXXuPT5/qh1o5gTvBP45TteAAZ7r17xeYka2pwwxuTfdztTBOd N2Ow== ARC-Authentication-Results: i=1; mx.google.com; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id p10si9880084ejg.131.2021.03.27.17.11.22; Sat, 27 Mar 2021 17:12:11 -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; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S230516AbhC0X74 (ORCPT + 99 others); Sat, 27 Mar 2021 19:59:56 -0400 Received: from mail-out.m-online.net ([212.18.0.9]:58623 "EHLO mail-out.m-online.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S230176AbhC0X74 (ORCPT ); Sat, 27 Mar 2021 19:59:56 -0400 Received: from frontend01.mail.m-online.net (unknown [192.168.8.182]) by mail-out.m-online.net (Postfix) with ESMTP id 4F7G6c6YR1z1qsZw; Sun, 28 Mar 2021 00:59:52 +0100 (CET) Received: from localhost (dynscan1.mnet-online.de [192.168.6.70]) by mail.m-online.net (Postfix) with ESMTP id 4F7G6c3r1Dz1qsXM; Sun, 28 Mar 2021 00:59:52 +0100 (CET) X-Virus-Scanned: amavisd-new at mnet-online.de Received: from mail.mnet-online.de ([192.168.8.182]) by localhost (dynscan1.mail.m-online.net [192.168.6.70]) (amavisd-new, port 10024) with ESMTP id YQEiKXlhb9gp; Sun, 28 Mar 2021 00:59:51 +0100 (CET) X-Auth-Info: 159iZLDHm8HXxgK/BQMih+LkW2l4iB+we4VHKoXqeIE= Received: from tr.lan (ip-89-176-112-137.net.upcbroadband.cz [89.176.112.137]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.mnet-online.de (Postfix) with ESMTPSA; Sun, 28 Mar 2021 00:59:51 +0100 (CET) From: Marek Vasut To: linux-wireless@vger.kernel.org Cc: Marek Vasut , Amitkumar Karwar , Angus Ainslie , "David S . Miller" , Jakub Kicinski , Kalle Valo , Karun Eagalapati , Martin Kepplinger , Sebastian Krzyszkowiak , Siva Rebbagondla , netdev@vger.kernel.org, stable@vger.kernel.org Subject: [PATCH] rsi: Use resume_noirq for SDIO Date: Sun, 28 Mar 2021 00:59:32 +0100 Message-Id: <20210327235932.175896-1-marex@denx.de> X-Mailer: git-send-email 2.30.2 MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-wireless@vger.kernel.org The rsi_resume() does access the bus to enable interrupts on the RSI SDIO WiFi card, however when calling sdio_claim_host() in the resume path, it is possible the bus is already claimed and sdio_claim_host() spins indefinitelly. Enable the SDIO card interrupts in resume_noirq instead to prevent anything else from claiming the SDIO bus first. Fixes: 20db07332736 ("rsi: sdio suspend and resume support") Signed-off-by: Marek Vasut Cc: Amitkumar Karwar Cc: Angus Ainslie Cc: David S. Miller Cc: Jakub Kicinski Cc: Kalle Valo Cc: Karun Eagalapati Cc: Martin Kepplinger Cc: Sebastian Krzyszkowiak Cc: Siva Rebbagondla Cc: netdev@vger.kernel.org Cc: stable@vger.kernel.org --- drivers/net/wireless/rsi/rsi_91x_sdio.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/drivers/net/wireless/rsi/rsi_91x_sdio.c b/drivers/net/wireless/rsi/rsi_91x_sdio.c index 122174fca672..8465a4ee9b61 100644 --- a/drivers/net/wireless/rsi/rsi_91x_sdio.c +++ b/drivers/net/wireless/rsi/rsi_91x_sdio.c @@ -1513,7 +1513,7 @@ static int rsi_restore(struct device *dev) } static const struct dev_pm_ops rsi_pm_ops = { .suspend = rsi_suspend, - .resume = rsi_resume, + .resume_noirq = rsi_resume, .freeze = rsi_freeze, .thaw = rsi_thaw, .restore = rsi_restore, -- 2.30.2