Received: by 2002:a25:c593:0:0:0:0:0 with SMTP id v141csp5667482ybe; Tue, 17 Sep 2019 11:33:28 -0700 (PDT) X-Google-Smtp-Source: APXvYqzptoBOhylylfRuaI8pv4KR9X0KeJMce1Lrh+RXhWc7B3PwCQZU8f6vNjWpRnH8hGgNTsXu X-Received: by 2002:a50:d68a:: with SMTP id r10mr6249530edi.151.1568745208346; Tue, 17 Sep 2019 11:33:28 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1568745208; cv=none; d=google.com; s=arc-20160816; b=mhWcR9YtATnUhy/+f5f5lM6Tv5zNoEOojV1llIoLVA7mKDZzebwxHQ+qN6zL27QNhM ITqMieNh65lRuHA7niO8fZOT/xSPx1XjGUXSSQo5FHRAKCO0IKRDshutYikKbnPRlEuv jld9BSwirsIEVc3mc1ExDsMzZhJ6EDfX7wzJBU9VNkscVkPh9Yy/kfkBu4Fmc4avlWIT FznPwVRXpgH1m9zOkOahxgfGxQvA4IE5m369T3bcdNBtl11aoMDpl17XMCdRGtden4aw QwErXyE5qcf3vRQdLH7MeDaf+nQdBKxHq9D0ApTk2RH/hVD8isFC8KlqqHEvhhbg13tt utug== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:date:message-id:in-reply-to:subject:cc:to :from:dkim-signature; bh=vaCvTr8Faen7PvXlxXOwvkyQjeDJvGKNYb4c/ee5Xm8=; b=tMNyQyIyH4pvHswPU+ZXy7Gia0k4rVbhKqUzht9qYU8pUYyirbr6ixuCEl9co7SKNS gbeg/kW+cU2JoJULVM2azyq03nnB6f3IGgjzfeiNaEKZdTwFhVcwE/KtUM+ODgjsJlNI dN17DX1hyxFJmuXQEinTQjT54HrGIi1F9U0diqvzq0RECEYZzqRt98nFKtas3frJqXOi RW9Kxlo6mP8R6u1j532MTD9DyoMott2mPwJH7IFtXKIYAOzJwsd6M1DWcCSFkgYkIoIT Dym2r5C43jfnrW7b7S9VpskYdPNOdQuUWSOYg4bj7Hd7S4/dP71/ONRgBKU8BkNFlH9o tyOg== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@sirena.org.uk header.s=20170815-heliosphere header.b="Mz17ytn/"; 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=fail (p=NONE sp=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id e18si1739624eds.68.2019.09.17.11.33.04; Tue, 17 Sep 2019 11:33:28 -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=fail header.i=@sirena.org.uk header.s=20170815-heliosphere header.b="Mz17ytn/"; 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=fail (p=NONE sp=NONE dis=NONE) header.from=kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727858AbfIQQDA (ORCPT + 99 others); Tue, 17 Sep 2019 12:03:00 -0400 Received: from heliosphere.sirena.org.uk ([172.104.155.198]:56508 "EHLO heliosphere.sirena.org.uk" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727779AbfIQQC7 (ORCPT ); Tue, 17 Sep 2019 12:02:59 -0400 DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=sirena.org.uk; s=20170815-heliosphere; h=Date:Message-Id:In-Reply-To: Subject:Cc:To:From:Sender:Reply-To:MIME-Version:Content-Type: Content-Transfer-Encoding:Content-ID:Content-Description:Resent-Date: Resent-From:Resent-Sender:Resent-To:Resent-Cc:Resent-Message-ID:References: List-Id:List-Help:List-Unsubscribe:List-Subscribe:List-Post:List-Owner: List-Archive; bh=vaCvTr8Faen7PvXlxXOwvkyQjeDJvGKNYb4c/ee5Xm8=; b=Mz17ytn/Ahg6 Y/QaIOxdq3D2Nbni7N3IVAxkvZEguVp+G4zD/hI84aVgabyrm9tJToQNYLjyGW2TRQZJwuaHPRIXM TXoWQHoDMfQJGxHzZpo6jC3IoBkY1JOR5u/gGx1zxxSnabRHWlYVLGVoWC+bMn8ibL2SwQi8STfEC l+osY=; Received: from cpc102320-sgyl38-2-0-cust46.18-2.cable.virginm.net ([82.37.168.47] helo=ypsilon.sirena.org.uk) by heliosphere.sirena.org.uk with esmtpsa (TLS1.3:ECDHE_RSA_AES_256_GCM_SHA384:256) (Exim 4.92) (envelope-from ) id 1iAFwH-0008O9-9x; Tue, 17 Sep 2019 16:02:49 +0000 Received: by ypsilon.sirena.org.uk (Postfix, from userid 1000) id B319D27428FE; Tue, 17 Sep 2019 17:02:48 +0100 (BST) From: Mark Brown To: Mihai Serban Cc: alsa-devel@alsa-project.org, broonie@kernel.org, Daniel Baluta , festevam@gmail.com, lgirdwood@gmail.com, linux-kernel@vger.kernel.org, Mark Brown , nicoleotsuka@gmail.com, Nicolin Chen , perex@perex.cz, timur@kernel.org, tiwai@suse.com, Xiubo.Lee@gmail.com Subject: Applied "ASoC: fsl_sai: Fix noise when using EDMA" to the asoc tree In-Reply-To: <20190913192807.8423-2-daniel.baluta@nxp.com> X-Patchwork-Hint: ignore Message-Id: <20190917160248.B319D27428FE@ypsilon.sirena.org.uk> Date: Tue, 17 Sep 2019 17:02:48 +0100 (BST) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org The patch ASoC: fsl_sai: Fix noise when using EDMA has been applied to the asoc tree at https://git.kernel.org/pub/scm/linux/kernel/git/broonie/sound.git for-5.4 All being well this means that it will be integrated into the linux-next tree (usually sometime in the next 24 hours) and sent to Linus during the next merge window (or sooner if it is a bug fix), however if problems are discovered then the patch may be dropped or reverted. You may get further e-mails resulting from automated or manual testing and review of the tree, please engage with people reporting problems and send followup patches addressing any issues that are reported if needed. If any updates are required or you are submitting further changes they should be sent as incremental updates against current git, existing patches will not be replaced. Please add any relevant lists and maintainers to the CCs when replying to this mail. Thanks, Mark From e75f4940e8ad0dd76527302a10c06b58bf7eb590 Mon Sep 17 00:00:00 2001 From: Mihai Serban Date: Fri, 13 Sep 2019 22:28:05 +0300 Subject: [PATCH] ASoC: fsl_sai: Fix noise when using EDMA EDMA requires the period size to be multiple of maxburst. Otherwise the remaining bytes are not transferred and thus noise is produced. We can handle this issue by adding a constraint on SNDRV_PCM_HW_PARAM_PERIOD_SIZE to be multiple of tx/rx maxburst value. Signed-off-by: Mihai Serban Signed-off-by: Daniel Baluta Acked-by: Nicolin Chen Link: https://lore.kernel.org/r/20190913192807.8423-2-daniel.baluta@nxp.com Signed-off-by: Mark Brown --- sound/soc/fsl/fsl_sai.c | 15 +++++++++++++++ sound/soc/fsl/fsl_sai.h | 1 + 2 files changed, 16 insertions(+) diff --git a/sound/soc/fsl/fsl_sai.c b/sound/soc/fsl/fsl_sai.c index ef0b74693093..b517e4bc1b87 100644 --- a/sound/soc/fsl/fsl_sai.c +++ b/sound/soc/fsl/fsl_sai.c @@ -628,6 +628,16 @@ static int fsl_sai_startup(struct snd_pcm_substream *substream, FSL_SAI_CR3_TRCE_MASK, FSL_SAI_CR3_TRCE); + /* + * EDMA controller needs period size to be a multiple of + * tx/rx maxburst + */ + if (sai->soc_data->use_edma) + snd_pcm_hw_constraint_step(substream->runtime, 0, + SNDRV_PCM_HW_PARAM_PERIOD_SIZE, + tx ? sai->dma_params_tx.maxburst : + sai->dma_params_rx.maxburst); + ret = snd_pcm_hw_constraint_list(substream->runtime, 0, SNDRV_PCM_HW_PARAM_RATE, &fsl_sai_rate_constraints); @@ -1026,30 +1036,35 @@ static int fsl_sai_remove(struct platform_device *pdev) static const struct fsl_sai_soc_data fsl_sai_vf610_data = { .use_imx_pcm = false, + .use_edma = false, .fifo_depth = 32, .reg_offset = 0, }; static const struct fsl_sai_soc_data fsl_sai_imx6sx_data = { .use_imx_pcm = true, + .use_edma = false, .fifo_depth = 32, .reg_offset = 0, }; static const struct fsl_sai_soc_data fsl_sai_imx7ulp_data = { .use_imx_pcm = true, + .use_edma = false, .fifo_depth = 16, .reg_offset = 8, }; static const struct fsl_sai_soc_data fsl_sai_imx8mq_data = { .use_imx_pcm = true, + .use_edma = false, .fifo_depth = 128, .reg_offset = 8, }; static const struct fsl_sai_soc_data fsl_sai_imx8qm_data = { .use_imx_pcm = true, + .use_edma = true, .fifo_depth = 64, .reg_offset = 0, }; diff --git a/sound/soc/fsl/fsl_sai.h b/sound/soc/fsl/fsl_sai.h index b12cb578f6d0..76b15deea80c 100644 --- a/sound/soc/fsl/fsl_sai.h +++ b/sound/soc/fsl/fsl_sai.h @@ -157,6 +157,7 @@ struct fsl_sai_soc_data { bool use_imx_pcm; + bool use_edma; unsigned int fifo_depth; unsigned int reg_offset; }; -- 2.20.1