Received: by 2002:a05:6902:102b:0:0:0:0 with SMTP id x11csp545066ybt; Wed, 8 Jul 2020 06:13:41 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzaWiNM4BOoGq0m8/8P/qON5jrq+mqtIwMkRP2NodguEgM0sbOLKWOrCVNHwhoyUPWxH2vI X-Received: by 2002:aa7:c5d4:: with SMTP id h20mr65422828eds.115.1594214021598; Wed, 08 Jul 2020 06:13:41 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1594214021; cv=none; d=google.com; s=arc-20160816; b=QfUb7l4UPKno6qx5K0S7etenM5D3sblHfndfNyKyX8t5awe30ZlhyuhB+do0HPuxY5 wltPmx7kS63SuJr+CS6c+nwQymdyuobkxphvsP4erzbUk3v2xbiEm7NnDGNQtXwbfmWo DBzQVtVlVHLbr19Tp61KZYv/gS+DnNoM4i/AV1G3RV7vgglUvPCOhNp8T7GnGzcXrKJQ pSmvVCKWjJw5VJcVcU4rYKNKfbD6aGuANQAjckOKLp635JpzwB90XW0AEz3ynvR9PNP9 HtD+wapTor7BLNrhncO0crq0DxPDPLOY6PrGGoLPZCkxf5Oq/gO3wNWCQArqw381CgUf wS4A== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:references:in-reply-to:message-id:date :subject:cc:to:from; bh=eROGeY4Slb6TA/Tw7NWJqi+TlG8Ns0hJ5E4AQ8NKUxs=; b=tvILWXbEG3T8GwNp1iwXw0LYH+EI6/YHvuSuanj8cP51wwWPFboBeEtHLQByiI9V5T 9eGG7muSthOo70VmptxlRGXfk48IeSJHAIoaazSUBZfC6EhUVokZG/a3q570vtROmKua dG2qIcddMMCjVV6Tc1KPCFrD9kl1x/oZCsV22NNiEyGRzZa7LrlyUDeVu9G5ReZQBxEO v8vM1Ko+rhlUAFJn2p/sV9VNO3+axUdoAMWfiSYXfyo/Rq4PBGFsSFz6cSuIa0fOc3PP mlXrckpfAWIJLlU5yffy4Tiu52XLIxnsnX7bSlQ6uz+85F9M1/pNNy2RCTaqh1g8e6/a fz9g== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-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 n19si12224198edt.434.2020.07.08.06.13.18; Wed, 08 Jul 2020 06:13:41 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-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-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1729310AbgGHNM1 (ORCPT + 99 others); Wed, 8 Jul 2020 09:12:27 -0400 Received: from alexa-out.qualcomm.com ([129.46.98.28]:24034 "EHLO alexa-out.qualcomm.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728997AbgGHNM0 (ORCPT ); Wed, 8 Jul 2020 09:12:26 -0400 Received: from ironmsg07-lv.qualcomm.com (HELO ironmsg07-lv.qulacomm.com) ([10.47.202.151]) by alexa-out.qualcomm.com with ESMTP; 08 Jul 2020 06:12:25 -0700 Received: from ironmsg01-blr.qualcomm.com ([10.86.208.130]) by ironmsg07-lv.qulacomm.com with ESMTP/TLS/AES256-SHA; 08 Jul 2020 06:12:24 -0700 Received: from vbadigan-linux.qualcomm.com ([10.206.24.109]) by ironmsg01-blr.qualcomm.com with ESMTP; 08 Jul 2020 18:42:11 +0530 Received: by vbadigan-linux.qualcomm.com (Postfix, from userid 76677) id F1CAF4D31; Wed, 8 Jul 2020 18:42:10 +0530 (IST) From: Veerabhadrarao Badiganti To: adrian.hunter@intel.com, ulf.hansson@linaro.org, bjorn.andersson@linaro.org Cc: linux-mmc@vger.kernel.org, linux-kernel@vger.kernel.org, linux-arm-msm@vger.kernel.org, Veerabhadrarao Badiganti , Andy Gross Subject: [PATCH V1] mmc: sdhci-msm: Set IO pins in low power state during suspend Date: Wed, 8 Jul 2020 18:41:20 +0530 Message-Id: <1594213888-2780-2-git-send-email-vbadigan@codeaurora.org> X-Mailer: git-send-email 1.9.1 In-Reply-To: <1594213888-2780-1-git-send-email-vbadigan@codeaurora.org> References: <1594213888-2780-1-git-send-email-vbadigan@codeaurora.org> Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Configure SDHC IO pins with low power configuration when the driver is in suspend state. Signed-off-by: Veerabhadrarao Badiganti --- drivers/mmc/host/sdhci-msm.c | 17 +++++++++++++++++ 1 file changed, 17 insertions(+) diff --git a/drivers/mmc/host/sdhci-msm.c b/drivers/mmc/host/sdhci-msm.c index 392d41d57a6e..efd2bae1430c 100644 --- a/drivers/mmc/host/sdhci-msm.c +++ b/drivers/mmc/host/sdhci-msm.c @@ -15,6 +15,7 @@ #include #include #include +#include #include "sdhci-pltfm.h" #include "cqhci.h" @@ -1352,6 +1353,19 @@ static void sdhci_msm_set_uhs_signaling(struct sdhci_host *host, sdhci_msm_hs400(host, &mmc->ios); } +static int sdhci_msm_set_pincfg(struct sdhci_msm_host *msm_host, bool level) +{ + struct platform_device *pdev = msm_host->pdev; + int ret; + + if (level) + ret = pinctrl_pm_select_default_state(&pdev->dev); + else + ret = pinctrl_pm_select_sleep_state(&pdev->dev); + + return ret; +} + static int sdhci_msm_set_vmmc(struct mmc_host *mmc) { if (IS_ERR(mmc->supply.vmmc)) @@ -1596,6 +1610,9 @@ static void sdhci_msm_handle_pwr_irq(struct sdhci_host *host, int irq) ret = sdhci_msm_set_vqmmc(msm_host, mmc, pwr_state & REQ_BUS_ON); if (!ret) + ret = sdhci_msm_set_pincfg(msm_host, + pwr_state & REQ_BUS_ON); + if (!ret) irq_ack |= CORE_PWRCTL_BUS_SUCCESS; else irq_ack |= CORE_PWRCTL_BUS_FAIL; -- Qualcomm India Private Limited, on behalf of Qualcomm Innovation Center, Inc., is a member of Code Aurora Forum, a Linux Foundation Collaborative Project