Re: [PATCH v1 3/4] ASoC: qcom: q6apm-lpass-dais: Add MI2S clock control

From: kernel test robot

Date: Wed Mar 11 2026 - 14:26:58 EST


Hi Mohammad,

kernel test robot noticed the following build warnings:

[auto build test WARNING on a0ae2a256046c0c5d3778d1a194ff2e171f16e5f]

url: https://github.com/intel-lab-lkp/linux/commits/Mohammad-Rafi-Shaik/ASoC-dt-bindings-qcom-q6apm-lpass-dais-Document-DAI-subnode/20260309-191956
base: a0ae2a256046c0c5d3778d1a194ff2e171f16e5f
patch link: https://lore.kernel.org/r/20260309111300.2484262-4-mohammad.rafi.shaik%40oss.qualcomm.com
patch subject: [PATCH v1 3/4] ASoC: qcom: q6apm-lpass-dais: Add MI2S clock control
config: hexagon-allmodconfig (https://download.01.org/0day-ci/archive/20260312/202603120247.NRy9LSop-lkp@xxxxxxxxx/config)
compiler: clang version 17.0.6 (https://github.com/llvm/llvm-project 6009708b4367171ccdbf4b5905cb6a803753fe18)
reproduce (this is a W=1 build): (https://download.01.org/0day-ci/archive/20260312/202603120247.NRy9LSop-lkp@xxxxxxxxx/reproduce)

If you fix the issue in a separate patch/commit (i.e. not just a new version of
the same patch/commit), kindly add following tags
| Reported-by: kernel test robot <lkp@xxxxxxxxx>
| Closes: https://lore.kernel.org/oe-kbuild-all/202603120247.NRy9LSop-lkp@xxxxxxxxx/

All warnings (new ones prefixed by >>):

>> sound/soc/qcom/qdsp6/q6apm-lpass-dais.c:298:2: warning: variable 'sysclk' is used uninitialized whenever switch default is taken [-Wsometimes-uninitialized]
298 | default:
| ^~~~~~~
sound/soc/qcom/qdsp6/q6apm-lpass-dais.c:302:6: note: uninitialized use occurs here
302 | if (sysclk) {
| ^~~~~~
sound/soc/qcom/qdsp6/q6apm-lpass-dais.c:281:20: note: initialize the variable 'sysclk' to silence this warning
281 | struct clk *sysclk;
| ^
| = NULL
1 warning generated.


vim +/sysclk +298 sound/soc/qcom/qdsp6/q6apm-lpass-dais.c

277
278 static int q6i2s_set_sysclk(struct snd_soc_dai *dai, int clk_id, unsigned int freq, int dir)
279 {
280 struct q6apm_lpass_dai_data *dai_data = dev_get_drvdata(dai->dev);
281 struct clk *sysclk;
282 bool *enabled;
283 int ret = 0;
284
285 switch (clk_id) {
286 case LPAIF_MI2S_MCLK:
287 sysclk = dai_data->priv[dai->id].mclk;
288 enabled = &dai_data->priv[dai->id].mclk_enabled;
289 break;
290 case LPAIF_MI2S_BCLK:
291 sysclk = dai_data->priv[dai->id].bclk;
292 enabled = &dai_data->priv[dai->id].bclk_enabled;
293 break;
294 case LPAIF_MI2S_ECLK:
295 sysclk = dai_data->priv[dai->id].eclk;
296 enabled = &dai_data->priv[dai->id].eclk_enabled;
297 break;
> 298 default:
299 break;
300 }
301
302 if (sysclk) {
303 clk_set_rate(sysclk, freq);
304 ret = clk_prepare_enable(sysclk);
305 if (ret) {
306 dev_err(dai->dev, "Error, Unable to prepare (%d) sysclk\n", clk_id);
307 return ret;
308 }
309
310 *enabled = true;
311 }
312
313 return ret;
314 }
315

--
0-DAY CI Kernel Test Service
https://github.com/intel/lkp-tests/wiki