Received: by 2002:a25:8b12:0:0:0:0:0 with SMTP id i18csp857184ybl; Wed, 14 Aug 2019 07:04:24 -0700 (PDT) X-Google-Smtp-Source: APXvYqzqNPcJQFCoUIkF6yoUsNMv0eNzhlo+HrHn9HQAK/O9MTwWVy25l0wGo3ClrBsqeJJjNBzO X-Received: by 2002:a17:90a:2ec1:: with SMTP id h1mr7455430pjs.101.1565791464134; Wed, 14 Aug 2019 07:04:24 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1565791464; cv=none; d=google.com; s=arc-20160816; b=ZxKRYCUPODq2RehZWC9LxnNO2sup3wMyItSounYfsOm+WeKNh0RE5Jhdjd+uEVEz4g E2QF00recS6x24/YyvlsJQkwx3ChrENkhyXjXccNfAJQYRWm/ytYjPsEc10mS9k3vXb0 Jdf6BKtiWyYwhE+wEGeFC0CyuXnBl1wRY+G5VKXXGnFHt5KWjCR07yuGB7AuNJqNgVnH nU6QxOf7UW10Nx9smPakzOcPyELy88wKpn/loK5db6TLOV+Wg5XqrxJWyJbUmxOCstIs Q307JBWBcaFQkKuc3ZGtRL8WRP3FCZwxSJQcQhMoOzYsW06EtNDMjjtC+enLPreVdXX7 tBtA== 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=9BCsaT/ypWtdhsmfXKzhWUE99AeirQdOEW2jeMnFuhQ=; b=LOY6vCRi8+JKgk8oQ4JI/4qf+RwzM/4QLi1GlZzM7JJv8ky8FD/7lzv5RVa1De0kkz Dw6IZjPrpmwPi5Ai2TKmcIc6ADZZk9MLzHzdgTHs1sva/8WbKL5y7+xlFPuhHjii1mZy CVoXMlCVd+jg6pygn3oA2MOP/Dxlwssmt6Mvh2aCkWqkAyo7dBgphYeOqneYSBo1LWPJ 0nLs3rNT8hRMxIdFmvUAZOu91iIUNG0YmG6Y4DVIQyp9Y5+aJ5vLh4T5NtWxo1hLiedx WZVrCb6OnVXLxr5cKi3QKpIGXy6BvCSxCiWKYws2/CkU2n+3Co8VuJ3ODGCaddwYbXSx S5Cw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=hdGANqTQ; 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 b23si2976516pjp.62.2019.08.14.07.04.07; Wed, 14 Aug 2019 07:04:24 -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=@gmail.com header.s=20161025 header.b=hdGANqTQ; 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 S1727815AbfHNOCp (ORCPT + 99 others); Wed, 14 Aug 2019 10:02:45 -0400 Received: from mail-wr1-f68.google.com ([209.85.221.68]:35432 "EHLO mail-wr1-f68.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726525AbfHNOCp (ORCPT ); Wed, 14 Aug 2019 10:02:45 -0400 Received: by mail-wr1-f68.google.com with SMTP id k2so25367503wrq.2 for ; Wed, 14 Aug 2019 07:02:43 -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=9BCsaT/ypWtdhsmfXKzhWUE99AeirQdOEW2jeMnFuhQ=; b=hdGANqTQ9F21qw3u2Ego2JScgA5oHNpiXRoKNozB7yNZReqYDa7LJmrxWHn8/BjFZA VJcIcgSCiwFebMJ6Wtunw9n3td5KB8oF2KoPTxrozb5S9wPP2eysU9YFtFwLKO1ILLlG jQZKIyxO1J99qglc+9rCgLVT8PBm7dz6RLjVXXvvqyF5mNtqHCr7TVDtUNZuSWfLZIwy W7b58nIVz03ZjHRkydJi9TxhYyhV65qrJCm3UPE3NUxx8FS/tXQRvwTOGX92IlEb3a1r 5d2ZPTWM+Js2wa1jV7NZysCGy2pKT1lHA9sYZZQOb4mAMnJn2ywplnG9+Nf5MB/bPrUr cShw== 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=9BCsaT/ypWtdhsmfXKzhWUE99AeirQdOEW2jeMnFuhQ=; b=sEhp50mCvbhzVeU3+US8OBpXpQEpsyrgqBERNxmbGjyFkTwgUURkohAGl0kWX7ZQXl blsipr/jnkTqHge2Ycovkyof+C4LNTWQpimOXFKzIKLMkX49YVt66Zb9CzyNr+3f1LoU x9f63FPHNOnz0jjhSs7zlbrPKUF6s9voYAmwMEJO3x8zN2Dpfwccgiz6yfnhpOVQgMIT FSfcBbDe56i4w9t8bKfO1FN/KA9a/X3kQ5lQ5+FR9a3wysetHIUM+fEURH4diBFS3t3N HiH+2fAKbQ4LhxK9QCaCkDSj4xIUjSyqmBvj1tj7jEOfgDfQcTJiphIy3oWZoBPlMafR XhRg== X-Gm-Message-State: APjAAAWKnpfKymZjSAmk2TOPGy7mvvjxM4do9oZ3FVXf9eWpX4sSp60O rNanzVNW9Ktwkbjw6ojVwsTco4xoR330ddO6UL8= X-Received: by 2002:a5d:4310:: with SMTP id h16mr45630912wrq.212.1565791362736; Wed, 14 Aug 2019 07:02:42 -0700 (PDT) MIME-Version: 1.0 References: <20190811195545.32606-1-daniel.baluta@nxp.com> <20190814013916.GB13398@Asurada-Nvidia.nvidia.com> In-Reply-To: <20190814013916.GB13398@Asurada-Nvidia.nvidia.com> From: Daniel Baluta Date: Wed, 14 Aug 2019 17:02:31 +0300 Message-ID: Subject: Re: [RFC PATCH] ASoC: fsl_sai: Enable data lines based on input channels To: Nicolin Chen Cc: Daniel Baluta , Mark Brown , Linux Kernel Mailing List , dl-linux-imx , Takashi Iwai , Linux-ALSA , Fabio Estevam 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 Wed, Aug 14, 2019 at 4:39 AM Nicolin Chen wrote: > > On Sun, Aug 11, 2019 at 10:55:45PM +0300, Daniel Baluta wrote: > > An audio data frame consists of a number of slots one for each > > channel. In the case of I2S there are 2 data slots / frame. > > > > The maximum number of SAI slots / frame is configurable at > > IP integration time. This affects the width of Mask Register. > > SAI supports up to 32 slots per frame. > > > > The number of datalines is also configurable (up to 8 datalines) > > and affects TCE/RCE and the number of data/FIFO registers. > > > > The number of needed data lines (pins) is computed as follows: > > > > * pins = channels / slots. > > > > This can be computed in hw_params function so lets move TRCE bits > > seting from startup to hw_params. > > > > Signed-off-by: Daniel Baluta > > --- > > sound/soc/fsl/fsl_sai.c | 34 +++++++++++++--------------------- > > sound/soc/fsl/fsl_sai.h | 2 +- > > 2 files changed, 14 insertions(+), 22 deletions(-) > > > > diff --git a/sound/soc/fsl/fsl_sai.c b/sound/soc/fsl/fsl_sai.c > > index 69cf3678c859..b70032c82fe2 100644 > > --- a/sound/soc/fsl/fsl_sai.c > > +++ b/sound/soc/fsl/fsl_sai.c > > > @@ -480,13 +483,17 @@ static int fsl_sai_hw_params(struct snd_pcm_substream *substream, > > > - regmap_write(sai->regmap, FSL_SAI_xMR(tx), ~0UL - ((1 << channels) - 1)); > > + regmap_write(sai->regmap, FSL_SAI_xMR(tx), ~0UL - ((1 << slots) - 1)); > > Would this break mono channel audio? Indeed, this isn't good for mono. I see in our internal tree that we have min(channels, slots). This would fix mono, let me think if this is really the right solution. > > > static int fsl_sai_dai_probe(struct snd_soc_dai *cpu_dai) > > > @@ -881,6 +872,7 @@ static int fsl_sai_probe(struct platform_device *pdev) > > return -ENOMEM; > > > > sai->pdev = pdev; > > + > > Seemly unnecessary Oh, ok. Will fix in next version.