aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--drivers/scsi/isci/core/sci_util.c9
-rw-r--r--drivers/scsi/isci/core/sci_util.h3
-rw-r--r--drivers/scsi/isci/core/scic_io_request.h33
-rw-r--r--drivers/scsi/isci/core/scic_sds_controller.c2
-rw-r--r--drivers/scsi/isci/core/scic_sds_request.c53
-rw-r--r--drivers/scsi/isci/core/scic_sds_request.h14
-rw-r--r--drivers/scsi/isci/core/scic_sds_stp_request.c4
-rw-r--r--drivers/scsi/isci/core/scic_task_request.h36
-rw-r--r--drivers/scsi/isci/host.c8
-rw-r--r--drivers/scsi/isci/host.h1
-rw-r--r--drivers/scsi/isci/remote_device.c2
-rw-r--r--drivers/scsi/isci/request.c168
-rw-r--r--drivers/scsi/isci/request.h12
-rw-r--r--drivers/scsi/isci/sata.c10
-rw-r--r--drivers/scsi/isci/task.c30
15 files changed, 128 insertions, 257 deletions
diff --git a/drivers/scsi/isci/core/sci_util.c b/drivers/scsi/isci/core/sci_util.c
index 0c75d14240a1..4e60d55836e9 100644
--- a/drivers/scsi/isci/core/sci_util.c
+++ b/drivers/scsi/isci/core/sci_util.c
@@ -59,14 +59,14 @@
59 59
60void *scic_request_get_virt_addr(struct scic_sds_request *sci_req, dma_addr_t phys_addr) 60void *scic_request_get_virt_addr(struct scic_sds_request *sci_req, dma_addr_t phys_addr)
61{ 61{
62 struct isci_request *ireq = sci_req->ireq; 62 struct isci_request *ireq = sci_req_to_ireq(sci_req);
63 dma_addr_t offset; 63 dma_addr_t offset;
64 64
65 BUG_ON(phys_addr < ireq->request_daddr); 65 BUG_ON(phys_addr < ireq->request_daddr);
66 66
67 offset = phys_addr - ireq->request_daddr; 67 offset = phys_addr - ireq->request_daddr;
68 68
69 BUG_ON(offset >= ireq->request_alloc_size); 69 BUG_ON(offset >= sizeof(*ireq));
70 70
71 return (char *)ireq + offset; 71 return (char *)ireq + offset;
72} 72}
@@ -74,14 +74,13 @@ void *scic_request_get_virt_addr(struct scic_sds_request *sci_req, dma_addr_t ph
74dma_addr_t scic_io_request_get_dma_addr(struct scic_sds_request *sds_request, 74dma_addr_t scic_io_request_get_dma_addr(struct scic_sds_request *sds_request,
75 void *virt_addr) 75 void *virt_addr)
76{ 76{
77 struct isci_request *isci_request = sds_request->ireq; 77 struct isci_request *isci_request = sci_req_to_ireq(sds_request);
78 78
79 char *requested_addr = (char *)virt_addr; 79 char *requested_addr = (char *)virt_addr;
80 char *base_addr = (char *)isci_request; 80 char *base_addr = (char *)isci_request;
81 81
82 BUG_ON(requested_addr < base_addr); 82 BUG_ON(requested_addr < base_addr);
83 BUG_ON((requested_addr - base_addr) >= 83 BUG_ON((requested_addr - base_addr) >= sizeof(*isci_request));
84 isci_request->request_alloc_size);
85 84
86 return isci_request->request_daddr + (requested_addr - base_addr); 85 return isci_request->request_daddr + (requested_addr - base_addr);
87} 86}
diff --git a/drivers/scsi/isci/core/sci_util.h b/drivers/scsi/isci/core/sci_util.h
index 4e9c3189cf95..0f9dd0fe1266 100644
--- a/drivers/scsi/isci/core/sci_util.h
+++ b/drivers/scsi/isci/core/sci_util.h
@@ -66,9 +66,6 @@
66 | ((char_buffer)[3]) \ 66 | ((char_buffer)[3]) \
67 ) 67 )
68 68
69#define SCI_FIELD_OFFSET(type, field) ((unsigned long)&(((type *)0)->field))
70
71
72#define sci_cb_make_physical_address(physical_addr, addr_upper, addr_lower) \ 69#define sci_cb_make_physical_address(physical_addr, addr_upper, addr_lower) \
73 ((physical_addr) = (addr_lower) | ((u64)addr_upper) << 32) 70 ((physical_addr) = (addr_lower) | ((u64)addr_upper) << 32)
74 71
diff --git a/drivers/scsi/isci/core/scic_io_request.h b/drivers/scsi/isci/core/scic_io_request.h
index cb3667decb3c..f7c6d426f8c0 100644
--- a/drivers/scsi/isci/core/scic_io_request.h
+++ b/drivers/scsi/isci/core/scic_io_request.h
@@ -102,41 +102,10 @@ typedef enum {
102 102
103} SCIC_TRANSPORT_PROTOCOL; 103} SCIC_TRANSPORT_PROTOCOL;
104 104
105
106/**
107 * scic_io_request_construct() - This method is called by the SCI user to
108 * construct all SCI Core IO requests. Memory initialization and
109 * functionality common to all IO request types is performed in this method.
110 * @scic_controller: the handle to the core controller object for which to
111 * build an IO request.
112 * @scic_remote_device: the handle to the core remote device object for which
113 * to build an IO request.
114 * @io_tag: This parameter specifies the IO tag to be associated with this
115 * request. If SCI_CONTROLLER_INVALID_IO_TAG is passed, then a copy of the
116 * request is built internally. The request will be copied into the actual
117 * controller request memory when the IO tag is allocated internally during
118 * the scic_controller_start_io() method.
119 * @user_io_request_object: This parameter specifies the user IO request to be
120 * utilized during IO construction. This IO pointer will become the
121 * associated object for the core IO request object.
122 * @scic_io_request_memory: This parameter specifies the memory location to be
123 * utilized when building the core request.
124 * @new_scic_io_request_handle: This parameter specifies a pointer to the
125 * handle the core will expect in further interactions with the core IO
126 * request object.
127 *
128 * The SCI core implementation will create an association between the user IO
129 * request object and the core IO request object. Indicate if the controller
130 * successfully built the IO request. SCI_SUCCESS This value is returned if the
131 * IO request was successfully built.
132 */
133enum sci_status scic_io_request_construct( 105enum sci_status scic_io_request_construct(
134 struct scic_sds_controller *scic_controller, 106 struct scic_sds_controller *scic_controller,
135 struct scic_sds_remote_device *scic_remote_device, 107 struct scic_sds_remote_device *scic_remote_device,
136 u16 io_tag, 108 u16 io_tag, struct scic_sds_request *sci_req);
137 void *user_io_request_object,
138 struct scic_sds_request *scic_io_request_memory,
139 struct scic_sds_request **new_scic_io_request_handle);
140 109
141/** 110/**
142 * scic_io_request_construct_basic_ssp() - This method is called by the SCI 111 * scic_io_request_construct_basic_ssp() - This method is called by the SCI
diff --git a/drivers/scsi/isci/core/scic_sds_controller.c b/drivers/scsi/isci/core/scic_sds_controller.c
index 4179bdf3eda7..852b7d52f84f 100644
--- a/drivers/scsi/isci/core/scic_sds_controller.c
+++ b/drivers/scsi/isci/core/scic_sds_controller.c
@@ -1572,7 +1572,7 @@ void scic_sds_controller_copy_task_context(
1572 1572
1573 memcpy(task_context_buffer, 1573 memcpy(task_context_buffer,
1574 sci_req->task_context_buffer, 1574 sci_req->task_context_buffer,
1575 SCI_FIELD_OFFSET(struct scu_task_context, sgl_snapshot_ac)); 1575 offsetof(struct scu_task_context, sgl_snapshot_ac));
1576 1576
1577 /* 1577 /*
1578 * Now that the soft copy of the TC has been copied into the TC 1578 * Now that the soft copy of the TC has been copied into the TC
diff --git a/drivers/scsi/isci/core/scic_sds_request.c b/drivers/scsi/isci/core/scic_sds_request.c
index 36c2b310c175..50dd19bba3db 100644
--- a/drivers/scsi/isci/core/scic_sds_request.c
+++ b/drivers/scsi/isci/core/scic_sds_request.c
@@ -117,7 +117,7 @@ static struct scu_sgl_element_pair *scic_sds_request_get_sgl_element_pair(
117 */ 117 */
118void scic_sds_request_build_sgl(struct scic_sds_request *sds_request) 118void scic_sds_request_build_sgl(struct scic_sds_request *sds_request)
119{ 119{
120 struct isci_request *isci_request = sds_request->ireq; 120 struct isci_request *isci_request = sci_req_to_ireq(sds_request);
121 struct isci_host *isci_host = isci_request->isci_host; 121 struct isci_host *isci_host = isci_request->isci_host;
122 struct sas_task *task = isci_request_access_task(isci_request); 122 struct sas_task *task = isci_request_access_task(isci_request);
123 struct scatterlist *sg = NULL; 123 struct scatterlist *sg = NULL;
@@ -190,7 +190,7 @@ static void scic_sds_ssp_io_request_assign_buffers(struct scic_sds_request *sci_
190static void scic_sds_io_request_build_ssp_command_iu(struct scic_sds_request *sci_req) 190static void scic_sds_io_request_build_ssp_command_iu(struct scic_sds_request *sci_req)
191{ 191{
192 struct ssp_cmd_iu *cmd_iu; 192 struct ssp_cmd_iu *cmd_iu;
193 struct isci_request *ireq = sci_req->ireq; 193 struct isci_request *ireq = sci_req_to_ireq(sci_req);
194 struct sas_task *task = isci_request_access_task(ireq); 194 struct sas_task *task = isci_request_access_task(ireq);
195 195
196 cmd_iu = &sci_req->ssp.cmd; 196 cmd_iu = &sci_req->ssp.cmd;
@@ -211,7 +211,7 @@ static void scic_sds_io_request_build_ssp_command_iu(struct scic_sds_request *sc
211static void scic_sds_task_request_build_ssp_task_iu(struct scic_sds_request *sci_req) 211static void scic_sds_task_request_build_ssp_task_iu(struct scic_sds_request *sci_req)
212{ 212{
213 struct ssp_task_iu *task_iu; 213 struct ssp_task_iu *task_iu;
214 struct isci_request *ireq = sci_req->ireq; 214 struct isci_request *ireq = sci_req_to_ireq(sci_req);
215 struct sas_task *task = isci_request_access_task(ireq); 215 struct sas_task *task = isci_request_access_task(ireq);
216 struct isci_tmf *isci_tmf = isci_request_access_tmf(ireq); 216 struct isci_tmf *isci_tmf = isci_request_access_tmf(ireq);
217 217
@@ -429,7 +429,7 @@ scic_io_request_construct_sata(struct scic_sds_request *sci_req,
429 bool copy) 429 bool copy)
430{ 430{
431 enum sci_status status = SCI_SUCCESS; 431 enum sci_status status = SCI_SUCCESS;
432 struct isci_request *ireq = sci_req->ireq; 432 struct isci_request *ireq = sci_req_to_ireq(sci_req);
433 struct sas_task *task = isci_request_access_task(ireq); 433 struct sas_task *task = isci_request_access_task(ireq);
434 434
435 /* check for management protocols */ 435 /* check for management protocols */
@@ -478,7 +478,7 @@ scic_io_request_construct_sata(struct scic_sds_request *sci_req,
478enum sci_status scic_io_request_construct_basic_ssp( 478enum sci_status scic_io_request_construct_basic_ssp(
479 struct scic_sds_request *sci_req) 479 struct scic_sds_request *sci_req)
480{ 480{
481 struct isci_request *ireq = sci_req->ireq; 481 struct isci_request *ireq = sci_req_to_ireq(sci_req);
482 struct sas_task *task = isci_request_access_task(ireq); 482 struct sas_task *task = isci_request_access_task(ireq);
483 483
484 sci_req->protocol = SCIC_SSP_PROTOCOL; 484 sci_req->protocol = SCIC_SSP_PROTOCOL;
@@ -519,7 +519,7 @@ enum sci_status scic_io_request_construct_basic_sata(
519 enum sci_status status; 519 enum sci_status status;
520 struct scic_sds_stp_request *stp_req; 520 struct scic_sds_stp_request *stp_req;
521 bool copy = false; 521 bool copy = false;
522 struct isci_request *isci_request = sci_req->ireq; 522 struct isci_request *isci_request = sci_req_to_ireq(sci_req);
523 struct sas_task *task = isci_request_access_task(isci_request); 523 struct sas_task *task = isci_request_access_task(isci_request);
524 524
525 stp_req = &sci_req->stp.req; 525 stp_req = &sci_req->stp.req;
@@ -540,11 +540,10 @@ enum sci_status scic_io_request_construct_basic_sata(
540} 540}
541 541
542 542
543enum sci_status scic_task_request_construct_sata( 543enum sci_status scic_task_request_construct_sata(struct scic_sds_request *sci_req)
544 struct scic_sds_request *sci_req)
545{ 544{
546 enum sci_status status = SCI_SUCCESS; 545 enum sci_status status = SCI_SUCCESS;
547 struct isci_request *ireq = sci_req->ireq; 546 struct isci_request *ireq = sci_req_to_ireq(sci_req);
548 547
549 /* check for management protocols */ 548 /* check for management protocols */
550 if (ireq->ttype == tmf_task) { 549 if (ireq->ttype == tmf_task) {
@@ -740,7 +739,7 @@ void scic_sds_io_request_copy_response(struct scic_sds_request *sci_req)
740 void *resp_buf; 739 void *resp_buf;
741 u32 len; 740 u32 len;
742 struct ssp_response_iu *ssp_response; 741 struct ssp_response_iu *ssp_response;
743 struct isci_request *ireq = sci_req->ireq; 742 struct isci_request *ireq = sci_req_to_ireq(sci_req);
744 struct isci_tmf *isci_tmf = isci_request_access_tmf(ireq); 743 struct isci_tmf *isci_tmf = isci_request_access_tmf(ireq);
745 744
746 ssp_response = &sci_req->ssp.rsp; 745 ssp_response = &sci_req->ssp.rsp;
@@ -1342,7 +1341,7 @@ static void scic_sds_request_completed_state_enter(void *object)
1342 struct scic_sds_controller *scic = 1341 struct scic_sds_controller *scic =
1343 scic_sds_request_get_controller(sci_req); 1342 scic_sds_request_get_controller(sci_req);
1344 struct isci_host *ihost = scic_to_ihost(scic); 1343 struct isci_host *ihost = scic_to_ihost(scic);
1345 struct isci_request *ireq = sci_req->ireq; 1344 struct isci_request *ireq = sci_req_to_ireq(sci_req);
1346 1345
1347 SET_STATE_HANDLER(sci_req, 1346 SET_STATE_HANDLER(sci_req,
1348 scic_sds_request_state_handler_table, 1347 scic_sds_request_state_handler_table,
@@ -1424,16 +1423,13 @@ static const struct sci_base_state scic_sds_request_state_table[] = {
1424 1423
1425static void scic_sds_general_request_construct(struct scic_sds_controller *scic, 1424static void scic_sds_general_request_construct(struct scic_sds_controller *scic,
1426 struct scic_sds_remote_device *sci_dev, 1425 struct scic_sds_remote_device *sci_dev,
1427 u16 io_tag, 1426 u16 io_tag, struct scic_sds_request *sci_req)
1428 void *user_io_request_object,
1429 struct scic_sds_request *sci_req)
1430{ 1427{
1431 sci_base_state_machine_construct(&sci_req->state_machine, sci_req, 1428 sci_base_state_machine_construct(&sci_req->state_machine, sci_req,
1432 scic_sds_request_state_table, SCI_BASE_REQUEST_STATE_INITIAL); 1429 scic_sds_request_state_table, SCI_BASE_REQUEST_STATE_INITIAL);
1433 sci_base_state_machine_start(&sci_req->state_machine); 1430 sci_base_state_machine_start(&sci_req->state_machine);
1434 1431
1435 sci_req->io_tag = io_tag; 1432 sci_req->io_tag = io_tag;
1436 sci_req->user_request = user_io_request_object;
1437 sci_req->owning_controller = scic; 1433 sci_req->owning_controller = scic;
1438 sci_req->target_device = sci_dev; 1434 sci_req->target_device = sci_dev;
1439 sci_req->has_started_substate_machine = false; 1435 sci_req->has_started_substate_machine = false;
@@ -1461,20 +1457,13 @@ static void scic_sds_general_request_construct(struct scic_sds_controller *scic,
1461enum sci_status 1457enum sci_status
1462scic_io_request_construct(struct scic_sds_controller *scic, 1458scic_io_request_construct(struct scic_sds_controller *scic,
1463 struct scic_sds_remote_device *sci_dev, 1459 struct scic_sds_remote_device *sci_dev,
1464 u16 io_tag, 1460 u16 io_tag, struct scic_sds_request *sci_req)
1465 void *user_req,
1466 struct scic_sds_request *sci_req,
1467 struct scic_sds_request **new_sci_req)
1468{ 1461{
1469 struct domain_device *dev = sci_dev_to_domain(sci_dev); 1462 struct domain_device *dev = sci_dev_to_domain(sci_dev);
1470 enum sci_status status = SCI_SUCCESS; 1463 enum sci_status status = SCI_SUCCESS;
1471 1464
1472 /* Build the common part of the request */ 1465 /* Build the common part of the request */
1473 scic_sds_general_request_construct(scic, 1466 scic_sds_general_request_construct(scic, sci_dev, io_tag, sci_req);
1474 sci_dev,
1475 io_tag,
1476 user_req,
1477 sci_req);
1478 1467
1479 if (sci_dev->rnc.remote_node_index == 1468 if (sci_dev->rnc.remote_node_index ==
1480 SCIC_SDS_REMOTE_NODE_CONTEXT_INVALID_INDEX) 1469 SCIC_SDS_REMOTE_NODE_CONTEXT_INVALID_INDEX)
@@ -1493,10 +1482,8 @@ scic_io_request_construct(struct scic_sds_controller *scic,
1493 status = SCI_FAILURE_UNSUPPORTED_PROTOCOL; 1482 status = SCI_FAILURE_UNSUPPORTED_PROTOCOL;
1494 1483
1495 if (status == SCI_SUCCESS) { 1484 if (status == SCI_SUCCESS) {
1496 memset(sci_req->task_context_buffer, 1485 memset(sci_req->task_context_buffer, 0,
1497 0, 1486 offsetof(struct scu_task_context, sgl_pair_ab));
1498 SCI_FIELD_OFFSET(struct scu_task_context, sgl_pair_ab));
1499 *new_sci_req = sci_req;
1500 } 1487 }
1501 1488
1502 return status; 1489 return status;
@@ -1504,18 +1491,13 @@ scic_io_request_construct(struct scic_sds_controller *scic,
1504 1491
1505enum sci_status scic_task_request_construct(struct scic_sds_controller *scic, 1492enum sci_status scic_task_request_construct(struct scic_sds_controller *scic,
1506 struct scic_sds_remote_device *sci_dev, 1493 struct scic_sds_remote_device *sci_dev,
1507 u16 io_tag, 1494 u16 io_tag, struct scic_sds_request *sci_req)
1508 void *user_io_request_object,
1509 struct scic_sds_request *sci_req,
1510 struct scic_sds_request **new_sci_req)
1511{ 1495{
1512 struct domain_device *dev = sci_dev_to_domain(sci_dev); 1496 struct domain_device *dev = sci_dev_to_domain(sci_dev);
1513 enum sci_status status = SCI_SUCCESS; 1497 enum sci_status status = SCI_SUCCESS;
1514 1498
1515 /* Build the common part of the request */ 1499 /* Build the common part of the request */
1516 scic_sds_general_request_construct(scic, sci_dev, io_tag, 1500 scic_sds_general_request_construct(scic, sci_dev, io_tag, sci_req);
1517 user_io_request_object,
1518 sci_req);
1519 1501
1520 if (dev->dev_type == SAS_END_DEV) { 1502 if (dev->dev_type == SAS_END_DEV) {
1521 scic_sds_ssp_task_request_assign_buffers(sci_req); 1503 scic_sds_ssp_task_request_assign_buffers(sci_req);
@@ -1537,7 +1519,6 @@ enum sci_status scic_task_request_construct(struct scic_sds_controller *scic,
1537 if (status == SCI_SUCCESS) { 1519 if (status == SCI_SUCCESS) {
1538 sci_req->is_task_management_request = true; 1520 sci_req->is_task_management_request = true;
1539 memset(sci_req->task_context_buffer, 0, sizeof(struct scu_task_context)); 1521 memset(sci_req->task_context_buffer, 0, sizeof(struct scu_task_context));
1540 *new_sci_req = sci_req;
1541 } 1522 }
1542 1523
1543 return status; 1524 return status;
diff --git a/drivers/scsi/isci/core/scic_sds_request.h b/drivers/scsi/isci/core/scic_sds_request.h
index 3f551eaf3dfa..1dd98aabe32d 100644
--- a/drivers/scsi/isci/core/scic_sds_request.h
+++ b/drivers/scsi/isci/core/scic_sds_request.h
@@ -113,26 +113,12 @@ enum scic_sds_smp_request_started_substates {
113 SCIC_SDS_SMP_REQUEST_STARTED_SUBSTATE_AWAIT_TC_COMPLETION, 113 SCIC_SDS_SMP_REQUEST_STARTED_SUBSTATE_AWAIT_TC_COMPLETION,
114}; 114};
115 115
116struct isci_request;
117/**
118 * struct scic_sds_request - This structure contains or references all of
119 * the data necessary to process a task management or normal IO request.
120 *
121 *
122 */
123struct scic_sds_request { 116struct scic_sds_request {
124 /** 117 /**
125 * The field specifies that the peer object for the request object.
126 */
127 struct isci_request *ireq;
128
129 /**
130 * This field contains the information for the base request state machine. 118 * This field contains the information for the base request state machine.
131 */ 119 */
132 struct sci_base_state_machine state_machine; 120 struct sci_base_state_machine state_machine;
133 121
134 void *user_request;
135
136 /** 122 /**
137 * This field simply points to the controller to which this IO request 123 * This field simply points to the controller to which this IO request
138 * is associated. 124 * is associated.
diff --git a/drivers/scsi/isci/core/scic_sds_stp_request.c b/drivers/scsi/isci/core/scic_sds_stp_request.c
index c7a8931a3bcb..2677393db6f4 100644
--- a/drivers/scsi/isci/core/scic_sds_stp_request.c
+++ b/drivers/scsi/isci/core/scic_sds_stp_request.c
@@ -627,7 +627,7 @@ scic_sds_stp_request_pio_data_in_copy_data_buffer(struct scic_sds_stp_request *s
627 int total_len = len; 627 int total_len = len;
628 628
629 sci_req = to_sci_req(stp_req); 629 sci_req = to_sci_req(stp_req);
630 ireq = scic_sds_request_get_user_request(sci_req); 630 ireq = sci_req_to_ireq(sci_req);
631 task = isci_request_access_task(ireq); 631 task = isci_request_access_task(ireq);
632 src_addr = data_buf; 632 src_addr = data_buf;
633 633
@@ -737,7 +737,7 @@ static enum sci_status scic_sds_stp_request_pio_await_frame_frame_handler(struct
737{ 737{
738 struct scic_sds_controller *scic = sci_req->owning_controller; 738 struct scic_sds_controller *scic = sci_req->owning_controller;
739 struct scic_sds_stp_request *stp_req = &sci_req->stp.req; 739 struct scic_sds_stp_request *stp_req = &sci_req->stp.req;
740 struct isci_request *ireq = sci_req->ireq; 740 struct isci_request *ireq = sci_req_to_ireq(sci_req);
741 struct sas_task *task = isci_request_access_task(ireq); 741 struct sas_task *task = isci_request_access_task(ireq);
742 struct dev_to_host_fis *frame_header; 742 struct dev_to_host_fis *frame_header;
743 enum sci_status status; 743 enum sci_status status;
diff --git a/drivers/scsi/isci/core/scic_task_request.h b/drivers/scsi/isci/core/scic_task_request.h
index 7e6d20aa0f02..98cfaa9e6d38 100644
--- a/drivers/scsi/isci/core/scic_task_request.h
+++ b/drivers/scsi/isci/core/scic_task_request.h
@@ -72,44 +72,10 @@ struct scic_sds_remote_device;
72struct scic_sds_controller; 72struct scic_sds_controller;
73 73
74 74
75/**
76 * scic_task_request_construct() - This method is called by the SCI user to
77 * construct all SCI Core task management requests, regardless of protocol.
78 * Memory initialization and functionality common to all task request types
79 * is performed in this method.
80 * @scic_controller: the handle to the core controller object for which to
81 * build the task managmement request.
82 * @scic_remote_device: the handle to the core remote device object for which
83 * to build the task management request. passed, then a copy of the request
84 * is built internally. The request will be copied into the actual
85 * controller request memory when the task is allocated internally during
86 * the scic_controller_start_task() method.
87 * @io_tag: This parameter specifies the IO tag to be associated with this
88 * request. If SCI_CONTROLLER_INVALID_IO_TAG is passed, then a copy of the
89 * request is built internally. The request will be copied into the actual
90 * controller request memory when the IO tag is allocated internally during
91 * the scic_controller_start_io() method.
92 * @user_task_request_object: This parameter specifies the user task request to
93 * be utilized during construction. This task pointer will become the
94 * associated object for the core task request object.
95 * @scic_task_request_memory: This parameter specifies the memory location to
96 * be utilized when building the core request.
97 * @new_scic_task_request_handle: This parameter specifies a pointer to the
98 * handle the core will expect in further interactions with the core task
99 * request object.
100 *
101 * The SCI core implementation will create an association between the user task
102 * request object and the core task request object. Indicate if the controller
103 * successfully built the task request. SCI_SUCCESS This value is returned if
104 * the task request was successfully built.
105 */
106enum sci_status scic_task_request_construct( 75enum sci_status scic_task_request_construct(
107 struct scic_sds_controller *scic_controller, 76 struct scic_sds_controller *scic_controller,
108 struct scic_sds_remote_device *scic_remote_device, 77 struct scic_sds_remote_device *scic_remote_device,
109 u16 io_tag, 78 u16 io_tag, struct scic_sds_request *sci_req);
110 void *user_task_request_object,
111 void *scic_task_request_memory,
112 struct scic_sds_request **new_scic_task_request_handle);
113 79
114/** 80/**
115 * scic_task_request_construct_ssp() - This method is called by the SCI user to 81 * scic_task_request_construct_ssp() - This method is called by the SCI user to
diff --git a/drivers/scsi/isci/host.c b/drivers/scsi/isci/host.c
index 4d0ee7bf847b..271a7e171e7d 100644
--- a/drivers/scsi/isci/host.c
+++ b/drivers/scsi/isci/host.c
@@ -428,14 +428,8 @@ int isci_host_init(struct isci_host *isci_host)
428 if (err) 428 if (err)
429 return err; 429 return err;
430 430
431 /*
432 * keep the pool alloc size around, will use it for a bounds checking
433 * when trying to convert virtual addresses to physical addresses
434 */
435 isci_host->dma_pool_alloc_size = sizeof(struct isci_request) +
436 sizeof(struct scic_sds_request);
437 isci_host->dma_pool = dmam_pool_create(DRV_NAME, &isci_host->pdev->dev, 431 isci_host->dma_pool = dmam_pool_create(DRV_NAME, &isci_host->pdev->dev,
438 isci_host->dma_pool_alloc_size, 432 sizeof(struct isci_request),
439 SLAB_HWCACHE_ALIGN, 0); 433 SLAB_HWCACHE_ALIGN, 0);
440 434
441 if (!isci_host->dma_pool) 435 if (!isci_host->dma_pool)
diff --git a/drivers/scsi/isci/host.h b/drivers/scsi/isci/host.h
index 5a414c31a877..afa41e83eaa7 100644
--- a/drivers/scsi/isci/host.h
+++ b/drivers/scsi/isci/host.h
@@ -82,7 +82,6 @@ struct isci_host {
82 struct list_head timers; 82 struct list_head timers;
83 void *core_ctrl_memory; 83 void *core_ctrl_memory;
84 struct dma_pool *dma_pool; 84 struct dma_pool *dma_pool;
85 unsigned int dma_pool_alloc_size;
86 struct isci_phy phys[SCI_MAX_PHYS]; 85 struct isci_phy phys[SCI_MAX_PHYS];
87 struct isci_port ports[SCI_MAX_PORTS + 1]; /* includes dummy port */ 86 struct isci_port ports[SCI_MAX_PORTS + 1]; /* includes dummy port */
88 struct sas_ha_struct sas_ha; 87 struct sas_ha_struct sas_ha;
diff --git a/drivers/scsi/isci/remote_device.c b/drivers/scsi/isci/remote_device.c
index a441c23b6859..8b1ef19a6732 100644
--- a/drivers/scsi/isci/remote_device.c
+++ b/drivers/scsi/isci/remote_device.c
@@ -473,7 +473,7 @@ enum sci_status scic_sds_remote_device_start_io(struct scic_sds_controller *scic
473 struct sci_base_state_machine *sm = &sci_dev->state_machine; 473 struct sci_base_state_machine *sm = &sci_dev->state_machine;
474 enum scic_sds_remote_device_states state = sm->current_state_id; 474 enum scic_sds_remote_device_states state = sm->current_state_id;
475 struct scic_sds_port *sci_port = sci_dev->owning_port; 475 struct scic_sds_port *sci_port = sci_dev->owning_port;
476 struct isci_request *ireq = sci_req->ireq; 476 struct isci_request *ireq = sci_req_to_ireq(sci_req);
477 enum sci_status status; 477 enum sci_status status;
478 478
479 switch (state) { 479 switch (state) {
diff --git a/drivers/scsi/isci/request.c b/drivers/scsi/isci/request.c
index a5b9b22d3b3a..4961ee347091 100644
--- a/drivers/scsi/isci/request.c
+++ b/drivers/scsi/isci/request.c
@@ -73,9 +73,7 @@ static enum sci_status isci_request_ssp_request_construct(
73 "%s: request = %p\n", 73 "%s: request = %p\n",
74 __func__, 74 __func__,
75 request); 75 request);
76 status = scic_io_request_construct_basic_ssp( 76 status = scic_io_request_construct_basic_ssp(&request->sci);
77 request->sci_request_handle
78 );
79 return status; 77 return status;
80} 78}
81 79
@@ -96,9 +94,7 @@ static enum sci_status isci_request_stp_request_construct(
96 */ 94 */
97 register_fis = isci_sata_task_to_fis_copy(task); 95 register_fis = isci_sata_task_to_fis_copy(task);
98 96
99 status = scic_io_request_construct_basic_sata( 97 status = scic_io_request_construct_basic_sata(&request->sci);
100 request->sci_request_handle
101 );
102 98
103 /* Set the ncq tag in the fis, from the queue 99 /* Set the ncq tag in the fis, from the queue
104 * command in the task. 100 * command in the task.
@@ -125,7 +121,7 @@ static enum sci_status isci_smp_request_build(struct isci_request *ireq)
125{ 121{
126 enum sci_status status = SCI_FAILURE; 122 enum sci_status status = SCI_FAILURE;
127 struct sas_task *task = isci_request_access_task(ireq); 123 struct sas_task *task = isci_request_access_task(ireq);
128 struct scic_sds_request *sci_req = ireq->sci_request_handle; 124 struct scic_sds_request *sci_req = &ireq->sci;
129 125
130 dev_dbg(&ireq->isci_host->pdev->dev, 126 dev_dbg(&ireq->isci_host->pdev->dev,
131 "%s: request = %p\n", __func__, ireq); 127 "%s: request = %p\n", __func__, ireq);
@@ -201,8 +197,7 @@ static enum sci_status isci_io_request_build(
201 */ 197 */
202 status = scic_io_request_construct(&isci_host->sci, sci_device, 198 status = scic_io_request_construct(&isci_host->sci, sci_device,
203 SCI_CONTROLLER_INVALID_IO_TAG, 199 SCI_CONTROLLER_INVALID_IO_TAG,
204 request, request->sci_req, 200 &request->sci);
205 &request->sci_request_handle);
206 201
207 if (status != SCI_SUCCESS) { 202 if (status != SCI_SUCCESS) {
208 dev_warn(&isci_host->pdev->dev, 203 dev_warn(&isci_host->pdev->dev,
@@ -211,8 +206,6 @@ static enum sci_status isci_io_request_build(
211 return SCI_FAILURE; 206 return SCI_FAILURE;
212 } 207 }
213 208
214 request->sci_request_handle->ireq = request;
215
216 switch (task->task_proto) { 209 switch (task->task_proto) {
217 case SAS_PROTOCOL_SMP: 210 case SAS_PROTOCOL_SMP:
218 status = isci_smp_request_build(request); 211 status = isci_smp_request_build(request);
@@ -276,8 +269,8 @@ static int isci_request_alloc_core(
276 request->isci_host = isci_host; 269 request->isci_host = isci_host;
277 request->isci_device = isci_device; 270 request->isci_device = isci_device;
278 request->io_request_completion = NULL; 271 request->io_request_completion = NULL;
272 request->terminated = false;
279 273
280 request->request_alloc_size = isci_host->dma_pool_alloc_size;
281 request->num_sg_entries = 0; 274 request->num_sg_entries = 0;
282 275
283 request->complete_in_target = false; 276 request->complete_in_target = false;
@@ -381,80 +374,74 @@ int isci_request_execute(
381 goto out; 374 goto out;
382 375
383 status = isci_io_request_build(isci_host, request, isci_device); 376 status = isci_io_request_build(isci_host, request, isci_device);
384 if (status == SCI_SUCCESS) { 377 if (status != SCI_SUCCESS) {
385 378 dev_warn(&isci_host->pdev->dev,
386 spin_lock_irqsave(&isci_host->scic_lock, flags); 379 "%s: request_construct failed - status = 0x%x\n",
387 380 __func__,
388 /* send the request, let the core assign the IO TAG. */ 381 status);
389 status = scic_controller_start_io( 382 goto out;
390 &isci_host->sci, 383 }
391 sci_device,
392 request->sci_request_handle,
393 SCI_CONTROLLER_INVALID_IO_TAG
394 );
395
396 if (status == SCI_SUCCESS ||
397 status == SCI_FAILURE_REMOTE_DEVICE_RESET_REQUIRED) {
398
399 /* Either I/O started OK, or the core has signaled that
400 * the device needs a target reset.
401 *
402 * In either case, hold onto the I/O for later.
403 *
404 * Update it's status and add it to the list in the
405 * remote device object.
406 */
407 isci_request_change_state(request, started);
408 list_add(&request->dev_node,
409 &isci_device->reqs_in_process);
410
411 if (status == SCI_SUCCESS) {
412 /* Save the tag for possible task mgmt later. */
413 request->io_tag = scic_io_request_get_io_tag(
414 request->sci_request_handle);
415 } else {
416 /* The request did not really start in the
417 * hardware, so clear the request handle
418 * here so no terminations will be done.
419 */
420 request->sci_request_handle = NULL;
421 }
422 384
423 } else 385 spin_lock_irqsave(&isci_host->scic_lock, flags);
424 dev_warn(&isci_host->pdev->dev,
425 "%s: failed request start (0x%x)\n",
426 __func__, status);
427 386
387 /* send the request, let the core assign the IO TAG. */
388 status = scic_controller_start_io(&isci_host->sci, sci_device,
389 &request->sci,
390 SCI_CONTROLLER_INVALID_IO_TAG);
391 if (status != SCI_SUCCESS &&
392 status != SCI_FAILURE_REMOTE_DEVICE_RESET_REQUIRED) {
393 dev_warn(&isci_host->pdev->dev,
394 "%s: failed request start (0x%x)\n",
395 __func__, status);
428 spin_unlock_irqrestore(&isci_host->scic_lock, flags); 396 spin_unlock_irqrestore(&isci_host->scic_lock, flags);
397 goto out;
398 }
429 399
430 if (status == 400 /* Either I/O started OK, or the core has signaled that
431 SCI_FAILURE_REMOTE_DEVICE_RESET_REQUIRED) { 401 * the device needs a target reset.
432 /* Signal libsas that we need the SCSI error 402 *
433 * handler thread to work on this I/O and that 403 * In either case, hold onto the I/O for later.
434 * we want a device reset. 404 *
435 */ 405 * Update it's status and add it to the list in the
436 spin_lock_irqsave(&task->task_state_lock, flags); 406 * remote device object.
437 task->task_state_flags |= SAS_TASK_NEED_DEV_RESET; 407 */
438 spin_unlock_irqrestore(&task->task_state_lock, flags); 408 isci_request_change_state(request, started);
439 409 list_add(&request->dev_node, &isci_device->reqs_in_process);
440 /* Cause this task to be scheduled in the SCSI error
441 * handler thread.
442 */
443 isci_execpath_callback(isci_host, task,
444 sas_task_abort);
445
446 /* Change the status, since we are holding
447 * the I/O until it is managed by the SCSI
448 * error handler.
449 */
450 status = SCI_SUCCESS;
451 }
452 410
453 } else 411 if (status == SCI_SUCCESS) {
454 dev_warn(&isci_host->pdev->dev, 412 /* Save the tag for possible task mgmt later. */
455 "%s: request_construct failed - status = 0x%x\n", 413 request->io_tag = scic_io_request_get_io_tag(&request->sci);
456 __func__, 414 } else {
457 status); 415 /* The request did not really start in the
416 * hardware, so clear the request handle
417 * here so no terminations will be done.
418 */
419 request->terminated = true;
420 }
421 spin_unlock_irqrestore(&isci_host->scic_lock, flags);
422
423 if (status ==
424 SCI_FAILURE_REMOTE_DEVICE_RESET_REQUIRED) {
425 /* Signal libsas that we need the SCSI error
426 * handler thread to work on this I/O and that
427 * we want a device reset.
428 */
429 spin_lock_irqsave(&task->task_state_lock, flags);
430 task->task_state_flags |= SAS_TASK_NEED_DEV_RESET;
431 spin_unlock_irqrestore(&task->task_state_lock, flags);
432
433 /* Cause this task to be scheduled in the SCSI error
434 * handler thread.
435 */
436 isci_execpath_callback(isci_host, task,
437 sas_task_abort);
438
439 /* Change the status, since we are holding
440 * the I/O until it is managed by the SCSI
441 * error handler.
442 */
443 status = SCI_SUCCESS;
444 }
458 445
459 out: 446 out:
460 if (status != SCI_SUCCESS) { 447 if (status != SCI_SUCCESS) {
@@ -554,9 +541,7 @@ static void isci_request_handle_controller_specific_errors(
554{ 541{
555 unsigned int cstatus; 542 unsigned int cstatus;
556 543
557 cstatus = scic_request_get_controller_status( 544 cstatus = scic_request_get_controller_status(&request->sci);
558 request->sci_request_handle
559 );
560 545
561 dev_dbg(&request->isci_host->pdev->dev, 546 dev_dbg(&request->isci_host->pdev->dev,
562 "%s: %p SCI_FAILURE_CONTROLLER_SPECIFIC_IO_ERR " 547 "%s: %p SCI_FAILURE_CONTROLLER_SPECIFIC_IO_ERR "
@@ -997,13 +982,13 @@ void isci_request_io_request_complete(
997 task); 982 task);
998 983
999 if (sas_protocol_ata(task->task_proto)) { 984 if (sas_protocol_ata(task->task_proto)) {
1000 resp_buf = &request->sci_request_handle->stp.rsp; 985 resp_buf = &request->sci.stp.rsp;
1001 isci_request_process_stp_response(task, 986 isci_request_process_stp_response(task,
1002 resp_buf); 987 resp_buf);
1003 } else if (SAS_PROTOCOL_SSP == task->task_proto) { 988 } else if (SAS_PROTOCOL_SSP == task->task_proto) {
1004 989
1005 /* crack the iu response buffer. */ 990 /* crack the iu response buffer. */
1006 resp_iu = &request->sci_request_handle->ssp.rsp; 991 resp_iu = &request->sci.ssp.rsp;
1007 isci_request_process_response_iu(task, resp_iu, 992 isci_request_process_response_iu(task, resp_iu,
1008 &isci_host->pdev->dev); 993 &isci_host->pdev->dev);
1009 994
@@ -1034,7 +1019,7 @@ void isci_request_io_request_complete(
1034 request->complete_in_target = true; 1019 request->complete_in_target = true;
1035 1020
1036 if (task->task_proto == SAS_PROTOCOL_SMP) { 1021 if (task->task_proto == SAS_PROTOCOL_SMP) {
1037 void *rsp = &request->sci_request_handle->smp.rsp; 1022 void *rsp = &request->sci.smp.rsp;
1038 1023
1039 dev_dbg(&isci_host->pdev->dev, 1024 dev_dbg(&isci_host->pdev->dev,
1040 "%s: SMP protocol completion\n", 1025 "%s: SMP protocol completion\n",
@@ -1051,8 +1036,7 @@ void isci_request_io_request_complete(
1051 * the maximum was transferred. 1036 * the maximum was transferred.
1052 */ 1037 */
1053 u32 transferred_length 1038 u32 transferred_length
1054 = scic_io_request_get_number_of_bytes_transferred( 1039 = scic_io_request_get_number_of_bytes_transferred(&request->sci);
1055 request->sci_request_handle);
1056 1040
1057 task->task_status.residual 1041 task->task_status.residual
1058 = task->total_xfer_len - transferred_length; 1042 = task->total_xfer_len - transferred_length;
@@ -1165,12 +1149,12 @@ void isci_request_io_request_complete(
1165 /* complete the io request to the core. */ 1149 /* complete the io request to the core. */
1166 scic_controller_complete_io(&isci_host->sci, 1150 scic_controller_complete_io(&isci_host->sci,
1167 &isci_device->sci, 1151 &isci_device->sci,
1168 request->sci_request_handle); 1152 &request->sci);
1169 /* NULL the request handle so it cannot be completed or 1153 /* set terminated handle so it cannot be completed or
1170 * terminated again, and to cause any calls into abort 1154 * terminated again, and to cause any calls into abort
1171 * task to recognize the already completed case. 1155 * task to recognize the already completed case.
1172 */ 1156 */
1173 request->sci_request_handle = NULL; 1157 request->terminated = true;
1174 1158
1175 isci_host_can_dequeue(isci_host, 1); 1159 isci_host_can_dequeue(isci_host, 1);
1176} 1160}
diff --git a/drivers/scsi/isci/request.h b/drivers/scsi/isci/request.h
index ddfbf71c97e5..89d8b0a27dfe 100644
--- a/drivers/scsi/isci/request.h
+++ b/drivers/scsi/isci/request.h
@@ -82,11 +82,11 @@ enum task_type {
82}; 82};
83 83
84struct isci_request { 84struct isci_request {
85 struct scic_sds_request *sci_request_handle;
86 enum isci_request_status status; 85 enum isci_request_status status;
87 enum task_type ttype; 86 enum task_type ttype;
88 unsigned short io_tag; 87 unsigned short io_tag;
89 bool complete_in_target; 88 bool complete_in_target;
89 bool terminated;
90 90
91 union ttype_ptr_union { 91 union ttype_ptr_union {
92 struct sas_task *io_task_ptr; /* When ttype==io_task */ 92 struct sas_task *io_task_ptr; /* When ttype==io_task */
@@ -103,7 +103,6 @@ struct isci_request {
103 dma_addr_t zero_scatter_daddr; 103 dma_addr_t zero_scatter_daddr;
104 104
105 unsigned int num_sg_entries; /* returned by pci_alloc_sg */ 105 unsigned int num_sg_entries; /* returned by pci_alloc_sg */
106 unsigned int request_alloc_size; /* size of block from dma_pool_alloc */
107 106
108 /** Note: "io_request_completion" is completed in two different ways 107 /** Note: "io_request_completion" is completed in two different ways
109 * depending on whether this is a TMF or regular request. 108 * depending on whether this is a TMF or regular request.
@@ -115,9 +114,16 @@ struct isci_request {
115 * TMF was aborting is guaranteed to have completed. 114 * TMF was aborting is guaranteed to have completed.
116 */ 115 */
117 struct completion *io_request_completion; 116 struct completion *io_request_completion;
118 struct scic_sds_request sci_req[0] ____cacheline_aligned; 117 struct scic_sds_request sci;
119}; 118};
120 119
120static inline struct isci_request *sci_req_to_ireq(struct scic_sds_request *sci_req)
121{
122 struct isci_request *ireq = container_of(sci_req, typeof(*ireq), sci);
123
124 return ireq;
125}
126
121/** 127/**
122 * This function gets the status of the request object. 128 * This function gets the status of the request object.
123 * @request: This parameter points to the isci_request object 129 * @request: This parameter points to the isci_request object
diff --git a/drivers/scsi/isci/sata.c b/drivers/scsi/isci/sata.c
index 578b1c5d40a9..08dabf08f7d7 100644
--- a/drivers/scsi/isci/sata.c
+++ b/drivers/scsi/isci/sata.c
@@ -72,7 +72,7 @@
72struct host_to_dev_fis *isci_sata_task_to_fis_copy(struct sas_task *task) 72struct host_to_dev_fis *isci_sata_task_to_fis_copy(struct sas_task *task)
73{ 73{
74 struct isci_request *ireq = task->lldd_task; 74 struct isci_request *ireq = task->lldd_task;
75 struct host_to_dev_fis *fis = &ireq->sci_request_handle->stp.cmd; 75 struct host_to_dev_fis *fis = &ireq->sci.stp.cmd;
76 76
77 memcpy(fis, &task->ata_task.fis, sizeof(struct host_to_dev_fis)); 77 memcpy(fis, &task->ata_task.fis, sizeof(struct host_to_dev_fis));
78 78
@@ -118,7 +118,7 @@ void isci_sata_set_ncq_tag(
118 struct isci_request *request = task->lldd_task; 118 struct isci_request *request = task->lldd_task;
119 119
120 register_fis->sector_count = qc->tag << 3; 120 register_fis->sector_count = qc->tag << 3;
121 scic_stp_io_request_set_ncq_tag(request->sci_request_handle, qc->tag); 121 scic_stp_io_request_set_ncq_tag(&request->sci, qc->tag);
122} 122}
123 123
124/** 124/**
@@ -156,7 +156,7 @@ void isci_request_process_stp_response(struct sas_task *task,
156 156
157enum sci_status isci_sata_management_task_request_build(struct isci_request *ireq) 157enum sci_status isci_sata_management_task_request_build(struct isci_request *ireq)
158{ 158{
159 struct scic_sds_request *sci_req = ireq->sci_request_handle; 159 struct scic_sds_request *sci_req = &ireq->sci;
160 struct isci_tmf *isci_tmf; 160 struct isci_tmf *isci_tmf;
161 enum sci_status status; 161 enum sci_status status;
162 162
@@ -190,9 +190,7 @@ enum sci_status isci_sata_management_task_request_build(struct isci_request *ire
190 /* core builds the protocol specific request 190 /* core builds the protocol specific request
191 * based on the h2d fis. 191 * based on the h2d fis.
192 */ 192 */
193 status = scic_task_request_construct_sata( 193 status = scic_task_request_construct_sata(&ireq->sci);
194 ireq->sci_request_handle
195 );
196 194
197 return status; 195 return status;
198} 196}
diff --git a/drivers/scsi/isci/task.c b/drivers/scsi/isci/task.c
index 492faeea8b3a..7adaf71c19d1 100644
--- a/drivers/scsi/isci/task.c
+++ b/drivers/scsi/isci/task.c
@@ -300,8 +300,7 @@ static enum sci_status isci_task_request_build(
300 /* let the core do it's construct. */ 300 /* let the core do it's construct. */
301 status = scic_task_request_construct(&isci_host->sci, sci_device, 301 status = scic_task_request_construct(&isci_host->sci, sci_device,
302 SCI_CONTROLLER_INVALID_IO_TAG, 302 SCI_CONTROLLER_INVALID_IO_TAG,
303 request, &request->sci_req, 303 &request->sci);
304 &request->sci_request_handle);
305 304
306 if (status != SCI_SUCCESS) { 305 if (status != SCI_SUCCESS) {
307 dev_warn(&isci_host->pdev->dev, 306 dev_warn(&isci_host->pdev->dev,
@@ -312,14 +311,10 @@ static enum sci_status isci_task_request_build(
312 goto errout; 311 goto errout;
313 } 312 }
314 313
315 request->sci_request_handle->ireq = request;
316
317 /* XXX convert to get this from task->tproto like other drivers */ 314 /* XXX convert to get this from task->tproto like other drivers */
318 if (dev->dev_type == SAS_END_DEV) { 315 if (dev->dev_type == SAS_END_DEV) {
319 isci_tmf->proto = SAS_PROTOCOL_SSP; 316 isci_tmf->proto = SAS_PROTOCOL_SSP;
320 status = scic_task_request_construct_ssp( 317 status = scic_task_request_construct_ssp(&request->sci);
321 request->sci_request_handle
322 );
323 if (status != SCI_SUCCESS) 318 if (status != SCI_SUCCESS)
324 goto errout; 319 goto errout;
325 } 320 }
@@ -376,8 +371,7 @@ static void isci_tmf_timeout_cb(void *tmf_request_arg)
376 status = scic_controller_terminate_request( 371 status = scic_controller_terminate_request(
377 &request->isci_host->sci, 372 &request->isci_host->sci,
378 &request->isci_device->sci, 373 &request->isci_device->sci,
379 request->sci_request_handle 374 &request->sci);
380 );
381 375
382 dev_dbg(&request->isci_host->pdev->dev, 376 dev_dbg(&request->isci_host->pdev->dev,
383 "%s: tmf_request = %p; tmf = %p; status = %d\n", 377 "%s: tmf_request = %p; tmf = %p; status = %d\n",
@@ -467,9 +461,8 @@ int isci_task_execute_tmf(
467 status = scic_controller_start_task( 461 status = scic_controller_start_task(
468 &isci_host->sci, 462 &isci_host->sci,
469 sci_device, 463 sci_device,
470 request->sci_request_handle, 464 &request->sci,
471 SCI_CONTROLLER_INVALID_IO_TAG 465 SCI_CONTROLLER_INVALID_IO_TAG);
472 );
473 466
474 if (status != SCI_TASK_SUCCESS) { 467 if (status != SCI_TASK_SUCCESS) {
475 dev_warn(&isci_host->pdev->dev, 468 dev_warn(&isci_host->pdev->dev,
@@ -764,13 +757,13 @@ static void isci_terminate_request_core(
764 * device condition (if the request handle is NULL, then the 757 * device condition (if the request handle is NULL, then the
765 * request completed but needed additional handling here). 758 * request completed but needed additional handling here).
766 */ 759 */
767 if (isci_request->sci_request_handle != NULL) { 760 if (!isci_request->terminated) {
768 was_terminated = true; 761 was_terminated = true;
769 needs_cleanup_handling = true; 762 needs_cleanup_handling = true;
770 status = scic_controller_terminate_request( 763 status = scic_controller_terminate_request(
771 &isci_host->sci, 764 &isci_host->sci,
772 &isci_device->sci, 765 &isci_device->sci,
773 isci_request->sci_request_handle); 766 &isci_request->sci);
774 } 767 }
775 spin_unlock_irqrestore(&isci_host->scic_lock, flags); 768 spin_unlock_irqrestore(&isci_host->scic_lock, flags);
776 769
@@ -1430,7 +1423,7 @@ isci_task_request_complete(struct isci_host *ihost,
1430 enum isci_request_status old_state; 1423 enum isci_request_status old_state;
1431 struct isci_tmf *tmf = isci_request_access_tmf(ireq); 1424 struct isci_tmf *tmf = isci_request_access_tmf(ireq);
1432 struct completion *tmf_complete; 1425 struct completion *tmf_complete;
1433 struct scic_sds_request *sci_req = ireq->sci_request_handle; 1426 struct scic_sds_request *sci_req = &ireq->sci;
1434 1427
1435 dev_dbg(&ihost->pdev->dev, 1428 dev_dbg(&ihost->pdev->dev,
1436 "%s: request = %p, status=%d\n", 1429 "%s: request = %p, status=%d\n",
@@ -1460,12 +1453,11 @@ isci_task_request_complete(struct isci_host *ihost,
1460 /* PRINT_TMF( ((struct isci_tmf *)request->task)); */ 1453 /* PRINT_TMF( ((struct isci_tmf *)request->task)); */
1461 tmf_complete = tmf->complete; 1454 tmf_complete = tmf->complete;
1462 1455
1463 scic_controller_complete_io(&ihost->sci, &idev->sci, 1456 scic_controller_complete_io(&ihost->sci, &idev->sci, &ireq->sci);
1464 ireq->sci_request_handle); 1457 /* set the 'terminated' flag handle to make sure it cannot be terminated
1465 /* NULL the request handle to make sure it cannot be terminated
1466 * or completed again. 1458 * or completed again.
1467 */ 1459 */
1468 ireq->sci_request_handle = NULL; 1460 ireq->terminated = true;;
1469 1461
1470 isci_request_change_state(ireq, unallocated); 1462 isci_request_change_state(ireq, unallocated);
1471 list_del_init(&ireq->dev_node); 1463 list_del_init(&ireq->dev_node);