Commit 92bb6505 authored by sumit.saxena@avagotech.com's avatar sumit.saxena@avagotech.com Committed by Martin K. Petersen

megaraid_sas: Code refactor for use of requestorId

Some of these code changes were proposed by David Binderman.

Removed redudant check of requestorId. Redundant condition:
instance.requestorId. Check for plasma firmware 1.11 are now
restructured to support only specific device id.
Signed-off-by: default avatarSumit Saxena <sumit.saxena@avagotech.com>
Signed-off-by: default avatarKashyap Desai <kashyap.desai@avagotech.com>
Reviewed-by: default avatarMartin K. Petersen <martin.petersen@oracle.com>
Signed-off-by: default avatarMartin K. Petersen <martin.petersen@oracle.com>
parent 75b96061
...@@ -4842,18 +4842,22 @@ static int megasas_init_fw(struct megasas_instance *instance) ...@@ -4842,18 +4842,22 @@ static int megasas_init_fw(struct megasas_instance *instance)
} }
if (ctrl_info->host_interface.SRIOV) { if (ctrl_info->host_interface.SRIOV) {
if (!ctrl_info->adapterOperations2.activePassive) instance->requestorId = ctrl_info->iov.requestorId;
instance->PlasmaFW111 = 1; if (instance->pdev->device == PCI_DEVICE_ID_LSI_PLASMA) {
if (!ctrl_info->adapterOperations2.activePassive)
if (!instance->PlasmaFW111) instance->PlasmaFW111 = 1;
instance->requestorId =
ctrl_info->iov.requestorId; dev_info(&instance->pdev->dev, "SR-IOV: firmware type: %s\n",
else { instance->PlasmaFW111 ? "1.11" : "new");
iovPtr = (struct IOV_111 *)((unsigned char *)ctrl_info + IOV_111_OFFSET);
instance->requestorId = iovPtr->requestorId; if (instance->PlasmaFW111) {
iovPtr = (struct IOV_111 *)
((unsigned char *)ctrl_info + IOV_111_OFFSET);
instance->requestorId = iovPtr->requestorId;
}
} }
dev_warn(&instance->pdev->dev, "I am VF " dev_info(&instance->pdev->dev, "SRIOV: VF requestorId %d\n",
"requestorId %d\n", instance->requestorId); instance->requestorId);
} }
instance->crash_dump_fw_support = instance->crash_dump_fw_support =
...@@ -6723,8 +6727,7 @@ megasas_aen_polling(struct work_struct *work) ...@@ -6723,8 +6727,7 @@ megasas_aen_polling(struct work_struct *work)
case MR_EVT_CFG_CLEARED: case MR_EVT_CFG_CLEARED:
case MR_EVT_LD_DELETED: case MR_EVT_LD_DELETED:
if (!instance->requestorId || if (!instance->requestorId ||
(instance->requestorId && megasas_get_ld_vf_affiliation(instance, 0)) {
megasas_get_ld_vf_affiliation(instance, 0))) {
if (megasas_ld_list_query(instance, if (megasas_ld_list_query(instance,
MR_LD_QUERY_TYPE_EXPOSED_TO_HOST)) MR_LD_QUERY_TYPE_EXPOSED_TO_HOST))
megasas_get_ld_list(instance); megasas_get_ld_list(instance);
...@@ -6755,8 +6758,7 @@ megasas_aen_polling(struct work_struct *work) ...@@ -6755,8 +6758,7 @@ megasas_aen_polling(struct work_struct *work)
break; break;
case MR_EVT_LD_CREATED: case MR_EVT_LD_CREATED:
if (!instance->requestorId || if (!instance->requestorId ||
(instance->requestorId && megasas_get_ld_vf_affiliation(instance, 0)) {
megasas_get_ld_vf_affiliation(instance, 0))) {
if (megasas_ld_list_query(instance, if (megasas_ld_list_query(instance,
MR_LD_QUERY_TYPE_EXPOSED_TO_HOST)) MR_LD_QUERY_TYPE_EXPOSED_TO_HOST))
megasas_get_ld_list(instance); megasas_get_ld_list(instance);
...@@ -6822,8 +6824,7 @@ megasas_aen_polling(struct work_struct *work) ...@@ -6822,8 +6824,7 @@ megasas_aen_polling(struct work_struct *work)
} }
if (!instance->requestorId || if (!instance->requestorId ||
(instance->requestorId && megasas_get_ld_vf_affiliation(instance, 0)) {
megasas_get_ld_vf_affiliation(instance, 0))) {
if (megasas_ld_list_query(instance, if (megasas_ld_list_query(instance,
MR_LD_QUERY_TYPE_EXPOSED_TO_HOST)) MR_LD_QUERY_TYPE_EXPOSED_TO_HOST))
megasas_get_ld_list(instance); megasas_get_ld_list(instance);
......
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