Received: by 2002:a25:683:0:0:0:0:0 with SMTP id 125csp1201235ybg; Thu, 11 Jun 2020 03:45:48 -0700 (PDT) X-Google-Smtp-Source: ABdhPJy6C7hphQT/y8VIkdT+0h+FNGuW1IpYSFX9IOlrLtKAgLsZslDnwG6QoIO8jRm8r7ZMS+/m X-Received: by 2002:a17:907:7283:: with SMTP id dt3mr8041610ejc.195.1591872348118; Thu, 11 Jun 2020 03:45:48 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1591872348; cv=none; d=google.com; s=arc-20160816; b=E7MxxyVzymXCRdv6T1ABiKsiXCBgOnXW7G+3a/YVAI6ym2rQ2XXY0bBTExuCttIouH p1yhHQHbT/mNymWcLphcHQcYVsIeFRWKOxIIVx3jXcO6uvZQVaht3UrU0vg5hbyrCmZI NfIWZ7bLd/IwbFJNf7vNujcfulekSiYYtlQe6Riwsx9w2es4zEMTGDa6mpKOcz6wIBU5 jfk37h187TzF8IoG+L1Sf3Zw22TLy/YwInt3p0Tr+8lHTsg2pdDnP7ES/nfKBMfO+bny oJySywO1wTFj5uxFADyUtVy2n1HWeXiu8sxlXxuq6BS3kBFiCbGrhfGZ/SE+NP+yYWuI H9JQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:in-reply-to :content-disposition:mime-version:references:message-id:subject:cc :to:from:date:dkim-signature; bh=hecjCZmbcbcFVoaRPrzhg4UVh2uD/Zn308eU+DldDzo=; b=fG8npWxqskQjoUmaubEr1q1MCeOOWHemfJPzghmkQpVYvV7NwFWkmvCeMuMInDPcdU KyOjFhwcTi0l9ndY30vDY4TPgaZR4gQBlNVi5LKroq/RkfYXTz8lXmPqHQ/MSmxr4fvJ fwI69s1upW8ETZY7bzl0F1hLxwh5JlFtrVc8TsdRoSU4wNFQI+7tHIqRoG7FwjpVr0kv n8HZ83M/rXs3H2J2G9XMN9gcHcbM5mndy+/BLMfgug+45H/URHnp6upJnUmusFEzrEkE +lF/mu99aUBvcRtztxxkNxahuC/NoccqO7jzauqTEFktpgbbc+dRJGMWL4Um19DtIB6t GgZg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@cirrus.com header.s=PODMain02222019 header.b=HTd6NhjH; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=REJECT sp=REJECT dis=NONE) header.from=cirrus.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id m9si1362824edp.531.2020.06.11.03.45.24; Thu, 11 Jun 2020 03:45:48 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@cirrus.com header.s=PODMain02222019 header.b=HTd6NhjH; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=REJECT sp=REJECT dis=NONE) header.from=cirrus.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726984AbgFKKnV (ORCPT + 99 others); Thu, 11 Jun 2020 06:43:21 -0400 Received: from mx0a-001ae601.pphosted.com ([67.231.149.25]:33648 "EHLO mx0b-001ae601.pphosted.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1726407AbgFKKnV (ORCPT ); Thu, 11 Jun 2020 06:43:21 -0400 Received: from pps.filterd (m0077473.ppops.net [127.0.0.1]) by mx0a-001ae601.pphosted.com (8.16.0.42/8.16.0.42) with SMTP id 05BAdYdW014068; Thu, 11 Jun 2020 05:42:36 -0500 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=cirrus.com; h=date : from : to : cc : subject : message-id : references : mime-version : content-type : in-reply-to; s=PODMain02222019; bh=hecjCZmbcbcFVoaRPrzhg4UVh2uD/Zn308eU+DldDzo=; b=HTd6NhjHsJ1utxmwA+HwNGN2KO2c2C2LCGg81uqtDkR1oKgm7TuPpr3wBOpYertH2Z+l jIVyH20CS/nD5nsdvMkn6ET0VedzAr/+2sp4/9Q+iaaWc5r5sLzxK/2RQE/Zs+PyjR20 weEW5r4d+4JZ5tWZkr7ieAq49PAMNA2GJ2+4vrGfsJIkLQrvtPwmsQiIRArRGR0/lBV/ bh1HUcc3ZxCsIwE1b86iZT96ZtxuJ0Nlqk6oEyc6JS+ztT8cWU5eG1K5OdamcNX9ZBhk 0+5bLGQ79XGotvK+bUmKaa3aSAz3NHQDJ8MyyZfV7ojL62XIHkLgzOK2M6wUadpmXf4H TA== Authentication-Results: ppops.net; spf=fail smtp.mailfrom=ckeepax@opensource.cirrus.com Received: from ediex01.ad.cirrus.com ([87.246.76.36]) by mx0a-001ae601.pphosted.com with ESMTP id 31g8j47t17-1 (version=TLSv1.2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128 verify=NOT); Thu, 11 Jun 2020 05:42:36 -0500 Received: from EDIEX01.ad.cirrus.com (198.61.84.80) by EDIEX01.ad.cirrus.com (198.61.84.80) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.1913.5; Thu, 11 Jun 2020 11:42:34 +0100 Received: from ediswmail.ad.cirrus.com (198.61.86.93) by EDIEX01.ad.cirrus.com (198.61.84.80) with Microsoft SMTP Server id 15.1.1913.5 via Frontend Transport; Thu, 11 Jun 2020 11:42:34 +0100 Received: from ediswmail.ad.cirrus.com (ediswmail.ad.cirrus.com [198.61.86.93]) by ediswmail.ad.cirrus.com (Postfix) with ESMTP id 79F5B448; Thu, 11 Jun 2020 10:42:34 +0000 (UTC) Date: Thu, 11 Jun 2020 10:42:34 +0000 From: Charles Keepax To: Vinod Koul CC: Jaroslav Kysela , , , , , Srinivas Kandagatla Subject: Re: [RFC PATCH] ALSA: compress: Fix gapless playback state machine Message-ID: <20200611104234.GQ71940@ediswmail.ad.cirrus.com> References: <20200610100729.362-1-srinivas.kandagatla@linaro.org> <817d009e-fa09-e897-cfc3-997bf1dd5e30@perex.cz> <20200610105820.GA1393454@vkoul-mobl> <20200611084659.GO71940@ediswmail.ad.cirrus.com> <6a984302-ff01-e326-d338-e50e1f532cd9@perex.cz> <20200611094423.GB1393454@vkoul-mobl> MIME-Version: 1.0 Content-Type: text/plain; charset="us-ascii" Content-Disposition: inline In-Reply-To: <20200611094423.GB1393454@vkoul-mobl> User-Agent: Mutt/1.5.21 (2010-09-15) X-Proofpoint-SPF-Result: fail X-Proofpoint-SPF-Record: v=spf1 include:spf-001ae601.pphosted.com include:spf.protection.outlook.com ip4:5.172.152.52 -all X-Proofpoint-Spam-Details: rule=notspam policy=default score=0 malwarescore=0 mlxlogscore=999 adultscore=0 suspectscore=0 cotscore=-2147483648 lowpriorityscore=0 phishscore=0 mlxscore=0 priorityscore=1501 spamscore=0 bulkscore=0 clxscore=1015 impostorscore=0 classifier=spam adjust=0 reason=mlx scancount=1 engine=8.12.0-2004280000 definitions=main-2006110083 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Thu, Jun 11, 2020 at 03:14:23PM +0530, Vinod Koul wrote: > On 11-06-20, 11:09, Jaroslav Kysela wrote: > > Dne 11. 06. 20 v 10:46 Charles Keepax napsal(a): > > > On Wed, Jun 10, 2020 at 04:28:20PM +0530, Vinod Koul wrote: > > > > On 10-06-20, 12:40, Jaroslav Kysela wrote: > > > > > Dne 10. 06. 20 v 12:07 Srinivas Kandagatla napsal(a): > > > > > > Here is the sequence of events and state transitions: > > > > > > > > > > > > 1. set_params (Track 1), state = SNDRV_PCM_STATE_SETUP > > > > > > 2. set_metadata (Track 1), no state change, state = SNDRV_PCM_STATE_SETUP > > > > > > 3. fill and trigger start (Track 1), state = SNDRV_PCM_STATE_RUNNING > > > > > > 4. set_next_track (Track 2), state = SNDRV_PCM_STATE_RUNNING > > > > > > 5. partial_drain (Track 1), state = SNDRV_PCM_STATE_SETUP > > > > > > 6 snd_compr_drain_notify (Track 1), state = SNDRV_PCM_STATE_SETUP > > > > > > 7. fill data (Track 2), state = SNDRV_PCM_STATE_PREPARED > > > > > > 8. set_metadata (Track 3), no state change, state = SNDRV_PCM_STATE_PREPARED > > > > > > 9. set_next_track (Track 3), !! FAILURE as state != SNDRV_PCM_STATE_RUNNING > Yeah sorry I overlooked that case and was thinking of it being invoked > from driver! > > Yes this would make the snd_compr_stop() behave incorrectly.. so this > cant be done as proposed. > > But we still need to set the draining stream state properly and I am > thinking below now: > > diff --git a/sound/core/compress_offload.c b/sound/core/compress_offload.c > index 509290f2efa8..9aba851732d7 100644 > --- a/sound/core/compress_offload.c > +++ b/sound/core/compress_offload.c > @@ -929,7 +929,9 @@ static int snd_compr_partial_drain(struct snd_compr_stream *stream) > } > > stream->next_track = false; > - return snd_compress_wait_for_drain(stream); > + retval = snd_compress_wait_for_drain(stream); > + stream->runtime->state = SNDRV_PCM_STATE_RUNNING; > + return retval; This is looking better, I think you probably need to make the switch to RUNNING conditional on snd_compress_wait_for_drain succeeding, as the state should remain in DRAINING if we are interrupted or some such. I also have a slight concern that since snd_compress_wait_for_drain, releases the lock the set_next_track could come in before the state is moved to RUNNING, but I guess from user-spaces perspective that is the same as it coming in whilst the state is still DRAINING, so should be handled fine? Thanks, Charles