|
@@ -1444,32 +1444,37 @@ err:
|
|
|
spin_unlock_bh(&adapter->mcc_lock);
|
|
|
}
|
|
|
|
|
|
-/* Uses Mbox */
|
|
|
-int be_cmd_get_fw_ver(struct be_adapter *adapter, char *fw_ver)
|
|
|
+/* Uses synchronous mcc */
|
|
|
+int be_cmd_get_fw_ver(struct be_adapter *adapter, char *fw_ver,
|
|
|
+ char *fw_on_flash)
|
|
|
{
|
|
|
struct be_mcc_wrb *wrb;
|
|
|
struct be_cmd_req_get_fw_version *req;
|
|
|
int status;
|
|
|
|
|
|
- if (mutex_lock_interruptible(&adapter->mbox_lock))
|
|
|
- return -1;
|
|
|
+ spin_lock_bh(&adapter->mcc_lock);
|
|
|
|
|
|
- wrb = wrb_from_mbox(adapter);
|
|
|
- req = embedded_payload(wrb);
|
|
|
+ wrb = wrb_from_mccq(adapter);
|
|
|
+ if (!wrb) {
|
|
|
+ status = -EBUSY;
|
|
|
+ goto err;
|
|
|
+ }
|
|
|
|
|
|
+ req = embedded_payload(wrb);
|
|
|
be_wrb_hdr_prepare(wrb, sizeof(*req), true, 0,
|
|
|
- OPCODE_COMMON_GET_FW_VERSION);
|
|
|
-
|
|
|
+ OPCODE_COMMON_GET_FW_VERSION);
|
|
|
be_cmd_hdr_prepare(&req->hdr, CMD_SUBSYSTEM_COMMON,
|
|
|
- OPCODE_COMMON_GET_FW_VERSION, sizeof(*req));
|
|
|
+ OPCODE_COMMON_GET_FW_VERSION, sizeof(*req));
|
|
|
|
|
|
- status = be_mbox_notify_wait(adapter);
|
|
|
+ status = be_mcc_notify_wait(adapter);
|
|
|
if (!status) {
|
|
|
struct be_cmd_resp_get_fw_version *resp = embedded_payload(wrb);
|
|
|
- strncpy(fw_ver, resp->firmware_version_string, FW_VER_LEN);
|
|
|
+ strcpy(fw_ver, resp->firmware_version_string);
|
|
|
+ if (fw_on_flash)
|
|
|
+ strcpy(fw_on_flash, resp->fw_on_flash_version_string);
|
|
|
}
|
|
|
-
|
|
|
- mutex_unlock(&adapter->mbox_lock);
|
|
|
+err:
|
|
|
+ spin_unlock_bh(&adapter->mcc_lock);
|
|
|
return status;
|
|
|
}
|
|
|
|