Received: by 2002:ac0:aed5:0:0:0:0:0 with SMTP id t21csp4353254imb; Wed, 6 Mar 2019 11:15:52 -0800 (PST) X-Google-Smtp-Source: APXvYqySNERkv/KL8xBx6hpJ4Vw7/NjzsXeVgdWjC7IDHwmEVWCA7FBydQdZqL4R0zKuQcuuWqpG X-Received: by 2002:a62:4287:: with SMTP id h7mr8939070pfd.110.1551899752147; Wed, 06 Mar 2019 11:15:52 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1551899752; cv=none; d=google.com; s=arc-20160816; b=GEsrYyMzS4KFwL/JMHAcXTZ+k2jDLQ6yq9ZsY2fPbxSEL/Vu0IOFg9qQLzBMjjFvnr 1Wl7ArPBVHdAr+Q/un+kNH8CXnRmeJD/Vew59eVCXU54bk8Bopt/Ilc7uR/EEEjgEAPP RPkd7iqW+oaytfhAp2cql6OyxoxUPlFVsbfMZO0ls/7LVeKtd9c6Xmne4ib9dm9tgd05 XUTXW1LpPZtzURlgLLWsaUSFxF/ucZQWmhy5r05sRZSETeIifMQnhEjdithSsOntlDYW 5j9fcBR1fK7tzQiNGG1gfTeN6T+U2C2BKV2//ePEeYO8IKHs985UJYz2Y2ng6etPZv9T WcOg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:mime-version:message-id:date:subject:to :from; bh=yKKmKxst5BRuc0E7bySRt0qiEc1rwzLevqCH6axdBRs=; b=UDd4D4F0GorN581j4yZCLuQ6UYDgC7sa0/ZMnnjPVSWnGORB+IR3mu0QjRCCnWdbyq sVnPS6towjcgGQd+DOPYE4iHSENWwaC0BZ/lz5vGB4DPXikkQLECIEB/ktGBNZKlVplv OP0Md4JI0OokXz0QYTOwPoLs+Wx6uXxufg+QxuhM8YnziPuMaH1Sx7jfnUBmNolBVShy UZ/wQ5nVq57rhYkSxm3Sql9AzWet1D4PtgJgBfb+5t9QOyJ1Ip6rXZs8rfnUgFdIlJAO GyozXLBg63hIw1tkUp3sWTn2ZXULXEok95ZUrpPzFaN95qmxB8CeSucOWowrei50onyW gCXg== ARC-Authentication-Results: i=1; mx.google.com; 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 z17si2014603pgv.292.2019.03.06.11.15.36; Wed, 06 Mar 2019 11:15:52 -0800 (PST) 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; 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 S1729930AbfCFQtg (ORCPT + 99 others); Wed, 6 Mar 2019 11:49:36 -0500 Received: from mx08-00178001.pphosted.com ([91.207.212.93]:32637 "EHLO mx07-00178001.pphosted.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1727964AbfCFQtg (ORCPT ); Wed, 6 Mar 2019 11:49:36 -0500 Received: from pps.filterd (m0046660.ppops.net [127.0.0.1]) by mx08-00178001.pphosted.com (8.16.0.27/8.16.0.27) with SMTP id x26GhPTu013356; Wed, 6 Mar 2019 17:48:34 +0100 Received: from beta.dmz-eu.st.com (beta.dmz-eu.st.com [164.129.1.35]) by mx08-00178001.pphosted.com with ESMTP id 2qyhgb14hy-1 (version=TLSv1 cipher=ECDHE-RSA-AES256-SHA bits=256 verify=NOT); Wed, 06 Mar 2019 17:48:34 +0100 Received: from zeta.dmz-eu.st.com (zeta.dmz-eu.st.com [164.129.230.9]) by beta.dmz-eu.st.com (STMicroelectronics) with ESMTP id 164CE3A; Wed, 6 Mar 2019 16:48:32 +0000 (GMT) Received: from Webmail-eu.st.com (Safex1hubcas24.st.com [10.75.90.94]) by zeta.dmz-eu.st.com (STMicroelectronics) with ESMTP id C21AC5079; Wed, 6 Mar 2019 16:48:32 +0000 (GMT) Received: from SAFEX1HUBCAS21.st.com (10.75.90.44) by Safex1hubcas24.st.com (10.75.90.94) with Microsoft SMTP Server (TLS) id 14.3.361.1; Wed, 6 Mar 2019 17:48:32 +0100 Received: from localhost (10.201.23.16) by Webmail-ga.st.com (10.75.90.48) with Microsoft SMTP Server (TLS) id 14.3.361.1; Wed, 6 Mar 2019 17:48:32 +0100 From: Olivier Moysan To: , , , , , , , , , , , , Subject: [PATCH] ASoC: stm32: spdifrx: add power management Date: Wed, 6 Mar 2019 17:48:08 +0100 Message-ID: <1551890888-24622-1-git-send-email-olivier.moysan@st.com> X-Mailer: git-send-email 2.7.4 MIME-Version: 1.0 Content-Type: text/plain X-Originating-IP: [10.201.23.16] X-Proofpoint-Virus-Version: vendor=fsecure engine=2.50.10434:,, definitions=2019-03-06_11:,, signatures=0 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Add suspend and resume sleep callbacks to STM32 SPDIFRX driver, to support system low power modes. Signed-off-by: Olivier Moysan --- sound/soc/stm/stm32_spdifrx.c | 42 +++++++++++++++++++++++++++++++++++++++--- 1 file changed, 39 insertions(+), 3 deletions(-) diff --git a/sound/soc/stm/stm32_spdifrx.c b/sound/soc/stm/stm32_spdifrx.c index 373df4f24be1..b4c3d983e195 100644 --- a/sound/soc/stm/stm32_spdifrx.c +++ b/sound/soc/stm/stm32_spdifrx.c @@ -21,6 +21,7 @@ #include #include #include +#include #include #include @@ -471,6 +472,8 @@ static int stm32_spdifrx_get_ctrl_data(struct stm32_spdifrx_data *spdifrx) memset(spdifrx->cs, 0, SPDIFRX_CS_BYTES_NB); memset(spdifrx->ub, 0, SPDIFRX_UB_BYTES_NB); + pinctrl_pm_select_default_state(&spdifrx->pdev->dev); + ret = stm32_spdifrx_dma_ctrl_start(spdifrx); if (ret < 0) return ret; @@ -502,6 +505,7 @@ static int stm32_spdifrx_get_ctrl_data(struct stm32_spdifrx_data *spdifrx) end: clk_disable_unprepare(spdifrx->kclk); + pinctrl_pm_select_sleep_state(&spdifrx->pdev->dev); return ret; } @@ -611,10 +615,15 @@ static bool stm32_spdifrx_readable_reg(struct device *dev, unsigned int reg) static bool stm32_spdifrx_volatile_reg(struct device *dev, unsigned int reg) { - if (reg == STM32_SPDIFRX_DR) + switch (reg) { + case STM32_SPDIFRX_DR: + case STM32_SPDIFRX_CSR: + case STM32_SPDIFRX_SR: + case STM32_SPDIFRX_DIR: return true; - - return false; + default: + return false; + } } static bool stm32_spdifrx_writeable_reg(struct device *dev, unsigned int reg) @@ -638,6 +647,7 @@ static const struct regmap_config stm32_h7_spdifrx_regmap_conf = { .volatile_reg = stm32_spdifrx_volatile_reg, .writeable_reg = stm32_spdifrx_writeable_reg, .fast_io = true, + .cache_type = REGCACHE_FLAT, }; static irqreturn_t stm32_spdifrx_isr(int irq, void *devid) @@ -983,10 +993,36 @@ static int stm32_spdifrx_remove(struct platform_device *pdev) MODULE_DEVICE_TABLE(of, stm32_spdifrx_ids); +#ifdef CONFIG_PM_SLEEP +static int stm32_spdifrx_suspend(struct device *dev) +{ + struct stm32_spdifrx_data *spdifrx = dev_get_drvdata(dev); + + regcache_cache_only(spdifrx->regmap, true); + regcache_mark_dirty(spdifrx->regmap); + + return 0; +} + +static int stm32_spdifrx_resume(struct device *dev) +{ + struct stm32_spdifrx_data *spdifrx = dev_get_drvdata(dev); + + regcache_cache_only(spdifrx->regmap, false); + + return regcache_sync(spdifrx->regmap); +} +#endif /* CONFIG_PM_SLEEP */ + +static const struct dev_pm_ops stm32_spdifrx_pm_ops = { + SET_SYSTEM_SLEEP_PM_OPS(stm32_spdifrx_suspend, stm32_spdifrx_resume) +}; + static struct platform_driver stm32_spdifrx_driver = { .driver = { .name = "st,stm32-spdifrx", .of_match_table = stm32_spdifrx_ids, + .pm = &stm32_spdifrx_pm_ops, }, .probe = stm32_spdifrx_probe, .remove = stm32_spdifrx_remove, -- 2.7.4