From: Pierre-Louis Bossart <pierre-louis.bossart@linux.dev>
To: Bard Liao <yung-chuan.liao@linux.intel.com>,
linux-sound@vger.kernel.org, vkoul@kernel.org
Cc: vinod.koul@linaro.org, linux-kernel@vger.kernel.org, bard.liao@intel.com
Subject: Re: [PATCH 1/2] soundwire: cadence_master: set frame shape and divider based on actual clk freq
Date: Tue, 7 Jan 2025 13:19:54 -0600 [thread overview]
Message-ID: <ff37ea9b-e162-4d6f-ae33-26ec2e342cc6@linux.dev> (raw)
In-Reply-To: <20250107015824.5046-2-yung-chuan.liao@linux.intel.com>
> -static void cdns_init_clock_ctrl(struct sdw_cdns *cdns)
> +static int cdns_init_clock_ctrl(struct sdw_cdns *cdns)
> {
> struct sdw_bus *bus = &cdns->bus;
> struct sdw_master_prop *prop = &bus->prop;
> u32 val;
> u32 ssp_interval;
> int divider;
> + int freq;
>
> dev_dbg(cdns->dev, "mclk %d max %d row %d col %d\n",
> prop->mclk_freq,
> @@ -1356,13 +1357,25 @@ static void cdns_init_clock_ctrl(struct sdw_cdns *cdns)
> prop->default_col);
>
> /* Set clock divider */
> - divider = (prop->mclk_freq / prop->max_clk_freq) - 1;
> + divider = (prop->mclk_freq * SDW_DOUBLE_RATE_FACTOR /
> + bus->params.curr_dr_freq) - 1;
> + freq = bus->params.curr_dr_freq >> 1;
do you actually need this intermediate variable? see below [1] ...
>
> cdns_updatel(cdns, CDNS_MCP_CLK_CTRL0,
> CDNS_MCP_CLK_MCLKD_MASK, divider);
> cdns_updatel(cdns, CDNS_MCP_CLK_CTRL1,
> CDNS_MCP_CLK_MCLKD_MASK, divider);
>
> + /* Set frame shape base on the actual bus frequency. */
> + if (!prop->default_frame_rate || !prop->default_row) {
> + dev_err(cdns->dev, "Default frame_rate %d or row %d is invalid\n",
> + prop->default_frame_rate, prop->default_row);
> + return -EINVAL;
> + }
maybe check the values before writing the divider registers?
> +
> + prop->default_col = freq * SDW_DOUBLE_RATE_FACTOR /
> + prop->default_frame_rate / prop->default_row;
[1] ... this is the only place where 'freq' is used, and you multiply it by two after dividing it by two.
couldn't this just be:
prop->default_col = bus->params.curr_dr_freq /
prop->default_frame_rate / prop->default_row;
next prev parent reply other threads:[~2025-01-07 20:12 UTC|newest]
Thread overview: 6+ messages / expand[flat|nested] mbox.gz Atom feed top
2025-01-07 1:58 [PATCH 0/2] soundwire: set frame shape and divider based on actual clk freq Bard Liao
2025-01-07 1:58 ` [PATCH 1/2] soundwire: cadence_master: " Bard Liao
2025-01-07 19:19 ` Pierre-Louis Bossart [this message]
2025-01-07 1:58 ` [PATCH 2/2] Revert "soundwire: intel_auxdevice: start the bus at default frequency" Bard Liao
2025-01-07 19:22 ` Pierre-Louis Bossart
-- strict thread matches above, loose matches on Subject: below --
2025-02-05 7:42 [PATCH 0/2] soundwire: Intel: support more then 1 sdw bus clock frequency Bard Liao
2025-02-05 7:42 ` [PATCH 1/2] soundwire: cadence_master: set frame shape and divider based on actual clk freq Bard Liao
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=ff37ea9b-e162-4d6f-ae33-26ec2e342cc6@linux.dev \
--to=pierre-louis.bossart@linux.dev \
--cc=bard.liao@intel.com \
--cc=linux-kernel@vger.kernel.org \
--cc=linux-sound@vger.kernel.org \
--cc=vinod.koul@linaro.org \
--cc=vkoul@kernel.org \
--cc=yung-chuan.liao@linux.intel.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