Received: by 2002:ac0:8845:0:0:0:0:0 with SMTP id g63csp613354img; Tue, 26 Feb 2019 05:52:25 -0800 (PST) X-Google-Smtp-Source: AHgI3IaYmgn4UzvgEKjg4zUYjxrj0KGVt9plFolIdn5OWiJp+CyJhvAwNK2MqCkgIee4HyjLROIg X-Received: by 2002:a63:2d6:: with SMTP id 205mr24960519pgc.180.1551189145140; Tue, 26 Feb 2019 05:52:25 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1551189145; cv=none; d=google.com; s=arc-20160816; b=Nn9H+ROB+CZIB/UYi3KFlTDx8gSE7iXDtdZrZB0rVg76S+IqAtiiRjcLyQoz+4Vpmr OLwkH4APYjWkQryLLksIceSwUCxovgk0C2sOszBJ5GQYRjJG/HT7F3iarHz+Q/nwhWJF kVhAfL056a/vqIWTL+Vy2hrNmPTNagfJRkocsw7HBQ+pl34VABIybhK7mNYtEgzICQBC 7vQwXY+3+eIREPd5hEPEAWrpCHxyrPR3gNtogvcs6MIlS4H/QJAjVUaiLkNq9Gu32qFr FZmbTNI4D28G+B6FBE/Fyh9E4Z+5mqIBKFmwskMknClE9/cElQDR7fdU9537eQQKdxPS 8HgQ== 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=ExPDUMR2SSU/Nc3Vh8HeLg9kACq8KeiaoWno/JCXYMY=; b=almSrTZqYgkWav+x+MgMj195DXD99RSY3OoXi7nquB/2ZUNld/iJXg+JNOdLaKKW3I 8T+z366Xf9W8ejY9RosjgcMXvEQHjyRKPBy8O2wXlcGDJdeY3kaZkUoUk9OWTvsfJ8om otfDSgCwzsnVAR89UvKjMcTepTPvlEq8VfBaXMzeFQera3BprAqqdGVbdrzwOQde5SWm bjlgXI0hhp/7iOqp9gi6K2mjCPY5ODg/vENcNvUaXpEmxHODZZPR96jT5yUWMpuA/PKB YEu3AlPu7AgiGeVCWYnEk/OPw6O6u9XsdeXtQZnXHeeBVyW/HDPOnOMtVHPw3wd598p3 jrEA== 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 a62si12175947pge.506.2019.02.26.05.52.09; Tue, 26 Feb 2019 05:52:25 -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 S1727405AbfBZNvo (ORCPT + 99 others); Tue, 26 Feb 2019 08:51:44 -0500 Received: from mx07-00178001.pphosted.com ([62.209.51.94]:50571 "EHLO mx07-00178001.pphosted.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727054AbfBZNvk (ORCPT ); Tue, 26 Feb 2019 08:51:40 -0500 Received: from pps.filterd (m0046037.ppops.net [127.0.0.1]) by mx07-00178001.pphosted.com (8.16.0.27/8.16.0.27) with SMTP id x1QDnKKT007733; Tue, 26 Feb 2019 14:51:23 +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 2qtvtx04bu-1 (version=TLSv1 cipher=ECDHE-RSA-AES256-SHA bits=256 verify=NOT); Tue, 26 Feb 2019 14:51:23 +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 058B33A; Tue, 26 Feb 2019 13:51:23 +0000 (GMT) Received: from Webmail-eu.st.com (Safex1hubcas22.st.com [10.75.90.92]) by zeta.dmz-eu.st.com (STMicroelectronics) with ESMTP id DB8A95478; Tue, 26 Feb 2019 13:51:22 +0000 (GMT) Received: from SAFEX1HUBCAS24.st.com (10.75.90.95) by Safex1hubcas22.st.com (10.75.90.92) with Microsoft SMTP Server (TLS) id 14.3.361.1; Tue, 26 Feb 2019 14:51:22 +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; Tue, 26 Feb 2019 14:51:22 +0100 From: Olivier Moysan To: , , , , , , , , , , , , Subject: [PATCH 6/7] ASoC: stm32: i2s: fix race condition in irq handler Date: Tue, 26 Feb 2019 14:51:09 +0100 Message-ID: <1551189070-15469-7-git-send-email-olivier.moysan@st.com> X-Mailer: git-send-email 2.7.4 In-Reply-To: <1551189070-15469-1-git-send-email-olivier.moysan@st.com> References: <1551189070-15469-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-02-26_09:,, signatures=0 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org When snd_pcm_stop_xrun() is called in interrupt routine, substream context may have already been released. Add protection on substream context. Signed-off-by: Olivier Moysan --- sound/soc/stm/stm32_i2s.c | 17 ++++++++++++++--- 1 file changed, 14 insertions(+), 3 deletions(-) diff --git a/sound/soc/stm/stm32_i2s.c b/sound/soc/stm/stm32_i2s.c index 9edb753ffa1b..42ce87a35104 100644 --- a/sound/soc/stm/stm32_i2s.c +++ b/sound/soc/stm/stm32_i2s.c @@ -201,6 +201,7 @@ enum i2s_datlen { * @base: mmio register base virtual address * @phys_addr: I2S registers physical base address * @lock_fd: lock to manage race conditions in full duplex mode + * @irq_lock: prevent race condition with IRQ * @dais_name: DAI name * @mclk_rate: master clock frequency (Hz) * @fmt: DAI protocol @@ -222,6 +223,7 @@ struct stm32_i2s_data { void __iomem *base; dma_addr_t phys_addr; spinlock_t lock_fd; /* Manage race conditions for full duplex */ + spinlock_t irq_lock; /* used to prevent race condition with IRQ */ char dais_name[STM32_I2S_DAI_NAME_SIZE]; unsigned int mclk_rate; unsigned int fmt; @@ -263,8 +265,10 @@ static irqreturn_t stm32_i2s_isr(int irq, void *devid) if (flags & I2S_SR_TIFRE) dev_dbg(&pdev->dev, "Frame error\n"); - if (err) + spin_lock(&i2s->irq_lock); + if (err && i2s->substream) snd_pcm_stop_xrun(i2s->substream); + spin_unlock(&i2s->irq_lock); return IRQ_HANDLED; } @@ -540,9 +544,12 @@ static int stm32_i2s_startup(struct snd_pcm_substream *substream, struct snd_soc_dai *cpu_dai) { struct stm32_i2s_data *i2s = snd_soc_dai_get_drvdata(cpu_dai); + unsigned long flags; int ret; + spin_lock_irqsave(&i2s->irq_lock, flags); i2s->substream = substream; + spin_unlock_irqrestore(&i2s->irq_lock, flags); ret = clk_prepare_enable(i2s->i2sclk); if (ret < 0) { @@ -673,13 +680,16 @@ static void stm32_i2s_shutdown(struct snd_pcm_substream *substream, struct snd_soc_dai *cpu_dai) { struct stm32_i2s_data *i2s = snd_soc_dai_get_drvdata(cpu_dai); - - i2s->substream = NULL; + unsigned long flags; regmap_update_bits(i2s->regmap, STM32_I2S_CGFR_REG, I2S_CGFR_MCKOE, (unsigned int)~I2S_CGFR_MCKOE); clk_disable_unprepare(i2s->i2sclk); + + spin_lock_irqsave(&i2s->irq_lock, flags); + i2s->substream = NULL; + spin_unlock_irqrestore(&i2s->irq_lock, flags); } static int stm32_i2s_dai_probe(struct snd_soc_dai *cpu_dai) @@ -874,6 +884,7 @@ static int stm32_i2s_probe(struct platform_device *pdev) i2s->pdev = pdev; i2s->ms_flg = I2S_MS_NOT_SET; spin_lock_init(&i2s->lock_fd); + spin_lock_init(&i2s->irq_lock); platform_set_drvdata(pdev, i2s); ret = stm32_i2s_dais_init(pdev, i2s); -- 2.7.4