Skip to content

Commit ebdbe19

Browse files
bijudasgregkh
authored andcommitted
ASoC: renesas: rz-ssi: Fix rz_ssi_priv::hw_params_cache::sample_width
[ Upstream commit 2bae7be ] The strm->sample_width is not filled during rz_ssi_dai_hw_params(). This wrong value is used for caching sample_width in struct hw_params_cache. Fix this issue by replacing 'strm->sample_width'->'params_width(params)' in rz_ssi_dai_hw_params(). After this drop the variable sample_width from struct rz_ssi_stream as it is unused. Cc: stable@kernel.org Fixes: 4f8cd05 ("ASoC: sh: rz-ssi: Add full duplex support") Reviewed-by: Kuninori Morimoto <kuninori.morimoto.gx@renesas.com> Signed-off-by: Biju Das <biju.das.jz@bp.renesas.com> Link: https://patch.msgid.link/20251114073709.4376-3-biju.das.jz@bp.renesas.com Signed-off-by: Mark Brown <broonie@kernel.org> Signed-off-by: Sasha Levin <sashal@kernel.org> Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
1 parent 985131a commit ebdbe19

1 file changed

Lines changed: 4 additions & 9 deletions

File tree

sound/soc/sh/rz-ssi.c

Lines changed: 4 additions & 9 deletions
Original file line numberDiff line numberDiff line change
@@ -12,6 +12,7 @@
1212
#include <linux/module.h>
1313
#include <linux/pm_runtime.h>
1414
#include <linux/reset.h>
15+
#include <sound/pcm_params.h>
1516
#include <sound/soc.h>
1617

1718
/* REGISTER OFFSET */
@@ -85,7 +86,6 @@ struct rz_ssi_stream {
8586
int fifo_sample_size; /* sample capacity of SSI FIFO */
8687
int dma_buffer_pos; /* The address for the next DMA descriptor */
8788
int period_counter; /* for keeping track of periods transferred */
88-
int sample_width;
8989
int buffer_pos; /* current frame position in the buffer */
9090
int running; /* 0=stopped, 1=running */
9191

@@ -231,10 +231,7 @@ static inline bool rz_ssi_is_stream_running(struct rz_ssi_stream *strm)
231231
static void rz_ssi_stream_init(struct rz_ssi_stream *strm,
232232
struct snd_pcm_substream *substream)
233233
{
234-
struct snd_pcm_runtime *runtime = substream->runtime;
235-
236234
rz_ssi_set_substream(strm, substream);
237-
strm->sample_width = samples_to_bytes(runtime, 1);
238235
strm->dma_buffer_pos = 0;
239236
strm->period_counter = 0;
240237
strm->buffer_pos = 0;
@@ -960,9 +957,9 @@ static int rz_ssi_dai_hw_params(struct snd_pcm_substream *substream,
960957
struct snd_soc_dai *dai)
961958
{
962959
struct rz_ssi_priv *ssi = snd_soc_dai_get_drvdata(dai);
963-
struct rz_ssi_stream *strm = rz_ssi_stream_get(ssi, substream);
964960
unsigned int sample_bits = hw_param_interval(params,
965961
SNDRV_PCM_HW_PARAM_SAMPLE_BITS)->min;
962+
unsigned int sample_width = params_width(params);
966963
unsigned int channels = params_channels(params);
967964
unsigned int rate = params_rate(params);
968965

@@ -980,16 +977,14 @@ static int rz_ssi_dai_hw_params(struct snd_pcm_substream *substream,
980977

981978
if (rz_ssi_is_stream_running(&ssi->playback) ||
982979
rz_ssi_is_stream_running(&ssi->capture)) {
983-
if (rz_ssi_is_valid_hw_params(ssi, rate, channels,
984-
strm->sample_width, sample_bits))
980+
if (rz_ssi_is_valid_hw_params(ssi, rate, channels, sample_width, sample_bits))
985981
return 0;
986982

987983
dev_err(ssi->dev, "Full duplex needs same HW params\n");
988984
return -EINVAL;
989985
}
990986

991-
rz_ssi_cache_hw_params(ssi, rate, channels, strm->sample_width,
992-
sample_bits);
987+
rz_ssi_cache_hw_params(ssi, rate, channels, sample_width, sample_bits);
993988

994989
return rz_ssi_clk_setup(ssi, rate, channels);
995990
}

0 commit comments

Comments
 (0)