Commit a6b3a016 authored by Dmitry Antipov's avatar Dmitry Antipov Committed by Kalle Valo
Browse files

wifi: mwifiex: handle possible mwifiex_write_reg() errors



Return -1 on possible 'mwifiex_write_reg()' errors in
'mwifiex_init_sdio_ioport()', do not ignore the value
returned by the latter in 'mwifiex_init_sdio()' and
'mwifiex_sdio_up_dev()' as well.

Found by Linux Verification Center (linuxtesting.org) with SVACE.

Acked-by: default avatarBrian Norris <briannorris@chromium.org>
Signed-off-by: default avatarDmitry Antipov <dmantipov@yandex.ru>
Signed-off-by: default avatarKalle Valo <kvalo@kernel.org>
Link: https://lore.kernel.org/r/20230802160726.85545-4-dmantipov@yandex.ru
parent 968d02c6
Loading
Loading
Loading
Loading
+12 −10
Original line number Diff line number Diff line
@@ -1083,17 +1083,17 @@ static int mwifiex_init_sdio_ioport(struct mwifiex_adapter *adapter)
		    "info: SDIO FUNC1 IO port: %#x\n", adapter->ioport);

	/* Set Host interrupt reset to read to clear */
	if (!mwifiex_read_reg(adapter, card->reg->host_int_rsr_reg, &reg))
		mwifiex_write_reg(adapter, card->reg->host_int_rsr_reg,
				  reg | card->reg->sdio_int_mask);
	else
	if (mwifiex_read_reg(adapter, card->reg->host_int_rsr_reg, &reg))
		return -1;
	if (mwifiex_write_reg(adapter, card->reg->host_int_rsr_reg,
			      reg | card->reg->sdio_int_mask))
		return -1;

	/* Dnld/Upld ready set to auto reset */
	if (!mwifiex_read_reg(adapter, card->reg->card_misc_cfg_reg, &reg))
		mwifiex_write_reg(adapter, card->reg->card_misc_cfg_reg,
				  reg | AUTO_RE_ENABLE_INT);
	else
	if (mwifiex_read_reg(adapter, card->reg->card_misc_cfg_reg, &reg))
		return -1;
	if (mwifiex_write_reg(adapter, card->reg->card_misc_cfg_reg,
			      reg | AUTO_RE_ENABLE_INT))
		return -1;

	return 0;
@@ -2525,7 +2525,8 @@ static int mwifiex_init_sdio(struct mwifiex_adapter *adapter)
	mwifiex_read_reg(adapter, card->reg->host_int_status_reg, &sdio_ireg);

	/* Get SDIO ioport */
	mwifiex_init_sdio_ioport(adapter);
	if (mwifiex_init_sdio_ioport(adapter))
		return -EIO;

	/* Initialize SDIO variables in card */
	card->mp_rd_bitmap = 0;
@@ -3141,7 +3142,8 @@ static void mwifiex_sdio_up_dev(struct mwifiex_adapter *adapter)
	 */
	mwifiex_read_reg(adapter, card->reg->host_int_status_reg, &sdio_ireg);

	mwifiex_init_sdio_ioport(adapter);
	if (mwifiex_init_sdio_ioport(adapter))
		dev_err(&card->func->dev, "error enabling SDIO port\n");
}

static struct mwifiex_if_ops sdio_ops = {