Commit 4e1609c9 authored by Kalle Valo's avatar Kalle Valo

ath6kl: fix usb related error handling and warnings

It was annoying to debug usb warm reboot initialisation problems as many usb
related functions just ignored errors and it wasn't obvious from the kernel
logs what was failing. Fix all that so that error messages are printed and
errors are handled properly.
Signed-off-by: default avatarKalle Valo <kvalo@qca.qualcomm.com>
parent ec1461dc
...@@ -1167,7 +1167,7 @@ static int htc_wait_recv_ctrl_message(struct htc_target *target) ...@@ -1167,7 +1167,7 @@ static int htc_wait_recv_ctrl_message(struct htc_target *target)
} }
if (count <= 0) { if (count <= 0) {
ath6kl_dbg(ATH6KL_DBG_HTC, "%s: Timeout!\n", __func__); ath6kl_warn("htc pipe control receive timeout!\n");
return -ECOMM; return -ECOMM;
} }
...@@ -1581,7 +1581,7 @@ static int ath6kl_htc_pipe_wait_target(struct htc_target *target) ...@@ -1581,7 +1581,7 @@ static int ath6kl_htc_pipe_wait_target(struct htc_target *target)
return status; return status;
if (target->pipe.ctrl_response_len < sizeof(*ready_msg)) { if (target->pipe.ctrl_response_len < sizeof(*ready_msg)) {
ath6kl_dbg(ATH6KL_DBG_HTC, "invalid htc ready msg len:%d!\n", ath6kl_warn("invalid htc pipe ready msg len: %d\n",
target->pipe.ctrl_response_len); target->pipe.ctrl_response_len);
return -ECOMM; return -ECOMM;
} }
...@@ -1589,7 +1589,7 @@ static int ath6kl_htc_pipe_wait_target(struct htc_target *target) ...@@ -1589,7 +1589,7 @@ static int ath6kl_htc_pipe_wait_target(struct htc_target *target)
ready_msg = (struct htc_ready_ext_msg *) target->pipe.ctrl_response_buf; ready_msg = (struct htc_ready_ext_msg *) target->pipe.ctrl_response_buf;
if (ready_msg->ver2_0_info.msg_id != cpu_to_le16(HTC_MSG_READY_ID)) { if (ready_msg->ver2_0_info.msg_id != cpu_to_le16(HTC_MSG_READY_ID)) {
ath6kl_dbg(ATH6KL_DBG_HTC, "invalid htc ready msg : 0x%X !\n", ath6kl_warn("invalid htc pipe ready msg: 0x%x\n",
ready_msg->ver2_0_info.msg_id); ready_msg->ver2_0_info.msg_id);
return -ECOMM; return -ECOMM;
} }
......
...@@ -1657,13 +1657,15 @@ static int __ath6kl_init_hw_start(struct ath6kl *ar) ...@@ -1657,13 +1657,15 @@ static int __ath6kl_init_hw_start(struct ath6kl *ar)
* driver layer has to init BMI in order to set the host block * driver layer has to init BMI in order to set the host block
* size. * size.
*/ */
if (ath6kl_htc_wait_target(ar->htc_target)) { ret = ath6kl_htc_wait_target(ar->htc_target);
ret = -EIO; if (ret) {
ath6kl_err("htc wait target failed: %d\n", ret);
goto err_power_off; goto err_power_off;
} }
if (ath6kl_init_service_ep(ar)) { ret = ath6kl_init_service_ep(ar);
ret = -EIO; if (ret) {
ath6kl_err("Endpoint service initilisation failed: %d\n", ret);
goto err_cleanup_scatter; goto err_cleanup_scatter;
} }
......
...@@ -872,8 +872,9 @@ static int ath6kl_usb_submit_ctrl_out(struct ath6kl_usb *ar_usb, ...@@ -872,8 +872,9 @@ static int ath6kl_usb_submit_ctrl_out(struct ath6kl_usb *ar_usb,
size, 1000); size, 1000);
if (ret < 0) { if (ret < 0) {
ath6kl_dbg(ATH6KL_DBG_USB, "%s failed,result = %d\n", ath6kl_warn("Failed to submit usb control message: %d\n", ret);
__func__, ret); kfree(buf);
return ret;
} }
kfree(buf); kfree(buf);
...@@ -903,8 +904,9 @@ static int ath6kl_usb_submit_ctrl_in(struct ath6kl_usb *ar_usb, ...@@ -903,8 +904,9 @@ static int ath6kl_usb_submit_ctrl_in(struct ath6kl_usb *ar_usb,
size, 2 * HZ); size, 2 * HZ);
if (ret < 0) { if (ret < 0) {
ath6kl_dbg(ATH6KL_DBG_USB, "%s failed,result = %d\n", ath6kl_warn("Failed to read usb control message: %d\n", ret);
__func__, ret); kfree(buf);
return ret;
} }
memcpy((u8 *) data, buf, size); memcpy((u8 *) data, buf, size);
...@@ -961,8 +963,10 @@ static int ath6kl_usb_diag_read32(struct ath6kl *ar, u32 address, u32 *data) ...@@ -961,8 +963,10 @@ static int ath6kl_usb_diag_read32(struct ath6kl *ar, u32 address, u32 *data)
ATH6KL_USB_CONTROL_REQ_DIAG_RESP, ATH6KL_USB_CONTROL_REQ_DIAG_RESP,
ar_usb->diag_resp_buffer, &resp_len); ar_usb->diag_resp_buffer, &resp_len);
if (ret) if (ret) {
ath6kl_warn("diag read32 failed: %d\n", ret);
return ret; return ret;
}
resp = (struct ath6kl_usb_ctrl_diag_resp_read *) resp = (struct ath6kl_usb_ctrl_diag_resp_read *)
ar_usb->diag_resp_buffer; ar_usb->diag_resp_buffer;
...@@ -976,6 +980,7 @@ static int ath6kl_usb_diag_write32(struct ath6kl *ar, u32 address, __le32 data) ...@@ -976,6 +980,7 @@ static int ath6kl_usb_diag_write32(struct ath6kl *ar, u32 address, __le32 data)
{ {
struct ath6kl_usb *ar_usb = ar->hif_priv; struct ath6kl_usb *ar_usb = ar->hif_priv;
struct ath6kl_usb_ctrl_diag_cmd_write *cmd; struct ath6kl_usb_ctrl_diag_cmd_write *cmd;
int ret;
cmd = (struct ath6kl_usb_ctrl_diag_cmd_write *) ar_usb->diag_cmd_buffer; cmd = (struct ath6kl_usb_ctrl_diag_cmd_write *) ar_usb->diag_cmd_buffer;
...@@ -984,12 +989,17 @@ static int ath6kl_usb_diag_write32(struct ath6kl *ar, u32 address, __le32 data) ...@@ -984,12 +989,17 @@ static int ath6kl_usb_diag_write32(struct ath6kl *ar, u32 address, __le32 data)
cmd->address = cpu_to_le32(address); cmd->address = cpu_to_le32(address);
cmd->value = data; cmd->value = data;
return ath6kl_usb_ctrl_msg_exchange(ar_usb, ret = ath6kl_usb_ctrl_msg_exchange(ar_usb,
ATH6KL_USB_CONTROL_REQ_DIAG_CMD, ATH6KL_USB_CONTROL_REQ_DIAG_CMD,
(u8 *) cmd, (u8 *) cmd,
sizeof(*cmd), sizeof(*cmd),
0, NULL, NULL); 0, NULL, NULL);
if (ret) {
ath6kl_warn("diag_write32 failed: %d\n", ret);
return ret;
}
return 0;
} }
static int ath6kl_usb_bmi_read(struct ath6kl *ar, u8 *buf, u32 len) static int ath6kl_usb_bmi_read(struct ath6kl *ar, u8 *buf, u32 len)
...@@ -1001,7 +1011,7 @@ static int ath6kl_usb_bmi_read(struct ath6kl *ar, u8 *buf, u32 len) ...@@ -1001,7 +1011,7 @@ static int ath6kl_usb_bmi_read(struct ath6kl *ar, u8 *buf, u32 len)
ret = ath6kl_usb_submit_ctrl_in(ar_usb, ret = ath6kl_usb_submit_ctrl_in(ar_usb,
ATH6KL_USB_CONTROL_REQ_RECV_BMI_RESP, ATH6KL_USB_CONTROL_REQ_RECV_BMI_RESP,
0, 0, buf, len); 0, 0, buf, len);
if (ret != 0) { if (ret) {
ath6kl_err("Unable to read the bmi data from the device: %d\n", ath6kl_err("Unable to read the bmi data from the device: %d\n",
ret); ret);
return ret; return ret;
...@@ -1019,7 +1029,7 @@ static int ath6kl_usb_bmi_write(struct ath6kl *ar, u8 *buf, u32 len) ...@@ -1019,7 +1029,7 @@ static int ath6kl_usb_bmi_write(struct ath6kl *ar, u8 *buf, u32 len)
ret = ath6kl_usb_submit_ctrl_out(ar_usb, ret = ath6kl_usb_submit_ctrl_out(ar_usb,
ATH6KL_USB_CONTROL_REQ_SEND_BMI_CMD, ATH6KL_USB_CONTROL_REQ_SEND_BMI_CMD,
0, 0, buf, len); 0, 0, buf, len);
if (ret != 0) { if (ret) {
ath6kl_err("unable to send the bmi data to the device: %d\n", ath6kl_err("unable to send the bmi data to the device: %d\n",
ret); ret);
return ret; return ret;
......
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