isci: unify remote_device data structures
authorDan Williams <dan.j.williams@intel.com>
Fri, 22 Apr 2011 01:14:45 +0000 (18:14 -0700)
committerDan Williams <dan.j.williams@intel.com>
Sun, 3 Jul 2011 11:00:38 +0000 (04:00 -0700)
Make it explicit that isci_remote_device and scic_sds_remote_device are
one in the same object.

Signed-off-by: Dan Williams <dan.j.williams@intel.com>
drivers/scsi/isci/core/scic_remote_device.h
drivers/scsi/isci/core/scic_sds_remote_device.c
drivers/scsi/isci/host.c
drivers/scsi/isci/host.h
drivers/scsi/isci/init.c
drivers/scsi/isci/remote_device.c
drivers/scsi/isci/remote_device.h
drivers/scsi/isci/request.c
drivers/scsi/isci/task.c

index 62fa7fd572c1cb517c93bcbc6bab59125eaa9476..23e90af5a01bbb33aee2df832d406c0cd763265a 100644 (file)
@@ -86,18 +86,6 @@ enum scic_remote_device_not_ready_reason_code {
 
 };
 
-/**
- * scic_remote_device_get_object_size() - This method simply returns the
- *    maximum memory space needed to store a remote device object.
- *
- * a positive integer value indicating the size (in bytes) of the remote device
- * object.
- */
-u32 scic_remote_device_get_object_size(
-       void);
-
-struct scic_sds_port;
-struct scic_sds_remote_device;
 /**
  * scic_remote_device_construct() - This method will perform the construction
  *    common to all remote device objects.
index 22788bfcf9c35b75d110b08fd1dd17b5585592d7..d314e2b2088bc602889fee19eeb9e03508acb4c7 100644 (file)
 
 #define SCIC_SDS_REMOTE_DEVICE_RESET_TIMEOUT  (1000)
 
-/*
- * *****************************************************************************
- * *  CORE REMOTE DEVICE PRIVATE METHODS
- * ***************************************************************************** */
-
-/*
- * *****************************************************************************
- * *  CORE REMOTE DEVICE PUBLIC METHODS
- * ***************************************************************************** */
-
-u32 scic_remote_device_get_object_size(void)
-{
-       return sizeof (struct scic_sds_remote_device);
-}
-
 enum sci_status scic_remote_device_da_construct(
        struct scic_sds_remote_device *sci_dev)
 {
index 0d706b2ce25e5707444639190a1b62bb1616bf02..3aceb9219d7bd46a43e9db3bacfa03d354805564 100644 (file)
@@ -467,7 +467,7 @@ int isci_host_init(struct isci_host *isci_host)
                isci_phy_init(&isci_host->phys[i], isci_host, i);
 
        for (i = 0; i < SCI_MAX_REMOTE_DEVICES; i++) {
-               struct isci_remote_device *idev = idev_by_id(isci_host, i);
+               struct isci_remote_device *idev = &isci_host->devices[i];
 
                INIT_LIST_HEAD(&idev->reqs_in_process);
                INIT_LIST_HEAD(&idev->node);
index 6e660744d8d4fbc9f5381a7cdb70da670b085497..21bd7d88e5d85c95f6d1f4870735e1cccc46f9d6 100644 (file)
@@ -110,18 +110,9 @@ struct isci_host {
        struct list_head requests_to_errorback;
        spinlock_t scic_lock;
 
-       /* careful only access this via idev_by_id */
-       struct isci_remote_device devices[0];
+       struct isci_remote_device devices[SCI_MAX_REMOTE_DEVICES];
 };
 
-static inline struct isci_remote_device *idev_by_id(struct isci_host *ihost, int i)
-{
-       void *p = ihost->devices;
-
-       return p + i * (sizeof(struct isci_remote_device) +
-                       scic_remote_device_get_object_size());
-}
-
 /**
  * struct isci_pci_info - This class represents the pci function containing the
  *    controllers. Depending on PCI SKU, there could be up to 2 controllers in
index 5a9cd5fbeab9e80f85302bb33044836f087816f8..a23ea2c1c7db5a453a24fff827a28a0d461c9a72 100644 (file)
@@ -396,10 +396,7 @@ static struct isci_host *isci_host_alloc(struct pci_dev *pdev, int id)
        struct Scsi_Host *shost;
        int err;
 
-       isci_host = devm_kzalloc(&pdev->dev, sizeof(*isci_host) +
-                                SCI_MAX_REMOTE_DEVICES *
-                                (sizeof(struct isci_remote_device) +
-                                 scic_remote_device_get_object_size()), GFP_KERNEL);
+       isci_host = devm_kzalloc(&pdev->dev, sizeof(*isci_host), GFP_KERNEL);
        if (!isci_host)
                return NULL;
 
index 9301e25dff31adc39505b055467287c30637bc42..1553221fe4d7e3ea950cee531abea02e676cbb8b 100644 (file)
@@ -87,7 +87,7 @@ static void isci_remote_device_deconstruct(struct isci_host *ihost, struct isci_
                BUG();
        }
 
-       scic_remote_device_destruct(to_sci_dev(idev));
+       scic_remote_device_destruct(&idev->sci);
        idev->domain_dev->lldd_dev = NULL;
        idev->domain_dev = NULL;
        idev->isci_port = NULL;
@@ -117,7 +117,7 @@ static enum sci_status isci_remote_device_construct(
 
        /* let the core do it's common constuction. */
        scic_remote_device_construct(port->sci_port_handle,
-                                    to_sci_dev(isci_device));
+                                    &isci_device->sci);
 
        /* let the core do it's device specific constuction. */
        if (isci_device->domain_dev->parent &&
@@ -183,11 +183,11 @@ static enum sci_status isci_remote_device_construct(
                        "%s: parent->dev_type = EDGE_DEV\n",
                        __func__);
 
-               status = scic_remote_device_ea_construct(to_sci_dev(isci_device),
+               status = scic_remote_device_ea_construct(&isci_device->sci,
                                (struct smp_response_discover *)&discover_response);
 
        } else
-               status = scic_remote_device_da_construct(to_sci_dev(isci_device));
+               status = scic_remote_device_da_construct(&isci_device->sci);
 
 
        if (status != SCI_SUCCESS) {
@@ -200,10 +200,11 @@ static enum sci_status isci_remote_device_construct(
                return status;
        }
 
-       sci_object_set_association(to_sci_dev(isci_device), isci_device);
+       /* XXX will be killed with sci_base_object removal */
+       sci_object_set_association(&isci_device->sci, isci_device);
 
        /* start the device. */
-       status = scic_remote_device_start(to_sci_dev(isci_device),
+       status = scic_remote_device_start(&isci_device->sci,
                                          ISCI_REMOTE_DEVICE_START_TIMEOUT);
 
        if (status != SCI_SUCCESS) {
@@ -245,7 +246,7 @@ isci_remote_device_alloc(struct isci_host *ihost, struct isci_port *iport)
        int i;
 
        for (i = 0; i < SCI_MAX_REMOTE_DEVICES; i++) {
-               idev = idev_by_id(ihost, i);
+               idev = &ihost->devices[i];
                if (!test_and_set_bit(IDEV_ALLOCATED, &idev->flags))
                        break;
        }
@@ -374,7 +375,7 @@ enum sci_status isci_remote_device_stop(struct isci_host *ihost, struct isci_rem
        set_bit(IDEV_STOP_PENDING, &idev->flags);
 
        spin_lock_irqsave(&ihost->scic_lock, flags);
-       status = scic_remote_device_stop(to_sci_dev(idev), 50);
+       status = scic_remote_device_stop(&idev->sci, 50);
        spin_unlock_irqrestore(&ihost->scic_lock, flags);
 
        /* Wait for the stop complete callback. */
index 9925316ac55a57e33a2c74b59222841823dab29b..aeda39568a1c99b82568430c5493c4a2a733c7ee 100644 (file)
@@ -55,9 +55,9 @@
 
 #if !defined(_ISCI_REMOTE_DEVICE_H_)
 #define _ISCI_REMOTE_DEVICE_H_
+#include "scic_sds_remote_device.h"
 
 struct isci_host;
-struct scic_sds_remote_device;
 
 struct isci_remote_device {
        enum isci_status status;
@@ -70,14 +70,9 @@ struct isci_remote_device {
        struct list_head node;
        struct list_head reqs_in_process;
        spinlock_t state_lock;
+       struct scic_sds_remote_device sci;
 };
 
-static inline struct scic_sds_remote_device *to_sci_dev(struct isci_remote_device *idev)
-{
-       /* core data is an opaque buffer at the end of the idev */
-       return (struct scic_sds_remote_device *) &idev[1];
-}
-
 #define ISCI_REMOTE_DEVICE_START_TIMEOUT 5000
 
 void isci_remote_device_start_complete(struct isci_host *ihost,
index a90c299b723a0c1703b3f21739a353aefbafc917..8d2125b520eaa831cf04d6ba0539d44b736a3c08 100644 (file)
@@ -179,7 +179,7 @@ static enum sci_status isci_io_request_build(
        struct smp_discover_response_protocols dev_protocols;
        enum sci_status status = SCI_SUCCESS;
        struct sas_task *task = isci_request_access_task(request);
-       struct scic_sds_remote_device *sci_device = to_sci_dev(isci_device);
+       struct scic_sds_remote_device *sci_device = &isci_device->sci;
 
        dev_dbg(&isci_host->pdev->dev,
                "%s: isci_device = 0x%p; request = %p, "
@@ -380,7 +380,7 @@ int isci_request_execute(
        unsigned long flags;
 
        isci_device = task->dev->lldd_dev;
-       sci_device = to_sci_dev(isci_device);
+       sci_device = &isci_device->sci;
 
        /* do common allocation and init of request object. */
        ret = isci_request_alloc_io(
@@ -1194,11 +1194,9 @@ void isci_request_io_request_complete(
                                                  );
 
        /* complete the io request to the core. */
-       scic_controller_complete_io(
-               isci_host->core_controller,
-               to_sci_dev(isci_device),
-               request->sci_request_handle
-               );
+       scic_controller_complete_io(isci_host->core_controller,
+                                   &isci_device->sci,
+                                   request->sci_request_handle);
        /* NULL the request handle so it cannot be completed or
         * terminated again, and to cause any calls into abort
         * task to recognize the already completed case.
index c79968db871cc7a687fef1804817eed1747e2153..f54f523b8d40e8dee2796a9e9f16593aefd7a7f0 100644 (file)
@@ -282,7 +282,7 @@ static enum sci_status isci_task_request_build(
                "%s: isci_tmf = %p\n", __func__, isci_tmf);
 
        isci_device = isci_tmf->device;
-       sci_device = to_sci_dev(isci_device);
+       sci_device = &isci_device->sci;
 
        /* do common allocation and init of request object. */
        status = isci_request_alloc_tmf(
@@ -390,7 +390,7 @@ static void isci_tmf_timeout_cb(void *tmf_request_arg)
                /* Terminate the TMF transmit request. */
                status = scic_controller_terminate_request(
                        request->isci_host->core_controller,
-                       to_sci_dev(request->isci_device),
+                       &request->isci_device->sci,
                        request->sci_request_handle
                        );
 
@@ -448,7 +448,7 @@ int isci_task_execute_tmf(
                        "%s: isci_device = %p\n",
                        __func__, isci_device);
 
-       sci_device = to_sci_dev(isci_device);
+       sci_device = &isci_device->sci;
 
        /* Assign the pointer to the TMF's completion kernel wait structure. */
        tmf->complete = &completion;
@@ -784,9 +784,8 @@ static void isci_terminate_request_core(
                needs_cleanup_handling = true;
                status = scic_controller_terminate_request(
                        isci_host->core_controller,
-                       to_sci_dev(isci_device),
-                       isci_request->sci_request_handle
-                       );
+                       &isci_device->sci,
+                       isci_request->sci_request_handle);
        }
        spin_unlock_irqrestore(&isci_host->scic_lock, flags);
 
@@ -1483,9 +1482,8 @@ void isci_task_request_complete(
 
        scic_controller_complete_io(
                isci_host->core_controller,
-               to_sci_dev(isci_device),
-               request->sci_request_handle
-               );
+               &isci_device->sci,
+               request->sci_request_handle);
        /* NULL the request handle to make sure it cannot be terminated
         *  or completed again.
         */
@@ -1611,7 +1609,7 @@ int isci_bus_reset_handler(struct scsi_cmnd *cmd)
        }
 
        spin_lock_irqsave(&isci_host->scic_lock, flags);
-       status = scic_remote_device_reset(to_sci_dev(isci_dev));
+       status = scic_remote_device_reset(&isci_dev->sci);
        if (status != SCI_SUCCESS) {
                spin_unlock_irqrestore(&isci_host->scic_lock, flags);
 
@@ -1645,7 +1643,7 @@ int isci_bus_reset_handler(struct scsi_cmnd *cmd)
 
        /* WHAT TO DO HERE IF sas_phy_reset FAILS? */
        spin_lock_irqsave(&isci_host->scic_lock, flags);
-       status = scic_remote_device_reset_complete(to_sci_dev(isci_dev));
+       status = scic_remote_device_reset_complete(&isci_dev->sci);
        spin_unlock_irqrestore(&isci_host->scic_lock, flags);
 
        if (status != SCI_SUCCESS) {