Received: by 2002:a25:4158:0:0:0:0:0 with SMTP id o85csp2540948yba; Mon, 6 May 2019 07:44:05 -0700 (PDT) X-Google-Smtp-Source: APXvYqwNAqpV36n8j4+IQDf7lvrLAfXmUhxqVO1EMcObUC+4ZFXM0d927rzdol8hTkeRzCgG9qIT X-Received: by 2002:a63:c14:: with SMTP id b20mr31985953pgl.163.1557153845229; Mon, 06 May 2019 07:44:05 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1557153845; cv=none; d=google.com; s=arc-20160816; b=zBvyLVGdqXxjDWeqPraIy72/HvgwoeVvg+lmMX0pajxCWGkdds1h4948gjD6I9b+lP uxtt/49GlNx9tzmYHiP0WwcU9bzonpVKNkS4CQdEGd74t+92uOAvzdXFHnhMVA3qeIMU XP7AJHwUIF1Mo8jn7SbPAF95OQXtwtUCqHOuk7joo8EG0K60a/xbvOJV2z7tXnCoSLPh 1tpWSY9o8BkMiBMqpZGpWvA/BXtyR79T983+FpJj7OS/F6KAexMd9sBG/b7Dp/KvUQP7 +jkmBLwYXyf7sNJnzbHm4On/pRlR4hhYkR1E7iL8HEyNsbLaSqJJAg538fDpYOvjQtzf WIVQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=2JlaJZd4oFY5fqI7W0wX6+3P2hASFygIZdHlTaJWpO0=; b=tOuTbUHcSiHGvc+fM8Z2jbdPwBp0al6kuLHCyt3rSFTNtGlGwG58VgohKXJ+Qu4VfH efe8aNwB3tZoRrqUi7/LTB5WLNl+CZPPLCcvTIZ996AoEBAlhXSor+EeuAs9CoalUEKV K+9+4rhVA16wxnmNN1OWH18f4Yh6y1QaswUXnQ3odHkH1Jhj0WDBFZvfh5FaZG5Oz8Pz 082YGa5ZMoOg0cEv8WQnxmXqI4JmZqw5EmP3J6ZkicaN4zQgmmXr6L7I+g9ZDcKyEhte gtx6ecRa6BKLVYF3FKEAUPF5+fpUGkxbQtbB1ETEd7q2iTRF8gZoBWC56nY3zzpAGvJw HU3g== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=pNpI6vYM; 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 q197si14960809pgq.411.2019.05.06.07.43.49; Mon, 06 May 2019 07:44:05 -0700 (PDT) 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; dkim=pass header.i=@kernel.org header.s=default header.b=pNpI6vYM; 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 S1726598AbfEFOmZ (ORCPT + 99 others); Mon, 6 May 2019 10:42:25 -0400 Received: from mail.kernel.org ([198.145.29.99]:37142 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728463AbfEFOmX (ORCPT ); Mon, 6 May 2019 10:42:23 -0400 Received: from localhost (83-86-89-107.cable.dynamic.v4.ziggo.nl [83.86.89.107]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id CE75A2053B; Mon, 6 May 2019 14:42:21 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1557153742; bh=tVvR0QL7GT+PXhjn9vQ43FfBUr3wxctL7AKnJQs2I6I=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=pNpI6vYM9Wbbe2jOgOFDCM2YyQVl8mm92xIHPX/+V+/CPXmXpgCz8VylDonuBMYUS vRkIDFBeOcROlcr4127JYmeBgvLGLe1ti2XjbypLgWk8uua9NhEQHdhDr7V61IVh1k KppnS38xrHPEQluehpKhFktYA+3J5OFHVL4c8IDY= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Charles Keepax , Mark Brown Subject: [PATCH 4.19 79/99] ASoC: wm_adsp: Correct handling of compressed streams that restart Date: Mon, 6 May 2019 16:32:52 +0200 Message-Id: <20190506143101.240836871@linuxfoundation.org> X-Mailer: git-send-email 2.21.0 In-Reply-To: <20190506143053.899356316@linuxfoundation.org> References: <20190506143053.899356316@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Charles Keepax commit 639e5eb3c7d67e407f2a71fccd95323751398f6f upstream. Previously support was added to allow streams to be stopped and started again without the DSP being power cycled and this was done by clearing the buffer state in trigger start. Another supported use-case is using the DSP for a trigger event then opening the compressed stream later to receive the audio, unfortunately clearing the buffer state in trigger start destroys the data received from such a trigger. Correct this issue by moving the call to wm_adsp_buffer_clear to be in trigger stop instead. Fixes: 61fc060c40e6 ("ASoC: wm_adsp: Support streams which can start/stop with DSP active") Signed-off-by: Charles Keepax Signed-off-by: Mark Brown Signed-off-by: Greg Kroah-Hartman --- sound/soc/codecs/wm_adsp.c | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) --- a/sound/soc/codecs/wm_adsp.c +++ b/sound/soc/codecs/wm_adsp.c @@ -3441,8 +3441,6 @@ int wm_adsp_compr_trigger(struct snd_com } } - wm_adsp_buffer_clear(compr->buf); - /* Trigger the IRQ at one fragment of data */ ret = wm_adsp_buffer_write(compr->buf, HOST_BUFFER_FIELD(high_water_mark), @@ -3454,6 +3452,7 @@ int wm_adsp_compr_trigger(struct snd_com } break; case SNDRV_PCM_TRIGGER_STOP: + wm_adsp_buffer_clear(compr->buf); break; default: ret = -EINVAL;