From: "Amadeusz Sławiński" <amadeuszx.slawinski@linux.intel.com>
To: Syed Saba Kareem <Syed.SabaKareem@amd.com>,
broonie@kernel.org, alsa-devel@alsa-project.org
Cc: Vijendar.Mukunda@amd.com, Basavaraj.Hiregoudar@amd.com,
Sunil-kumar.Dommati@amd.com, mario.limonciello@amd.com,
venkataprasad.potturu@amd.com, arungopal.kondaveeti@amd.com,
mastan.katragadda@amd.com, juan.martinez@amd.com,
Liam Girdwood <lgirdwood@gmail.com>,
Jaroslav Kysela <perex@perex.cz>, Takashi Iwai <tiwai@suse.com>,
Kuninori Morimoto <kuninori.morimoto.gx@renesas.com>,
V Sujith Kumar Reddy <vsujithkumar.reddy@amd.com>,
open list <linux-kernel@vger.kernel.org>
Subject: Re: [PATCH 02/13] ASoC: amd: acp: refactor acp i2s clock generation code
Date: Mon, 23 Oct 2023 09:37:00 +0200 [thread overview]
Message-ID: <b3be3317-218a-48fd-907a-287bdcbec66f@linux.intel.com> (raw)
In-Reply-To: <20231021145110.478744-2-Syed.SabaKareem@amd.com>
On 10/21/2023 4:50 PM, Syed Saba Kareem wrote:
> Refactor acp i2s LRCLK,BCLK generation code and move to commnon file.
>
> Signed-off-by: Syed Saba Kareem <Syed.SabaKareem@amd.com>
> ---
> sound/soc/amd/acp/acp-i2s.c | 32 ++++++++++++++++++++++++++++++
> sound/soc/amd/acp/amd.h | 39 -------------------------------------
> 2 files changed, 32 insertions(+), 39 deletions(-)
>
> diff --git a/sound/soc/amd/acp/acp-i2s.c b/sound/soc/amd/acp/acp-i2s.c
> index df350014966a..59d3a499771a 100644
> --- a/sound/soc/amd/acp/acp-i2s.c
> +++ b/sound/soc/amd/acp/acp-i2s.c
> @@ -20,10 +20,42 @@
> #include <sound/soc.h>
> #include <sound/soc-dai.h>
> #include <linux/dma-mapping.h>
> +#include <linux/bitfield.h>
>
> #include "amd.h"
>
> #define DRV_NAME "acp_i2s_playcap"
> +#define I2S_MASTER_MODE_ENABLE 1
> +#define I2S_MODE_ENABLE 0
> +#define I2S_FORMAT_MODE GENMASK(1, 1)
> +#define LRCLK_DIV_FIELD GENMASK(10, 2)
> +#define BCLK_DIV_FIELD GENMASK(23, 11)
> +
> +static inline void acp_set_i2s_clk(struct acp_dev_data *adata, int dai_id)
> +{
> + u32 i2s_clk_reg, val;
> +
> + switch (dai_id) {
> + case I2S_SP_INSTANCE:
> + i2s_clk_reg = ACP_I2STDM0_MSTRCLKGEN;
> + break;
> + case I2S_BT_INSTANCE:
> + i2s_clk_reg = ACP_I2STDM1_MSTRCLKGEN;
> + break;
> + case I2S_HS_INSTANCE:
> + i2s_clk_reg = ACP_I2STDM2_MSTRCLKGEN;
> + break;
> + default:
> + i2s_clk_reg = ACP_I2STDM0_MSTRCLKGEN;
> + break;
> + }
> +
> + val = I2S_MASTER_MODE_ENABLE;
> + val |= I2S_MODE_ENABLE & BIT(1);
There is I2S_FORMAT_MODE define, you probably want to use it instead of
BIT(1), so there is no "magic number" mask?
> + val |= FIELD_PREP(LRCLK_DIV_FIELD, adata->lrclk_div);
> + val |= FIELD_PREP(BCLK_DIV_FIELD, adata->bclk_div);
> + writel(val, adata->acp_base + i2s_clk_reg);
> +}
>
> static int acp_i2s_set_fmt(struct snd_soc_dai *cpu_dai,
> unsigned int fmt)
> diff --git a/sound/soc/amd/acp/amd.h b/sound/soc/amd/acp/amd.h
> index 487eefa5985f..87d1e1f7d6b6 100644
> --- a/sound/soc/amd/acp/amd.h
> +++ b/sound/soc/amd/acp/amd.h
> @@ -188,17 +188,6 @@ struct acp_dev_data {
> u32 xfer_rx_resolution[3];
> };
>
> -union acp_i2stdm_mstrclkgen {
> - struct {
> - u32 i2stdm_master_mode : 1;
> - u32 i2stdm_format_mode : 1;
> - u32 i2stdm_lrclk_div_val : 9;
> - u32 i2stdm_bclk_div_val : 11;
> - u32:10;
> - } bitfields, bits;
> - u32 u32_all;
> -};
> -
> extern const struct snd_soc_dai_ops asoc_acp_cpu_dai_ops;
> extern const struct snd_soc_dai_ops acp_dmic_dai_ops;
>
> @@ -276,32 +265,4 @@ static inline u64 acp_get_byte_count(struct acp_dev_data *adata, int dai_id, int
> POINTER_RETURN_BYTES:
> return byte_count;
> }
> -
> -static inline void acp_set_i2s_clk(struct acp_dev_data *adata, int dai_id)
> -{
> - union acp_i2stdm_mstrclkgen mclkgen;
> - u32 master_reg;
> -
> - switch (dai_id) {
> - case I2S_SP_INSTANCE:
> - master_reg = ACP_I2STDM0_MSTRCLKGEN;
> - break;
> - case I2S_BT_INSTANCE:
> - master_reg = ACP_I2STDM1_MSTRCLKGEN;
> - break;
> - case I2S_HS_INSTANCE:
> - master_reg = ACP_I2STDM2_MSTRCLKGEN;
> - break;
> - default:
> - master_reg = ACP_I2STDM0_MSTRCLKGEN;
> - break;
> - }
> -
> - mclkgen.bits.i2stdm_master_mode = 0x1;
> - mclkgen.bits.i2stdm_format_mode = 0x00;
> -
> - mclkgen.bits.i2stdm_bclk_div_val = adata->bclk_div;
> - mclkgen.bits.i2stdm_lrclk_div_val = adata->lrclk_div;
> - writel(mclkgen.u32_all, adata->acp_base + master_reg);
> -}
> #endif
next prev parent reply other threads:[~2023-10-23 7:37 UTC|newest]
Thread overview: 24+ messages / expand[flat|nested] mbox.gz Atom feed top
2023-10-21 14:50 [PATCH 01/13] ASoC: amd: acp: Add acp6.3 pci legacy driver support Syed Saba Kareem
2023-10-21 14:50 ` [PATCH 02/13] ASoC: amd: acp: refactor acp i2s clock generation code Syed Saba Kareem
2023-10-23 7:37 ` Amadeusz Sławiński [this message]
2023-10-21 14:50 ` [PATCH 03/13] ASoC: amd: acp: add i2s clock generation support for acp6.3 based platforms Syed Saba Kareem
2023-10-21 14:50 ` [PATCH 04/13] ASoC: amd: acp: add machine driver support for acp6.3 platform Syed Saba Kareem
2023-10-21 14:50 ` [PATCH 05/13] ASoC: amd: acp: add Kconfig options for acp6.3 based platform driver Syed Saba Kareem
2023-10-21 14:50 ` [PATCH 06/13] ASoC: amd: acp: add code for scanning acp pdm controller Syed Saba Kareem
2023-10-21 14:50 ` [PATCH 07/13] ASoC: amd: acp: add platform and flag data to acp data structure Syed Saba Kareem
2023-10-21 14:50 ` [PATCH 08/13] ASoC: amd: acp: add condition check for i2s clock generation Syed Saba Kareem
2023-10-21 14:50 ` [PATCH 09/13] ASoC: amd: acp: add machine driver support for pdm use case Syed Saba Kareem
2023-10-27 8:49 ` Krzysztof Kozlowski
[not found] ` <3ec97548-1f91-49d0-adfb-4f8051ca9a97@amd.com>
[not found] ` <f8f8017c-4e76-4d70-918f-d7cb45186184@kernel.org>
[not found] ` <c0ea139c-9861-4ea1-b547-6e3c380301b3@amd.com>
[not found] ` <ZTvkCAYsrS62/82u@finisterre.sirena.org.uk>
2023-10-27 17:32 ` syed saba kareem
2023-10-28 9:14 ` Krzysztof Kozlowski
2023-10-21 14:50 ` [PATCH 10/13] ASoC: amd: acp: change acp-deinit function arguments Syed Saba Kareem
2023-10-21 14:50 ` [PATCH 11/13] ASoC: amd: acp: change acp power on mask macro value Syed Saba Kareem
2023-10-21 14:50 ` [PATCH 12/13] ASoC: amd: acp: Add pci legacy driver support for acp7.0 platform Syed Saba Kareem
2023-10-23 7:50 ` Amadeusz Sławiński
2023-10-26 10:04 ` syed saba kareem
2023-10-21 14:50 ` [PATCH 13/13] ASoC: amd: acp: add machine driver support for acp7.0 Syed Saba Kareem
2023-10-23 8:01 ` [PATCH 01/13] ASoC: amd: acp: Add acp6.3 pci legacy driver support Krzysztof Kozlowski
[not found] ` <12c8c0f3-8364-4f25-976e-8cca29b5e17f@amd.com>
2023-10-26 15:00 ` Krzysztof Kozlowski
2023-10-25 16:50 ` Mark Brown
2023-10-26 9:44 ` syed saba kareem
2023-10-26 15:12 ` Mark Brown
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=b3be3317-218a-48fd-907a-287bdcbec66f@linux.intel.com \
--to=amadeuszx.slawinski@linux.intel.com \
--cc=Basavaraj.Hiregoudar@amd.com \
--cc=Sunil-kumar.Dommati@amd.com \
--cc=Syed.SabaKareem@amd.com \
--cc=Vijendar.Mukunda@amd.com \
--cc=alsa-devel@alsa-project.org \
--cc=arungopal.kondaveeti@amd.com \
--cc=broonie@kernel.org \
--cc=juan.martinez@amd.com \
--cc=kuninori.morimoto.gx@renesas.com \
--cc=lgirdwood@gmail.com \
--cc=linux-kernel@vger.kernel.org \
--cc=mario.limonciello@amd.com \
--cc=mastan.katragadda@amd.com \
--cc=perex@perex.cz \
--cc=tiwai@suse.com \
--cc=venkataprasad.potturu@amd.com \
--cc=vsujithkumar.reddy@amd.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox