Commit 3dcb122b authored by Chris Lu's avatar Chris Lu Committed by Luiz Augusto von Dentz

Bluetooth: btusb: mediatek: return error for failed reg access

Update the code to immediately return an error code if accessing a
related register fails. This ensures that our desired logic for
subsequent register operations is maintained and allows us to promptly
catch any unexpected errors.
Signed-off-by: default avatarSean Wang <sean.wang@mediatek.com>
Signed-off-by: default avatarChris Lu <chris.lu@mediatek.com>
Signed-off-by: default avatarLuiz Augusto von Dentz <luiz.von.dentz@intel.com>
parent be71dfb9
...@@ -3041,47 +3041,98 @@ static int btusb_mtk_subsys_reset(struct hci_dev *hdev, u32 dev_id) ...@@ -3041,47 +3041,98 @@ static int btusb_mtk_subsys_reset(struct hci_dev *hdev, u32 dev_id)
int err; int err;
if (dev_id == 0x7922) { if (dev_id == 0x7922) {
btusb_mtk_uhw_reg_read(data, MTK_BT_SUBSYS_RST, &val); err = btusb_mtk_uhw_reg_read(data, MTK_BT_SUBSYS_RST, &val);
if (err < 0)
return err;
val |= 0x00002020; val |= 0x00002020;
btusb_mtk_uhw_reg_write(data, MTK_BT_SUBSYS_RST, val); err = btusb_mtk_uhw_reg_write(data, MTK_BT_SUBSYS_RST, val);
btusb_mtk_uhw_reg_write(data, MTK_EP_RST_OPT, 0x00010001); if (err < 0)
btusb_mtk_uhw_reg_read(data, MTK_BT_SUBSYS_RST, &val); return err;
err = btusb_mtk_uhw_reg_write(data, MTK_EP_RST_OPT, 0x00010001);
if (err < 0)
return err;
err = btusb_mtk_uhw_reg_read(data, MTK_BT_SUBSYS_RST, &val);
if (err < 0)
return err;
val |= BIT(0); val |= BIT(0);
btusb_mtk_uhw_reg_write(data, MTK_BT_SUBSYS_RST, val); err = btusb_mtk_uhw_reg_write(data, MTK_BT_SUBSYS_RST, val);
if (err < 0)
return err;
msleep(100); msleep(100);
} else if (dev_id == 0x7925) { } else if (dev_id == 0x7925) {
btusb_mtk_uhw_reg_read(data, MTK_BT_RESET_REG_CONNV3, &val); err = btusb_mtk_uhw_reg_read(data, MTK_BT_RESET_REG_CONNV3, &val);
if (err < 0)
return err;
val |= (1 << 5); val |= (1 << 5);
btusb_mtk_uhw_reg_write(data, MTK_BT_RESET_REG_CONNV3, val); err = btusb_mtk_uhw_reg_write(data, MTK_BT_RESET_REG_CONNV3, val);
btusb_mtk_uhw_reg_read(data, MTK_BT_RESET_REG_CONNV3, &val); if (err < 0)
return err;
err = btusb_mtk_uhw_reg_read(data, MTK_BT_RESET_REG_CONNV3, &val);
if (err < 0)
return err;
val &= 0xFFFF00FF; val &= 0xFFFF00FF;
if (err < 0)
return err;
val |= (1 << 13); val |= (1 << 13);
btusb_mtk_uhw_reg_write(data, MTK_BT_RESET_REG_CONNV3, val); err = btusb_mtk_uhw_reg_write(data, MTK_BT_RESET_REG_CONNV3, val);
btusb_mtk_uhw_reg_write(data, MTK_EP_RST_OPT, 0x00010001); if (err < 0)
btusb_mtk_uhw_reg_read(data, MTK_BT_RESET_REG_CONNV3, &val); return err;
err = btusb_mtk_uhw_reg_write(data, MTK_EP_RST_OPT, 0x00010001);
if (err < 0)
return err;
err = btusb_mtk_uhw_reg_read(data, MTK_BT_RESET_REG_CONNV3, &val);
if (err < 0)
return err;
val |= (1 << 0); val |= (1 << 0);
btusb_mtk_uhw_reg_write(data, MTK_BT_RESET_REG_CONNV3, val); err = btusb_mtk_uhw_reg_write(data, MTK_BT_RESET_REG_CONNV3, val);
btusb_mtk_uhw_reg_write(data, MTK_UDMA_INT_STA_BT, 0x000000FF); if (err < 0)
btusb_mtk_uhw_reg_read(data, MTK_UDMA_INT_STA_BT, &val); return err;
btusb_mtk_uhw_reg_write(data, MTK_UDMA_INT_STA_BT1, 0x000000FF); err = btusb_mtk_uhw_reg_write(data, MTK_UDMA_INT_STA_BT, 0x000000FF);
btusb_mtk_uhw_reg_read(data, MTK_UDMA_INT_STA_BT1, &val); if (err < 0)
return err;
err = btusb_mtk_uhw_reg_read(data, MTK_UDMA_INT_STA_BT, &val);
if (err < 0)
return err;
err = btusb_mtk_uhw_reg_write(data, MTK_UDMA_INT_STA_BT1, 0x000000FF);
if (err < 0)
return err;
err = btusb_mtk_uhw_reg_read(data, MTK_UDMA_INT_STA_BT1, &val);
if (err < 0)
return err;
msleep(100); msleep(100);
} else { } else {
/* It's Device EndPoint Reset Option Register */ /* It's Device EndPoint Reset Option Register */
bt_dev_dbg(hdev, "Initiating reset mechanism via uhw"); bt_dev_dbg(hdev, "Initiating reset mechanism via uhw");
btusb_mtk_uhw_reg_write(data, MTK_EP_RST_OPT, MTK_EP_RST_IN_OUT_OPT); err = btusb_mtk_uhw_reg_write(data, MTK_EP_RST_OPT, MTK_EP_RST_IN_OUT_OPT);
btusb_mtk_uhw_reg_read(data, MTK_BT_WDT_STATUS, &val); if (err < 0)
return err;
err = btusb_mtk_uhw_reg_read(data, MTK_BT_WDT_STATUS, &val);
if (err < 0)
return err;
/* Reset the bluetooth chip via USB interface. */ /* Reset the bluetooth chip via USB interface. */
btusb_mtk_uhw_reg_write(data, MTK_BT_SUBSYS_RST, 1); err = btusb_mtk_uhw_reg_write(data, MTK_BT_SUBSYS_RST, 1);
btusb_mtk_uhw_reg_write(data, MTK_UDMA_INT_STA_BT, 0x000000FF); if (err < 0)
btusb_mtk_uhw_reg_read(data, MTK_UDMA_INT_STA_BT, &val); return err;
btusb_mtk_uhw_reg_write(data, MTK_UDMA_INT_STA_BT1, 0x000000FF); err = btusb_mtk_uhw_reg_write(data, MTK_UDMA_INT_STA_BT, 0x000000FF);
btusb_mtk_uhw_reg_read(data, MTK_UDMA_INT_STA_BT1, &val); if (err < 0)
return err;
err = btusb_mtk_uhw_reg_read(data, MTK_UDMA_INT_STA_BT, &val);
if (err < 0)
return err;
err = btusb_mtk_uhw_reg_write(data, MTK_UDMA_INT_STA_BT1, 0x000000FF);
if (err < 0)
return err;
err = btusb_mtk_uhw_reg_read(data, MTK_UDMA_INT_STA_BT1, &val);
if (err < 0)
return err;
/* MT7921 need to delay 20ms between toggle reset bit */ /* MT7921 need to delay 20ms between toggle reset bit */
msleep(20); msleep(20);
btusb_mtk_uhw_reg_write(data, MTK_BT_SUBSYS_RST, 0); err = btusb_mtk_uhw_reg_write(data, MTK_BT_SUBSYS_RST, 0);
btusb_mtk_uhw_reg_read(data, MTK_BT_SUBSYS_RST, &val); if (err < 0)
return err;
err = btusb_mtk_uhw_reg_read(data, MTK_BT_SUBSYS_RST, &val);
if (err < 0)
return err;
} }
err = readx_poll_timeout(btusb_mtk_reset_done, hdev, val, err = readx_poll_timeout(btusb_mtk_reset_done, hdev, val,
...@@ -3089,11 +3140,14 @@ static int btusb_mtk_subsys_reset(struct hci_dev *hdev, u32 dev_id) ...@@ -3089,11 +3140,14 @@ static int btusb_mtk_subsys_reset(struct hci_dev *hdev, u32 dev_id)
if (err < 0) if (err < 0)
bt_dev_err(hdev, "Reset timeout"); bt_dev_err(hdev, "Reset timeout");
if (dev_id == 0x7922) if (dev_id == 0x7922) {
btusb_mtk_uhw_reg_write(data, MTK_UDMA_INT_STA_BT, 0x000000FF); err = btusb_mtk_uhw_reg_write(data, MTK_UDMA_INT_STA_BT, 0x000000FF);
if (err < 0)
return err;
}
btusb_mtk_id_get(data, 0x70010200, &val); err = btusb_mtk_id_get(data, 0x70010200, &val);
if (!val) if (err < 0 || !val)
bt_dev_err(hdev, "Can't get device id, subsys reset fail."); bt_dev_err(hdev, "Can't get device id, subsys reset fail.");
return err; return err;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment