Received: by 2002:ac0:8845:0:0:0:0:0 with SMTP id g63csp613614img; Tue, 26 Feb 2019 05:52:42 -0800 (PST) X-Google-Smtp-Source: AHgI3Ia5JAFp4o0E54QO8GFhgLMeYTLFMQCbdKhLVCexsWK3WFXi3zLU0dWfMQ0f+y9xjsa0Mtva X-Received: by 2002:a63:aa46:: with SMTP id x6mr24568953pgo.452.1551189162772; Tue, 26 Feb 2019 05:52:42 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1551189162; cv=none; d=google.com; s=arc-20160816; b=GrQxcJhJP4uLc0fr8u4uWfhHlvYBufsXUK4qaH9Iwk+xT2oca2cdHEXRywX1lVsh43 oUcdbfn9nT2Goc5kIRgZy0Ze38GxMeXCCMNhSugagPTg2MhIx42QHnM3WW3rFsn1Sjae J3fQXjpvza+jiw6BaoyxqUEkVgbTBgNPBrhpOxv4aZflHl6tdYKDbU6Bw4EUWwh7nuBH jZDVP3RnVIYYCLKU51C7S82trEK1ebHu7fW6ZNC7dT/Q7JyIBR8pv0ESy/a+ew05X0rP jp56CbXOfBSAVrzYG68oxBBkCLAo5OGiU02uAzy9vPrWNdJAvHYH/sFUTTUosgWnxsOK NYHQ== 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=9ocHsXpf3Kr4NtWhV7h8/WvXcClMdjdHJF3J/CDk3VA=; b=eKysGdglL+R2OQqNFm9aoyO5M9eLFC2FMXLX9cBYhLYtsLDjoWKvwm8/NXYMjQBXyV KjXuSFqazLlYt4oIvN0nMSSNokep5DDG/udpAs5/zkOUd+jiBw1fmX0jS5Xj3qxACQWO 6CGRR4vKz265oJUekpVnLE/RFIPxMMBhBsndU/c7E3kN+lTz6uzryT1nE4InZ7+VdTtH 4lDE2mOKo07Dz+fJnXG+0PLtPwo0zYgEH5N1UcJR8BADu83NMbR+Ev+A/IzWreHXhyaL o+CdLc9ieGU3imXM4hcJ3nNmie04n4f8DAx0LPF78/WeNJycIwgFDogJhhOVr5Q+c/ti e1Uw== 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 p65si12768197pfi.76.2019.02.26.05.52.27; Tue, 26 Feb 2019 05:52:42 -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 S1727465AbfBZNvy (ORCPT + 99 others); Tue, 26 Feb 2019 08:51:54 -0500 Received: from mx07-00178001.pphosted.com ([62.209.51.94]:39438 "EHLO mx07-00178001.pphosted.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727051AbfBZNvk (ORCPT ); Tue, 26 Feb 2019 08:51:40 -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 x1QDlDsF028519; Tue, 26 Feb 2019 14:51:17 +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 2qtvh3g8pc-1 (version=TLSv1 cipher=ECDHE-RSA-AES256-SHA bits=256 verify=NOT); Tue, 26 Feb 2019 14:51:17 +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 4D85A31; Tue, 26 Feb 2019 13:51:17 +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 310055476; Tue, 26 Feb 2019 13:51:17 +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:17 +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:16 +0100 From: Olivier Moysan To: , , , , , , , , , , , , Subject: [PATCH 3/7] ASoC: stm32: i2s: fix stream count management Date: Tue, 26 Feb 2019 14:51:06 +0100 Message-ID: <1551189070-15469-4-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 Move counter handling to trigger start section to manage multiple start/stop events. Signed-off-by: Olivier Moysan --- sound/soc/stm/stm32_i2s.c | 12 +++++------- 1 file changed, 5 insertions(+), 7 deletions(-) diff --git a/sound/soc/stm/stm32_i2s.c b/sound/soc/stm/stm32_i2s.c index 7d4c67433916..7f56d7b51ba3 100644 --- a/sound/soc/stm/stm32_i2s.c +++ b/sound/soc/stm/stm32_i2s.c @@ -554,10 +554,6 @@ static int stm32_i2s_startup(struct snd_pcm_substream *substream, return ret; } - spin_lock(&i2s->lock_fd); - i2s->refcount++; - spin_unlock(&i2s->lock_fd); - return regmap_write_bits(i2s->regmap, STM32_I2S_IFCR_REG, I2S_IFCR_MASK, I2S_IFCR_MASK); } @@ -613,18 +609,19 @@ static int stm32_i2s_trigger(struct snd_pcm_substream *substream, int cmd, regmap_write_bits(i2s->regmap, STM32_I2S_IFCR_REG, I2S_IFCR_MASK, I2S_IFCR_MASK); + spin_lock(&i2s->lock_fd); + i2s->refcount++; if (playback_flg) { ier = I2S_IER_UDRIE; } else { ier = I2S_IER_OVRIE; - spin_lock(&i2s->lock_fd); if (i2s->refcount == 1) /* dummy write to trigger capture */ regmap_write(i2s->regmap, STM32_I2S_TXDR_REG, 0); - spin_unlock(&i2s->lock_fd); } + spin_unlock(&i2s->lock_fd); if (STM32_I2S_IS_SLAVE(i2s)) ier |= I2S_IER_TIFREIE; @@ -649,7 +646,6 @@ static int stm32_i2s_trigger(struct snd_pcm_substream *substream, int cmd, spin_unlock(&i2s->lock_fd); break; } - spin_unlock(&i2s->lock_fd); dev_dbg(cpu_dai->dev, "stop I2S\n"); @@ -657,8 +653,10 @@ static int stm32_i2s_trigger(struct snd_pcm_substream *substream, int cmd, I2S_CR1_SPE, 0); if (ret < 0) { dev_err(cpu_dai->dev, "Error %d disabling I2S\n", ret); + spin_unlock(&i2s->lock_fd); return ret; } + spin_unlock(&i2s->lock_fd); cfg1_mask = I2S_CFG1_RXDMAEN | I2S_CFG1_TXDMAEN; regmap_update_bits(i2s->regmap, STM32_I2S_CFG1_REG, -- 2.7.4