scsi: megaraid_sas: 32 bit descriptor fire cmd optimization
authorShivasharan S <shivasharan.srikanteshwara@broadcom.com>
Fri, 10 Feb 2017 08:59:04 +0000 (00:59 -0800)
committerMartin K. Petersen <martin.petersen@oracle.com>
Mon, 13 Feb 2017 12:26:21 +0000 (07:26 -0500)
No functional change. Code refactor.

megasas_fire_cmd_fusion can always use 32 bit descriptor write for
ventura. No need to pass extra flag.  Only IOC INIT required 64 bit
Descriptor write.

Signed-off-by: Shivasharan S <shivasharan.srikanteshwara@broadcom.com>
Signed-off-by: Kashyap Desai <kashyap.desai@broadcom.com>
Reviewed-by: Tomas Henzl <thenzl@redhat.com>
Reviewed-by: Hannes Reinecke <hare@suse.com>
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com>
drivers/scsi/megaraid/megaraid_sas_fusion.c

index 751658996e0693afe45a27e4b7043b2369a49497..24b72c58e075b535be6730283c0e2030aa247f99 100644 (file)
@@ -188,40 +188,35 @@ inline void megasas_return_cmd_fusion(struct megasas_instance *instance,
 
 /**
  * megasas_fire_cmd_fusion -   Sends command to the FW
+ * @instance:                  Adapter soft state
+ * @req_desc:                  32bit or 64bit Request descriptor
+ *
+ * Perform PCI Write. Ventura supports 32 bit Descriptor.
+ * Prior to Ventura (12G) MR controller supports 64 bit Descriptor.
  */
+
 static void
 megasas_fire_cmd_fusion(struct megasas_instance *instance,
-       union MEGASAS_REQUEST_DESCRIPTOR_UNION *req_desc, bool is_32bit)
+               union MEGASAS_REQUEST_DESCRIPTOR_UNION *req_desc)
 {
-       struct megasas_register_set __iomem *regs = instance->reg_set;
-       unsigned long flags;
-
-       if (is_32bit)
+       if (instance->is_ventura)
                writel(le32_to_cpu(req_desc->u.low),
-                       &(regs)->inbound_single_queue_port);
-       else if (instance->is_ventura) {
+                       &instance->reg_set->inbound_single_queue_port);
+       else {
+#if defined(writeq) && defined(CONFIG_64BIT)
+               u64 req_data = (((u64)le32_to_cpu(req_desc->u.high) << 32) |
+                               le32_to_cpu(req_desc->u.low));
+
+               writeq(req_data, &instance->reg_set->inbound_low_queue_port);
+#else
+               unsigned long flags;
                spin_lock_irqsave(&instance->hba_lock, flags);
                writel(le32_to_cpu(req_desc->u.low),
-                       &(regs)->inbound_low_queue_port);
+                       &instance->reg_set->inbound_low_queue_port);
                writel(le32_to_cpu(req_desc->u.high),
-                       &(regs)->inbound_high_queue_port);
+                       &instance->reg_set->inbound_high_queue_port);
                mmiowb();
                spin_unlock_irqrestore(&instance->hba_lock, flags);
-       } else {
-#if defined(writeq) && defined(CONFIG_64BIT)
-       u64 req_data = (((u64)le32_to_cpu(req_desc->u.high) << 32) |
-                       le32_to_cpu(req_desc->u.low));
-
-       writeq(req_data, &instance->reg_set->inbound_low_queue_port);
-#else
-
-       spin_lock_irqsave(&instance->hba_lock, flags);
-       writel(le32_to_cpu(req_desc->u.low),
-               &instance->reg_set->inbound_low_queue_port);
-       writel(le32_to_cpu(req_desc->u.high),
-               &instance->reg_set->inbound_high_queue_port);
-       mmiowb();
-       spin_unlock_irqrestore(&instance->hba_lock, flags);
 #endif
        }
 }
@@ -771,6 +766,7 @@ megasas_ioc_init_fusion(struct megasas_instance *instance)
        const char *sys_info;
        MFI_CAPABILITIES *drv_ops;
        u32 scratch_pad_2;
+       unsigned long flags;
 
        fusion = instance->ctrl_context;
 
@@ -897,7 +893,14 @@ megasas_ioc_init_fusion(struct megasas_instance *instance)
                        break;
        }
 
-       megasas_fire_cmd_fusion(instance, &req_desc, false);
+       /* For Ventura also IOC INIT required 64 bit Descriptor write. */
+       spin_lock_irqsave(&instance->hba_lock, flags);
+       writel(le32_to_cpu(req_desc.u.low),
+              &instance->reg_set->inbound_low_queue_port);
+       writel(le32_to_cpu(req_desc.u.high),
+              &instance->reg_set->inbound_high_queue_port);
+       mmiowb();
+       spin_unlock_irqrestore(&instance->hba_lock, flags);
 
        wait_and_poll(instance, cmd, MFI_POLL_TIMEOUT_SECS);
 
@@ -2577,11 +2580,10 @@ megasas_build_and_issue_cmd_fusion(struct megasas_instance *instance,
         * Issue the command to the FW
         */
 
-       megasas_fire_cmd_fusion(instance, req_desc, instance->is_ventura);
+       megasas_fire_cmd_fusion(instance, req_desc);
 
        if (r1_cmd)
-               megasas_fire_cmd_fusion(instance, r1_cmd->request_desc,
-                               instance->is_ventura);
+               megasas_fire_cmd_fusion(instance, r1_cmd->request_desc);
 
 
        return 0;
@@ -3001,7 +3003,7 @@ megasas_issue_dcmd_fusion(struct megasas_instance *instance,
                return DCMD_NOT_FIRED;
        }
 
-       megasas_fire_cmd_fusion(instance, req_desc, instance->is_ventura);
+       megasas_fire_cmd_fusion(instance, req_desc);
        return DCMD_SUCCESS;
 }
 
@@ -3294,8 +3296,7 @@ void megasas_refire_mgmt_cmd(struct megasas_instance *instance)
                                cpu_to_le32(MR_DCMD_SYSTEM_PD_MAP_GET_INFO)))
                                && !(cmd_mfi->flags & DRV_DCMD_SKIP_REFIRE);
                if (refire_cmd)
-                       megasas_fire_cmd_fusion(instance, req_desc,
-                               instance->is_ventura);
+                       megasas_fire_cmd_fusion(instance, req_desc);
                else
                        megasas_return_cmd(instance, cmd_mfi);
        }
@@ -3474,7 +3475,7 @@ megasas_issue_tm(struct megasas_instance *instance, u16 device_handle,
                mr_request->tmReqFlags.isTMForLD = 1;
 
        init_completion(&cmd_fusion->done);
-       megasas_fire_cmd_fusion(instance, req_desc, instance->is_ventura);
+       megasas_fire_cmd_fusion(instance, req_desc);
 
        timeleft = wait_for_completion_timeout(&cmd_fusion->done, 50 * HZ);