aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/scsi
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/scsi')
-rw-r--r--drivers/scsi/isci/request.c147
-rw-r--r--drivers/scsi/isci/request.h84
2 files changed, 89 insertions, 142 deletions
diff --git a/drivers/scsi/isci/request.c b/drivers/scsi/isci/request.c
index 3c7ed4e61b4a..8520626b02fa 100644
--- a/drivers/scsi/isci/request.c
+++ b/drivers/scsi/isci/request.c
@@ -433,24 +433,20 @@ static enum sci_status
433scic_sds_stp_pio_request_construct(struct scic_sds_request *sci_req, 433scic_sds_stp_pio_request_construct(struct scic_sds_request *sci_req,
434 bool copy_rx_frame) 434 bool copy_rx_frame)
435{ 435{
436 struct scic_sds_stp_request *stp_req = &sci_req->stp.req; 436 struct isci_stp_request *stp_req = &sci_req->stp.req;
437 struct scic_sds_stp_pio_request *pio = &stp_req->type.pio;
438 437
439 scu_stp_raw_request_construct_task_context(sci_req); 438 scu_stp_raw_request_construct_task_context(sci_req);
440 439
441 pio->current_transfer_bytes = 0; 440 stp_req->status = 0;
442 pio->ending_error = 0; 441 stp_req->sgl.offset = 0;
443 pio->ending_status = 0; 442 stp_req->sgl.set = SCU_SGL_ELEMENT_PAIR_A;
444
445 pio->request_current.sgl_offset = 0;
446 pio->request_current.sgl_set = SCU_SGL_ELEMENT_PAIR_A;
447 443
448 if (copy_rx_frame) { 444 if (copy_rx_frame) {
449 scic_sds_request_build_sgl(sci_req); 445 scic_sds_request_build_sgl(sci_req);
450 pio->request_current.sgl_index = 0; 446 stp_req->sgl.index = 0;
451 } else { 447 } else {
452 /* The user does not want the data copied to the SGL buffer location */ 448 /* The user does not want the data copied to the SGL buffer location */
453 pio->request_current.sgl_index = -1; 449 stp_req->sgl.index = -1;
454 } 450 }
455 451
456 return SCI_SUCCESS; 452 return SCI_SUCCESS;
@@ -1151,22 +1147,22 @@ void scic_stp_io_request_set_ncq_tag(struct scic_sds_request *req,
1151 req->tc->type.stp.ncq_tag = ncq_tag; 1147 req->tc->type.stp.ncq_tag = ncq_tag;
1152} 1148}
1153 1149
1154static struct scu_sgl_element *pio_sgl_next(struct scic_sds_stp_request *stp_req) 1150static struct scu_sgl_element *pio_sgl_next(struct isci_stp_request *stp_req)
1155{ 1151{
1156 struct scu_sgl_element *sgl; 1152 struct scu_sgl_element *sgl;
1157 struct scu_sgl_element_pair *sgl_pair; 1153 struct scu_sgl_element_pair *sgl_pair;
1158 struct scic_sds_request *sci_req = to_sci_req(stp_req); 1154 struct scic_sds_request *sci_req = to_sci_req(stp_req);
1159 struct scic_sds_request_pio_sgl *pio_sgl = &stp_req->type.pio.request_current; 1155 struct isci_stp_pio_sgl *pio_sgl = &stp_req->sgl;
1160 1156
1161 sgl_pair = to_sgl_element_pair(sci_req, pio_sgl->sgl_index); 1157 sgl_pair = to_sgl_element_pair(sci_req, pio_sgl->index);
1162 if (!sgl_pair) 1158 if (!sgl_pair)
1163 sgl = NULL; 1159 sgl = NULL;
1164 else if (pio_sgl->sgl_set == SCU_SGL_ELEMENT_PAIR_A) { 1160 else if (pio_sgl->set == SCU_SGL_ELEMENT_PAIR_A) {
1165 if (sgl_pair->B.address_lower == 0 && 1161 if (sgl_pair->B.address_lower == 0 &&
1166 sgl_pair->B.address_upper == 0) { 1162 sgl_pair->B.address_upper == 0) {
1167 sgl = NULL; 1163 sgl = NULL;
1168 } else { 1164 } else {
1169 pio_sgl->sgl_set = SCU_SGL_ELEMENT_PAIR_B; 1165 pio_sgl->set = SCU_SGL_ELEMENT_PAIR_B;
1170 sgl = &sgl_pair->B; 1166 sgl = &sgl_pair->B;
1171 } 1167 }
1172 } else { 1168 } else {
@@ -1174,9 +1170,9 @@ static struct scu_sgl_element *pio_sgl_next(struct scic_sds_stp_request *stp_req
1174 sgl_pair->next_pair_upper == 0) { 1170 sgl_pair->next_pair_upper == 0) {
1175 sgl = NULL; 1171 sgl = NULL;
1176 } else { 1172 } else {
1177 pio_sgl->sgl_index++; 1173 pio_sgl->index++;
1178 pio_sgl->sgl_set = SCU_SGL_ELEMENT_PAIR_A; 1174 pio_sgl->set = SCU_SGL_ELEMENT_PAIR_A;
1179 sgl_pair = to_sgl_element_pair(sci_req, pio_sgl->sgl_index); 1175 sgl_pair = to_sgl_element_pair(sci_req, pio_sgl->index);
1180 sgl = &sgl_pair->A; 1176 sgl = &sgl_pair->A;
1181 } 1177 }
1182 } 1178 }
@@ -1221,7 +1217,7 @@ static enum sci_status scic_sds_stp_request_pio_data_out_trasmit_data_frame(
1221 struct scic_sds_request *sci_req, 1217 struct scic_sds_request *sci_req,
1222 u32 length) 1218 u32 length)
1223{ 1219{
1224 struct scic_sds_stp_request *stp_req = &sci_req->stp.req; 1220 struct isci_stp_request *stp_req = &sci_req->stp.req;
1225 struct scu_task_context *task_context = sci_req->tc; 1221 struct scu_task_context *task_context = sci_req->tc;
1226 struct scu_sgl_element_pair *sgl_pair; 1222 struct scu_sgl_element_pair *sgl_pair;
1227 struct scu_sgl_element *current_sgl; 1223 struct scu_sgl_element *current_sgl;
@@ -1229,8 +1225,8 @@ static enum sci_status scic_sds_stp_request_pio_data_out_trasmit_data_frame(
1229 /* Recycle the TC and reconstruct it for sending out DATA FIS containing 1225 /* Recycle the TC and reconstruct it for sending out DATA FIS containing
1230 * for the data from current_sgl+offset for the input length 1226 * for the data from current_sgl+offset for the input length
1231 */ 1227 */
1232 sgl_pair = to_sgl_element_pair(sci_req, stp_req->type.pio.request_current.sgl_index); 1228 sgl_pair = to_sgl_element_pair(sci_req, stp_req->sgl.index);
1233 if (stp_req->type.pio.request_current.sgl_set == SCU_SGL_ELEMENT_PAIR_A) 1229 if (stp_req->sgl.set == SCU_SGL_ELEMENT_PAIR_A)
1234 current_sgl = &sgl_pair->A; 1230 current_sgl = &sgl_pair->A;
1235 else 1231 else
1236 current_sgl = &sgl_pair->B; 1232 current_sgl = &sgl_pair->B;
@@ -1247,54 +1243,48 @@ static enum sci_status scic_sds_stp_request_pio_data_out_trasmit_data_frame(
1247 1243
1248static enum sci_status scic_sds_stp_request_pio_data_out_transmit_data(struct scic_sds_request *sci_req) 1244static enum sci_status scic_sds_stp_request_pio_data_out_transmit_data(struct scic_sds_request *sci_req)
1249{ 1245{
1250 1246 struct isci_stp_request *stp_req = &sci_req->stp.req;
1251 struct scu_sgl_element *current_sgl;
1252 u32 sgl_offset;
1253 u32 remaining_bytes_in_current_sgl = 0;
1254 enum sci_status status = SCI_SUCCESS;
1255 struct scic_sds_stp_request *stp_req = &sci_req->stp.req;
1256 struct scu_sgl_element_pair *sgl_pair; 1247 struct scu_sgl_element_pair *sgl_pair;
1248 struct scu_sgl_element *sgl;
1249 enum sci_status status;
1250 u32 offset;
1251 u32 len = 0;
1257 1252
1258 sgl_offset = stp_req->type.pio.request_current.sgl_offset; 1253 offset = stp_req->sgl.offset;
1259 sgl_pair = to_sgl_element_pair(sci_req, stp_req->type.pio.request_current.sgl_index); 1254 sgl_pair = to_sgl_element_pair(sci_req, stp_req->sgl.index);
1260 if (WARN_ONCE(!sgl_pair, "%s: null sgl element", __func__)) 1255 if (WARN_ONCE(!sgl_pair, "%s: null sgl element", __func__))
1261 return SCI_FAILURE; 1256 return SCI_FAILURE;
1262 1257
1263 if (stp_req->type.pio.request_current.sgl_set == SCU_SGL_ELEMENT_PAIR_A) { 1258 if (stp_req->sgl.set == SCU_SGL_ELEMENT_PAIR_A) {
1264 current_sgl = &sgl_pair->A; 1259 sgl = &sgl_pair->A;
1265 remaining_bytes_in_current_sgl = sgl_pair->A.length - sgl_offset; 1260 len = sgl_pair->A.length - offset;
1266 } else { 1261 } else {
1267 current_sgl = &sgl_pair->B; 1262 sgl = &sgl_pair->B;
1268 remaining_bytes_in_current_sgl = sgl_pair->B.length - sgl_offset; 1263 len = sgl_pair->B.length - offset;
1269 } 1264 }
1270 1265
1271 if (stp_req->type.pio.pio_transfer_bytes > 0) { 1266 if (stp_req->pio_len == 0)
1272 if (stp_req->type.pio.pio_transfer_bytes >= remaining_bytes_in_current_sgl) { 1267 return SCI_SUCCESS;
1273 /* recycle the TC and send the H2D Data FIS from (current sgl + sgl_offset) and length = remaining_bytes_in_current_sgl */
1274 status = scic_sds_stp_request_pio_data_out_trasmit_data_frame(sci_req, remaining_bytes_in_current_sgl);
1275 if (status == SCI_SUCCESS) {
1276 stp_req->type.pio.pio_transfer_bytes -= remaining_bytes_in_current_sgl;
1277
1278 /* update the current sgl, sgl_offset and save for future */
1279 current_sgl = pio_sgl_next(stp_req);
1280 sgl_offset = 0;
1281 }
1282 } else if (stp_req->type.pio.pio_transfer_bytes < remaining_bytes_in_current_sgl) {
1283 /* recycle the TC and send the H2D Data FIS from (current sgl + sgl_offset) and length = type.pio.pio_transfer_bytes */
1284 scic_sds_stp_request_pio_data_out_trasmit_data_frame(sci_req, stp_req->type.pio.pio_transfer_bytes);
1285 1268
1286 if (status == SCI_SUCCESS) { 1269 if (stp_req->pio_len >= len) {
1287 /* Sgl offset will be adjusted and saved for future */ 1270 status = scic_sds_stp_request_pio_data_out_trasmit_data_frame(sci_req, len);
1288 sgl_offset += stp_req->type.pio.pio_transfer_bytes; 1271 if (status != SCI_SUCCESS)
1289 current_sgl->address_lower += stp_req->type.pio.pio_transfer_bytes; 1272 return status;
1290 stp_req->type.pio.pio_transfer_bytes = 0; 1273 stp_req->pio_len -= len;
1291 } 1274
1292 } 1275 /* update the current sgl, offset and save for future */
1276 sgl = pio_sgl_next(stp_req);
1277 offset = 0;
1278 } else if (stp_req->pio_len < len) {
1279 scic_sds_stp_request_pio_data_out_trasmit_data_frame(sci_req, stp_req->pio_len);
1280
1281 /* Sgl offset will be adjusted and saved for future */
1282 offset += stp_req->pio_len;
1283 sgl->address_lower += stp_req->pio_len;
1284 stp_req->pio_len = 0;
1293 } 1285 }
1294 1286
1295 if (status == SCI_SUCCESS) { 1287 stp_req->sgl.offset = offset;
1296 stp_req->type.pio.request_current.sgl_offset = sgl_offset;
1297 }
1298 1288
1299 return status; 1289 return status;
1300} 1290}
@@ -1309,7 +1299,7 @@ static enum sci_status scic_sds_stp_request_pio_data_out_transmit_data(struct sc
1309 * specified data region. enum sci_status 1299 * specified data region. enum sci_status
1310 */ 1300 */
1311static enum sci_status 1301static enum sci_status
1312scic_sds_stp_request_pio_data_in_copy_data_buffer(struct scic_sds_stp_request *stp_req, 1302scic_sds_stp_request_pio_data_in_copy_data_buffer(struct isci_stp_request *stp_req,
1313 u8 *data_buf, u32 len) 1303 u8 *data_buf, u32 len)
1314{ 1304{
1315 struct scic_sds_request *sci_req; 1305 struct scic_sds_request *sci_req;
@@ -1356,7 +1346,7 @@ scic_sds_stp_request_pio_data_in_copy_data_buffer(struct scic_sds_stp_request *s
1356 * Copy the data buffer to the io request data region. enum sci_status 1346 * Copy the data buffer to the io request data region. enum sci_status
1357 */ 1347 */
1358static enum sci_status scic_sds_stp_request_pio_data_in_copy_data( 1348static enum sci_status scic_sds_stp_request_pio_data_in_copy_data(
1359 struct scic_sds_stp_request *sci_req, 1349 struct isci_stp_request *stp_req,
1360 u8 *data_buffer) 1350 u8 *data_buffer)
1361{ 1351{
1362 enum sci_status status; 1352 enum sci_status status;
@@ -1364,19 +1354,19 @@ static enum sci_status scic_sds_stp_request_pio_data_in_copy_data(
1364 /* 1354 /*
1365 * If there is less than 1K remaining in the transfer request 1355 * If there is less than 1K remaining in the transfer request
1366 * copy just the data for the transfer */ 1356 * copy just the data for the transfer */
1367 if (sci_req->type.pio.pio_transfer_bytes < SCU_MAX_FRAME_BUFFER_SIZE) { 1357 if (stp_req->pio_len < SCU_MAX_FRAME_BUFFER_SIZE) {
1368 status = scic_sds_stp_request_pio_data_in_copy_data_buffer( 1358 status = scic_sds_stp_request_pio_data_in_copy_data_buffer(
1369 sci_req, data_buffer, sci_req->type.pio.pio_transfer_bytes); 1359 stp_req, data_buffer, stp_req->pio_len);
1370 1360
1371 if (status == SCI_SUCCESS) 1361 if (status == SCI_SUCCESS)
1372 sci_req->type.pio.pio_transfer_bytes = 0; 1362 stp_req->pio_len = 0;
1373 } else { 1363 } else {
1374 /* We are transfering the whole frame so copy */ 1364 /* We are transfering the whole frame so copy */
1375 status = scic_sds_stp_request_pio_data_in_copy_data_buffer( 1365 status = scic_sds_stp_request_pio_data_in_copy_data_buffer(
1376 sci_req, data_buffer, SCU_MAX_FRAME_BUFFER_SIZE); 1366 stp_req, data_buffer, SCU_MAX_FRAME_BUFFER_SIZE);
1377 1367
1378 if (status == SCI_SUCCESS) 1368 if (status == SCI_SUCCESS)
1379 sci_req->type.pio.pio_transfer_bytes -= SCU_MAX_FRAME_BUFFER_SIZE; 1369 stp_req->pio_len -= SCU_MAX_FRAME_BUFFER_SIZE;
1380 } 1370 }
1381 1371
1382 return status; 1372 return status;
@@ -1419,18 +1409,18 @@ pio_data_out_tx_done_tc_event(struct scic_sds_request *sci_req,
1419{ 1409{
1420 enum sci_status status = SCI_SUCCESS; 1410 enum sci_status status = SCI_SUCCESS;
1421 bool all_frames_transferred = false; 1411 bool all_frames_transferred = false;
1422 struct scic_sds_stp_request *stp_req = &sci_req->stp.req; 1412 struct isci_stp_request *stp_req = &sci_req->stp.req;
1423 1413
1424 switch (SCU_GET_COMPLETION_TL_STATUS(completion_code)) { 1414 switch (SCU_GET_COMPLETION_TL_STATUS(completion_code)) {
1425 case SCU_MAKE_COMPLETION_STATUS(SCU_TASK_DONE_GOOD): 1415 case SCU_MAKE_COMPLETION_STATUS(SCU_TASK_DONE_GOOD):
1426 /* Transmit data */ 1416 /* Transmit data */
1427 if (stp_req->type.pio.pio_transfer_bytes != 0) { 1417 if (stp_req->pio_len != 0) {
1428 status = scic_sds_stp_request_pio_data_out_transmit_data(sci_req); 1418 status = scic_sds_stp_request_pio_data_out_transmit_data(sci_req);
1429 if (status == SCI_SUCCESS) { 1419 if (status == SCI_SUCCESS) {
1430 if (stp_req->type.pio.pio_transfer_bytes == 0) 1420 if (stp_req->pio_len == 0)
1431 all_frames_transferred = true; 1421 all_frames_transferred = true;
1432 } 1422 }
1433 } else if (stp_req->type.pio.pio_transfer_bytes == 0) { 1423 } else if (stp_req->pio_len == 0) {
1434 /* 1424 /*
1435 * this will happen if the all data is written at the 1425 * this will happen if the all data is written at the
1436 * first time after the pio setup fis is received 1426 * first time after the pio setup fis is received
@@ -1507,7 +1497,7 @@ scic_sds_io_request_frame_handler(struct scic_sds_request *sci_req,
1507 u32 frame_index) 1497 u32 frame_index)
1508{ 1498{
1509 struct scic_sds_controller *scic = sci_req->owning_controller; 1499 struct scic_sds_controller *scic = sci_req->owning_controller;
1510 struct scic_sds_stp_request *stp_req = &sci_req->stp.req; 1500 struct isci_stp_request *stp_req = &sci_req->stp.req;
1511 enum sci_base_request_states state; 1501 enum sci_base_request_states state;
1512 enum sci_status status; 1502 enum sci_status status;
1513 ssize_t word_cnt; 1503 ssize_t word_cnt;
@@ -1727,16 +1717,16 @@ scic_sds_io_request_frame_handler(struct scic_sds_request *sci_req,
1727 */ 1717 */
1728 1718
1729 /* transfer_count: first 16bits in the 4th dword */ 1719 /* transfer_count: first 16bits in the 4th dword */
1730 stp_req->type.pio.pio_transfer_bytes = frame_buffer[3] & 0xffff; 1720 stp_req->pio_len = frame_buffer[3] & 0xffff;
1731 1721
1732 /* ending_status: 4th byte in the 3rd dword */ 1722 /* status: 4th byte in the 3rd dword */
1733 stp_req->type.pio.ending_status = (frame_buffer[2] >> 24) & 0xff; 1723 stp_req->status = (frame_buffer[2] >> 24) & 0xff;
1734 1724
1735 scic_sds_controller_copy_sata_response(&sci_req->stp.rsp, 1725 scic_sds_controller_copy_sata_response(&sci_req->stp.rsp,
1736 frame_header, 1726 frame_header,
1737 frame_buffer); 1727 frame_buffer);
1738 1728
1739 sci_req->stp.rsp.status = stp_req->type.pio.ending_status; 1729 sci_req->stp.rsp.status = stp_req->status;
1740 1730
1741 /* The next state is dependent on whether the 1731 /* The next state is dependent on whether the
1742 * request was PIO Data-in or Data out 1732 * request was PIO Data-in or Data out
@@ -1839,9 +1829,9 @@ scic_sds_io_request_frame_handler(struct scic_sds_request *sci_req,
1839 return status; 1829 return status;
1840 } 1830 }
1841 1831
1842 if (stp_req->type.pio.request_current.sgl_index < 0) { 1832 if (stp_req->sgl.index < 0) {
1843 sci_req->saved_rx_frame_index = frame_index; 1833 sci_req->saved_rx_frame_index = frame_index;
1844 stp_req->type.pio.pio_transfer_bytes = 0; 1834 stp_req->pio_len = 0;
1845 } else { 1835 } else {
1846 scic_sds_unsolicited_frame_control_get_buffer(&scic->uf_control, 1836 scic_sds_unsolicited_frame_control_get_buffer(&scic->uf_control,
1847 frame_index, 1837 frame_index,
@@ -1857,11 +1847,10 @@ scic_sds_io_request_frame_handler(struct scic_sds_request *sci_req,
1857 /* Check for the end of the transfer, are there more 1847 /* Check for the end of the transfer, are there more
1858 * bytes remaining for this data transfer 1848 * bytes remaining for this data transfer
1859 */ 1849 */
1860 if (status != SCI_SUCCESS || 1850 if (status != SCI_SUCCESS || stp_req->pio_len != 0)
1861 stp_req->type.pio.pio_transfer_bytes != 0)
1862 return status; 1851 return status;
1863 1852
1864 if ((stp_req->type.pio.ending_status & ATA_BUSY) == 0) { 1853 if ((stp_req->status & ATA_BUSY) == 0) {
1865 scic_sds_request_set_status(sci_req, 1854 scic_sds_request_set_status(sci_req,
1866 SCU_TASK_DONE_CHECK_RESPONSE, 1855 SCU_TASK_DONE_CHECK_RESPONSE,
1867 SCI_FAILURE_IO_RESPONSE_VALID); 1856 SCI_FAILURE_IO_RESPONSE_VALID);
diff --git a/drivers/scsi/isci/request.h b/drivers/scsi/isci/request.h
index 7628decbd535..7fd98531d1f2 100644
--- a/drivers/scsi/isci/request.h
+++ b/drivers/scsi/isci/request.h
@@ -89,67 +89,25 @@ enum sci_request_protocol {
89 SCIC_STP_PROTOCOL 89 SCIC_STP_PROTOCOL
90}; /* XXX remove me, use sas_task.{dev|task_proto} instead */; 90}; /* XXX remove me, use sas_task.{dev|task_proto} instead */;
91 91
92struct scic_sds_stp_request { 92/**
93 union { 93 * isci_stp_request - extra request infrastructure to handle pio/atapi protocol
94 u32 ncq; 94 * @pio_len - number of bytes requested at PIO setup
95 95 * @status - pio setup ending status value to tell us if we need
96 u32 udma; 96 * to wait for another fis or if the transfer is complete. Upon
97 97 * receipt of a d2h fis this will be the status field of that fis.
98 struct scic_sds_stp_pio_request { 98 * @sgl - track pio transfer progress as we iterate through the sgl
99 /* 99 * @device_cdb_len - atapi device advertises it's transfer constraints at setup
100 * Total transfer for the entire PIO request recorded 100 */
101 * at request constuction time. 101struct isci_stp_request {
102 * 102 u32 pio_len;
103 * @todo Should we just decrement this value for each 103 u8 status;
104 * byte of data transitted or received to elemenate 104
105 * the current_transfer_bytes field? 105 struct isci_stp_pio_sgl {
106 */ 106 int index;
107 u32 total_transfer_bytes; 107 u8 set;
108 108 u32 offset;
109 /* 109 } sgl;
110 * Total number of bytes received/transmitted in data 110 u32 device_cdb_len;
111 * frames since the start of the IO request. At the
112 * end of the IO request this should equal the
113 * total_transfer_bytes.
114 */
115 u32 current_transfer_bytes;
116
117 /*
118 * The number of bytes requested in the in the PIO
119 * setup.
120 */
121 u32 pio_transfer_bytes;
122
123 /*
124 * PIO Setup ending status value to tell us if we need
125 * to wait for another FIS or if the transfer is
126 * complete. On the receipt of a D2H FIS this will be
127 * the status field of that FIS.
128 */
129 u8 ending_status;
130
131 /*
132 * On receipt of a D2H FIS this will be the ending
133 * error field if the ending_status has the
134 * SATA_STATUS_ERR bit set.
135 */
136 u8 ending_error;
137
138 struct scic_sds_request_pio_sgl {
139 int sgl_index;
140 u8 sgl_set;
141 u32 sgl_offset;
142 } request_current;
143 } pio;
144
145 struct {
146 /*
147 * The number of bytes requested in the PIO setup
148 * before CDB data frame.
149 */
150 u32 device_preferred_cdb_length;
151 } packet;
152 } type;
153}; 111};
154 112
155struct scic_sds_request { 113struct scic_sds_request {
@@ -235,14 +193,14 @@ struct scic_sds_request {
235 } smp; 193 } smp;
236 194
237 struct { 195 struct {
238 struct scic_sds_stp_request req; 196 struct isci_stp_request req;
239 struct host_to_dev_fis cmd; 197 struct host_to_dev_fis cmd;
240 struct dev_to_host_fis rsp; 198 struct dev_to_host_fis rsp;
241 } stp; 199 } stp;
242 }; 200 };
243}; 201};
244 202
245static inline struct scic_sds_request *to_sci_req(struct scic_sds_stp_request *stp_req) 203static inline struct scic_sds_request *to_sci_req(struct isci_stp_request *stp_req)
246{ 204{
247 struct scic_sds_request *sci_req; 205 struct scic_sds_request *sci_req;
248 206