Received: by 2002:ac0:aed5:0:0:0:0:0 with SMTP id t21csp6253829imb; Fri, 8 Mar 2019 13:00:41 -0800 (PST) X-Google-Smtp-Source: APXvYqzeqyk2lcNn0TGdkstXwsybBAcAAyHkQj2ZYVIk7w/H1TdqJLQnnD6vn55BQd2N+XyJpvhI X-Received: by 2002:a62:a113:: with SMTP id b19mr20264523pff.227.1552078841336; Fri, 08 Mar 2019 13:00:41 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1552078841; cv=none; d=google.com; s=arc-20160816; b=oVF8QoNPCDJ1iask66bxmBMBW/RlG7d8K/cLYJmVPtb6c4Fd/kHzP+C4qrA/A3L0bW VE+B2+nZo/jyxDIqIZXMlJ2BRv8+GpOveddcxcxvnXMS2zsRmtRE5FUq4mV8MUxqZUlr 7wj6EaNJwCO22WLbptY4zUz/3P/kJVHvCzsDMfGBBANwMnVStzMsUYj1Dgi8K84lpzxz euPF5wS8qKM1OKIrPzX2BXy/MFcy96pLOR0s2MffacmDDgTINUbb5WWFX6b0IGKdRy/j 7BWhHOLxCQKudy9iqg6qx3hBNZLzXm+QVrm3hLz21MTIpvvKAS+zVkEn1SiSH6Dqr9ZL WONA== 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=SQfJPUdfepXhbeNiGtUR3W2GGFP/9RdPwPI2MEEDGFA=; b=L4bCwMWzcyJG/cmsh4ICtU7o9bObyFl5rDJIN95RrPGa1kdMBdw0D711A+pPJTlBFL GDR4VMFa6m7V0Ac30rUTWAy/S5au24Hg9anucUi43imMzZSJruG1EfQs0lb9u4n9b2R5 7588SKvsqCBDLpugfA9KTkZJn4LrSLdrRnWVLDNQrBq6AiHpODVHywCVV3Xcr/J1lDEK kux3UcZ2frfeH/EWx+UlCqMuDaZ6zqYBAc2+q3xGJNRco5FUsxI+77QZIprLn1Pa5iSv LOx6mFvW9yxg0cBBbzLuN/9kT3i4z9R8MvHG69LrMzMhFxwbaXNbGwZfJYSu0/K9FE8k DTpw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=cru93ztw; 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; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id l1si8032606pld.386.2019.03.08.13.00.24; Fri, 08 Mar 2019 13:00:41 -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; dkim=pass header.i=@gmail.com header.s=20161025 header.b=cru93ztw; 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; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727143AbfCHU6M (ORCPT + 99 others); Fri, 8 Mar 2019 15:58:12 -0500 Received: from mail-pg1-f193.google.com ([209.85.215.193]:37574 "EHLO mail-pg1-f193.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726465AbfCHU6M (ORCPT ); Fri, 8 Mar 2019 15:58:12 -0500 Received: by mail-pg1-f193.google.com with SMTP id q206so15061326pgq.4 for ; Fri, 08 Mar 2019 12:58:11 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=date:from:to:cc:subject:message-id:references:mime-version :content-disposition:in-reply-to:user-agent; bh=SQfJPUdfepXhbeNiGtUR3W2GGFP/9RdPwPI2MEEDGFA=; b=cru93ztwEgkxVLzHjrKP8V+BhOu2Gy1joL49CJw/B9fck6vZLDNIVa9mEeEN23WJN1 Q0VIyCJmGe5dX1kw9RimenLL3+bZ81fiWpQ31lvxx0kj1m6wtOOdYLWxpQi/lUJmSQnZ 0SdqaWAscz4SuOjWrS0eLbd3kg8QdubaV7lpsg8+PGkNFC21gExYg6zuUhjkDeRKndYQ xdMqPSxvMn36GKRtuJTjlPRWsBrxxChM4DSTtliy096Ey5sWEBNMyKjj5B+9iXpONkp1 gPH5Uuwx1PaNexyMtRQkjKoUWcflJkCMXyQU6+IAounerIHQrFw9tnpYRnlXW0d0jDel 09+w== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:date:from:to:cc:subject:message-id:references :mime-version:content-disposition:in-reply-to:user-agent; bh=SQfJPUdfepXhbeNiGtUR3W2GGFP/9RdPwPI2MEEDGFA=; b=hwrX/yzvVpdMItvtDXy9sL+zoN/JCLqcKzBtX7ZJgVr++I9HA3J7YQ3v3bgptYDt4J hqNPR7VH4Z6TbXkJcBp/Kmy2wKZO6ft2s/a31Z6Ma+RycKTO+kAlqp0prcZZXt+YlGWb viH3wxaHo+aRB3Yx+UMXqT7jxh1bsfitHsQsoz5WsTwngXb5ycruNjTO9+aYHIawFAmp r2cS7Dy4qpWcB9/enSo+/k3C6EE3X8nz15V/XWJ4gpVP61PtuSOMr0QoKJBhfCMkQvFu AbcRn1565BPd3NarjncNd/zTXfewYvZKK+g70UHMZImc/k6tVPBLv7va41CZA6EcA0WE dflQ== X-Gm-Message-State: APjAAAVrzH28A8VS6M7o9LfurwZjbqQFX7/aAi2eo0UEoBEMp82kopiZ pNaabSTcwzgyo5QJm4LIRP0= X-Received: by 2002:a63:591f:: with SMTP id n31mr18314064pgb.304.1552078691055; Fri, 08 Mar 2019 12:58:11 -0800 (PST) Received: from Asurada-Nvidia.nvidia.com (thunderhill.nvidia.com. [216.228.112.22]) by smtp.gmail.com with ESMTPSA id a7sm11797010pff.54.2019.03.08.12.58.10 (version=TLS1_2 cipher=ECDHE-RSA-CHACHA20-POLY1305 bits=256/256); Fri, 08 Mar 2019 12:58:10 -0800 (PST) Date: Fri, 8 Mar 2019 12:58:06 -0800 From: Nicolin Chen To: Daniel Baluta Cc: "broonie@kernel.org" , "festevam@gmail.com" , "timur@kernel.org" , "tiwai@suse.com" , "alsa-devel@alsa-project.org" , "linux-kernel@vger.kernel.org" , dl-linux-imx , "S.j. Wang" Subject: Re: [PATCH v2] ASoC: fsl: sai: Fix underrrun for playback stream start Message-ID: <20190308205805.GA8912@Asurada-Nvidia.nvidia.com> References: <20190308173904.27298-1-daniel.baluta@nxp.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20190308173904.27298-1-daniel.baluta@nxp.com> User-Agent: Mutt/1.9.4 (2018-02-28) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Fri, Mar 08, 2019 at 05:39:30PM +0000, Daniel Baluta wrote: > @@ -542,6 +544,11 @@ static int fsl_sai_trigger(struct snd_pcm_substream *substream, int cmd, > case SNDRV_PCM_TRIGGER_START: > case SNDRV_PCM_TRIGGER_RESUME: > case SNDRV_PCM_TRIGGER_PAUSE_RELEASE: > + for (i = 0; tx && i < channels; i++) > + regmap_write(sai->regmap, FSL_SAI_TDR, 0x0); Though it could reduce underrrun for sure, I don't feel it's a thorough fix, especially when dealing with a duplex case where RX is the first stream while the driver enables both TE and RE at the same time. So the transmitter might have started before TX DMA request gets enabled. We actually have something similar in the ESAI driver as that one is well documented. But SAI is apparently more tricky at the trigger() function. And the paragraph you pasted from the RM doesn't explicitly sound like we should do this. Btw, Instead of writing dummy data, have you tried polling the WFP pointer of the TFR0 register to make sure data is copied by the DMA? > + if (tx) > + udelay(10); Any justification for the delay? Missing a line of comments? I guess it's to address the 3-bit clocks timing. However, putting it before enabling DMA request doesn't make much sense to me. > + > regmap_update_bits(sai->regmap, FSL_SAI_xCSR(tx), > FSL_SAI_CSR_FRDE, FSL_SAI_CSR_FRDE); > > -- > 2.17.1 >