Received: by 2002:ac0:aed5:0:0:0:0:0 with SMTP id t21csp2505568imb; Mon, 4 Mar 2019 06:55:23 -0800 (PST) X-Google-Smtp-Source: APXvYqxIL72nvmM21jYokMtYH9/2qO0tLtC/qg6bvntbyPExxDwRo7F25jO6aZ3GdMVVv2aLYNs5 X-Received: by 2002:a63:6c41:: with SMTP id h62mr18491028pgc.371.1551711323167; Mon, 04 Mar 2019 06:55:23 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1551711323; cv=none; d=google.com; s=arc-20160816; b=MthrH60X+CEamIQkz+UKpsthiFUS4sHRVD1vnzTZmdT9lR0iKp3CcYxgavNxzqzYuy 0Q+1/zDBnHD9TlojFO4dndvEMh/WKwz3U+gdjMa7qNBLMKHI4rZ/ChN1nYXpyIqkanTp a2caU7YxjhKP+R4zT4IWw0bYOTZynH6Nq/Q3RliDJNeo9iM/8Ae0IFf6YQzEmS572VLO nU2cPcqwpsibHdPmTCzO1pDoI5mhq2x7HgdfPK2aLU5cnZZ77YuSf8qo2vf4e85ipefj srtnutxvfTe1jqUal/4+z/GtiT4kVVYyVH8siCHG8gmhRQbFQLTn/SQg5tcmGiR56S9e eWCg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:mime-version:references:in-reply-to :message-id:date:subject:to:from; bh=Z5dWBd0O/ei+e0C7ITSK8vE0+9yVEzCvg7qMHol3Wpw=; b=qkAWY3064uqRHVdA3JkcihfItOrQWdYMC2sV/IQI7CIIswUkzn4CndTx/Fy63JhbPc +Q/RyML2uyHw31oVW34vkMMn55q06lPClEmUaDGeRmdHS6n1go4yWmmpIVfAMO18tcR7 EoA8c1pfi2hZEQ24x3BOdxVLGdFBMe6NP6MHxh8MsFMRujBlcRAEcpJvvYqM/8A0qBVc vGYk4bV5i491SoLu/p6loM3ZIjcHQKCc+WboHcoIXtSoDYxhQRQF0QABiDm9FhrI2wqn 30DCY3U60mksg/1g3ALc6o0nxWjpe5oBPG/46RXQW4kFkkcWSIvbimvRD+J41gmqot1Y rTTA== 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 y192si5795536pfb.127.2019.03.04.06.55.08; Mon, 04 Mar 2019 06:55:23 -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 S1726765AbfCDOyE (ORCPT + 99 others); Mon, 4 Mar 2019 09:54:04 -0500 Received: from mx07-00178001.pphosted.com ([62.209.51.94]:29602 "EHLO mx07-00178001.pphosted.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726076AbfCDOyE (ORCPT ); Mon, 4 Mar 2019 09:54:04 -0500 Received: from pps.filterd (m0046668.ppops.net [127.0.0.1]) by mx07-00178001.pphosted.com (8.16.0.27/8.16.0.27) with SMTP id x24Eoxe6031315; Mon, 4 Mar 2019 15:53:06 +0100 Received: from beta.dmz-eu.st.com (beta.dmz-eu.st.com [164.129.1.35]) by mx07-00178001.pphosted.com with ESMTP id 2r0ju8mmwh-1 (version=TLSv1 cipher=ECDHE-RSA-AES256-SHA bits=256 verify=NOT); Mon, 04 Mar 2019 15:53:06 +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 30CEC3A; Mon, 4 Mar 2019 14:53:06 +0000 (GMT) Received: from Webmail-eu.st.com (Safex1hubcas23.st.com [10.75.90.46]) by zeta.dmz-eu.st.com (STMicroelectronics) with ESMTP id E4F384DD8; Mon, 4 Mar 2019 14:53:05 +0000 (GMT) Received: from SAFEX1HUBCAS21.st.com (10.75.90.44) by SAFEX1HUBCAS23.st.com (10.75.90.46) with Microsoft SMTP Server (TLS) id 14.3.361.1; Mon, 4 Mar 2019 15:53:05 +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; Mon, 4 Mar 2019 15:53:05 +0100 From: Olivier Moysan To: , , , , , , , , , , , , Subject: [PATCH 1/3] ASoC: stm32: dfsdm: manage multiple prepare Date: Mon, 4 Mar 2019 15:52:43 +0100 Message-ID: <1551711165-28684-2-git-send-email-olivier.moysan@st.com> X-Mailer: git-send-email 2.7.4 In-Reply-To: <1551711165-28684-1-git-send-email-olivier.moysan@st.com> References: <1551711165-28684-1-git-send-email-olivier.moysan@st.com> 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-04_06:,, signatures=0 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org The DFSDM must be stopped when a new setting is applied. restart systematically DFSDM on multiple prepare calls, to apply changes. Signed-off-by: Olivier Moysan --- sound/soc/stm/stm32_adfsdm.c | 17 ++++++++++++++++- 1 file changed, 16 insertions(+), 1 deletion(-) diff --git a/sound/soc/stm/stm32_adfsdm.c b/sound/soc/stm/stm32_adfsdm.c index 706ff005234f..71d341b732a4 100644 --- a/sound/soc/stm/stm32_adfsdm.c +++ b/sound/soc/stm/stm32_adfsdm.c @@ -9,6 +9,7 @@ #include #include +#include #include #include @@ -37,6 +38,8 @@ struct stm32_adfsdm_priv { /* PCM buffer */ unsigned char *pcm_buff; unsigned int pos; + + struct mutex lock; /* protect against race condition on iio state */ }; static const struct snd_pcm_hardware stm32_adfsdm_pcm_hw = { @@ -62,10 +65,12 @@ static void stm32_adfsdm_shutdown(struct snd_pcm_substream *substream, { struct stm32_adfsdm_priv *priv = snd_soc_dai_get_drvdata(dai); + mutex_lock(&priv->lock); if (priv->iio_active) { iio_channel_stop_all_cb(priv->iio_cb); priv->iio_active = false; } + mutex_unlock(&priv->lock); } static int stm32_adfsdm_dai_prepare(struct snd_pcm_substream *substream, @@ -74,13 +79,19 @@ static int stm32_adfsdm_dai_prepare(struct snd_pcm_substream *substream, struct stm32_adfsdm_priv *priv = snd_soc_dai_get_drvdata(dai); int ret; + mutex_lock(&priv->lock); + if (priv->iio_active) { + iio_channel_stop_all_cb(priv->iio_cb); + priv->iio_active = false; + } + ret = iio_write_channel_attribute(priv->iio_ch, substream->runtime->rate, 0, IIO_CHAN_INFO_SAMP_FREQ); if (ret < 0) { dev_err(dai->dev, "%s: Failed to set %d sampling rate\n", __func__, substream->runtime->rate); - return ret; + goto out; } if (!priv->iio_active) { @@ -92,6 +103,9 @@ static int stm32_adfsdm_dai_prepare(struct snd_pcm_substream *substream, __func__, ret); } +out: + mutex_unlock(&priv->lock); + return ret; } @@ -298,6 +312,7 @@ static int stm32_adfsdm_probe(struct platform_device *pdev) priv->dev = &pdev->dev; priv->dai_drv = stm32_adfsdm_dai; + mutex_init(&priv->lock); dev_set_drvdata(&pdev->dev, priv); -- 2.7.4