[bug report] ASoC: mediatek: mt8188: support etdm in platform driver
Trevor Wu (吳文良)
Trevor.Wu at mediatek.com
Mon Jan 30 01:25:52 PST 2023
Hi Dan,
Thank you for catching that.
I didn't notice that snprintf() never returns a negative value in
kernel code.
It is possible that I misunderstood the coverity error message, but I
can't find the original coverity scan result.
If I just remove the dead code, coverity will report some errors in the
future.
As a result, I prefer to keep the line and add another check "ret >=
sizeof(prop)", so that we can avoid the problem reported by coverity
and Smatch.
Thanks,
Trevor
On Wed, 2023-01-25 at 15:13 +0300, Dan Carpenter wrote:
> Hello Trevor Wu,
>
> The patch 2babb4777489: "ASoC: mediatek: mt8188: support etdm in
> platform driver" from Jan 16, 2023, leads to the following Smatch
> static checker warning:
>
> sound/soc/mediatek/mt8188/mt8188-dai-etdm.c:2487
> mt8188_dai_etdm_parse_of()
> warn: 'ret' returned from snprintf() might be larger than 48
>
> sound/soc/mediatek/mt8188/mt8188-dai-etdm.c
> 2455 static void mt8188_dai_etdm_parse_of(struct mtk_base_afe
> *afe)
> 2456 {
> 2457 const struct device_node *of_node = afe->dev-
> >of_node;
> 2458 struct mt8188_afe_private *afe_priv = afe-
> >platform_priv;
> 2459 struct mtk_dai_etdm_priv *etdm_data;
> 2460 char prop[48];
> 2461 u8 disable_chn[MT8188_ETDM_MAX_CHANNELS];
> 2462 int max_chn = MT8188_ETDM_MAX_CHANNELS;
> 2463 unsigned int sync_id;
> 2464 u32 sel;
> 2465 int ret;
> 2466 int dai_id;
> 2467 int i, j;
> 2468 struct {
> 2469 const char *name;
> 2470 const unsigned int sync_id;
> 2471 } of_afe_etdms[MT8188_AFE_IO_ETDM_NUM] = {
> 2472 {"etdm-in1", ETDM_SYNC_FROM_IN1},
> 2473 {"etdm-in2", ETDM_SYNC_FROM_IN2},
> 2474 {"etdm-out1", ETDM_SYNC_FROM_OUT1},
> 2475 {"etdm-out2", ETDM_SYNC_FROM_OUT2},
> 2476 {"etdm-out3", ETDM_SYNC_FROM_OUT3},
> 2477 };
> 2478
> 2479 for (i = 0; i < MT8188_AFE_IO_ETDM_NUM; i++) {
> 2480 dai_id = ETDM_TO_DAI_ID(i);
> 2481 etdm_data = afe_priv->dai_priv[dai_id];
> 2482
> 2483 ret = snprintf(prop, sizeof(prop),
> 2484 "mediatek,%s-multi-pin-mode",
> 2485 of_afe_etdms[i].name);
> 2486 if (ret < 0) {
> --> 2487 dev_err(afe->dev, "%s snprintf
> err=%d\n",
> 2488 __func__, ret);
>
>
> I guess the reason behind this warning is that we checked something
> but
> we didn't check if "ret >= sizeof(prop)" as one would normally
> suspect.
>
> In user space snprintf() can return negatives but in the kernel it
> never
> does. Changing that in the future is impossible because it would
> introduce a ton of security issues, so it never will.
>
> I guess I suggest just removing the dead code.
>
> 2489 return;
> 2490 }
> 2491 etdm_data->data_mode =
> of_property_read_bool(of_node, prop);
> 2492
> 2493 ret = snprintf(prop, sizeof(prop),
> 2494 "mediatek,%s-cowork-source",
> 2495 of_afe_etdms[i].name);
> 2496 if (ret < 0) {
>
> Same
>
> 2497 dev_err(afe->dev, "%s snprintf
> err=%d\n",
> 2498 __func__, ret);
> 2499 return;
> 2500 }
> 2501 ret = of_property_read_u32(of_node, prop,
> &sel);
> 2502 if (ret == 0) {
> 2503 if (sel >= MT8188_AFE_IO_ETDM_NUM) {
> 2504 dev_err(afe->dev, "%s
> invalid id=%d\n",
> 2505 __func__, sel);
> 2506 etdm_data->cowork_source_id
> = COWORK_ETDM_NONE;
> 2507 } else {
> 2508 sync_id =
> of_afe_etdms[sel].sync_id;
> 2509 etdm_data->cowork_source_id
> =
> 2510 sync_to_dai_id(sync_
> id);
> 2511 }
> 2512 } else {
> 2513 etdm_data->cowork_source_id =
> COWORK_ETDM_NONE;
> 2514 }
> 2515 }
> 2516
> 2517 /* etdm in only */
> 2518 for (i = 0; i < 2; i++) {
> 2519 ret = snprintf(prop, sizeof(prop),
> 2520 "mediatek,%s-chn-disabled",
> 2521 of_afe_etdms[i].name);
> 2522 if (ret < 0) {
>
> Same.
>
> 2523 dev_err(afe->dev, "%s snprintf
> err=%d\n",
> 2524 __func__, ret);
> 2525 return;
> 2526 }
> 2527 ret =
> of_property_read_variable_u8_array(of_node, prop,
> 2528 dis
> able_chn,
> 2529 1,
> max_chn);
> 2530 if (ret < 0)
> 2531 continue;
> 2532
> 2533 for (j = 0; j < ret; j++) {
> 2534 if (disable_chn[j] >=
> MT8188_ETDM_MAX_CHANNELS)
> 2535 dev_err(afe->dev, "%s [%d]
> invalid chn %u\n",
> 2536 __func__, j,
> disable_chn[j]);
> 2537 else
> 2538 etdm_data-
> >in_disable_ch[disable_chn[j]] = true;
> 2539 }
> 2540 }
> 2541 mt8188_etdm_update_sync_info(afe);
> 2542 }
>
> regards,
> dan carpenter
More information about the Linux-mediatek
mailing list