Received: by 2002:a05:6902:102b:0:0:0:0 with SMTP id x11csp2112439ybt; Mon, 15 Jun 2020 19:16:30 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxNNLfzQbKbIH0G8Z7U70/Y7EHomuLR7IRZShBdoc+t5jWYPSKt1F3U0xU7M6XiMEvc6m3h X-Received: by 2002:a50:e387:: with SMTP id b7mr588779edm.190.1592273790480; Mon, 15 Jun 2020 19:16:30 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1592273790; cv=none; d=google.com; s=arc-20160816; b=HYtf/+w22KgYqmqR/FbMlObe20/ZucMLP4dHZzP+CMtFUIKJY/yNYOW5LwFc0Rbhu9 6A1DAKOy9m7Fiefky2KxnMGfIpN7LcbYMgxYGS1Lk/TiJwaHdb1b6YTs90Vx03K1NKH7 DGbf9kC9ft3qY38XIgoniXdheHqBROzM6L3NtDy2xCluxSvnp0MmTPYUAHTUqsZFoUbX R4olW7GD8lkhPIPdV3JmZOIltF9Z1QE0DKBx0SULYBvdps7p+QHdUofIgV3ItN3sxMhK uuXxzuARSd5vZXdRaGtJVkujv4vrtWXZai+VLq3JZjL8jlYW668KtHETFkTIExoHT7SY aTGA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:cc:to:subject:message-id:date:from :in-reply-to:references:mime-version:dkim-signature; bh=OqI1jdVPVllWwB4NQYQ7J/+T0Dl98wGQyoaCCb+8rkw=; b=gPQR5fNWoRC+QwILxvLsYAOchGiwv0UWu3+lRKYMoOZK7TfXCj2cdbBUIqP1Z/Z75Y T4nJi5kQfrbxLpU4s5r4/KeXZKl+YVmkgybt/9a3Z6RavApbwv1W5ptJ08nTRM1stgZW Tzol5cifFGHdJ8F7d4HPyAvmylpHRdkJ/uufWsad7sZKVODhWTQSmBMvL2wV39KRx5tQ 5oYmPzEU/UuEKNl5X8IQfdr/5lAMfaGrXSvTnhAMitjaG+kKv04SLR9cghSH1vqmcc6a RTbkTnhSnKYrbKVMhU6JJaThLXC/74Tkbv0/qgL3ntYqJOSm464TiWsElzmmO4U48MWW cwtQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b="A1eqm0h/"; 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=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id v12si2591881ede.221.2020.06.15.19.16.07; Mon, 15 Jun 2020 19:16:30 -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=@gmail.com header.s=20161025 header.b="A1eqm0h/"; 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=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726562AbgFPCNt (ORCPT + 99 others); Mon, 15 Jun 2020 22:13:49 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:33772 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725978AbgFPCNs (ORCPT ); Mon, 15 Jun 2020 22:13:48 -0400 Received: from mail-qt1-x841.google.com (mail-qt1-x841.google.com [IPv6:2607:f8b0:4864:20::841]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 69D90C061A0E for ; Mon, 15 Jun 2020 19:13:47 -0700 (PDT) Received: by mail-qt1-x841.google.com with SMTP id q14so14341788qtr.9 for ; Mon, 15 Jun 2020 19:13:47 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=mime-version:references:in-reply-to:from:date:message-id:subject:to :cc; bh=OqI1jdVPVllWwB4NQYQ7J/+T0Dl98wGQyoaCCb+8rkw=; b=A1eqm0h/GP6q72tEHOqCab4ATVdq2Q6uLZpx/Xhp71Ro6O7aRDM70rCqh/pOo8KDJH mEd9HvSWhmRUpJb4qU2qjhONldNnIvzGrahcL78IuyFLCFH0NhcVX2OOwfZnQfP8uUIs d0MCDL9OKYw7Gf/tAJhrOOY5Q+88w57quOY/2iub8KMGuGH4Qz32O0sGo9Zmu02MizsS CYJhgr3bwF4T+OQEZM/g2mSFGAxN3y60YgMPad6ONhcXMV0HtNSDfaeMaiSTn3k5s7PP cTlZmvd/iY3uIqeVTjbWO89bZxBU51rp/8xfiwMsUTOJW8iliL7xl494ywlyizBFr8FQ oY5g== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:mime-version:references:in-reply-to:from:date :message-id:subject:to:cc; bh=OqI1jdVPVllWwB4NQYQ7J/+T0Dl98wGQyoaCCb+8rkw=; b=Ijol1ZXl+AW2WT1+pt23zkoakviSKEURtQeycsBQ3AerN3OTv67jnTQRo3BB2pF4+M 3QeoUXrfWr7vofIGrPh9vaOJAhgvaq0hxzmGMyvFr7vT60uUODVaGRgtZFwCF9Ay3QU9 zpHue2eTmVdPO8Bigf/8i2Z3fTzKLkbPY/Wbzfkqf4/uYJVr2snArJwZHBCP98subIgh VnhNXbZnfNzTPJP6rSZyfserc8TZ5JQWc5qc9flN24FYUKTIzesV0mt2tF8Yu5w6h9ho kvyXE54W8riVz7cZ4rzPk8jTZMTI54MYlRh5XpEkZJI9zglBX3hZbnhvJlbJfVLZN2ej 0zzQ== X-Gm-Message-State: AOAM533tJqdwMljlLU3oAzjpuGnzFYn0lEnW5/gaMZ4UHbQFLf8iSRog gx42D5pbtIFCiWdkCE9zNg/kz226xWhMpOgGOhg= X-Received: by 2002:ac8:f47:: with SMTP id l7mr18674103qtk.292.1592273626671; Mon, 15 Jun 2020 19:13:46 -0700 (PDT) MIME-Version: 1.0 References: <20200615230912.GA16681@Asurada-Nvidia> <20200616015851.GA23235@Asurada-Nvidia> In-Reply-To: <20200616015851.GA23235@Asurada-Nvidia> From: Shengjiu Wang Date: Tue, 16 Jun 2020 10:13:35 +0800 Message-ID: Subject: Re: [PATCH v2] ASoC: fsl_ssi: Fix bclk calculation for mono channel To: Nicolin Chen Cc: Shengjiu Wang , Linux-ALSA , Timur Tabi , Xiubo Li , linuxppc-dev@lists.ozlabs.org, Takashi Iwai , Mark Brown , Fabio Estevam , linux-kernel Content-Type: text/plain; charset="UTF-8" Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Tue, Jun 16, 2020 at 9:59 AM Nicolin Chen wrote: > > On Tue, Jun 16, 2020 at 09:48:39AM +0800, Shengjiu Wang wrote: > > On Tue, Jun 16, 2020 at 7:11 AM Nicolin Chen wrote: > > > > > > On Mon, Jun 15, 2020 at 01:56:18PM +0800, Shengjiu Wang wrote: > > > > For mono channel, SSI will switch to Normal mode. > > > > > > > > In Normal mode and Network mode, the Word Length Control bits > > > > control the word length divider in clock generator, which is > > > > different with I2S Master mode (the word length is fixed to > > > > 32bit), it should be the value of params_width(hw_params). > > > > > > > > The condition "slots == 2" is not good for I2S Master mode, > > > > because for Network mode and Normal mode, the slots can also > > > > be 2. Then we need to use (ssi->i2s_net & SSI_SCR_I2S_MODE_MASK) > > > > to check if it is I2S Master mode. > > > > > > The fsl_ssi_set_bclk is only called when fsl_ssi_is_i2s_master, > > > though I agree that that line of comments sounds confusing now. > > > > Actually I think fsl_ssi_is_i2s_master is not accurate, it just checks > > the Master mode, but didn't check the I2S mode. > > > > > > > > > So we refine the famula for mono channel, otherwise there > > > > > > famula => formula? > > > > > > > will be sound issue for S24_LE. > > > > > > > > Fixes: b0a7043d5c2c ("ASoC: fsl_ssi: Caculate bit clock rate using slot number and width") > > > > Signed-off-by: Shengjiu Wang > > > > --- > > > > changes in v2 > > > > - refine patch for Network mode and Normal mode. > > > > > > > > sound/soc/fsl/fsl_ssi.c | 15 +++++++++++---- > > > > 1 file changed, 11 insertions(+), 4 deletions(-) > > > > > > > > diff --git a/sound/soc/fsl/fsl_ssi.c b/sound/soc/fsl/fsl_ssi.c > > > > index bad89b0d129e..cbf67d132fda 100644 > > > > --- a/sound/soc/fsl/fsl_ssi.c > > > > +++ b/sound/soc/fsl/fsl_ssi.c > > > > @@ -678,7 +678,8 @@ static int fsl_ssi_set_bclk(struct snd_pcm_substream *substream, > > > > struct regmap *regs = ssi->regs; > > > > u32 pm = 999, div2, psr, stccr, mask, afreq, factor, i; > > > > unsigned long clkrate, baudrate, tmprate; > > > > - unsigned int slots = params_channels(hw_params); > > > > + unsigned int channels = params_channels(hw_params); > > > > + unsigned int slots; > > > > unsigned int slot_width = 32; > > > > u64 sub, savesub = 100000; > > > > unsigned int freq; > > > > @@ -688,9 +689,15 @@ static int fsl_ssi_set_bclk(struct snd_pcm_substream *substream, > > > > /* Override slots and slot_width if being specifically set... */ > > > > if (ssi->slots) > > > > slots = ssi->slots; > > > > - /* ...but keep 32 bits if slots is 2 -- I2S Master mode */ > > > > - if (ssi->slot_width && slots != 2) > > > > - slot_width = ssi->slot_width; > > > > + else > > > > + /* Apply two slots for mono channel, because DC = 2 */ > > > > + slots = (channels == 1) ? 2 : channels; > > > > + > > > > + /* ...but keep 32 bits if I2S Master mode */ > > > > + if ((ssi->i2s_net & SSI_SCR_I2S_MODE_MASK) != SSI_SCR_I2S_MODE_MASTER || > > > > + channels == 1) > > > > + slot_width = ssi->slot_width ? ssi->slot_width : > > > > > > This looks very complicated...can you review and try mine? > > > (Basically, take 32-bit out of default but force it later) > > > > > > @@ -678,8 +678,9 @@ static int fsl_ssi_set_bclk(struct snd_pcm_substream *substream, > > > struct regmap *regs = ssi->regs; > > > u32 pm = 999, div2, psr, stccr, mask, afreq, factor, i; > > > unsigned long clkrate, baudrate, tmprate; > > > - unsigned int slots = params_channels(hw_params); > > > - unsigned int slot_width = 32; > > > + unsigned int channels = params_channels(hw_params); > > > + unsigned int slot_width = params_width(hw_params); > > > + unsigned int slots = 2; > > > u64 sub, savesub = 100000; > > > unsigned int freq; > > > bool baudclk_is_used; > > > @@ -688,10 +689,16 @@ static int fsl_ssi_set_bclk(struct snd_pcm_substream *substream, > > > /* Override slots and slot_width if being specifically set... */ > > > if (ssi->slots) > > > slots = ssi->slots; > > > - /* ...but keep 32 bits if slots is 2 -- I2S Master mode */ > > > - if (ssi->slot_width && slots != 2) > > > + if (ssi->slot_width) > > > slot_width = ssi->slot_width; > > > > > > + /* > > > + * ...but force 32 bits for stereo audio. Note that mono audio is also > > > + * sent in 2 slots via NORMAL mode, so check both slots and channels. > > > + */ > > > + if (slots == 2 && channels == 2) > > > + slot_width = 32; > > > > slots ==2 && channels ==2 does not mean the I2S Master mode. > > For LEFT_J, it is also slots =2 & channels = 2, then the slot_width > > should be params_width(hw_params). > > and DSP_A/B also supports stereo. > > I think you have a point. Then would this condition work? > > + /* ...but force 32 bits for stereo audio using I2S Master Mode */ > + if (channels == 2 && > + ssi->i2s_net & SSI_SCR_I2S_MODE_MASK == SSI_SCR_I2S_MODE_MASTER) > > Similar to yours but the code above it could look straightforward. I think it should work.