hisi_sas: add device and slot alloc hw methods
authorJohn Garry <john.garry@huawei.com>
Fri, 15 Apr 2016 13:36:36 +0000 (21:36 +0800)
committerMartin K. Petersen <martin.petersen@oracle.com>
Fri, 15 Apr 2016 20:53:22 +0000 (16:53 -0400)
Add methods to use HW specific versions of functions to allocate slot
and device.  HW specific methods are permitted to workaround device id
vs IPTT collision issue in v2 hw.

Signed-off-by: John Garry <john.garry@huawei.com>
Reviewed-by: Hannes Reinicke <hare@suse.de>
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com>
drivers/scsi/hisi_sas/hisi_sas.h
drivers/scsi/hisi_sas/hisi_sas_main.c

index 0978016482c16114be5e695460fb536daeaf1690..d7cab724f203fadcc2f35cf8d4bd5c0ab68f54ab 100644 (file)
@@ -133,6 +133,9 @@ struct hisi_sas_hw {
        int (*hw_init)(struct hisi_hba *hisi_hba);
        void (*setup_itct)(struct hisi_hba *hisi_hba,
                           struct hisi_sas_device *device);
+       int (*slot_index_alloc)(struct hisi_hba *hisi_hba, int *slot_idx,
+                               struct domain_device *device);
+       struct hisi_sas_device *(*alloc_dev)(struct domain_device *device);
        void (*sl_notify)(struct hisi_hba *hisi_hba, int phy_no);
        int (*get_free_slot)(struct hisi_hba *hisi_hba, int *q, int *s);
        void (*start_delivery)(struct hisi_hba *hisi_hba);
index 097ab4f27a6ba8ca4f782007ef3571c169b9ea13..18dd5ea2c721e021be7214bd83952ce5cce9f4e9 100644 (file)
@@ -227,7 +227,11 @@ static int hisi_sas_task_prep(struct sas_task *task, struct hisi_hba *hisi_hba,
        } else
                n_elem = task->num_scatter;
 
-       rc = hisi_sas_slot_index_alloc(hisi_hba, &slot_idx);
+       if (hisi_hba->hw->slot_index_alloc)
+               rc = hisi_hba->hw->slot_index_alloc(hisi_hba, &slot_idx,
+                                                   device);
+       else
+               rc = hisi_sas_slot_index_alloc(hisi_hba, &slot_idx);
        if (rc)
                goto err_out;
        rc = hisi_hba->hw->get_free_slot(hisi_hba, &dlvry_queue,
@@ -417,7 +421,10 @@ static int hisi_sas_dev_found(struct domain_device *device)
        struct hisi_sas_device *sas_dev;
        struct device *dev = &hisi_hba->pdev->dev;
 
-       sas_dev = hisi_sas_alloc_dev(device);
+       if (hisi_hba->hw->alloc_dev)
+               sas_dev = hisi_hba->hw->alloc_dev(device);
+       else
+               sas_dev = hisi_sas_alloc_dev(device);
        if (!sas_dev) {
                dev_err(dev, "fail alloc dev: max support %d devices\n",
                        HISI_SAS_MAX_DEVICES);