aboutsummaryrefslogtreecommitdiffstats
path: root/drivers
diff options
context:
space:
mode:
authorDan Williams <dan.j.williams@intel.com>2011-06-30 19:31:37 -0400
committerDan Williams <dan.j.williams@intel.com>2011-07-03 07:04:52 -0400
commit78a6f06e0e82125787d7aa308fe28c2c8381540c (patch)
tree55ab54546aab6dbaccda4ff6d196d8995f453c83 /drivers
parentffe191c92ff195d73f9130b1490045ca2dd4c5e0 (diff)
isci: unify isci_remote_device and scic_sds_remote_device
Remove the distinction between these two implementations and unify on isci_remote_device (local instances named idev). Reported-by: Christoph Hellwig <hch@lst.de> Signed-off-by: Dan Williams <dan.j.williams@intel.com>
Diffstat (limited to 'drivers')
-rw-r--r--drivers/scsi/isci/host.c60
-rw-r--r--drivers/scsi/isci/host.h27
-rw-r--r--drivers/scsi/isci/port.c4
-rw-r--r--drivers/scsi/isci/port.h6
-rw-r--r--drivers/scsi/isci/remote_device.c396
-rw-r--r--drivers/scsi/isci/remote_device.h148
-rw-r--r--drivers/scsi/isci/remote_node_context.c48
-rw-r--r--drivers/scsi/isci/remote_node_context.h2
-rw-r--r--drivers/scsi/isci/request.c60
-rw-r--r--drivers/scsi/isci/request.h4
-rw-r--r--drivers/scsi/isci/task.c47
11 files changed, 365 insertions, 437 deletions
diff --git a/drivers/scsi/isci/host.c b/drivers/scsi/isci/host.c
index 4e11f9e6d766..45d7f71c609a 100644
--- a/drivers/scsi/isci/host.c
+++ b/drivers/scsi/isci/host.c
@@ -272,7 +272,7 @@ static void scic_sds_controller_sdma_completion(struct scic_sds_controller *scic
272{ 272{
273 u32 index; 273 u32 index;
274 struct isci_request *ireq; 274 struct isci_request *ireq;
275 struct scic_sds_remote_device *device; 275 struct isci_remote_device *idev;
276 276
277 index = SCU_GET_COMPLETION_INDEX(completion_entry); 277 index = SCU_GET_COMPLETION_INDEX(completion_entry);
278 278
@@ -289,9 +289,9 @@ static void scic_sds_controller_sdma_completion(struct scic_sds_controller *scic
289 case SCU_CONTEXT_COMMAND_REQUEST_TYPE_DUMP_RNC: 289 case SCU_CONTEXT_COMMAND_REQUEST_TYPE_DUMP_RNC:
290 case SCU_CONTEXT_COMMAND_REQUEST_TYPE_OTHER_RNC: 290 case SCU_CONTEXT_COMMAND_REQUEST_TYPE_OTHER_RNC:
291 case SCU_CONTEXT_COMMAND_REQUEST_TYPE_POST_RNC: 291 case SCU_CONTEXT_COMMAND_REQUEST_TYPE_POST_RNC:
292 device = scic->device_table[index]; 292 idev = scic->device_table[index];
293 dev_warn(scic_to_dev(scic), "%s: %x for device %p\n", 293 dev_warn(scic_to_dev(scic), "%s: %x for device %p\n",
294 __func__, completion_entry, device); 294 __func__, completion_entry, idev);
295 /* @todo For a port RNC operation we need to fail the 295 /* @todo For a port RNC operation we need to fail the
296 * device 296 * device
297 */ 297 */
@@ -312,7 +312,7 @@ static void scic_sds_controller_unsolicited_frame(struct scic_sds_controller *sc
312 struct isci_host *ihost = scic_to_ihost(scic); 312 struct isci_host *ihost = scic_to_ihost(scic);
313 struct scu_unsolicited_frame_header *frame_header; 313 struct scu_unsolicited_frame_header *frame_header;
314 struct isci_phy *iphy; 314 struct isci_phy *iphy;
315 struct scic_sds_remote_device *device; 315 struct isci_remote_device *idev;
316 316
317 enum sci_status result = SCI_FAILURE; 317 enum sci_status result = SCI_FAILURE;
318 318
@@ -348,12 +348,12 @@ static void scic_sds_controller_unsolicited_frame(struct scic_sds_controller *sc
348 result = scic_sds_phy_frame_handler(iphy, frame_index); 348 result = scic_sds_phy_frame_handler(iphy, frame_index);
349 } else { 349 } else {
350 if (index < scic->remote_node_entries) 350 if (index < scic->remote_node_entries)
351 device = scic->device_table[index]; 351 idev = scic->device_table[index];
352 else 352 else
353 device = NULL; 353 idev = NULL;
354 354
355 if (device != NULL) 355 if (idev != NULL)
356 result = scic_sds_remote_device_frame_handler(device, frame_index); 356 result = scic_sds_remote_device_frame_handler(idev, frame_index);
357 else 357 else
358 scic_sds_controller_release_frame(scic, frame_index); 358 scic_sds_controller_release_frame(scic, frame_index);
359 } 359 }
@@ -370,7 +370,7 @@ static void scic_sds_controller_event_completion(struct scic_sds_controller *sci
370 u32 completion_entry) 370 u32 completion_entry)
371{ 371{
372 struct isci_host *ihost = scic_to_ihost(scic); 372 struct isci_host *ihost = scic_to_ihost(scic);
373 struct scic_sds_remote_device *device; 373 struct isci_remote_device *idev;
374 struct isci_request *ireq; 374 struct isci_request *ireq;
375 struct isci_phy *iphy; 375 struct isci_phy *iphy;
376 u32 index; 376 u32 index;
@@ -426,9 +426,9 @@ static void scic_sds_controller_event_completion(struct scic_sds_controller *sci
426 break; 426 break;
427 427
428 case SCU_EVENT_SPECIFIC_IT_NEXUS_TIMEOUT: 428 case SCU_EVENT_SPECIFIC_IT_NEXUS_TIMEOUT:
429 device = scic->device_table[index]; 429 idev = scic->device_table[index];
430 if (device != NULL) 430 if (idev != NULL)
431 scic_sds_remote_device_event_handler(device, completion_entry); 431 scic_sds_remote_device_event_handler(idev, completion_entry);
432 else 432 else
433 dev_warn(scic_to_dev(scic), 433 dev_warn(scic_to_dev(scic),
434 "%s: SCIC Controller 0x%p received " 434 "%s: SCIC Controller 0x%p received "
@@ -460,10 +460,10 @@ static void scic_sds_controller_event_completion(struct scic_sds_controller *sci
460 case SCU_EVENT_TYPE_RNC_SUSPEND_TX_RX: 460 case SCU_EVENT_TYPE_RNC_SUSPEND_TX_RX:
461 case SCU_EVENT_TYPE_RNC_OPS_MISC: 461 case SCU_EVENT_TYPE_RNC_OPS_MISC:
462 if (index < scic->remote_node_entries) { 462 if (index < scic->remote_node_entries) {
463 device = scic->device_table[index]; 463 idev = scic->device_table[index];
464 464
465 if (device != NULL) 465 if (idev != NULL)
466 scic_sds_remote_device_event_handler(device, completion_entry); 466 scic_sds_remote_device_event_handler(idev, completion_entry);
467 } else 467 } else
468 dev_err(scic_to_dev(scic), 468 dev_err(scic_to_dev(scic),
469 "%s: SCIC Controller 0x%p received event 0x%x " 469 "%s: SCIC Controller 0x%p received event 0x%x "
@@ -2549,13 +2549,13 @@ static bool scic_sds_controller_has_remote_devices_stopping(
2549 * object that the remote device has stopped. 2549 * object that the remote device has stopped.
2550 */ 2550 */
2551void scic_sds_controller_remote_device_stopped(struct scic_sds_controller *scic, 2551void scic_sds_controller_remote_device_stopped(struct scic_sds_controller *scic,
2552 struct scic_sds_remote_device *sci_dev) 2552 struct isci_remote_device *idev)
2553{ 2553{
2554 if (scic->sm.current_state_id != SCIC_STOPPING) { 2554 if (scic->sm.current_state_id != SCIC_STOPPING) {
2555 dev_dbg(scic_to_dev(scic), 2555 dev_dbg(scic_to_dev(scic),
2556 "SCIC Controller 0x%p remote device stopped event " 2556 "SCIC Controller 0x%p remote device stopped event "
2557 "from device 0x%p in unexpected state %d\n", 2557 "from device 0x%p in unexpected state %d\n",
2558 scic, sci_dev, 2558 scic, idev,
2559 scic->sm.current_state_id); 2559 scic->sm.current_state_id);
2560 return; 2560 return;
2561 } 2561 }
@@ -2622,18 +2622,18 @@ struct isci_request *scic_request_by_tag(struct scic_sds_controller *scic, u16 i
2622 */ 2622 */
2623enum sci_status scic_sds_controller_allocate_remote_node_context( 2623enum sci_status scic_sds_controller_allocate_remote_node_context(
2624 struct scic_sds_controller *scic, 2624 struct scic_sds_controller *scic,
2625 struct scic_sds_remote_device *sci_dev, 2625 struct isci_remote_device *idev,
2626 u16 *node_id) 2626 u16 *node_id)
2627{ 2627{
2628 u16 node_index; 2628 u16 node_index;
2629 u32 remote_node_count = scic_sds_remote_device_node_count(sci_dev); 2629 u32 remote_node_count = scic_sds_remote_device_node_count(idev);
2630 2630
2631 node_index = scic_sds_remote_node_table_allocate_remote_node( 2631 node_index = scic_sds_remote_node_table_allocate_remote_node(
2632 &scic->available_remote_nodes, remote_node_count 2632 &scic->available_remote_nodes, remote_node_count
2633 ); 2633 );
2634 2634
2635 if (node_index != SCIC_SDS_REMOTE_NODE_CONTEXT_INVALID_INDEX) { 2635 if (node_index != SCIC_SDS_REMOTE_NODE_CONTEXT_INVALID_INDEX) {
2636 scic->device_table[node_index] = sci_dev; 2636 scic->device_table[node_index] = idev;
2637 2637
2638 *node_id = node_index; 2638 *node_id = node_index;
2639 2639
@@ -2654,12 +2654,12 @@ enum sci_status scic_sds_controller_allocate_remote_node_context(
2654 */ 2654 */
2655void scic_sds_controller_free_remote_node_context( 2655void scic_sds_controller_free_remote_node_context(
2656 struct scic_sds_controller *scic, 2656 struct scic_sds_controller *scic,
2657 struct scic_sds_remote_device *sci_dev, 2657 struct isci_remote_device *idev,
2658 u16 node_id) 2658 u16 node_id)
2659{ 2659{
2660 u32 remote_node_count = scic_sds_remote_device_node_count(sci_dev); 2660 u32 remote_node_count = scic_sds_remote_device_node_count(idev);
2661 2661
2662 if (scic->device_table[node_id] == sci_dev) { 2662 if (scic->device_table[node_id] == idev) {
2663 scic->device_table[node_id] = NULL; 2663 scic->device_table[node_id] = NULL;
2664 2664
2665 scic_sds_remote_node_table_release_remote_node_index( 2665 scic_sds_remote_node_table_release_remote_node_index(
@@ -2798,7 +2798,7 @@ enum sci_status isci_free_tag(struct isci_host *ihost, u16 io_tag)
2798 * user desires to be utilized for this request. 2798 * user desires to be utilized for this request.
2799 */ 2799 */
2800enum sci_status scic_controller_start_io(struct scic_sds_controller *scic, 2800enum sci_status scic_controller_start_io(struct scic_sds_controller *scic,
2801 struct scic_sds_remote_device *rdev, 2801 struct isci_remote_device *idev,
2802 struct isci_request *ireq) 2802 struct isci_request *ireq)
2803{ 2803{
2804 enum sci_status status; 2804 enum sci_status status;
@@ -2808,7 +2808,7 @@ enum sci_status scic_controller_start_io(struct scic_sds_controller *scic,
2808 return SCI_FAILURE_INVALID_STATE; 2808 return SCI_FAILURE_INVALID_STATE;
2809 } 2809 }
2810 2810
2811 status = scic_sds_remote_device_start_io(scic, rdev, ireq); 2811 status = scic_sds_remote_device_start_io(scic, idev, ireq);
2812 if (status != SCI_SUCCESS) 2812 if (status != SCI_SUCCESS)
2813 return status; 2813 return status;
2814 2814
@@ -2835,7 +2835,7 @@ enum sci_status scic_controller_start_io(struct scic_sds_controller *scic,
2835 */ 2835 */
2836enum sci_status scic_controller_terminate_request( 2836enum sci_status scic_controller_terminate_request(
2837 struct scic_sds_controller *scic, 2837 struct scic_sds_controller *scic,
2838 struct scic_sds_remote_device *rdev, 2838 struct isci_remote_device *idev,
2839 struct isci_request *ireq) 2839 struct isci_request *ireq)
2840{ 2840{
2841 enum sci_status status; 2841 enum sci_status status;
@@ -2873,7 +2873,7 @@ enum sci_status scic_controller_terminate_request(
2873 */ 2873 */
2874enum sci_status scic_controller_complete_io( 2874enum sci_status scic_controller_complete_io(
2875 struct scic_sds_controller *scic, 2875 struct scic_sds_controller *scic,
2876 struct scic_sds_remote_device *rdev, 2876 struct isci_remote_device *idev,
2877 struct isci_request *ireq) 2877 struct isci_request *ireq)
2878{ 2878{
2879 enum sci_status status; 2879 enum sci_status status;
@@ -2884,7 +2884,7 @@ enum sci_status scic_controller_complete_io(
2884 /* XXX: Implement this function */ 2884 /* XXX: Implement this function */
2885 return SCI_FAILURE; 2885 return SCI_FAILURE;
2886 case SCIC_READY: 2886 case SCIC_READY:
2887 status = scic_sds_remote_device_complete_io(scic, rdev, ireq); 2887 status = scic_sds_remote_device_complete_io(scic, idev, ireq);
2888 if (status != SCI_SUCCESS) 2888 if (status != SCI_SUCCESS)
2889 return status; 2889 return status;
2890 2890
@@ -2923,7 +2923,7 @@ enum sci_status scic_controller_continue_io(struct isci_request *ireq)
2923 */ 2923 */
2924enum sci_task_status scic_controller_start_task( 2924enum sci_task_status scic_controller_start_task(
2925 struct scic_sds_controller *scic, 2925 struct scic_sds_controller *scic,
2926 struct scic_sds_remote_device *rdev, 2926 struct isci_remote_device *idev,
2927 struct isci_request *ireq) 2927 struct isci_request *ireq)
2928{ 2928{
2929 enum sci_status status; 2929 enum sci_status status;
@@ -2936,7 +2936,7 @@ enum sci_task_status scic_controller_start_task(
2936 return SCI_TASK_FAILURE_INVALID_STATE; 2936 return SCI_TASK_FAILURE_INVALID_STATE;
2937 } 2937 }
2938 2938
2939 status = scic_sds_remote_device_start_task(scic, rdev, ireq); 2939 status = scic_sds_remote_device_start_task(scic, idev, ireq);
2940 switch (status) { 2940 switch (status) {
2941 case SCI_FAILURE_RESET_DEVICE_PARTIAL_SUCCESS: 2941 case SCI_FAILURE_RESET_DEVICE_PARTIAL_SUCCESS:
2942 set_bit(IREQ_ACTIVE, &ireq->flags); 2942 set_bit(IREQ_ACTIVE, &ireq->flags);
diff --git a/drivers/scsi/isci/host.h b/drivers/scsi/isci/host.h
index fb8048e5fce7..ca2e3b0ee0dd 100644
--- a/drivers/scsi/isci/host.h
+++ b/drivers/scsi/isci/host.h
@@ -163,7 +163,7 @@ struct scic_sds_controller {
163 * objects that need to handle device completion notifications from the 163 * objects that need to handle device completion notifications from the
164 * hardware. The table is RNi based. 164 * hardware. The table is RNi based.
165 */ 165 */
166 struct scic_sds_remote_device *device_table[SCI_MAX_REMOTE_DEVICES]; 166 struct isci_remote_device *device_table[SCI_MAX_REMOTE_DEVICES];
167 167
168 /** 168 /**
169 * This field is the free RNi data structure 169 * This field is the free RNi data structure
@@ -488,12 +488,12 @@ static inline struct isci_host *scic_to_ihost(struct scic_sds_controller *scic)
488#define ISCI_TAG_TCI(tag) ((tag) & (SCI_MAX_IO_REQUESTS-1)) 488#define ISCI_TAG_TCI(tag) ((tag) & (SCI_MAX_IO_REQUESTS-1))
489 489
490/* expander attached sata devices require 3 rnc slots */ 490/* expander attached sata devices require 3 rnc slots */
491static inline int scic_sds_remote_device_node_count(struct scic_sds_remote_device *sci_dev) 491static inline int scic_sds_remote_device_node_count(struct isci_remote_device *idev)
492{ 492{
493 struct domain_device *dev = sci_dev_to_domain(sci_dev); 493 struct domain_device *dev = idev->domain_dev;
494 494
495 if ((dev->dev_type == SATA_DEV || (dev->tproto & SAS_PROTOCOL_STP)) && 495 if ((dev->dev_type == SATA_DEV || (dev->tproto & SAS_PROTOCOL_STP)) &&
496 !sci_dev->is_direct_attached) 496 !idev->is_direct_attached)
497 return SCU_STP_REMOTE_NODE_COUNT; 497 return SCU_STP_REMOTE_NODE_COUNT;
498 return SCU_SSP_REMOTE_NODE_COUNT; 498 return SCU_SSP_REMOTE_NODE_COUNT;
499} 499}
@@ -541,11 +541,8 @@ static inline struct device *sciport_to_dev(struct isci_port *iport)
541 return &iport->isci_host->pdev->dev; 541 return &iport->isci_host->pdev->dev;
542} 542}
543 543
544static inline struct device *scirdev_to_dev(struct scic_sds_remote_device *sci_dev) 544static inline struct device *scirdev_to_dev(struct isci_remote_device *idev)
545{ 545{
546 struct isci_remote_device *idev =
547 container_of(sci_dev, typeof(*idev), sci);
548
549 if (!idev || !idev->isci_port || !idev->isci_port->isci_host) 546 if (!idev || !idev->isci_port || !idev->isci_port->isci_host)
550 return NULL; 547 return NULL;
551 548
@@ -589,11 +586,11 @@ void scic_sds_controller_copy_sata_response(void *response_buffer,
589 void *frame_header, 586 void *frame_header,
590 void *frame_buffer); 587 void *frame_buffer);
591enum sci_status scic_sds_controller_allocate_remote_node_context(struct scic_sds_controller *scic, 588enum sci_status scic_sds_controller_allocate_remote_node_context(struct scic_sds_controller *scic,
592 struct scic_sds_remote_device *sci_dev, 589 struct isci_remote_device *idev,
593 u16 *node_id); 590 u16 *node_id);
594void scic_sds_controller_free_remote_node_context( 591void scic_sds_controller_free_remote_node_context(
595 struct scic_sds_controller *scic, 592 struct scic_sds_controller *scic,
596 struct scic_sds_remote_device *sci_dev, 593 struct isci_remote_device *idev,
597 u16 node_id); 594 u16 node_id);
598union scu_remote_node_context *scic_sds_controller_get_remote_node_context_buffer( 595union scu_remote_node_context *scic_sds_controller_get_remote_node_context_buffer(
599 struct scic_sds_controller *scic, 596 struct scic_sds_controller *scic,
@@ -622,7 +619,7 @@ void scic_sds_controller_link_down(
622 619
623void scic_sds_controller_remote_device_stopped( 620void scic_sds_controller_remote_device_stopped(
624 struct scic_sds_controller *scic, 621 struct scic_sds_controller *scic,
625 struct scic_sds_remote_device *sci_dev); 622 struct isci_remote_device *idev);
626 623
627void scic_sds_controller_copy_task_context( 624void scic_sds_controller_copy_task_context(
628 struct scic_sds_controller *scic, 625 struct scic_sds_controller *scic,
@@ -662,22 +659,22 @@ void scic_controller_disable_interrupts(
662 659
663enum sci_status scic_controller_start_io( 660enum sci_status scic_controller_start_io(
664 struct scic_sds_controller *scic, 661 struct scic_sds_controller *scic,
665 struct scic_sds_remote_device *remote_device, 662 struct isci_remote_device *idev,
666 struct isci_request *ireq); 663 struct isci_request *ireq);
667 664
668enum sci_task_status scic_controller_start_task( 665enum sci_task_status scic_controller_start_task(
669 struct scic_sds_controller *scic, 666 struct scic_sds_controller *scic,
670 struct scic_sds_remote_device *remote_device, 667 struct isci_remote_device *idev,
671 struct isci_request *ireq); 668 struct isci_request *ireq);
672 669
673enum sci_status scic_controller_terminate_request( 670enum sci_status scic_controller_terminate_request(
674 struct scic_sds_controller *scic, 671 struct scic_sds_controller *scic,
675 struct scic_sds_remote_device *remote_device, 672 struct isci_remote_device *idev,
676 struct isci_request *ireq); 673 struct isci_request *ireq);
677 674
678enum sci_status scic_controller_complete_io( 675enum sci_status scic_controller_complete_io(
679 struct scic_sds_controller *scic, 676 struct scic_sds_controller *scic,
680 struct scic_sds_remote_device *remote_device, 677 struct isci_remote_device *idev,
681 struct isci_request *ireq); 678 struct isci_request *ireq);
682 679
683void scic_sds_port_configuration_agent_construct( 680void scic_sds_port_configuration_agent_construct(
diff --git a/drivers/scsi/isci/port.c b/drivers/scsi/isci/port.c
index 04591882ee77..df37b1bf7d11 100644
--- a/drivers/scsi/isci/port.c
+++ b/drivers/scsi/isci/port.c
@@ -1541,7 +1541,7 @@ enum sci_status scic_sds_port_link_down(struct isci_port *iport,
1541} 1541}
1542 1542
1543enum sci_status scic_sds_port_start_io(struct isci_port *iport, 1543enum sci_status scic_sds_port_start_io(struct isci_port *iport,
1544 struct scic_sds_remote_device *sci_dev, 1544 struct isci_remote_device *idev,
1545 struct isci_request *ireq) 1545 struct isci_request *ireq)
1546{ 1546{
1547 enum scic_sds_port_states state; 1547 enum scic_sds_port_states state;
@@ -1561,7 +1561,7 @@ enum sci_status scic_sds_port_start_io(struct isci_port *iport,
1561} 1561}
1562 1562
1563enum sci_status scic_sds_port_complete_io(struct isci_port *iport, 1563enum sci_status scic_sds_port_complete_io(struct isci_port *iport,
1564 struct scic_sds_remote_device *sci_dev, 1564 struct isci_remote_device *idev,
1565 struct isci_request *ireq) 1565 struct isci_request *ireq)
1566{ 1566{
1567 enum scic_sds_port_states state; 1567 enum scic_sds_port_states state;
diff --git a/drivers/scsi/isci/port.h b/drivers/scsi/isci/port.h
index cdea48ece005..b9bc89bf6519 100644
--- a/drivers/scsi/isci/port.h
+++ b/drivers/scsi/isci/port.h
@@ -283,15 +283,15 @@ enum sci_status scic_sds_port_link_down(struct isci_port *iport,
283 struct isci_phy *iphy); 283 struct isci_phy *iphy);
284 284
285struct isci_request; 285struct isci_request;
286struct scic_sds_remote_device; 286struct isci_remote_device;
287enum sci_status scic_sds_port_start_io( 287enum sci_status scic_sds_port_start_io(
288 struct isci_port *iport, 288 struct isci_port *iport,
289 struct scic_sds_remote_device *sci_dev, 289 struct isci_remote_device *idev,
290 struct isci_request *ireq); 290 struct isci_request *ireq);
291 291
292enum sci_status scic_sds_port_complete_io( 292enum sci_status scic_sds_port_complete_io(
293 struct isci_port *iport, 293 struct isci_port *iport,
294 struct scic_sds_remote_device *sci_dev, 294 struct isci_remote_device *idev,
295 struct isci_request *ireq); 295 struct isci_request *ireq);
296 296
297enum sas_linkrate scic_sds_port_get_max_allowed_speed( 297enum sas_linkrate scic_sds_port_get_max_allowed_speed(
diff --git a/drivers/scsi/isci/remote_device.c b/drivers/scsi/isci/remote_device.c
index 627cf731bad8..3b0234049a3d 100644
--- a/drivers/scsi/isci/remote_device.c
+++ b/drivers/scsi/isci/remote_device.c
@@ -93,7 +93,7 @@ static void isci_remote_device_not_ready(struct isci_host *ihost,
93 __func__, idev, ireq); 93 __func__, idev, ireq);
94 94
95 scic_controller_terminate_request(&ihost->sci, 95 scic_controller_terminate_request(&ihost->sci,
96 &idev->sci, 96 idev,
97 ireq); 97 ireq);
98 } 98 }
99 /* Fall through into the default case... */ 99 /* Fall through into the default case... */
@@ -127,15 +127,15 @@ static void isci_remote_device_ready(struct isci_host *ihost, struct isci_remote
127 */ 127 */
128static void rnc_destruct_done(void *_dev) 128static void rnc_destruct_done(void *_dev)
129{ 129{
130 struct scic_sds_remote_device *sci_dev = _dev; 130 struct isci_remote_device *idev = _dev;
131 131
132 BUG_ON(sci_dev->started_request_count != 0); 132 BUG_ON(idev->started_request_count != 0);
133 sci_change_state(&sci_dev->sm, SCI_DEV_STOPPED); 133 sci_change_state(&idev->sm, SCI_DEV_STOPPED);
134} 134}
135 135
136static enum sci_status scic_sds_remote_device_terminate_requests(struct scic_sds_remote_device *sci_dev) 136static enum sci_status scic_sds_remote_device_terminate_requests(struct isci_remote_device *idev)
137{ 137{
138 struct scic_sds_controller *scic = sci_dev->owning_port->owning_controller; 138 struct scic_sds_controller *scic = idev->owning_port->owning_controller;
139 struct isci_host *ihost = scic_to_ihost(scic); 139 struct isci_host *ihost = scic_to_ihost(scic);
140 enum sci_status status = SCI_SUCCESS; 140 enum sci_status status = SCI_SUCCESS;
141 u32 i; 141 u32 i;
@@ -145,10 +145,10 @@ static enum sci_status scic_sds_remote_device_terminate_requests(struct scic_sds
145 enum sci_status s; 145 enum sci_status s;
146 146
147 if (!test_bit(IREQ_ACTIVE, &ireq->flags) || 147 if (!test_bit(IREQ_ACTIVE, &ireq->flags) ||
148 ireq->target_device != sci_dev) 148 ireq->target_device != idev)
149 continue; 149 continue;
150 150
151 s = scic_controller_terminate_request(scic, sci_dev, ireq); 151 s = scic_controller_terminate_request(scic, idev, ireq);
152 if (s != SCI_SUCCESS) 152 if (s != SCI_SUCCESS)
153 status = s; 153 status = s;
154 } 154 }
@@ -156,10 +156,10 @@ static enum sci_status scic_sds_remote_device_terminate_requests(struct scic_sds
156 return status; 156 return status;
157} 157}
158 158
159enum sci_status scic_remote_device_stop(struct scic_sds_remote_device *sci_dev, 159enum sci_status scic_remote_device_stop(struct isci_remote_device *idev,
160 u32 timeout) 160 u32 timeout)
161{ 161{
162 struct sci_base_state_machine *sm = &sci_dev->sm; 162 struct sci_base_state_machine *sm = &idev->sm;
163 enum scic_sds_remote_device_states state = sm->current_state_id; 163 enum scic_sds_remote_device_states state = sm->current_state_id;
164 164
165 switch (state) { 165 switch (state) {
@@ -167,16 +167,16 @@ enum sci_status scic_remote_device_stop(struct scic_sds_remote_device *sci_dev,
167 case SCI_DEV_FAILED: 167 case SCI_DEV_FAILED:
168 case SCI_DEV_FINAL: 168 case SCI_DEV_FINAL:
169 default: 169 default:
170 dev_warn(scirdev_to_dev(sci_dev), "%s: in wrong state: %d\n", 170 dev_warn(scirdev_to_dev(idev), "%s: in wrong state: %d\n",
171 __func__, state); 171 __func__, state);
172 return SCI_FAILURE_INVALID_STATE; 172 return SCI_FAILURE_INVALID_STATE;
173 case SCI_DEV_STOPPED: 173 case SCI_DEV_STOPPED:
174 return SCI_SUCCESS; 174 return SCI_SUCCESS;
175 case SCI_DEV_STARTING: 175 case SCI_DEV_STARTING:
176 /* device not started so there had better be no requests */ 176 /* device not started so there had better be no requests */
177 BUG_ON(sci_dev->started_request_count != 0); 177 BUG_ON(idev->started_request_count != 0);
178 scic_sds_remote_node_context_destruct(&sci_dev->rnc, 178 scic_sds_remote_node_context_destruct(&idev->rnc,
179 rnc_destruct_done, sci_dev); 179 rnc_destruct_done, idev);
180 /* Transition to the stopping state and wait for the 180 /* Transition to the stopping state and wait for the
181 * remote node to complete being posted and invalidated. 181 * remote node to complete being posted and invalidated.
182 */ 182 */
@@ -191,28 +191,28 @@ enum sci_status scic_remote_device_stop(struct scic_sds_remote_device *sci_dev,
191 case SCI_SMP_DEV_IDLE: 191 case SCI_SMP_DEV_IDLE:
192 case SCI_SMP_DEV_CMD: 192 case SCI_SMP_DEV_CMD:
193 sci_change_state(sm, SCI_DEV_STOPPING); 193 sci_change_state(sm, SCI_DEV_STOPPING);
194 if (sci_dev->started_request_count == 0) { 194 if (idev->started_request_count == 0) {
195 scic_sds_remote_node_context_destruct(&sci_dev->rnc, 195 scic_sds_remote_node_context_destruct(&idev->rnc,
196 rnc_destruct_done, sci_dev); 196 rnc_destruct_done, idev);
197 return SCI_SUCCESS; 197 return SCI_SUCCESS;
198 } else 198 } else
199 return scic_sds_remote_device_terminate_requests(sci_dev); 199 return scic_sds_remote_device_terminate_requests(idev);
200 break; 200 break;
201 case SCI_DEV_STOPPING: 201 case SCI_DEV_STOPPING:
202 /* All requests should have been terminated, but if there is an 202 /* All requests should have been terminated, but if there is an
203 * attempt to stop a device already in the stopping state, then 203 * attempt to stop a device already in the stopping state, then
204 * try again to terminate. 204 * try again to terminate.
205 */ 205 */
206 return scic_sds_remote_device_terminate_requests(sci_dev); 206 return scic_sds_remote_device_terminate_requests(idev);
207 case SCI_DEV_RESETTING: 207 case SCI_DEV_RESETTING:
208 sci_change_state(sm, SCI_DEV_STOPPING); 208 sci_change_state(sm, SCI_DEV_STOPPING);
209 return SCI_SUCCESS; 209 return SCI_SUCCESS;
210 } 210 }
211} 211}
212 212
213enum sci_status scic_remote_device_reset(struct scic_sds_remote_device *sci_dev) 213enum sci_status scic_remote_device_reset(struct isci_remote_device *idev)
214{ 214{
215 struct sci_base_state_machine *sm = &sci_dev->sm; 215 struct sci_base_state_machine *sm = &idev->sm;
216 enum scic_sds_remote_device_states state = sm->current_state_id; 216 enum scic_sds_remote_device_states state = sm->current_state_id;
217 217
218 switch (state) { 218 switch (state) {
@@ -226,7 +226,7 @@ enum sci_status scic_remote_device_reset(struct scic_sds_remote_device *sci_dev)
226 case SCI_DEV_RESETTING: 226 case SCI_DEV_RESETTING:
227 case SCI_DEV_FINAL: 227 case SCI_DEV_FINAL:
228 default: 228 default:
229 dev_warn(scirdev_to_dev(sci_dev), "%s: in wrong state: %d\n", 229 dev_warn(scirdev_to_dev(idev), "%s: in wrong state: %d\n",
230 __func__, state); 230 __func__, state);
231 return SCI_FAILURE_INVALID_STATE; 231 return SCI_FAILURE_INVALID_STATE;
232 case SCI_DEV_READY: 232 case SCI_DEV_READY:
@@ -240,13 +240,13 @@ enum sci_status scic_remote_device_reset(struct scic_sds_remote_device *sci_dev)
240 } 240 }
241} 241}
242 242
243enum sci_status scic_remote_device_reset_complete(struct scic_sds_remote_device *sci_dev) 243enum sci_status scic_remote_device_reset_complete(struct isci_remote_device *idev)
244{ 244{
245 struct sci_base_state_machine *sm = &sci_dev->sm; 245 struct sci_base_state_machine *sm = &idev->sm;
246 enum scic_sds_remote_device_states state = sm->current_state_id; 246 enum scic_sds_remote_device_states state = sm->current_state_id;
247 247
248 if (state != SCI_DEV_RESETTING) { 248 if (state != SCI_DEV_RESETTING) {
249 dev_warn(scirdev_to_dev(sci_dev), "%s: in wrong state: %d\n", 249 dev_warn(scirdev_to_dev(idev), "%s: in wrong state: %d\n",
250 __func__, state); 250 __func__, state);
251 return SCI_FAILURE_INVALID_STATE; 251 return SCI_FAILURE_INVALID_STATE;
252 } 252 }
@@ -255,28 +255,28 @@ enum sci_status scic_remote_device_reset_complete(struct scic_sds_remote_device
255 return SCI_SUCCESS; 255 return SCI_SUCCESS;
256} 256}
257 257
258enum sci_status scic_sds_remote_device_suspend(struct scic_sds_remote_device *sci_dev, 258enum sci_status scic_sds_remote_device_suspend(struct isci_remote_device *idev,
259 u32 suspend_type) 259 u32 suspend_type)
260{ 260{
261 struct sci_base_state_machine *sm = &sci_dev->sm; 261 struct sci_base_state_machine *sm = &idev->sm;
262 enum scic_sds_remote_device_states state = sm->current_state_id; 262 enum scic_sds_remote_device_states state = sm->current_state_id;
263 263
264 if (state != SCI_STP_DEV_CMD) { 264 if (state != SCI_STP_DEV_CMD) {
265 dev_warn(scirdev_to_dev(sci_dev), "%s: in wrong state: %d\n", 265 dev_warn(scirdev_to_dev(idev), "%s: in wrong state: %d\n",
266 __func__, state); 266 __func__, state);
267 return SCI_FAILURE_INVALID_STATE; 267 return SCI_FAILURE_INVALID_STATE;
268 } 268 }
269 269
270 return scic_sds_remote_node_context_suspend(&sci_dev->rnc, 270 return scic_sds_remote_node_context_suspend(&idev->rnc,
271 suspend_type, NULL, NULL); 271 suspend_type, NULL, NULL);
272} 272}
273 273
274enum sci_status scic_sds_remote_device_frame_handler(struct scic_sds_remote_device *sci_dev, 274enum sci_status scic_sds_remote_device_frame_handler(struct isci_remote_device *idev,
275 u32 frame_index) 275 u32 frame_index)
276{ 276{
277 struct sci_base_state_machine *sm = &sci_dev->sm; 277 struct sci_base_state_machine *sm = &idev->sm;
278 enum scic_sds_remote_device_states state = sm->current_state_id; 278 enum scic_sds_remote_device_states state = sm->current_state_id;
279 struct scic_sds_controller *scic = sci_dev->owning_port->owning_controller; 279 struct scic_sds_controller *scic = idev->owning_port->owning_controller;
280 enum sci_status status; 280 enum sci_status status;
281 281
282 switch (state) { 282 switch (state) {
@@ -287,7 +287,7 @@ enum sci_status scic_sds_remote_device_frame_handler(struct scic_sds_remote_devi
287 case SCI_SMP_DEV_IDLE: 287 case SCI_SMP_DEV_IDLE:
288 case SCI_DEV_FINAL: 288 case SCI_DEV_FINAL:
289 default: 289 default:
290 dev_warn(scirdev_to_dev(sci_dev), "%s: in wrong state: %d\n", 290 dev_warn(scirdev_to_dev(idev), "%s: in wrong state: %d\n",
291 __func__, state); 291 __func__, state);
292 /* Return the frame back to the controller */ 292 /* Return the frame back to the controller */
293 scic_sds_controller_release_frame(scic, frame_index); 293 scic_sds_controller_release_frame(scic, frame_index);
@@ -313,7 +313,7 @@ enum sci_status scic_sds_remote_device_frame_handler(struct scic_sds_remote_devi
313 sci_swab32_cpy(&hdr, frame_header, word_cnt); 313 sci_swab32_cpy(&hdr, frame_header, word_cnt);
314 314
315 ireq = scic_request_by_tag(scic, be16_to_cpu(hdr.tag)); 315 ireq = scic_request_by_tag(scic, be16_to_cpu(hdr.tag));
316 if (ireq && ireq->target_device == sci_dev) { 316 if (ireq && ireq->target_device == idev) {
317 /* The IO request is now in charge of releasing the frame */ 317 /* The IO request is now in charge of releasing the frame */
318 status = scic_sds_io_request_frame_handler(ireq, frame_index); 318 status = scic_sds_io_request_frame_handler(ireq, frame_index);
319 } else { 319 } else {
@@ -335,7 +335,7 @@ enum sci_status scic_sds_remote_device_frame_handler(struct scic_sds_remote_devi
335 335
336 if (hdr->fis_type == FIS_SETDEVBITS && 336 if (hdr->fis_type == FIS_SETDEVBITS &&
337 (hdr->status & ATA_ERR)) { 337 (hdr->status & ATA_ERR)) {
338 sci_dev->not_ready_reason = SCIC_REMOTE_DEVICE_NOT_READY_SATA_SDB_ERROR_FIS_RECEIVED; 338 idev->not_ready_reason = SCIC_REMOTE_DEVICE_NOT_READY_SATA_SDB_ERROR_FIS_RECEIVED;
339 339
340 /* TODO Check sactive and complete associated IO if any. */ 340 /* TODO Check sactive and complete associated IO if any. */
341 sci_change_state(sm, SCI_STP_DEV_NCQ_ERROR); 341 sci_change_state(sm, SCI_STP_DEV_NCQ_ERROR);
@@ -345,8 +345,8 @@ enum sci_status scic_sds_remote_device_frame_handler(struct scic_sds_remote_devi
345 * Some devices return D2H FIS when an NCQ error is detected. 345 * Some devices return D2H FIS when an NCQ error is detected.
346 * Treat this like an SDB error FIS ready reason. 346 * Treat this like an SDB error FIS ready reason.
347 */ 347 */
348 sci_dev->not_ready_reason = SCIC_REMOTE_DEVICE_NOT_READY_SATA_SDB_ERROR_FIS_RECEIVED; 348 idev->not_ready_reason = SCIC_REMOTE_DEVICE_NOT_READY_SATA_SDB_ERROR_FIS_RECEIVED;
349 sci_change_state(&sci_dev->sm, SCI_STP_DEV_NCQ_ERROR); 349 sci_change_state(&idev->sm, SCI_STP_DEV_NCQ_ERROR);
350 } else 350 } else
351 status = SCI_FAILURE; 351 status = SCI_FAILURE;
352 352
@@ -359,17 +359,17 @@ enum sci_status scic_sds_remote_device_frame_handler(struct scic_sds_remote_devi
359 * in this state. All unsolicited frames are forwarded to the io request 359 * in this state. All unsolicited frames are forwarded to the io request
360 * object. 360 * object.
361 */ 361 */
362 status = scic_sds_io_request_frame_handler(sci_dev->working_request, frame_index); 362 status = scic_sds_io_request_frame_handler(idev->working_request, frame_index);
363 break; 363 break;
364 } 364 }
365 365
366 return status; 366 return status;
367} 367}
368 368
369static bool is_remote_device_ready(struct scic_sds_remote_device *sci_dev) 369static bool is_remote_device_ready(struct isci_remote_device *idev)
370{ 370{
371 371
372 struct sci_base_state_machine *sm = &sci_dev->sm; 372 struct sci_base_state_machine *sm = &idev->sm;
373 enum scic_sds_remote_device_states state = sm->current_state_id; 373 enum scic_sds_remote_device_states state = sm->current_state_id;
374 374
375 switch (state) { 375 switch (state) {
@@ -387,10 +387,10 @@ static bool is_remote_device_ready(struct scic_sds_remote_device *sci_dev)
387 } 387 }
388} 388}
389 389
390enum sci_status scic_sds_remote_device_event_handler(struct scic_sds_remote_device *sci_dev, 390enum sci_status scic_sds_remote_device_event_handler(struct isci_remote_device *idev,
391 u32 event_code) 391 u32 event_code)
392{ 392{
393 struct sci_base_state_machine *sm = &sci_dev->sm; 393 struct sci_base_state_machine *sm = &idev->sm;
394 enum scic_sds_remote_device_states state = sm->current_state_id; 394 enum scic_sds_remote_device_states state = sm->current_state_id;
395 enum sci_status status; 395 enum sci_status status;
396 396
@@ -398,21 +398,21 @@ enum sci_status scic_sds_remote_device_event_handler(struct scic_sds_remote_devi
398 case SCU_EVENT_TYPE_RNC_OPS_MISC: 398 case SCU_EVENT_TYPE_RNC_OPS_MISC:
399 case SCU_EVENT_TYPE_RNC_SUSPEND_TX: 399 case SCU_EVENT_TYPE_RNC_SUSPEND_TX:
400 case SCU_EVENT_TYPE_RNC_SUSPEND_TX_RX: 400 case SCU_EVENT_TYPE_RNC_SUSPEND_TX_RX:
401 status = scic_sds_remote_node_context_event_handler(&sci_dev->rnc, event_code); 401 status = scic_sds_remote_node_context_event_handler(&idev->rnc, event_code);
402 break; 402 break;
403 case SCU_EVENT_TYPE_PTX_SCHEDULE_EVENT: 403 case SCU_EVENT_TYPE_PTX_SCHEDULE_EVENT:
404 if (scu_get_event_code(event_code) == SCU_EVENT_IT_NEXUS_TIMEOUT) { 404 if (scu_get_event_code(event_code) == SCU_EVENT_IT_NEXUS_TIMEOUT) {
405 status = SCI_SUCCESS; 405 status = SCI_SUCCESS;
406 406
407 /* Suspend the associated RNC */ 407 /* Suspend the associated RNC */
408 scic_sds_remote_node_context_suspend(&sci_dev->rnc, 408 scic_sds_remote_node_context_suspend(&idev->rnc,
409 SCI_SOFTWARE_SUSPENSION, 409 SCI_SOFTWARE_SUSPENSION,
410 NULL, NULL); 410 NULL, NULL);
411 411
412 dev_dbg(scirdev_to_dev(sci_dev), 412 dev_dbg(scirdev_to_dev(idev),
413 "%s: device: %p event code: %x: %s\n", 413 "%s: device: %p event code: %x: %s\n",
414 __func__, sci_dev, event_code, 414 __func__, idev, event_code,
415 is_remote_device_ready(sci_dev) 415 is_remote_device_ready(idev)
416 ? "I_T_Nexus_Timeout event" 416 ? "I_T_Nexus_Timeout event"
417 : "I_T_Nexus_Timeout event in wrong state"); 417 : "I_T_Nexus_Timeout event in wrong state");
418 418
@@ -420,10 +420,10 @@ enum sci_status scic_sds_remote_device_event_handler(struct scic_sds_remote_devi
420 } 420 }
421 /* Else, fall through and treat as unhandled... */ 421 /* Else, fall through and treat as unhandled... */
422 default: 422 default:
423 dev_dbg(scirdev_to_dev(sci_dev), 423 dev_dbg(scirdev_to_dev(idev),
424 "%s: device: %p event code: %x: %s\n", 424 "%s: device: %p event code: %x: %s\n",
425 __func__, sci_dev, event_code, 425 __func__, idev, event_code,
426 is_remote_device_ready(sci_dev) 426 is_remote_device_ready(idev)
427 ? "unexpected event" 427 ? "unexpected event"
428 : "unexpected event in wrong state"); 428 : "unexpected event in wrong state");
429 status = SCI_FAILURE_INVALID_STATE; 429 status = SCI_FAILURE_INVALID_STATE;
@@ -440,34 +440,34 @@ enum sci_status scic_sds_remote_device_event_handler(struct scic_sds_remote_devi
440 */ 440 */
441 if (scu_get_event_type(event_code) == SCU_EVENT_TYPE_RNC_SUSPEND_TX || 441 if (scu_get_event_type(event_code) == SCU_EVENT_TYPE_RNC_SUSPEND_TX ||
442 scu_get_event_type(event_code) == SCU_EVENT_TYPE_RNC_SUSPEND_TX_RX) 442 scu_get_event_type(event_code) == SCU_EVENT_TYPE_RNC_SUSPEND_TX_RX)
443 status = scic_sds_remote_node_context_resume(&sci_dev->rnc, NULL, NULL); 443 status = scic_sds_remote_node_context_resume(&idev->rnc, NULL, NULL);
444 } 444 }
445 445
446 return status; 446 return status;
447} 447}
448 448
449static void scic_sds_remote_device_start_request(struct scic_sds_remote_device *sci_dev, 449static void scic_sds_remote_device_start_request(struct isci_remote_device *idev,
450 struct isci_request *ireq, 450 struct isci_request *ireq,
451 enum sci_status status) 451 enum sci_status status)
452{ 452{
453 struct isci_port *iport = sci_dev->owning_port; 453 struct isci_port *iport = idev->owning_port;
454 454
455 /* cleanup requests that failed after starting on the port */ 455 /* cleanup requests that failed after starting on the port */
456 if (status != SCI_SUCCESS) 456 if (status != SCI_SUCCESS)
457 scic_sds_port_complete_io(iport, sci_dev, ireq); 457 scic_sds_port_complete_io(iport, idev, ireq);
458 else { 458 else {
459 kref_get(&sci_dev_to_idev(sci_dev)->kref); 459 kref_get(&idev->kref);
460 scic_sds_remote_device_increment_request_count(sci_dev); 460 scic_sds_remote_device_increment_request_count(idev);
461 } 461 }
462} 462}
463 463
464enum sci_status scic_sds_remote_device_start_io(struct scic_sds_controller *scic, 464enum sci_status scic_sds_remote_device_start_io(struct scic_sds_controller *scic,
465 struct scic_sds_remote_device *sci_dev, 465 struct isci_remote_device *idev,
466 struct isci_request *ireq) 466 struct isci_request *ireq)
467{ 467{
468 struct sci_base_state_machine *sm = &sci_dev->sm; 468 struct sci_base_state_machine *sm = &idev->sm;
469 enum scic_sds_remote_device_states state = sm->current_state_id; 469 enum scic_sds_remote_device_states state = sm->current_state_id;
470 struct isci_port *iport = sci_dev->owning_port; 470 struct isci_port *iport = idev->owning_port;
471 enum sci_status status; 471 enum sci_status status;
472 472
473 switch (state) { 473 switch (state) {
@@ -480,7 +480,7 @@ enum sci_status scic_sds_remote_device_start_io(struct scic_sds_controller *scic
480 case SCI_DEV_RESETTING: 480 case SCI_DEV_RESETTING:
481 case SCI_DEV_FINAL: 481 case SCI_DEV_FINAL:
482 default: 482 default:
483 dev_warn(scirdev_to_dev(sci_dev), "%s: in wrong state: %d\n", 483 dev_warn(scirdev_to_dev(idev), "%s: in wrong state: %d\n",
484 __func__, state); 484 __func__, state);
485 return SCI_FAILURE_INVALID_STATE; 485 return SCI_FAILURE_INVALID_STATE;
486 case SCI_DEV_READY: 486 case SCI_DEV_READY:
@@ -489,11 +489,11 @@ enum sci_status scic_sds_remote_device_start_io(struct scic_sds_controller *scic
489 * successful it will start the request for the port object then 489 * successful it will start the request for the port object then
490 * increment its own request count. 490 * increment its own request count.
491 */ 491 */
492 status = scic_sds_port_start_io(iport, sci_dev, ireq); 492 status = scic_sds_port_start_io(iport, idev, ireq);
493 if (status != SCI_SUCCESS) 493 if (status != SCI_SUCCESS)
494 return status; 494 return status;
495 495
496 status = scic_sds_remote_node_context_start_io(&sci_dev->rnc, ireq); 496 status = scic_sds_remote_node_context_start_io(&idev->rnc, ireq);
497 if (status != SCI_SUCCESS) 497 if (status != SCI_SUCCESS)
498 break; 498 break;
499 499
@@ -511,11 +511,11 @@ enum sci_status scic_sds_remote_device_start_io(struct scic_sds_controller *scic
511 enum scic_sds_remote_device_states new_state; 511 enum scic_sds_remote_device_states new_state;
512 struct sas_task *task = isci_request_access_task(ireq); 512 struct sas_task *task = isci_request_access_task(ireq);
513 513
514 status = scic_sds_port_start_io(iport, sci_dev, ireq); 514 status = scic_sds_port_start_io(iport, idev, ireq);
515 if (status != SCI_SUCCESS) 515 if (status != SCI_SUCCESS)
516 return status; 516 return status;
517 517
518 status = scic_sds_remote_node_context_start_io(&sci_dev->rnc, ireq); 518 status = scic_sds_remote_node_context_start_io(&idev->rnc, ireq);
519 if (status != SCI_SUCCESS) 519 if (status != SCI_SUCCESS)
520 break; 520 break;
521 521
@@ -526,7 +526,7 @@ enum sci_status scic_sds_remote_device_start_io(struct scic_sds_controller *scic
526 if (task->ata_task.use_ncq) 526 if (task->ata_task.use_ncq)
527 new_state = SCI_STP_DEV_NCQ; 527 new_state = SCI_STP_DEV_NCQ;
528 else { 528 else {
529 sci_dev->working_request = ireq; 529 idev->working_request = ireq;
530 new_state = SCI_STP_DEV_CMD; 530 new_state = SCI_STP_DEV_CMD;
531 } 531 }
532 sci_change_state(sm, new_state); 532 sci_change_state(sm, new_state);
@@ -536,11 +536,11 @@ enum sci_status scic_sds_remote_device_start_io(struct scic_sds_controller *scic
536 struct sas_task *task = isci_request_access_task(ireq); 536 struct sas_task *task = isci_request_access_task(ireq);
537 537
538 if (task->ata_task.use_ncq) { 538 if (task->ata_task.use_ncq) {
539 status = scic_sds_port_start_io(iport, sci_dev, ireq); 539 status = scic_sds_port_start_io(iport, idev, ireq);
540 if (status != SCI_SUCCESS) 540 if (status != SCI_SUCCESS)
541 return status; 541 return status;
542 542
543 status = scic_sds_remote_node_context_start_io(&sci_dev->rnc, ireq); 543 status = scic_sds_remote_node_context_start_io(&idev->rnc, ireq);
544 if (status != SCI_SUCCESS) 544 if (status != SCI_SUCCESS)
545 break; 545 break;
546 546
@@ -552,11 +552,11 @@ enum sci_status scic_sds_remote_device_start_io(struct scic_sds_controller *scic
552 case SCI_STP_DEV_AWAIT_RESET: 552 case SCI_STP_DEV_AWAIT_RESET:
553 return SCI_FAILURE_REMOTE_DEVICE_RESET_REQUIRED; 553 return SCI_FAILURE_REMOTE_DEVICE_RESET_REQUIRED;
554 case SCI_SMP_DEV_IDLE: 554 case SCI_SMP_DEV_IDLE:
555 status = scic_sds_port_start_io(iport, sci_dev, ireq); 555 status = scic_sds_port_start_io(iport, idev, ireq);
556 if (status != SCI_SUCCESS) 556 if (status != SCI_SUCCESS)
557 return status; 557 return status;
558 558
559 status = scic_sds_remote_node_context_start_io(&sci_dev->rnc, ireq); 559 status = scic_sds_remote_node_context_start_io(&idev->rnc, ireq);
560 if (status != SCI_SUCCESS) 560 if (status != SCI_SUCCESS)
561 break; 561 break;
562 562
@@ -564,8 +564,8 @@ enum sci_status scic_sds_remote_device_start_io(struct scic_sds_controller *scic
564 if (status != SCI_SUCCESS) 564 if (status != SCI_SUCCESS)
565 break; 565 break;
566 566
567 sci_dev->working_request = ireq; 567 idev->working_request = ireq;
568 sci_change_state(&sci_dev->sm, SCI_SMP_DEV_CMD); 568 sci_change_state(&idev->sm, SCI_SMP_DEV_CMD);
569 break; 569 break;
570 case SCI_STP_DEV_CMD: 570 case SCI_STP_DEV_CMD:
571 case SCI_SMP_DEV_CMD: 571 case SCI_SMP_DEV_CMD:
@@ -575,12 +575,12 @@ enum sci_status scic_sds_remote_device_start_io(struct scic_sds_controller *scic
575 return SCI_FAILURE_INVALID_STATE; 575 return SCI_FAILURE_INVALID_STATE;
576 } 576 }
577 577
578 scic_sds_remote_device_start_request(sci_dev, ireq, status); 578 scic_sds_remote_device_start_request(idev, ireq, status);
579 return status; 579 return status;
580} 580}
581 581
582static enum sci_status common_complete_io(struct isci_port *iport, 582static enum sci_status common_complete_io(struct isci_port *iport,
583 struct scic_sds_remote_device *sci_dev, 583 struct isci_remote_device *idev,
584 struct isci_request *ireq) 584 struct isci_request *ireq)
585{ 585{
586 enum sci_status status; 586 enum sci_status status;
@@ -589,21 +589,21 @@ static enum sci_status common_complete_io(struct isci_port *iport,
589 if (status != SCI_SUCCESS) 589 if (status != SCI_SUCCESS)
590 return status; 590 return status;
591 591
592 status = scic_sds_port_complete_io(iport, sci_dev, ireq); 592 status = scic_sds_port_complete_io(iport, idev, ireq);
593 if (status != SCI_SUCCESS) 593 if (status != SCI_SUCCESS)
594 return status; 594 return status;
595 595
596 scic_sds_remote_device_decrement_request_count(sci_dev); 596 scic_sds_remote_device_decrement_request_count(idev);
597 return status; 597 return status;
598} 598}
599 599
600enum sci_status scic_sds_remote_device_complete_io(struct scic_sds_controller *scic, 600enum sci_status scic_sds_remote_device_complete_io(struct scic_sds_controller *scic,
601 struct scic_sds_remote_device *sci_dev, 601 struct isci_remote_device *idev,
602 struct isci_request *ireq) 602 struct isci_request *ireq)
603{ 603{
604 struct sci_base_state_machine *sm = &sci_dev->sm; 604 struct sci_base_state_machine *sm = &idev->sm;
605 enum scic_sds_remote_device_states state = sm->current_state_id; 605 enum scic_sds_remote_device_states state = sm->current_state_id;
606 struct isci_port *iport = sci_dev->owning_port; 606 struct isci_port *iport = idev->owning_port;
607 enum sci_status status; 607 enum sci_status status;
608 608
609 switch (state) { 609 switch (state) {
@@ -615,18 +615,18 @@ enum sci_status scic_sds_remote_device_complete_io(struct scic_sds_controller *s
615 case SCI_DEV_FAILED: 615 case SCI_DEV_FAILED:
616 case SCI_DEV_FINAL: 616 case SCI_DEV_FINAL:
617 default: 617 default:
618 dev_warn(scirdev_to_dev(sci_dev), "%s: in wrong state: %d\n", 618 dev_warn(scirdev_to_dev(idev), "%s: in wrong state: %d\n",
619 __func__, state); 619 __func__, state);
620 return SCI_FAILURE_INVALID_STATE; 620 return SCI_FAILURE_INVALID_STATE;
621 case SCI_DEV_READY: 621 case SCI_DEV_READY:
622 case SCI_STP_DEV_AWAIT_RESET: 622 case SCI_STP_DEV_AWAIT_RESET:
623 case SCI_DEV_RESETTING: 623 case SCI_DEV_RESETTING:
624 status = common_complete_io(iport, sci_dev, ireq); 624 status = common_complete_io(iport, idev, ireq);
625 break; 625 break;
626 case SCI_STP_DEV_CMD: 626 case SCI_STP_DEV_CMD:
627 case SCI_STP_DEV_NCQ: 627 case SCI_STP_DEV_NCQ:
628 case SCI_STP_DEV_NCQ_ERROR: 628 case SCI_STP_DEV_NCQ_ERROR:
629 status = common_complete_io(iport, sci_dev, ireq); 629 status = common_complete_io(iport, idev, ireq);
630 if (status != SCI_SUCCESS) 630 if (status != SCI_SUCCESS)
631 break; 631 break;
632 632
@@ -637,54 +637,54 @@ enum sci_status scic_sds_remote_device_complete_io(struct scic_sds_controller *s
637 * status of "DEVICE_RESET_REQUIRED", instead of "INVALID STATE". 637 * status of "DEVICE_RESET_REQUIRED", instead of "INVALID STATE".
638 */ 638 */
639 sci_change_state(sm, SCI_STP_DEV_AWAIT_RESET); 639 sci_change_state(sm, SCI_STP_DEV_AWAIT_RESET);
640 } else if (scic_sds_remote_device_get_request_count(sci_dev) == 0) 640 } else if (scic_sds_remote_device_get_request_count(idev) == 0)
641 sci_change_state(sm, SCI_STP_DEV_IDLE); 641 sci_change_state(sm, SCI_STP_DEV_IDLE);
642 break; 642 break;
643 case SCI_SMP_DEV_CMD: 643 case SCI_SMP_DEV_CMD:
644 status = common_complete_io(iport, sci_dev, ireq); 644 status = common_complete_io(iport, idev, ireq);
645 if (status != SCI_SUCCESS) 645 if (status != SCI_SUCCESS)
646 break; 646 break;
647 sci_change_state(sm, SCI_SMP_DEV_IDLE); 647 sci_change_state(sm, SCI_SMP_DEV_IDLE);
648 break; 648 break;
649 case SCI_DEV_STOPPING: 649 case SCI_DEV_STOPPING:
650 status = common_complete_io(iport, sci_dev, ireq); 650 status = common_complete_io(iport, idev, ireq);
651 if (status != SCI_SUCCESS) 651 if (status != SCI_SUCCESS)
652 break; 652 break;
653 653
654 if (scic_sds_remote_device_get_request_count(sci_dev) == 0) 654 if (scic_sds_remote_device_get_request_count(idev) == 0)
655 scic_sds_remote_node_context_destruct(&sci_dev->rnc, 655 scic_sds_remote_node_context_destruct(&idev->rnc,
656 rnc_destruct_done, 656 rnc_destruct_done,
657 sci_dev); 657 idev);
658 break; 658 break;
659 } 659 }
660 660
661 if (status != SCI_SUCCESS) 661 if (status != SCI_SUCCESS)
662 dev_err(scirdev_to_dev(sci_dev), 662 dev_err(scirdev_to_dev(idev),
663 "%s: Port:0x%p Device:0x%p Request:0x%p Status:0x%x " 663 "%s: Port:0x%p Device:0x%p Request:0x%p Status:0x%x "
664 "could not complete\n", __func__, iport, 664 "could not complete\n", __func__, iport,
665 sci_dev, ireq, status); 665 idev, ireq, status);
666 else 666 else
667 isci_put_device(sci_dev_to_idev(sci_dev)); 667 isci_put_device(idev);
668 668
669 return status; 669 return status;
670} 670}
671 671
672static void scic_sds_remote_device_continue_request(void *dev) 672static void scic_sds_remote_device_continue_request(void *dev)
673{ 673{
674 struct scic_sds_remote_device *sci_dev = dev; 674 struct isci_remote_device *idev = dev;
675 675
676 /* we need to check if this request is still valid to continue. */ 676 /* we need to check if this request is still valid to continue. */
677 if (sci_dev->working_request) 677 if (idev->working_request)
678 scic_controller_continue_io(sci_dev->working_request); 678 scic_controller_continue_io(idev->working_request);
679} 679}
680 680
681enum sci_status scic_sds_remote_device_start_task(struct scic_sds_controller *scic, 681enum sci_status scic_sds_remote_device_start_task(struct scic_sds_controller *scic,
682 struct scic_sds_remote_device *sci_dev, 682 struct isci_remote_device *idev,
683 struct isci_request *ireq) 683 struct isci_request *ireq)
684{ 684{
685 struct sci_base_state_machine *sm = &sci_dev->sm; 685 struct sci_base_state_machine *sm = &idev->sm;
686 enum scic_sds_remote_device_states state = sm->current_state_id; 686 enum scic_sds_remote_device_states state = sm->current_state_id;
687 struct isci_port *iport = sci_dev->owning_port; 687 struct isci_port *iport = idev->owning_port;
688 enum sci_status status; 688 enum sci_status status;
689 689
690 switch (state) { 690 switch (state) {
@@ -698,7 +698,7 @@ enum sci_status scic_sds_remote_device_start_task(struct scic_sds_controller *sc
698 case SCI_DEV_RESETTING: 698 case SCI_DEV_RESETTING:
699 case SCI_DEV_FINAL: 699 case SCI_DEV_FINAL:
700 default: 700 default:
701 dev_warn(scirdev_to_dev(sci_dev), "%s: in wrong state: %d\n", 701 dev_warn(scirdev_to_dev(idev), "%s: in wrong state: %d\n",
702 __func__, state); 702 __func__, state);
703 return SCI_FAILURE_INVALID_STATE; 703 return SCI_FAILURE_INVALID_STATE;
704 case SCI_STP_DEV_IDLE: 704 case SCI_STP_DEV_IDLE:
@@ -706,11 +706,11 @@ enum sci_status scic_sds_remote_device_start_task(struct scic_sds_controller *sc
706 case SCI_STP_DEV_NCQ: 706 case SCI_STP_DEV_NCQ:
707 case SCI_STP_DEV_NCQ_ERROR: 707 case SCI_STP_DEV_NCQ_ERROR:
708 case SCI_STP_DEV_AWAIT_RESET: 708 case SCI_STP_DEV_AWAIT_RESET:
709 status = scic_sds_port_start_io(iport, sci_dev, ireq); 709 status = scic_sds_port_start_io(iport, idev, ireq);
710 if (status != SCI_SUCCESS) 710 if (status != SCI_SUCCESS)
711 return status; 711 return status;
712 712
713 status = scic_sds_remote_node_context_start_task(&sci_dev->rnc, ireq); 713 status = scic_sds_remote_node_context_start_task(&idev->rnc, ireq);
714 if (status != SCI_SUCCESS) 714 if (status != SCI_SUCCESS)
715 goto out; 715 goto out;
716 716
@@ -722,7 +722,7 @@ enum sci_status scic_sds_remote_device_start_task(struct scic_sds_controller *sc
722 * replace the request that probably resulted in the task 722 * replace the request that probably resulted in the task
723 * management request. 723 * management request.
724 */ 724 */
725 sci_dev->working_request = ireq; 725 idev->working_request = ireq;
726 sci_change_state(sm, SCI_STP_DEV_CMD); 726 sci_change_state(sm, SCI_STP_DEV_CMD);
727 727
728 /* The remote node context must cleanup the TCi to NCQ mapping 728 /* The remote node context must cleanup the TCi to NCQ mapping
@@ -732,32 +732,32 @@ enum sci_status scic_sds_remote_device_start_task(struct scic_sds_controller *sc
732 * the correct action when the remote node context is suspended 732 * the correct action when the remote node context is suspended
733 * and later resumed. 733 * and later resumed.
734 */ 734 */
735 scic_sds_remote_node_context_suspend(&sci_dev->rnc, 735 scic_sds_remote_node_context_suspend(&idev->rnc,
736 SCI_SOFTWARE_SUSPENSION, NULL, NULL); 736 SCI_SOFTWARE_SUSPENSION, NULL, NULL);
737 scic_sds_remote_node_context_resume(&sci_dev->rnc, 737 scic_sds_remote_node_context_resume(&idev->rnc,
738 scic_sds_remote_device_continue_request, 738 scic_sds_remote_device_continue_request,
739 sci_dev); 739 idev);
740 740
741 out: 741 out:
742 scic_sds_remote_device_start_request(sci_dev, ireq, status); 742 scic_sds_remote_device_start_request(idev, ireq, status);
743 /* We need to let the controller start request handler know that 743 /* We need to let the controller start request handler know that
744 * it can't post TC yet. We will provide a callback function to 744 * it can't post TC yet. We will provide a callback function to
745 * post TC when RNC gets resumed. 745 * post TC when RNC gets resumed.
746 */ 746 */
747 return SCI_FAILURE_RESET_DEVICE_PARTIAL_SUCCESS; 747 return SCI_FAILURE_RESET_DEVICE_PARTIAL_SUCCESS;
748 case SCI_DEV_READY: 748 case SCI_DEV_READY:
749 status = scic_sds_port_start_io(iport, sci_dev, ireq); 749 status = scic_sds_port_start_io(iport, idev, ireq);
750 if (status != SCI_SUCCESS) 750 if (status != SCI_SUCCESS)
751 return status; 751 return status;
752 752
753 status = scic_sds_remote_node_context_start_task(&sci_dev->rnc, ireq); 753 status = scic_sds_remote_node_context_start_task(&idev->rnc, ireq);
754 if (status != SCI_SUCCESS) 754 if (status != SCI_SUCCESS)
755 break; 755 break;
756 756
757 status = scic_sds_request_start(ireq); 757 status = scic_sds_request_start(ireq);
758 break; 758 break;
759 } 759 }
760 scic_sds_remote_device_start_request(sci_dev, ireq, status); 760 scic_sds_remote_device_start_request(idev, ireq, status);
761 761
762 return status; 762 return status;
763} 763}
@@ -771,15 +771,15 @@ enum sci_status scic_sds_remote_device_start_task(struct scic_sds_controller *sc
771 * request and then requests the controller to post the request. none 771 * request and then requests the controller to post the request. none
772 */ 772 */
773void scic_sds_remote_device_post_request( 773void scic_sds_remote_device_post_request(
774 struct scic_sds_remote_device *sci_dev, 774 struct isci_remote_device *idev,
775 u32 request) 775 u32 request)
776{ 776{
777 u32 context; 777 u32 context;
778 778
779 context = scic_sds_remote_device_build_command_context(sci_dev, request); 779 context = scic_sds_remote_device_build_command_context(idev, request);
780 780
781 scic_sds_controller_post_request( 781 scic_sds_controller_post_request(
782 scic_sds_remote_device_get_controller(sci_dev), 782 scic_sds_remote_device_get_controller(idev),
783 context 783 context
784 ); 784 );
785} 785}
@@ -790,34 +790,33 @@ void scic_sds_remote_device_post_request(
790 */ 790 */
791static void remote_device_resume_done(void *_dev) 791static void remote_device_resume_done(void *_dev)
792{ 792{
793 struct scic_sds_remote_device *sci_dev = _dev; 793 struct isci_remote_device *idev = _dev;
794 794
795 if (is_remote_device_ready(sci_dev)) 795 if (is_remote_device_ready(idev))
796 return; 796 return;
797 797
798 /* go 'ready' if we are not already in a ready state */ 798 /* go 'ready' if we are not already in a ready state */
799 sci_change_state(&sci_dev->sm, SCI_DEV_READY); 799 sci_change_state(&idev->sm, SCI_DEV_READY);
800} 800}
801 801
802static void scic_sds_stp_remote_device_ready_idle_substate_resume_complete_handler(void *_dev) 802static void scic_sds_stp_remote_device_ready_idle_substate_resume_complete_handler(void *_dev)
803{ 803{
804 struct scic_sds_remote_device *sci_dev = _dev; 804 struct isci_remote_device *idev = _dev;
805 struct isci_remote_device *idev = sci_dev_to_idev(sci_dev); 805 struct scic_sds_controller *scic = idev->owning_port->owning_controller;
806 struct scic_sds_controller *scic = sci_dev->owning_port->owning_controller;
807 806
808 /* For NCQ operation we do not issue a isci_remote_device_not_ready(). 807 /* For NCQ operation we do not issue a isci_remote_device_not_ready().
809 * As a result, avoid sending the ready notification. 808 * As a result, avoid sending the ready notification.
810 */ 809 */
811 if (sci_dev->sm.previous_state_id != SCI_STP_DEV_NCQ) 810 if (idev->sm.previous_state_id != SCI_STP_DEV_NCQ)
812 isci_remote_device_ready(scic_to_ihost(scic), idev); 811 isci_remote_device_ready(scic_to_ihost(scic), idev);
813} 812}
814 813
815static void scic_sds_remote_device_initial_state_enter(struct sci_base_state_machine *sm) 814static void scic_sds_remote_device_initial_state_enter(struct sci_base_state_machine *sm)
816{ 815{
817 struct scic_sds_remote_device *sci_dev = container_of(sm, typeof(*sci_dev), sm); 816 struct isci_remote_device *idev = container_of(sm, typeof(*idev), sm);
818 817
819 /* Initial state is a transitional state to the stopped state */ 818 /* Initial state is a transitional state to the stopped state */
820 sci_change_state(&sci_dev->sm, SCI_DEV_STOPPED); 819 sci_change_state(&idev->sm, SCI_DEV_STOPPED);
821} 820}
822 821
823/** 822/**
@@ -833,22 +832,22 @@ static void scic_sds_remote_device_initial_state_enter(struct sci_base_state_mac
833 * device isn't valid (e.g. it's already been destoryed, the handle isn't 832 * device isn't valid (e.g. it's already been destoryed, the handle isn't
834 * valid, etc.). 833 * valid, etc.).
835 */ 834 */
836static enum sci_status scic_remote_device_destruct(struct scic_sds_remote_device *sci_dev) 835static enum sci_status scic_remote_device_destruct(struct isci_remote_device *idev)
837{ 836{
838 struct sci_base_state_machine *sm = &sci_dev->sm; 837 struct sci_base_state_machine *sm = &idev->sm;
839 enum scic_sds_remote_device_states state = sm->current_state_id; 838 enum scic_sds_remote_device_states state = sm->current_state_id;
840 struct scic_sds_controller *scic; 839 struct scic_sds_controller *scic;
841 840
842 if (state != SCI_DEV_STOPPED) { 841 if (state != SCI_DEV_STOPPED) {
843 dev_warn(scirdev_to_dev(sci_dev), "%s: in wrong state: %d\n", 842 dev_warn(scirdev_to_dev(idev), "%s: in wrong state: %d\n",
844 __func__, state); 843 __func__, state);
845 return SCI_FAILURE_INVALID_STATE; 844 return SCI_FAILURE_INVALID_STATE;
846 } 845 }
847 846
848 scic = sci_dev->owning_port->owning_controller; 847 scic = idev->owning_port->owning_controller;
849 scic_sds_controller_free_remote_node_context(scic, sci_dev, 848 scic_sds_controller_free_remote_node_context(scic, idev,
850 sci_dev->rnc.remote_node_index); 849 idev->rnc.remote_node_index);
851 sci_dev->rnc.remote_node_index = SCIC_SDS_REMOTE_NODE_CONTEXT_INVALID_INDEX; 850 idev->rnc.remote_node_index = SCIC_SDS_REMOTE_NODE_CONTEXT_INVALID_INDEX;
852 sci_change_state(sm, SCI_DEV_FINAL); 851 sci_change_state(sm, SCI_DEV_FINAL);
853 852
854 return SCI_SUCCESS; 853 return SCI_SUCCESS;
@@ -871,34 +870,32 @@ static void isci_remote_device_deconstruct(struct isci_host *ihost, struct isci_
871 * io requests in process */ 870 * io requests in process */
872 BUG_ON(!list_empty(&idev->reqs_in_process)); 871 BUG_ON(!list_empty(&idev->reqs_in_process));
873 872
874 scic_remote_device_destruct(&idev->sci); 873 scic_remote_device_destruct(idev);
875 list_del_init(&idev->node); 874 list_del_init(&idev->node);
876 isci_put_device(idev); 875 isci_put_device(idev);
877} 876}
878 877
879static void scic_sds_remote_device_stopped_state_enter(struct sci_base_state_machine *sm) 878static void scic_sds_remote_device_stopped_state_enter(struct sci_base_state_machine *sm)
880{ 879{
881 struct scic_sds_remote_device *sci_dev = container_of(sm, typeof(*sci_dev), sm); 880 struct isci_remote_device *idev = container_of(sm, typeof(*idev), sm);
882 struct scic_sds_controller *scic = sci_dev->owning_port->owning_controller; 881 struct scic_sds_controller *scic = idev->owning_port->owning_controller;
883 struct isci_remote_device *idev = sci_dev_to_idev(sci_dev);
884 u32 prev_state; 882 u32 prev_state;
885 883
886 /* If we are entering from the stopping state let the SCI User know that 884 /* If we are entering from the stopping state let the SCI User know that
887 * the stop operation has completed. 885 * the stop operation has completed.
888 */ 886 */
889 prev_state = sci_dev->sm.previous_state_id; 887 prev_state = idev->sm.previous_state_id;
890 if (prev_state == SCI_DEV_STOPPING) 888 if (prev_state == SCI_DEV_STOPPING)
891 isci_remote_device_deconstruct(scic_to_ihost(scic), idev); 889 isci_remote_device_deconstruct(scic_to_ihost(scic), idev);
892 890
893 scic_sds_controller_remote_device_stopped(scic, sci_dev); 891 scic_sds_controller_remote_device_stopped(scic, idev);
894} 892}
895 893
896static void scic_sds_remote_device_starting_state_enter(struct sci_base_state_machine *sm) 894static void scic_sds_remote_device_starting_state_enter(struct sci_base_state_machine *sm)
897{ 895{
898 struct scic_sds_remote_device *sci_dev = container_of(sm, typeof(*sci_dev), sm); 896 struct isci_remote_device *idev = container_of(sm, typeof(*idev), sm);
899 struct scic_sds_controller *scic = scic_sds_remote_device_get_controller(sci_dev); 897 struct scic_sds_controller *scic = scic_sds_remote_device_get_controller(idev);
900 struct isci_host *ihost = scic_to_ihost(scic); 898 struct isci_host *ihost = scic_to_ihost(scic);
901 struct isci_remote_device *idev = sci_dev_to_idev(sci_dev);
902 899
903 isci_remote_device_not_ready(ihost, idev, 900 isci_remote_device_not_ready(ihost, idev,
904 SCIC_REMOTE_DEVICE_NOT_READY_START_REQUESTED); 901 SCIC_REMOTE_DEVICE_NOT_READY_START_REQUESTED);
@@ -906,27 +903,25 @@ static void scic_sds_remote_device_starting_state_enter(struct sci_base_state_ma
906 903
907static void scic_sds_remote_device_ready_state_enter(struct sci_base_state_machine *sm) 904static void scic_sds_remote_device_ready_state_enter(struct sci_base_state_machine *sm)
908{ 905{
909 struct scic_sds_remote_device *sci_dev = container_of(sm, typeof(*sci_dev), sm); 906 struct isci_remote_device *idev = container_of(sm, typeof(*idev), sm);
910 struct scic_sds_controller *scic = sci_dev->owning_port->owning_controller; 907 struct scic_sds_controller *scic = idev->owning_port->owning_controller;
911 struct isci_remote_device *idev = sci_dev_to_idev(sci_dev);
912 struct domain_device *dev = idev->domain_dev; 908 struct domain_device *dev = idev->domain_dev;
913 909
914 if (dev->dev_type == SATA_DEV || (dev->tproto & SAS_PROTOCOL_SATA)) { 910 if (dev->dev_type == SATA_DEV || (dev->tproto & SAS_PROTOCOL_SATA)) {
915 sci_change_state(&sci_dev->sm, SCI_STP_DEV_IDLE); 911 sci_change_state(&idev->sm, SCI_STP_DEV_IDLE);
916 } else if (dev_is_expander(dev)) { 912 } else if (dev_is_expander(dev)) {
917 sci_change_state(&sci_dev->sm, SCI_SMP_DEV_IDLE); 913 sci_change_state(&idev->sm, SCI_SMP_DEV_IDLE);
918 } else 914 } else
919 isci_remote_device_ready(scic_to_ihost(scic), idev); 915 isci_remote_device_ready(scic_to_ihost(scic), idev);
920} 916}
921 917
922static void scic_sds_remote_device_ready_state_exit(struct sci_base_state_machine *sm) 918static void scic_sds_remote_device_ready_state_exit(struct sci_base_state_machine *sm)
923{ 919{
924 struct scic_sds_remote_device *sci_dev = container_of(sm, typeof(*sci_dev), sm); 920 struct isci_remote_device *idev = container_of(sm, typeof(*idev), sm);
925 struct domain_device *dev = sci_dev_to_domain(sci_dev); 921 struct domain_device *dev = idev->domain_dev;
926 922
927 if (dev->dev_type == SAS_END_DEV) { 923 if (dev->dev_type == SAS_END_DEV) {
928 struct scic_sds_controller *scic = sci_dev->owning_port->owning_controller; 924 struct scic_sds_controller *scic = idev->owning_port->owning_controller;
929 struct isci_remote_device *idev = sci_dev_to_idev(sci_dev);
930 925
931 isci_remote_device_not_ready(scic_to_ihost(scic), idev, 926 isci_remote_device_not_ready(scic_to_ihost(scic), idev,
932 SCIC_REMOTE_DEVICE_NOT_READY_STOP_REQUESTED); 927 SCIC_REMOTE_DEVICE_NOT_READY_STOP_REQUESTED);
@@ -935,82 +930,81 @@ static void scic_sds_remote_device_ready_state_exit(struct sci_base_state_machin
935 930
936static void scic_sds_remote_device_resetting_state_enter(struct sci_base_state_machine *sm) 931static void scic_sds_remote_device_resetting_state_enter(struct sci_base_state_machine *sm)
937{ 932{
938 struct scic_sds_remote_device *sci_dev = container_of(sm, typeof(*sci_dev), sm); 933 struct isci_remote_device *idev = container_of(sm, typeof(*idev), sm);
939 934
940 scic_sds_remote_node_context_suspend( 935 scic_sds_remote_node_context_suspend(
941 &sci_dev->rnc, SCI_SOFTWARE_SUSPENSION, NULL, NULL); 936 &idev->rnc, SCI_SOFTWARE_SUSPENSION, NULL, NULL);
942} 937}
943 938
944static void scic_sds_remote_device_resetting_state_exit(struct sci_base_state_machine *sm) 939static void scic_sds_remote_device_resetting_state_exit(struct sci_base_state_machine *sm)
945{ 940{
946 struct scic_sds_remote_device *sci_dev = container_of(sm, typeof(*sci_dev), sm); 941 struct isci_remote_device *idev = container_of(sm, typeof(*idev), sm);
947 942
948 scic_sds_remote_node_context_resume(&sci_dev->rnc, NULL, NULL); 943 scic_sds_remote_node_context_resume(&idev->rnc, NULL, NULL);
949} 944}
950 945
951static void scic_sds_stp_remote_device_ready_idle_substate_enter(struct sci_base_state_machine *sm) 946static void scic_sds_stp_remote_device_ready_idle_substate_enter(struct sci_base_state_machine *sm)
952{ 947{
953 struct scic_sds_remote_device *sci_dev = container_of(sm, typeof(*sci_dev), sm); 948 struct isci_remote_device *idev = container_of(sm, typeof(*idev), sm);
954 949
955 sci_dev->working_request = NULL; 950 idev->working_request = NULL;
956 if (scic_sds_remote_node_context_is_ready(&sci_dev->rnc)) { 951 if (scic_sds_remote_node_context_is_ready(&idev->rnc)) {
957 /* 952 /*
958 * Since the RNC is ready, it's alright to finish completion 953 * Since the RNC is ready, it's alright to finish completion
959 * processing (e.g. signal the remote device is ready). */ 954 * processing (e.g. signal the remote device is ready). */
960 scic_sds_stp_remote_device_ready_idle_substate_resume_complete_handler(sci_dev); 955 scic_sds_stp_remote_device_ready_idle_substate_resume_complete_handler(idev);
961 } else { 956 } else {
962 scic_sds_remote_node_context_resume(&sci_dev->rnc, 957 scic_sds_remote_node_context_resume(&idev->rnc,
963 scic_sds_stp_remote_device_ready_idle_substate_resume_complete_handler, 958 scic_sds_stp_remote_device_ready_idle_substate_resume_complete_handler,
964 sci_dev); 959 idev);
965 } 960 }
966} 961}
967 962
968static void scic_sds_stp_remote_device_ready_cmd_substate_enter(struct sci_base_state_machine *sm) 963static void scic_sds_stp_remote_device_ready_cmd_substate_enter(struct sci_base_state_machine *sm)
969{ 964{
970 struct scic_sds_remote_device *sci_dev = container_of(sm, typeof(*sci_dev), sm); 965 struct isci_remote_device *idev = container_of(sm, typeof(*idev), sm);
971 struct scic_sds_controller *scic = scic_sds_remote_device_get_controller(sci_dev); 966 struct scic_sds_controller *scic = scic_sds_remote_device_get_controller(idev);
972 967
973 BUG_ON(sci_dev->working_request == NULL); 968 BUG_ON(idev->working_request == NULL);
974 969
975 isci_remote_device_not_ready(scic_to_ihost(scic), sci_dev_to_idev(sci_dev), 970 isci_remote_device_not_ready(scic_to_ihost(scic), idev,
976 SCIC_REMOTE_DEVICE_NOT_READY_SATA_REQUEST_STARTED); 971 SCIC_REMOTE_DEVICE_NOT_READY_SATA_REQUEST_STARTED);
977} 972}
978 973
979static void scic_sds_stp_remote_device_ready_ncq_error_substate_enter(struct sci_base_state_machine *sm) 974static void scic_sds_stp_remote_device_ready_ncq_error_substate_enter(struct sci_base_state_machine *sm)
980{ 975{
981 struct scic_sds_remote_device *sci_dev = container_of(sm, typeof(*sci_dev), sm); 976 struct isci_remote_device *idev = container_of(sm, typeof(*idev), sm);
982 struct scic_sds_controller *scic = scic_sds_remote_device_get_controller(sci_dev); 977 struct scic_sds_controller *scic = scic_sds_remote_device_get_controller(idev);
983 struct isci_remote_device *idev = sci_dev_to_idev(sci_dev);
984 978
985 if (sci_dev->not_ready_reason == SCIC_REMOTE_DEVICE_NOT_READY_SATA_SDB_ERROR_FIS_RECEIVED) 979 if (idev->not_ready_reason == SCIC_REMOTE_DEVICE_NOT_READY_SATA_SDB_ERROR_FIS_RECEIVED)
986 isci_remote_device_not_ready(scic_to_ihost(scic), idev, 980 isci_remote_device_not_ready(scic_to_ihost(scic), idev,
987 sci_dev->not_ready_reason); 981 idev->not_ready_reason);
988} 982}
989 983
990static void scic_sds_smp_remote_device_ready_idle_substate_enter(struct sci_base_state_machine *sm) 984static void scic_sds_smp_remote_device_ready_idle_substate_enter(struct sci_base_state_machine *sm)
991{ 985{
992 struct scic_sds_remote_device *sci_dev = container_of(sm, typeof(*sci_dev), sm); 986 struct isci_remote_device *idev = container_of(sm, typeof(*idev), sm);
993 struct scic_sds_controller *scic = scic_sds_remote_device_get_controller(sci_dev); 987 struct scic_sds_controller *scic = scic_sds_remote_device_get_controller(idev);
994 988
995 isci_remote_device_ready(scic_to_ihost(scic), sci_dev_to_idev(sci_dev)); 989 isci_remote_device_ready(scic_to_ihost(scic), idev);
996} 990}
997 991
998static void scic_sds_smp_remote_device_ready_cmd_substate_enter(struct sci_base_state_machine *sm) 992static void scic_sds_smp_remote_device_ready_cmd_substate_enter(struct sci_base_state_machine *sm)
999{ 993{
1000 struct scic_sds_remote_device *sci_dev = container_of(sm, typeof(*sci_dev), sm); 994 struct isci_remote_device *idev = container_of(sm, typeof(*idev), sm);
1001 struct scic_sds_controller *scic = scic_sds_remote_device_get_controller(sci_dev); 995 struct scic_sds_controller *scic = scic_sds_remote_device_get_controller(idev);
1002 996
1003 BUG_ON(sci_dev->working_request == NULL); 997 BUG_ON(idev->working_request == NULL);
1004 998
1005 isci_remote_device_not_ready(scic_to_ihost(scic), sci_dev_to_idev(sci_dev), 999 isci_remote_device_not_ready(scic_to_ihost(scic), idev,
1006 SCIC_REMOTE_DEVICE_NOT_READY_SMP_REQUEST_STARTED); 1000 SCIC_REMOTE_DEVICE_NOT_READY_SMP_REQUEST_STARTED);
1007} 1001}
1008 1002
1009static void scic_sds_smp_remote_device_ready_cmd_substate_exit(struct sci_base_state_machine *sm) 1003static void scic_sds_smp_remote_device_ready_cmd_substate_exit(struct sci_base_state_machine *sm)
1010{ 1004{
1011 struct scic_sds_remote_device *sci_dev = container_of(sm, typeof(*sci_dev), sm); 1005 struct isci_remote_device *idev = container_of(sm, typeof(*idev), sm);
1012 1006
1013 sci_dev->working_request = NULL; 1007 idev->working_request = NULL;
1014} 1008}
1015 1009
1016static const struct sci_base_state scic_sds_remote_device_state_table[] = { 1010static const struct sci_base_state scic_sds_remote_device_state_table[] = {
@@ -1065,14 +1059,14 @@ static const struct sci_base_state scic_sds_remote_device_state_table[] = {
1065 * frees the remote_node_context(s) for the device. 1059 * frees the remote_node_context(s) for the device.
1066 */ 1060 */
1067static void scic_remote_device_construct(struct isci_port *iport, 1061static void scic_remote_device_construct(struct isci_port *iport,
1068 struct scic_sds_remote_device *sci_dev) 1062 struct isci_remote_device *idev)
1069{ 1063{
1070 sci_dev->owning_port = iport; 1064 idev->owning_port = iport;
1071 sci_dev->started_request_count = 0; 1065 idev->started_request_count = 0;
1072 1066
1073 sci_init_sm(&sci_dev->sm, scic_sds_remote_device_state_table, SCI_DEV_INITIAL); 1067 sci_init_sm(&idev->sm, scic_sds_remote_device_state_table, SCI_DEV_INITIAL);
1074 1068
1075 scic_sds_remote_node_context_construct(&sci_dev->rnc, 1069 scic_sds_remote_node_context_construct(&idev->rnc,
1076 SCIC_SDS_REMOTE_NODE_CONTEXT_INVALID_INDEX); 1070 SCIC_SDS_REMOTE_NODE_CONTEXT_INVALID_INDEX);
1077} 1071}
1078 1072
@@ -1091,21 +1085,21 @@ static void scic_remote_device_construct(struct isci_port *iport,
1091 * SCI_FAILURE_INSUFFICIENT_RESOURCES - remote node contexts exhausted. 1085 * SCI_FAILURE_INSUFFICIENT_RESOURCES - remote node contexts exhausted.
1092 */ 1086 */
1093static enum sci_status scic_remote_device_da_construct(struct isci_port *iport, 1087static enum sci_status scic_remote_device_da_construct(struct isci_port *iport,
1094 struct scic_sds_remote_device *sci_dev) 1088 struct isci_remote_device *idev)
1095{ 1089{
1096 enum sci_status status; 1090 enum sci_status status;
1097 struct domain_device *dev = sci_dev_to_domain(sci_dev); 1091 struct domain_device *dev = idev->domain_dev;
1098 1092
1099 scic_remote_device_construct(iport, sci_dev); 1093 scic_remote_device_construct(iport, idev);
1100 1094
1101 /* 1095 /*
1102 * This information is request to determine how many remote node context 1096 * This information is request to determine how many remote node context
1103 * entries will be needed to store the remote node. 1097 * entries will be needed to store the remote node.
1104 */ 1098 */
1105 sci_dev->is_direct_attached = true; 1099 idev->is_direct_attached = true;
1106 status = scic_sds_controller_allocate_remote_node_context(iport->owning_controller, 1100 status = scic_sds_controller_allocate_remote_node_context(iport->owning_controller,
1107 sci_dev, 1101 idev,
1108 &sci_dev->rnc.remote_node_index); 1102 &idev->rnc.remote_node_index);
1109 1103
1110 if (status != SCI_SUCCESS) 1104 if (status != SCI_SUCCESS)
1111 return status; 1105 return status;
@@ -1116,10 +1110,10 @@ static enum sci_status scic_remote_device_da_construct(struct isci_port *iport,
1116 else 1110 else
1117 return SCI_FAILURE_UNSUPPORTED_PROTOCOL; 1111 return SCI_FAILURE_UNSUPPORTED_PROTOCOL;
1118 1112
1119 sci_dev->connection_rate = scic_sds_port_get_max_allowed_speed(iport); 1113 idev->connection_rate = scic_sds_port_get_max_allowed_speed(iport);
1120 1114
1121 /* / @todo Should I assign the port width by reading all of the phys on the port? */ 1115 /* / @todo Should I assign the port width by reading all of the phys on the port? */
1122 sci_dev->device_port_width = 1; 1116 idev->device_port_width = 1;
1123 1117
1124 return SCI_SUCCESS; 1118 return SCI_SUCCESS;
1125} 1119}
@@ -1137,16 +1131,16 @@ static enum sci_status scic_remote_device_da_construct(struct isci_port *iport,
1137 * SCI_FAILURE_INSUFFICIENT_RESOURCES - remote node contexts exhausted. 1131 * SCI_FAILURE_INSUFFICIENT_RESOURCES - remote node contexts exhausted.
1138 */ 1132 */
1139static enum sci_status scic_remote_device_ea_construct(struct isci_port *iport, 1133static enum sci_status scic_remote_device_ea_construct(struct isci_port *iport,
1140 struct scic_sds_remote_device *sci_dev) 1134 struct isci_remote_device *idev)
1141{ 1135{
1142 struct domain_device *dev = sci_dev_to_domain(sci_dev); 1136 struct domain_device *dev = idev->domain_dev;
1143 enum sci_status status; 1137 enum sci_status status;
1144 1138
1145 scic_remote_device_construct(iport, sci_dev); 1139 scic_remote_device_construct(iport, idev);
1146 1140
1147 status = scic_sds_controller_allocate_remote_node_context(iport->owning_controller, 1141 status = scic_sds_controller_allocate_remote_node_context(iport->owning_controller,
1148 sci_dev, 1142 idev,
1149 &sci_dev->rnc.remote_node_index); 1143 &idev->rnc.remote_node_index);
1150 if (status != SCI_SUCCESS) 1144 if (status != SCI_SUCCESS)
1151 return status; 1145 return status;
1152 1146
@@ -1163,11 +1157,11 @@ static enum sci_status scic_remote_device_ea_construct(struct isci_port *iport,
1163 * connection the logical link rate is that same as the 1157 * connection the logical link rate is that same as the
1164 * physical. Furthermore, the SAS-2 and SAS-1.1 fields overlay 1158 * physical. Furthermore, the SAS-2 and SAS-1.1 fields overlay
1165 * one another, so this code works for both situations. */ 1159 * one another, so this code works for both situations. */
1166 sci_dev->connection_rate = min_t(u16, scic_sds_port_get_max_allowed_speed(iport), 1160 idev->connection_rate = min_t(u16, scic_sds_port_get_max_allowed_speed(iport),
1167 dev->linkrate); 1161 dev->linkrate);
1168 1162
1169 /* / @todo Should I assign the port width by reading all of the phys on the port? */ 1163 /* / @todo Should I assign the port width by reading all of the phys on the port? */
1170 sci_dev->device_port_width = 1; 1164 idev->device_port_width = 1;
1171 1165
1172 return SCI_SUCCESS; 1166 return SCI_SUCCESS;
1173} 1167}
@@ -1185,22 +1179,22 @@ static enum sci_status scic_remote_device_ea_construct(struct isci_port *iport,
1185 * SCI_FAILURE_INVALID_PHY This value is returned if the user attempts to start 1179 * SCI_FAILURE_INVALID_PHY This value is returned if the user attempts to start
1186 * the device when there have been no phys added to it. 1180 * the device when there have been no phys added to it.
1187 */ 1181 */
1188static enum sci_status scic_remote_device_start(struct scic_sds_remote_device *sci_dev, 1182static enum sci_status scic_remote_device_start(struct isci_remote_device *idev,
1189 u32 timeout) 1183 u32 timeout)
1190{ 1184{
1191 struct sci_base_state_machine *sm = &sci_dev->sm; 1185 struct sci_base_state_machine *sm = &idev->sm;
1192 enum scic_sds_remote_device_states state = sm->current_state_id; 1186 enum scic_sds_remote_device_states state = sm->current_state_id;
1193 enum sci_status status; 1187 enum sci_status status;
1194 1188
1195 if (state != SCI_DEV_STOPPED) { 1189 if (state != SCI_DEV_STOPPED) {
1196 dev_warn(scirdev_to_dev(sci_dev), "%s: in wrong state: %d\n", 1190 dev_warn(scirdev_to_dev(idev), "%s: in wrong state: %d\n",
1197 __func__, state); 1191 __func__, state);
1198 return SCI_FAILURE_INVALID_STATE; 1192 return SCI_FAILURE_INVALID_STATE;
1199 } 1193 }
1200 1194
1201 status = scic_sds_remote_node_context_resume(&sci_dev->rnc, 1195 status = scic_sds_remote_node_context_resume(&idev->rnc,
1202 remote_device_resume_done, 1196 remote_device_resume_done,
1203 sci_dev); 1197 idev);
1204 if (status != SCI_SUCCESS) 1198 if (status != SCI_SUCCESS)
1205 return status; 1199 return status;
1206 1200
@@ -1217,9 +1211,9 @@ static enum sci_status isci_remote_device_construct(struct isci_port *iport,
1217 enum sci_status status; 1211 enum sci_status status;
1218 1212
1219 if (dev->parent && dev_is_expander(dev->parent)) 1213 if (dev->parent && dev_is_expander(dev->parent))
1220 status = scic_remote_device_ea_construct(iport, &idev->sci); 1214 status = scic_remote_device_ea_construct(iport, idev);
1221 else 1215 else
1222 status = scic_remote_device_da_construct(iport, &idev->sci); 1216 status = scic_remote_device_da_construct(iport, idev);
1223 1217
1224 if (status != SCI_SUCCESS) { 1218 if (status != SCI_SUCCESS) {
1225 dev_dbg(&ihost->pdev->dev, "%s: construct failed: %d\n", 1219 dev_dbg(&ihost->pdev->dev, "%s: construct failed: %d\n",
@@ -1229,7 +1223,7 @@ static enum sci_status isci_remote_device_construct(struct isci_port *iport,
1229 } 1223 }
1230 1224
1231 /* start the device. */ 1225 /* start the device. */
1232 status = scic_remote_device_start(&idev->sci, ISCI_REMOTE_DEVICE_START_TIMEOUT); 1226 status = scic_remote_device_start(idev, ISCI_REMOTE_DEVICE_START_TIMEOUT);
1233 1227
1234 if (status != SCI_SUCCESS) 1228 if (status != SCI_SUCCESS)
1235 dev_warn(&ihost->pdev->dev, "remote device start failed: %d\n", 1229 dev_warn(&ihost->pdev->dev, "remote device start failed: %d\n",
@@ -1330,7 +1324,7 @@ enum sci_status isci_remote_device_stop(struct isci_host *ihost, struct isci_rem
1330 set_bit(IDEV_STOP_PENDING, &idev->flags); 1324 set_bit(IDEV_STOP_PENDING, &idev->flags);
1331 1325
1332 spin_lock_irqsave(&ihost->scic_lock, flags); 1326 spin_lock_irqsave(&ihost->scic_lock, flags);
1333 status = scic_remote_device_stop(&idev->sci, 50); 1327 status = scic_remote_device_stop(idev, 50);
1334 spin_unlock_irqrestore(&ihost->scic_lock, flags); 1328 spin_unlock_irqrestore(&ihost->scic_lock, flags);
1335 1329
1336 /* Wait for the stop complete callback. */ 1330 /* Wait for the stop complete callback. */
diff --git a/drivers/scsi/isci/remote_device.h b/drivers/scsi/isci/remote_device.h
index 578d75b8cd16..45798582fc14 100644
--- a/drivers/scsi/isci/remote_device.h
+++ b/drivers/scsi/isci/remote_device.h
@@ -70,65 +70,14 @@ enum scic_remote_device_not_ready_reason_code {
70 SCIC_REMOTE_DEVICE_NOT_READY_REASON_CODE_MAX 70 SCIC_REMOTE_DEVICE_NOT_READY_REASON_CODE_MAX
71}; 71};
72 72
73struct scic_sds_remote_device { 73/**
74 /** 74 * isci_remote_device - isci representation of a sas expander / end point
75 * This field contains the information for the base remote device state 75 * @device_port_width: hw setting for number of simultaneous connections
76 * machine. 76 * @connection_rate: per-taskcontext connection rate for this device
77 */ 77 * @working_request: SATA requests have no tag we for unaccelerated
78 struct sci_base_state_machine sm; 78 * protocols we need a method to associate unsolicited
79 79 * frames with a pending request
80 /** 80 */
81 * This field is the programmed device port width. This value is
82 * written to the RCN data structure to tell the SCU how many open
83 * connections this device can have.
84 */
85 u32 device_port_width;
86
87 /**
88 * This field is the programmed connection rate for this remote device. It is
89 * used to program the TC with the maximum allowed connection rate.
90 */
91 enum sas_linkrate connection_rate;
92
93 /**
94 * This filed is assinged the value of true if the device is directly
95 * attached to the port.
96 */
97 bool is_direct_attached;
98
99 /**
100 * This filed contains a pointer back to the port to which this device
101 * is assigned.
102 */
103 struct isci_port *owning_port;
104
105 /**
106 * This field contains the SCU silicon remote node context specific
107 * information.
108 */
109 struct scic_sds_remote_node_context rnc;
110
111 /**
112 * This field contains the stated request count for the remote device. The
113 * device can not reach the SCI_DEV_STOPPED until all
114 * requests are complete and the rnc_posted value is false.
115 */
116 u32 started_request_count;
117
118 /**
119 * This field contains a pointer to the working request object. It is only
120 * used only for SATA requests since the unsolicited frames we get from the
121 * hardware have no Tag value to look up the io request object.
122 */
123 struct isci_request *working_request;
124
125 /**
126 * This field contains the reason for the remote device going not_ready. It is
127 * assigned in the state handlers and used in the state transition.
128 */
129 u32 not_ready_reason;
130};
131
132struct isci_remote_device { 81struct isci_remote_device {
133 #define IDEV_START_PENDING 0 82 #define IDEV_START_PENDING 0
134 #define IDEV_STOP_PENDING 1 83 #define IDEV_STOP_PENDING 1
@@ -143,7 +92,16 @@ struct isci_remote_device {
143 struct domain_device *domain_dev; 92 struct domain_device *domain_dev;
144 struct list_head node; 93 struct list_head node;
145 struct list_head reqs_in_process; 94 struct list_head reqs_in_process;
146 struct scic_sds_remote_device sci; 95 struct sci_base_state_machine sm;
96 u32 device_port_width;
97 enum sas_linkrate connection_rate;
98 bool is_direct_attached;
99 struct isci_port *owning_port;
100 struct scic_sds_remote_node_context rnc;
101 /* XXX unify with device reference counting and delete */
102 u32 started_request_count;
103 struct isci_request *working_request;
104 u32 not_ready_reason;
147}; 105};
148 106
149#define ISCI_REMOTE_DEVICE_START_TIMEOUT 5000 107#define ISCI_REMOTE_DEVICE_START_TIMEOUT 5000
@@ -191,7 +149,7 @@ void isci_device_clear_reset_pending(struct isci_host *ihost,
191 * successfully stopped. 149 * successfully stopped.
192 */ 150 */
193enum sci_status scic_remote_device_stop( 151enum sci_status scic_remote_device_stop(
194 struct scic_sds_remote_device *remote_device, 152 struct isci_remote_device *idev,
195 u32 timeout); 153 u32 timeout);
196 154
197/** 155/**
@@ -207,7 +165,7 @@ enum sci_status scic_remote_device_stop(
207 * started. 165 * started.
208 */ 166 */
209enum sci_status scic_remote_device_reset( 167enum sci_status scic_remote_device_reset(
210 struct scic_sds_remote_device *remote_device); 168 struct isci_remote_device *idev);
211 169
212/** 170/**
213 * scic_remote_device_reset_complete() - This method informs the device object 171 * scic_remote_device_reset_complete() - This method informs the device object
@@ -220,7 +178,7 @@ enum sci_status scic_remote_device_reset(
220 * is resuming operation. 178 * is resuming operation.
221 */ 179 */
222enum sci_status scic_remote_device_reset_complete( 180enum sci_status scic_remote_device_reset_complete(
223 struct scic_sds_remote_device *remote_device); 181 struct isci_remote_device *idev);
224 182
225#define scic_remote_device_is_atapi(device_handle) false 183#define scic_remote_device_is_atapi(device_handle) false
226 184
@@ -335,27 +293,15 @@ enum scic_sds_remote_device_states {
335 SCI_DEV_FINAL, 293 SCI_DEV_FINAL,
336}; 294};
337 295
338static inline struct scic_sds_remote_device *rnc_to_dev(struct scic_sds_remote_node_context *rnc) 296static inline struct isci_remote_device *rnc_to_dev(struct scic_sds_remote_node_context *rnc)
339{ 297{
340 struct scic_sds_remote_device *sci_dev; 298 struct isci_remote_device *idev;
341 299
342 sci_dev = container_of(rnc, typeof(*sci_dev), rnc); 300 idev = container_of(rnc, typeof(*idev), rnc);
343
344 return sci_dev;
345}
346
347static inline struct isci_remote_device *sci_dev_to_idev(struct scic_sds_remote_device *sci_dev)
348{
349 struct isci_remote_device *idev = container_of(sci_dev, typeof(*idev), sci);
350 301
351 return idev; 302 return idev;
352} 303}
353 304
354static inline struct domain_device *sci_dev_to_domain(struct scic_sds_remote_device *sci_dev)
355{
356 return sci_dev_to_idev(sci_dev)->domain_dev;
357}
358
359static inline bool dev_is_expander(struct domain_device *dev) 305static inline bool dev_is_expander(struct domain_device *dev)
360{ 306{
361 return dev->dev_type == EDGE_DEV || dev->dev_type == FANOUT_DEV; 307 return dev->dev_type == EDGE_DEV || dev->dev_type == FANOUT_DEV;
@@ -366,8 +312,8 @@ static inline bool dev_is_expander(struct domain_device *dev)
366 * 312 *
367 * This macro incrments the request count for this device 313 * This macro incrments the request count for this device
368 */ 314 */
369#define scic_sds_remote_device_increment_request_count(sci_dev) \ 315#define scic_sds_remote_device_increment_request_count(idev) \
370 ((sci_dev)->started_request_count++) 316 ((idev)->started_request_count++)
371 317
372/** 318/**
373 * scic_sds_remote_device_decrement_request_count() - 319 * scic_sds_remote_device_decrement_request_count() -
@@ -375,44 +321,44 @@ static inline bool dev_is_expander(struct domain_device *dev)
375 * This macro decrements the request count for this device. This count will 321 * This macro decrements the request count for this device. This count will
376 * never decrment past 0. 322 * never decrment past 0.
377 */ 323 */
378#define scic_sds_remote_device_decrement_request_count(sci_dev) \ 324#define scic_sds_remote_device_decrement_request_count(idev) \
379 ((sci_dev)->started_request_count > 0 ? \ 325 ((idev)->started_request_count > 0 ? \
380 (sci_dev)->started_request_count-- : 0) 326 (idev)->started_request_count-- : 0)
381 327
382/** 328/**
383 * scic_sds_remote_device_get_request_count() - 329 * scic_sds_remote_device_get_request_count() -
384 * 330 *
385 * This is a helper macro to return the current device request count. 331 * This is a helper macro to return the current device request count.
386 */ 332 */
387#define scic_sds_remote_device_get_request_count(sci_dev) \ 333#define scic_sds_remote_device_get_request_count(idev) \
388 ((sci_dev)->started_request_count) 334 ((idev)->started_request_count)
389 335
390/** 336/**
391 * scic_sds_remote_device_get_controller() - 337 * scic_sds_remote_device_get_controller() -
392 * 338 *
393 * This macro returns the controller object that contains this device object 339 * This macro returns the controller object that contains this device object
394 */ 340 */
395#define scic_sds_remote_device_get_controller(sci_dev) \ 341#define scic_sds_remote_device_get_controller(idev) \
396 scic_sds_port_get_controller(scic_sds_remote_device_get_port(sci_dev)) 342 scic_sds_port_get_controller(scic_sds_remote_device_get_port(idev))
397 343
398/** 344/**
399 * scic_sds_remote_device_get_port() - 345 * scic_sds_remote_device_get_port() -
400 * 346 *
401 * This macro returns the owning port of this device 347 * This macro returns the owning port of this device
402 */ 348 */
403#define scic_sds_remote_device_get_port(sci_dev) \ 349#define scic_sds_remote_device_get_port(idev) \
404 ((sci_dev)->owning_port) 350 ((idev)->owning_port)
405 351
406/** 352/**
407 * scic_sds_remote_device_get_controller_peg() - 353 * scic_sds_remote_device_get_controller_peg() -
408 * 354 *
409 * This macro returns the controllers protocol engine group 355 * This macro returns the controllers protocol engine group
410 */ 356 */
411#define scic_sds_remote_device_get_controller_peg(sci_dev) \ 357#define scic_sds_remote_device_get_controller_peg(idev) \
412 (\ 358 (\
413 scic_sds_controller_get_protocol_engine_group(\ 359 scic_sds_controller_get_protocol_engine_group(\
414 scic_sds_port_get_controller(\ 360 scic_sds_port_get_controller(\
415 scic_sds_remote_device_get_port(sci_dev) \ 361 scic_sds_remote_device_get_port(idev) \
416 ) \ 362 ) \
417 ) \ 363 ) \
418 ) 364 )
@@ -422,8 +368,8 @@ static inline bool dev_is_expander(struct domain_device *dev)
422 * 368 *
423 * This macro returns the remote node index for this device object 369 * This macro returns the remote node index for this device object
424 */ 370 */
425#define scic_sds_remote_device_get_index(sci_dev) \ 371#define scic_sds_remote_device_get_index(idev) \
426 ((sci_dev)->rnc.remote_node_index) 372 ((idev)->rnc.remote_node_index)
427 373
428/** 374/**
429 * scic_sds_remote_device_build_command_context() - 375 * scic_sds_remote_device_build_command_context() -
@@ -448,36 +394,36 @@ static inline bool dev_is_expander(struct domain_device *dev)
448 ((device)->working_request = (request)) 394 ((device)->working_request = (request))
449 395
450enum sci_status scic_sds_remote_device_frame_handler( 396enum sci_status scic_sds_remote_device_frame_handler(
451 struct scic_sds_remote_device *sci_dev, 397 struct isci_remote_device *idev,
452 u32 frame_index); 398 u32 frame_index);
453 399
454enum sci_status scic_sds_remote_device_event_handler( 400enum sci_status scic_sds_remote_device_event_handler(
455 struct scic_sds_remote_device *sci_dev, 401 struct isci_remote_device *idev,
456 u32 event_code); 402 u32 event_code);
457 403
458enum sci_status scic_sds_remote_device_start_io( 404enum sci_status scic_sds_remote_device_start_io(
459 struct scic_sds_controller *controller, 405 struct scic_sds_controller *controller,
460 struct scic_sds_remote_device *sci_dev, 406 struct isci_remote_device *idev,
461 struct isci_request *ireq); 407 struct isci_request *ireq);
462 408
463enum sci_status scic_sds_remote_device_start_task( 409enum sci_status scic_sds_remote_device_start_task(
464 struct scic_sds_controller *controller, 410 struct scic_sds_controller *controller,
465 struct scic_sds_remote_device *sci_dev, 411 struct isci_remote_device *idev,
466 struct isci_request *ireq); 412 struct isci_request *ireq);
467 413
468enum sci_status scic_sds_remote_device_complete_io( 414enum sci_status scic_sds_remote_device_complete_io(
469 struct scic_sds_controller *controller, 415 struct scic_sds_controller *controller,
470 struct scic_sds_remote_device *sci_dev, 416 struct isci_remote_device *idev,
471 struct isci_request *ireq); 417 struct isci_request *ireq);
472 418
473enum sci_status scic_sds_remote_device_suspend( 419enum sci_status scic_sds_remote_device_suspend(
474 struct scic_sds_remote_device *sci_dev, 420 struct isci_remote_device *idev,
475 u32 suspend_type); 421 u32 suspend_type);
476 422
477void scic_sds_remote_device_post_request( 423void scic_sds_remote_device_post_request(
478 struct scic_sds_remote_device *sci_dev, 424 struct isci_remote_device *idev,
479 u32 request); 425 u32 request);
480 426
481#define scic_sds_remote_device_is_atapi(sci_dev) false 427#define scic_sds_remote_device_is_atapi(idev) false
482 428
483#endif /* !defined(_ISCI_REMOTE_DEVICE_H_) */ 429#endif /* !defined(_ISCI_REMOTE_DEVICE_H_) */
diff --git a/drivers/scsi/isci/remote_node_context.c b/drivers/scsi/isci/remote_node_context.c
index 1b51fe55314d..e485744e1263 100644
--- a/drivers/scsi/isci/remote_node_context.c
+++ b/drivers/scsi/isci/remote_node_context.c
@@ -103,22 +103,22 @@ bool scic_sds_remote_node_context_is_ready(
103static void scic_sds_remote_node_context_construct_buffer( 103static void scic_sds_remote_node_context_construct_buffer(
104 struct scic_sds_remote_node_context *sci_rnc) 104 struct scic_sds_remote_node_context *sci_rnc)
105{ 105{
106 struct scic_sds_remote_device *sci_dev = rnc_to_dev(sci_rnc); 106 struct isci_remote_device *idev = rnc_to_dev(sci_rnc);
107 struct domain_device *dev = sci_dev_to_domain(sci_dev); 107 struct domain_device *dev = idev->domain_dev;
108 int rni = sci_rnc->remote_node_index; 108 int rni = sci_rnc->remote_node_index;
109 union scu_remote_node_context *rnc; 109 union scu_remote_node_context *rnc;
110 struct scic_sds_controller *scic; 110 struct scic_sds_controller *scic;
111 __le64 sas_addr; 111 __le64 sas_addr;
112 112
113 scic = scic_sds_remote_device_get_controller(sci_dev); 113 scic = scic_sds_remote_device_get_controller(idev);
114 rnc = scic_sds_controller_get_remote_node_context_buffer(scic, rni); 114 rnc = scic_sds_controller_get_remote_node_context_buffer(scic, rni);
115 115
116 memset(rnc, 0, sizeof(union scu_remote_node_context) 116 memset(rnc, 0, sizeof(union scu_remote_node_context)
117 * scic_sds_remote_device_node_count(sci_dev)); 117 * scic_sds_remote_device_node_count(idev));
118 118
119 rnc->ssp.remote_node_index = rni; 119 rnc->ssp.remote_node_index = rni;
120 rnc->ssp.remote_node_port_width = sci_dev->device_port_width; 120 rnc->ssp.remote_node_port_width = idev->device_port_width;
121 rnc->ssp.logical_port_index = sci_dev->owning_port->physical_port_index; 121 rnc->ssp.logical_port_index = idev->owning_port->physical_port_index;
122 122
123 /* sas address is __be64, context ram format is __le64 */ 123 /* sas address is __be64, context ram format is __le64 */
124 sas_addr = cpu_to_le64(SAS_ADDR(dev->sas_addr)); 124 sas_addr = cpu_to_le64(SAS_ADDR(dev->sas_addr));
@@ -148,7 +148,7 @@ static void scic_sds_remote_node_context_construct_buffer(
148 rnc->ssp.initial_arbitration_wait_time = 0; 148 rnc->ssp.initial_arbitration_wait_time = 0;
149 149
150 /* Open Address Frame Parameters */ 150 /* Open Address Frame Parameters */
151 rnc->ssp.oaf_connection_rate = sci_dev->connection_rate; 151 rnc->ssp.oaf_connection_rate = idev->connection_rate;
152 rnc->ssp.oaf_features = 0; 152 rnc->ssp.oaf_features = 0;
153 rnc->ssp.oaf_source_zone_group = 0; 153 rnc->ssp.oaf_source_zone_group = 0;
154 rnc->ssp.oaf_more_compatibility_features = 0; 154 rnc->ssp.oaf_more_compatibility_features = 0;
@@ -220,26 +220,26 @@ static void scic_sds_remote_node_context_continue_state_transitions(struct scic_
220static void scic_sds_remote_node_context_validate_context_buffer( 220static void scic_sds_remote_node_context_validate_context_buffer(
221 struct scic_sds_remote_node_context *sci_rnc) 221 struct scic_sds_remote_node_context *sci_rnc)
222{ 222{
223 struct scic_sds_remote_device *sci_dev = rnc_to_dev(sci_rnc); 223 struct isci_remote_device *idev = rnc_to_dev(sci_rnc);
224 struct domain_device *dev = sci_dev_to_domain(sci_dev); 224 struct domain_device *dev = idev->domain_dev;
225 union scu_remote_node_context *rnc_buffer; 225 union scu_remote_node_context *rnc_buffer;
226 226
227 rnc_buffer = scic_sds_controller_get_remote_node_context_buffer( 227 rnc_buffer = scic_sds_controller_get_remote_node_context_buffer(
228 scic_sds_remote_device_get_controller(sci_dev), 228 scic_sds_remote_device_get_controller(idev),
229 sci_rnc->remote_node_index 229 sci_rnc->remote_node_index
230 ); 230 );
231 231
232 rnc_buffer->ssp.is_valid = true; 232 rnc_buffer->ssp.is_valid = true;
233 233
234 if (!sci_dev->is_direct_attached && 234 if (!idev->is_direct_attached &&
235 (dev->dev_type == SATA_DEV || (dev->tproto & SAS_PROTOCOL_STP))) { 235 (dev->dev_type == SATA_DEV || (dev->tproto & SAS_PROTOCOL_STP))) {
236 scic_sds_remote_device_post_request(sci_dev, 236 scic_sds_remote_device_post_request(idev,
237 SCU_CONTEXT_COMMAND_POST_RNC_96); 237 SCU_CONTEXT_COMMAND_POST_RNC_96);
238 } else { 238 } else {
239 scic_sds_remote_device_post_request(sci_dev, SCU_CONTEXT_COMMAND_POST_RNC_32); 239 scic_sds_remote_device_post_request(idev, SCU_CONTEXT_COMMAND_POST_RNC_32);
240 240
241 if (sci_dev->is_direct_attached) { 241 if (idev->is_direct_attached) {
242 scic_sds_port_setup_transports(sci_dev->owning_port, 242 scic_sds_port_setup_transports(idev->owning_port,
243 sci_rnc->remote_node_index); 243 sci_rnc->remote_node_index);
244 } 244 }
245 } 245 }
@@ -296,11 +296,11 @@ static void scic_sds_remote_node_context_invalidating_state_enter(struct sci_bas
296static void scic_sds_remote_node_context_resuming_state_enter(struct sci_base_state_machine *sm) 296static void scic_sds_remote_node_context_resuming_state_enter(struct sci_base_state_machine *sm)
297{ 297{
298 struct scic_sds_remote_node_context *rnc = container_of(sm, typeof(*rnc), sm); 298 struct scic_sds_remote_node_context *rnc = container_of(sm, typeof(*rnc), sm);
299 struct scic_sds_remote_device *sci_dev; 299 struct isci_remote_device *idev;
300 struct domain_device *dev; 300 struct domain_device *dev;
301 301
302 sci_dev = rnc_to_dev(rnc); 302 idev = rnc_to_dev(rnc);
303 dev = sci_dev_to_domain(sci_dev); 303 dev = idev->domain_dev;
304 304
305 /* 305 /*
306 * For direct attached SATA devices we need to clear the TLCR 306 * For direct attached SATA devices we need to clear the TLCR
@@ -309,11 +309,11 @@ static void scic_sds_remote_node_context_resuming_state_enter(struct sci_base_st
309 * the STPTLDARNI register with the RNi of the device 309 * the STPTLDARNI register with the RNi of the device
310 */ 310 */
311 if ((dev->dev_type == SATA_DEV || (dev->tproto & SAS_PROTOCOL_STP)) && 311 if ((dev->dev_type == SATA_DEV || (dev->tproto & SAS_PROTOCOL_STP)) &&
312 sci_dev->is_direct_attached) 312 idev->is_direct_attached)
313 scic_sds_port_setup_transports(sci_dev->owning_port, 313 scic_sds_port_setup_transports(idev->owning_port,
314 rnc->remote_node_index); 314 rnc->remote_node_index);
315 315
316 scic_sds_remote_device_post_request(sci_dev, SCU_CONTEXT_COMMAND_POST_RNC_RESUME); 316 scic_sds_remote_device_post_request(idev, SCU_CONTEXT_COMMAND_POST_RNC_RESUME);
317} 317}
318 318
319static void scic_sds_remote_node_context_ready_state_enter(struct sci_base_state_machine *sm) 319static void scic_sds_remote_node_context_ready_state_enter(struct sci_base_state_machine *sm)
@@ -564,8 +564,8 @@ enum sci_status scic_sds_remote_node_context_resume(struct scic_sds_remote_node_
564 sci_rnc->user_cookie = cb_p; 564 sci_rnc->user_cookie = cb_p;
565 return SCI_SUCCESS; 565 return SCI_SUCCESS;
566 case SCI_RNC_TX_SUSPENDED: { 566 case SCI_RNC_TX_SUSPENDED: {
567 struct scic_sds_remote_device *sci_dev = rnc_to_dev(sci_rnc); 567 struct isci_remote_device *idev = rnc_to_dev(sci_rnc);
568 struct domain_device *dev = sci_dev_to_domain(sci_dev); 568 struct domain_device *dev = idev->domain_dev;
569 569
570 scic_sds_remote_node_context_setup_to_resume(sci_rnc, cb_fn, cb_p); 570 scic_sds_remote_node_context_setup_to_resume(sci_rnc, cb_fn, cb_p);
571 571
@@ -573,7 +573,7 @@ enum sci_status scic_sds_remote_node_context_resume(struct scic_sds_remote_node_
573 if (dev->dev_type == SAS_END_DEV || dev_is_expander(dev)) 573 if (dev->dev_type == SAS_END_DEV || dev_is_expander(dev))
574 sci_change_state(&sci_rnc->sm, SCI_RNC_RESUMING); 574 sci_change_state(&sci_rnc->sm, SCI_RNC_RESUMING);
575 else if (dev->dev_type == SATA_DEV || (dev->tproto & SAS_PROTOCOL_STP)) { 575 else if (dev->dev_type == SATA_DEV || (dev->tproto & SAS_PROTOCOL_STP)) {
576 if (sci_dev->is_direct_attached) { 576 if (idev->is_direct_attached) {
577 /* @todo Fix this since I am being silly in writing to the STPTLDARNI register. */ 577 /* @todo Fix this since I am being silly in writing to the STPTLDARNI register. */
578 sci_change_state(&sci_rnc->sm, SCI_RNC_RESUMING); 578 sci_change_state(&sci_rnc->sm, SCI_RNC_RESUMING);
579 } else { 579 } else {
diff --git a/drivers/scsi/isci/remote_node_context.h b/drivers/scsi/isci/remote_node_context.h
index 35e6ae616903..7a24c7a12de1 100644
--- a/drivers/scsi/isci/remote_node_context.h
+++ b/drivers/scsi/isci/remote_node_context.h
@@ -79,7 +79,7 @@
79#define SCI_SOFTWARE_SUSPENSION (1) 79#define SCI_SOFTWARE_SUSPENSION (1)
80 80
81struct isci_request; 81struct isci_request;
82struct scic_sds_remote_device; 82struct isci_remote_device;
83struct scic_sds_remote_node_context; 83struct scic_sds_remote_node_context;
84 84
85typedef void (*scics_sds_remote_node_context_callback)(void *); 85typedef void (*scics_sds_remote_node_context_callback)(void *);
diff --git a/drivers/scsi/isci/request.c b/drivers/scsi/isci/request.c
index 2d29abf3ce1f..90ead662828d 100644
--- a/drivers/scsi/isci/request.c
+++ b/drivers/scsi/isci/request.c
@@ -209,17 +209,17 @@ static void scu_ssp_reqeust_construct_task_context(
209 struct scu_task_context *task_context) 209 struct scu_task_context *task_context)
210{ 210{
211 dma_addr_t dma_addr; 211 dma_addr_t dma_addr;
212 struct scic_sds_remote_device *target_device; 212 struct isci_remote_device *idev;
213 struct isci_port *iport; 213 struct isci_port *iport;
214 214
215 target_device = scic_sds_request_get_device(ireq); 215 idev = scic_sds_request_get_device(ireq);
216 iport = scic_sds_request_get_port(ireq); 216 iport = scic_sds_request_get_port(ireq);
217 217
218 /* Fill in the TC with the its required data */ 218 /* Fill in the TC with the its required data */
219 task_context->abort = 0; 219 task_context->abort = 0;
220 task_context->priority = 0; 220 task_context->priority = 0;
221 task_context->initiator_request = 1; 221 task_context->initiator_request = 1;
222 task_context->connection_rate = target_device->connection_rate; 222 task_context->connection_rate = idev->connection_rate;
223 task_context->protocol_engine_index = 223 task_context->protocol_engine_index =
224 scic_sds_controller_get_protocol_engine_group(controller); 224 scic_sds_controller_get_protocol_engine_group(controller);
225 task_context->logical_port_index = scic_sds_port_get_index(iport); 225 task_context->logical_port_index = scic_sds_port_get_index(iport);
@@ -227,8 +227,7 @@ static void scu_ssp_reqeust_construct_task_context(
227 task_context->valid = SCU_TASK_CONTEXT_VALID; 227 task_context->valid = SCU_TASK_CONTEXT_VALID;
228 task_context->context_type = SCU_TASK_CONTEXT_TYPE; 228 task_context->context_type = SCU_TASK_CONTEXT_TYPE;
229 229
230 task_context->remote_node_index = 230 task_context->remote_node_index = scic_sds_remote_device_get_index(idev);
231 scic_sds_remote_device_get_index(ireq->target_device);
232 task_context->command_code = 0; 231 task_context->command_code = 0;
233 232
234 task_context->link_layer_control = 0; 233 task_context->link_layer_control = 0;
@@ -348,17 +347,17 @@ static void scu_sata_reqeust_construct_task_context(
348 struct scu_task_context *task_context) 347 struct scu_task_context *task_context)
349{ 348{
350 dma_addr_t dma_addr; 349 dma_addr_t dma_addr;
351 struct scic_sds_remote_device *target_device; 350 struct isci_remote_device *idev;
352 struct isci_port *iport; 351 struct isci_port *iport;
353 352
354 target_device = scic_sds_request_get_device(ireq); 353 idev = scic_sds_request_get_device(ireq);
355 iport = scic_sds_request_get_port(ireq); 354 iport = scic_sds_request_get_port(ireq);
356 355
357 /* Fill in the TC with the its required data */ 356 /* Fill in the TC with the its required data */
358 task_context->abort = 0; 357 task_context->abort = 0;
359 task_context->priority = SCU_TASK_PRIORITY_NORMAL; 358 task_context->priority = SCU_TASK_PRIORITY_NORMAL;
360 task_context->initiator_request = 1; 359 task_context->initiator_request = 1;
361 task_context->connection_rate = target_device->connection_rate; 360 task_context->connection_rate = idev->connection_rate;
362 task_context->protocol_engine_index = 361 task_context->protocol_engine_index =
363 scic_sds_controller_get_protocol_engine_group(controller); 362 scic_sds_controller_get_protocol_engine_group(controller);
364 task_context->logical_port_index = 363 task_context->logical_port_index =
@@ -367,8 +366,7 @@ static void scu_sata_reqeust_construct_task_context(
367 task_context->valid = SCU_TASK_CONTEXT_VALID; 366 task_context->valid = SCU_TASK_CONTEXT_VALID;
368 task_context->context_type = SCU_TASK_CONTEXT_TYPE; 367 task_context->context_type = SCU_TASK_CONTEXT_TYPE;
369 368
370 task_context->remote_node_index = 369 task_context->remote_node_index = scic_sds_remote_device_get_index(idev);
371 scic_sds_remote_device_get_index(ireq->target_device);
372 task_context->command_code = 0; 370 task_context->command_code = 0;
373 371
374 task_context->link_layer_control = 0; 372 task_context->link_layer_control = 0;
@@ -2850,7 +2848,7 @@ static void isci_request_io_request_complete(struct isci_host *isci_host,
2850static void scic_sds_request_started_state_enter(struct sci_base_state_machine *sm) 2848static void scic_sds_request_started_state_enter(struct sci_base_state_machine *sm)
2851{ 2849{
2852 struct isci_request *ireq = container_of(sm, typeof(*ireq), sm); 2850 struct isci_request *ireq = container_of(sm, typeof(*ireq), sm);
2853 struct domain_device *dev = sci_dev_to_domain(ireq->target_device); 2851 struct domain_device *dev = ireq->target_device->domain_dev;
2854 struct sas_task *task; 2852 struct sas_task *task;
2855 2853
2856 /* XXX as hch said always creating an internal sas_task for tmf 2854 /* XXX as hch said always creating an internal sas_task for tmf
@@ -2988,12 +2986,12 @@ static const struct sci_base_state scic_sds_request_state_table[] = {
2988 2986
2989static void 2987static void
2990scic_sds_general_request_construct(struct scic_sds_controller *scic, 2988scic_sds_general_request_construct(struct scic_sds_controller *scic,
2991 struct scic_sds_remote_device *sci_dev, 2989 struct isci_remote_device *idev,
2992 struct isci_request *ireq) 2990 struct isci_request *ireq)
2993{ 2991{
2994 sci_init_sm(&ireq->sm, scic_sds_request_state_table, SCI_REQ_INIT); 2992 sci_init_sm(&ireq->sm, scic_sds_request_state_table, SCI_REQ_INIT);
2995 2993
2996 ireq->target_device = sci_dev; 2994 ireq->target_device = idev;
2997 ireq->protocol = SCIC_NO_PROTOCOL; 2995 ireq->protocol = SCIC_NO_PROTOCOL;
2998 ireq->saved_rx_frame_index = SCU_INVALID_FRAME_INDEX; 2996 ireq->saved_rx_frame_index = SCU_INVALID_FRAME_INDEX;
2999 2997
@@ -3004,16 +3002,16 @@ scic_sds_general_request_construct(struct scic_sds_controller *scic,
3004 3002
3005static enum sci_status 3003static enum sci_status
3006scic_io_request_construct(struct scic_sds_controller *scic, 3004scic_io_request_construct(struct scic_sds_controller *scic,
3007 struct scic_sds_remote_device *sci_dev, 3005 struct isci_remote_device *idev,
3008 struct isci_request *ireq) 3006 struct isci_request *ireq)
3009{ 3007{
3010 struct domain_device *dev = sci_dev_to_domain(sci_dev); 3008 struct domain_device *dev = idev->domain_dev;
3011 enum sci_status status = SCI_SUCCESS; 3009 enum sci_status status = SCI_SUCCESS;
3012 3010
3013 /* Build the common part of the request */ 3011 /* Build the common part of the request */
3014 scic_sds_general_request_construct(scic, sci_dev, ireq); 3012 scic_sds_general_request_construct(scic, idev, ireq);
3015 3013
3016 if (sci_dev->rnc.remote_node_index == SCIC_SDS_REMOTE_NODE_CONTEXT_INVALID_INDEX) 3014 if (idev->rnc.remote_node_index == SCIC_SDS_REMOTE_NODE_CONTEXT_INVALID_INDEX)
3017 return SCI_FAILURE_INVALID_REMOTE_DEVICE; 3015 return SCI_FAILURE_INVALID_REMOTE_DEVICE;
3018 3016
3019 if (dev->dev_type == SAS_END_DEV) 3017 if (dev->dev_type == SAS_END_DEV)
@@ -3031,14 +3029,14 @@ scic_io_request_construct(struct scic_sds_controller *scic,
3031} 3029}
3032 3030
3033enum sci_status scic_task_request_construct(struct scic_sds_controller *scic, 3031enum sci_status scic_task_request_construct(struct scic_sds_controller *scic,
3034 struct scic_sds_remote_device *sci_dev, 3032 struct isci_remote_device *idev,
3035 u16 io_tag, struct isci_request *ireq) 3033 u16 io_tag, struct isci_request *ireq)
3036{ 3034{
3037 struct domain_device *dev = sci_dev_to_domain(sci_dev); 3035 struct domain_device *dev = idev->domain_dev;
3038 enum sci_status status = SCI_SUCCESS; 3036 enum sci_status status = SCI_SUCCESS;
3039 3037
3040 /* Build the common part of the request */ 3038 /* Build the common part of the request */
3041 scic_sds_general_request_construct(scic, sci_dev, ireq); 3039 scic_sds_general_request_construct(scic, idev, ireq);
3042 3040
3043 if (dev->dev_type == SAS_END_DEV || 3041 if (dev->dev_type == SAS_END_DEV ||
3044 dev->dev_type == SATA_DEV || (dev->tproto & SAS_PROTOCOL_STP)) { 3042 dev->dev_type == SATA_DEV || (dev->tproto & SAS_PROTOCOL_STP)) {
@@ -3102,7 +3100,7 @@ scic_io_request_construct_smp(struct device *dev,
3102 struct sas_task *task) 3100 struct sas_task *task)
3103{ 3101{
3104 struct scatterlist *sg = &task->smp_task.smp_req; 3102 struct scatterlist *sg = &task->smp_task.smp_req;
3105 struct scic_sds_remote_device *sci_dev; 3103 struct isci_remote_device *idev;
3106 struct scu_task_context *task_context; 3104 struct scu_task_context *task_context;
3107 struct isci_port *iport; 3105 struct isci_port *iport;
3108 struct smp_req *smp_req; 3106 struct smp_req *smp_req;
@@ -3147,7 +3145,7 @@ scic_io_request_construct_smp(struct device *dev,
3147 3145
3148 task_context = ireq->tc; 3146 task_context = ireq->tc;
3149 3147
3150 sci_dev = scic_sds_request_get_device(ireq); 3148 idev = scic_sds_request_get_device(ireq);
3151 iport = scic_sds_request_get_port(ireq); 3149 iport = scic_sds_request_get_port(ireq);
3152 3150
3153 /* 3151 /*
@@ -3156,7 +3154,7 @@ scic_io_request_construct_smp(struct device *dev,
3156 */ 3154 */
3157 task_context->priority = 0; 3155 task_context->priority = 0;
3158 task_context->initiator_request = 1; 3156 task_context->initiator_request = 1;
3159 task_context->connection_rate = sci_dev->connection_rate; 3157 task_context->connection_rate = idev->connection_rate;
3160 task_context->protocol_engine_index = 3158 task_context->protocol_engine_index =
3161 scic_sds_controller_get_protocol_engine_group(scic); 3159 scic_sds_controller_get_protocol_engine_group(scic);
3162 task_context->logical_port_index = scic_sds_port_get_index(iport); 3160 task_context->logical_port_index = scic_sds_port_get_index(iport);
@@ -3166,7 +3164,7 @@ scic_io_request_construct_smp(struct device *dev,
3166 task_context->context_type = SCU_TASK_CONTEXT_TYPE; 3164 task_context->context_type = SCU_TASK_CONTEXT_TYPE;
3167 3165
3168 /* 04h */ 3166 /* 04h */
3169 task_context->remote_node_index = sci_dev->rnc.remote_node_index; 3167 task_context->remote_node_index = idev->rnc.remote_node_index;
3170 task_context->command_code = 0; 3168 task_context->command_code = 0;
3171 task_context->task_type = SCU_TASK_TYPE_SMP_REQUEST; 3169 task_context->task_type = SCU_TASK_TYPE_SMP_REQUEST;
3172 3170
@@ -3257,17 +3255,16 @@ static enum sci_status isci_smp_request_build(struct isci_request *ireq)
3257 */ 3255 */
3258static enum sci_status isci_io_request_build(struct isci_host *isci_host, 3256static enum sci_status isci_io_request_build(struct isci_host *isci_host,
3259 struct isci_request *request, 3257 struct isci_request *request,
3260 struct isci_remote_device *isci_device) 3258 struct isci_remote_device *idev)
3261{ 3259{
3262 enum sci_status status = SCI_SUCCESS; 3260 enum sci_status status = SCI_SUCCESS;
3263 struct sas_task *task = isci_request_access_task(request); 3261 struct sas_task *task = isci_request_access_task(request);
3264 struct scic_sds_remote_device *sci_device = &isci_device->sci;
3265 3262
3266 dev_dbg(&isci_host->pdev->dev, 3263 dev_dbg(&isci_host->pdev->dev,
3267 "%s: isci_device = 0x%p; request = %p, " 3264 "%s: idev = 0x%p; request = %p, "
3268 "num_scatter = %d\n", 3265 "num_scatter = %d\n",
3269 __func__, 3266 __func__,
3270 isci_device, 3267 idev,
3271 request, 3268 request,
3272 task->num_scatter); 3269 task->num_scatter);
3273 3270
@@ -3290,8 +3287,7 @@ static enum sci_status isci_io_request_build(struct isci_host *isci_host,
3290 return SCI_FAILURE_INSUFFICIENT_RESOURCES; 3287 return SCI_FAILURE_INSUFFICIENT_RESOURCES;
3291 } 3288 }
3292 3289
3293 status = scic_io_request_construct(&isci_host->sci, sci_device, 3290 status = scic_io_request_construct(&isci_host->sci, idev, request);
3294 request);
3295 3291
3296 if (status != SCI_SUCCESS) { 3292 if (status != SCI_SUCCESS) {
3297 dev_warn(&isci_host->pdev->dev, 3293 dev_warn(&isci_host->pdev->dev,
@@ -3397,14 +3393,14 @@ int isci_request_execute(struct isci_host *ihost, struct isci_remote_device *ide
3397 * ireq->is_task_management_request is false). 3393 * ireq->is_task_management_request is false).
3398 */ 3394 */
3399 status = scic_controller_start_task(&ihost->sci, 3395 status = scic_controller_start_task(&ihost->sci,
3400 &idev->sci, 3396 idev,
3401 ireq); 3397 ireq);
3402 } else { 3398 } else {
3403 status = SCI_FAILURE; 3399 status = SCI_FAILURE;
3404 } 3400 }
3405 } else { 3401 } else {
3406 /* send the request, let the core assign the IO TAG. */ 3402 /* send the request, let the core assign the IO TAG. */
3407 status = scic_controller_start_io(&ihost->sci, &idev->sci, 3403 status = scic_controller_start_io(&ihost->sci, idev,
3408 ireq); 3404 ireq);
3409 } 3405 }
3410 3406
diff --git a/drivers/scsi/isci/request.h b/drivers/scsi/isci/request.h
index 68d8a27357eb..ca64ea207ac8 100644
--- a/drivers/scsi/isci/request.h
+++ b/drivers/scsi/isci/request.h
@@ -146,7 +146,7 @@ struct isci_request {
146 struct completion *io_request_completion; 146 struct completion *io_request_completion;
147 struct sci_base_state_machine sm; 147 struct sci_base_state_machine sm;
148 struct scic_sds_controller *owning_controller; 148 struct scic_sds_controller *owning_controller;
149 struct scic_sds_remote_device *target_device; 149 struct isci_remote_device *target_device;
150 u16 io_tag; 150 u16 io_tag;
151 enum sci_request_protocol protocol; 151 enum sci_request_protocol protocol;
152 u32 scu_status; /* hardware result */ 152 u32 scu_status; /* hardware result */
@@ -501,7 +501,7 @@ void isci_terminate_pending_requests(struct isci_host *ihost,
501 struct isci_remote_device *idev); 501 struct isci_remote_device *idev);
502enum sci_status 502enum sci_status
503scic_task_request_construct(struct scic_sds_controller *scic, 503scic_task_request_construct(struct scic_sds_controller *scic,
504 struct scic_sds_remote_device *sci_dev, 504 struct isci_remote_device *idev,
505 u16 io_tag, 505 u16 io_tag,
506 struct isci_request *ireq); 506 struct isci_request *ireq);
507enum sci_status 507enum sci_status
diff --git a/drivers/scsi/isci/task.c b/drivers/scsi/isci/task.c
index 700708c82678..89b01eef44b1 100644
--- a/drivers/scsi/isci/task.c
+++ b/drivers/scsi/isci/task.c
@@ -257,7 +257,7 @@ static struct isci_request *isci_task_request_build(struct isci_host *ihost,
257 return NULL; 257 return NULL;
258 258
259 /* let the core do it's construct. */ 259 /* let the core do it's construct. */
260 status = scic_task_request_construct(&ihost->sci, &idev->sci, tag, 260 status = scic_task_request_construct(&ihost->sci, idev, tag,
261 ireq); 261 ireq);
262 262
263 if (status != SCI_SUCCESS) { 263 if (status != SCI_SUCCESS) {
@@ -288,12 +288,11 @@ static struct isci_request *isci_task_request_build(struct isci_host *ihost,
288} 288}
289 289
290int isci_task_execute_tmf(struct isci_host *ihost, 290int isci_task_execute_tmf(struct isci_host *ihost,
291 struct isci_remote_device *isci_device, 291 struct isci_remote_device *idev,
292 struct isci_tmf *tmf, unsigned long timeout_ms) 292 struct isci_tmf *tmf, unsigned long timeout_ms)
293{ 293{
294 DECLARE_COMPLETION_ONSTACK(completion); 294 DECLARE_COMPLETION_ONSTACK(completion);
295 enum sci_task_status status = SCI_TASK_FAILURE; 295 enum sci_task_status status = SCI_TASK_FAILURE;
296 struct scic_sds_remote_device *sci_device;
297 struct isci_request *ireq; 296 struct isci_request *ireq;
298 int ret = TMF_RESP_FUNC_FAILED; 297 int ret = TMF_RESP_FUNC_FAILED;
299 unsigned long flags; 298 unsigned long flags;
@@ -310,34 +309,30 @@ int isci_task_execute_tmf(struct isci_host *ihost,
310 /* sanity check, return TMF_RESP_FUNC_FAILED 309 /* sanity check, return TMF_RESP_FUNC_FAILED
311 * if the device is not there and ready. 310 * if the device is not there and ready.
312 */ 311 */
313 if (!isci_device || 312 if (!idev ||
314 (!test_bit(IDEV_IO_READY, &isci_device->flags) && 313 (!test_bit(IDEV_IO_READY, &idev->flags) &&
315 !test_bit(IDEV_IO_NCQERROR, &isci_device->flags))) { 314 !test_bit(IDEV_IO_NCQERROR, &idev->flags))) {
316 dev_dbg(&ihost->pdev->dev, 315 dev_dbg(&ihost->pdev->dev,
317 "%s: isci_device = %p not ready (%#lx)\n", 316 "%s: idev = %p not ready (%#lx)\n",
318 __func__, 317 __func__,
319 isci_device, isci_device ? isci_device->flags : 0); 318 idev, idev ? idev->flags : 0);
320 goto err_tci; 319 goto err_tci;
321 } else 320 } else
322 dev_dbg(&ihost->pdev->dev, 321 dev_dbg(&ihost->pdev->dev,
323 "%s: isci_device = %p\n", 322 "%s: idev = %p\n",
324 __func__, isci_device); 323 __func__, idev);
325
326 sci_device = &isci_device->sci;
327 324
328 /* Assign the pointer to the TMF's completion kernel wait structure. */ 325 /* Assign the pointer to the TMF's completion kernel wait structure. */
329 tmf->complete = &completion; 326 tmf->complete = &completion;
330 327
331 ireq = isci_task_request_build(ihost, isci_device, tag, tmf); 328 ireq = isci_task_request_build(ihost, idev, tag, tmf);
332 if (!ireq) 329 if (!ireq)
333 goto err_tci; 330 goto err_tci;
334 331
335 spin_lock_irqsave(&ihost->scic_lock, flags); 332 spin_lock_irqsave(&ihost->scic_lock, flags);
336 333
337 /* start the TMF io. */ 334 /* start the TMF io. */
338 status = scic_controller_start_task(&ihost->sci, 335 status = scic_controller_start_task(&ihost->sci, idev, ireq);
339 sci_device,
340 ireq);
341 336
342 if (status != SCI_TASK_SUCCESS) { 337 if (status != SCI_TASK_SUCCESS) {
343 dev_warn(&ihost->pdev->dev, 338 dev_warn(&ihost->pdev->dev,
@@ -355,7 +350,7 @@ int isci_task_execute_tmf(struct isci_host *ihost,
355 isci_request_change_state(ireq, started); 350 isci_request_change_state(ireq, started);
356 351
357 /* add the request to the remote device request list. */ 352 /* add the request to the remote device request list. */
358 list_add(&ireq->dev_node, &isci_device->reqs_in_process); 353 list_add(&ireq->dev_node, &idev->reqs_in_process);
359 354
360 spin_unlock_irqrestore(&ihost->scic_lock, flags); 355 spin_unlock_irqrestore(&ihost->scic_lock, flags);
361 356
@@ -370,7 +365,7 @@ int isci_task_execute_tmf(struct isci_host *ihost,
370 tmf->cb_state_func(isci_tmf_timed_out, tmf, tmf->cb_data); 365 tmf->cb_state_func(isci_tmf_timed_out, tmf, tmf->cb_data);
371 366
372 scic_controller_terminate_request(&ihost->sci, 367 scic_controller_terminate_request(&ihost->sci,
373 &isci_device->sci, 368 idev,
374 ireq); 369 ireq);
375 370
376 spin_unlock_irqrestore(&ihost->scic_lock, flags); 371 spin_unlock_irqrestore(&ihost->scic_lock, flags);
@@ -520,13 +515,13 @@ static void isci_request_cleanup_completed_loiterer(
520 * from a thread that can wait. Note that the request is terminated and 515 * from a thread that can wait. Note that the request is terminated and
521 * completed (back to the host, if started there). 516 * completed (back to the host, if started there).
522 * @isci_host: This SCU. 517 * @isci_host: This SCU.
523 * @isci_device: The target. 518 * @idev: The target.
524 * @isci_request: The I/O request to be terminated. 519 * @isci_request: The I/O request to be terminated.
525 * 520 *
526 */ 521 */
527static void isci_terminate_request_core( 522static void isci_terminate_request_core(
528 struct isci_host *isci_host, 523 struct isci_host *isci_host,
529 struct isci_remote_device *isci_device, 524 struct isci_remote_device *idev,
530 struct isci_request *isci_request) 525 struct isci_request *isci_request)
531{ 526{
532 enum sci_status status = SCI_SUCCESS; 527 enum sci_status status = SCI_SUCCESS;
@@ -540,7 +535,7 @@ static void isci_terminate_request_core(
540 535
541 dev_dbg(&isci_host->pdev->dev, 536 dev_dbg(&isci_host->pdev->dev,
542 "%s: device = %p; request = %p\n", 537 "%s: device = %p; request = %p\n",
543 __func__, isci_device, isci_request); 538 __func__, idev, isci_request);
544 539
545 spin_lock_irqsave(&isci_host->scic_lock, flags); 540 spin_lock_irqsave(&isci_host->scic_lock, flags);
546 541
@@ -564,7 +559,7 @@ static void isci_terminate_request_core(
564 needs_cleanup_handling = true; 559 needs_cleanup_handling = true;
565 status = scic_controller_terminate_request( 560 status = scic_controller_terminate_request(
566 &isci_host->sci, 561 &isci_host->sci,
567 &isci_device->sci, 562 idev,
568 isci_request); 563 isci_request);
569 } 564 }
570 spin_unlock_irqrestore(&isci_host->scic_lock, flags); 565 spin_unlock_irqrestore(&isci_host->scic_lock, flags);
@@ -683,7 +678,7 @@ static void isci_terminate_request_core(
683 } 678 }
684 if (needs_cleanup_handling) 679 if (needs_cleanup_handling)
685 isci_request_cleanup_completed_loiterer( 680 isci_request_cleanup_completed_loiterer(
686 isci_host, isci_device, isci_request, task); 681 isci_host, idev, isci_request, task);
687 } 682 }
688} 683}
689 684
@@ -694,7 +689,7 @@ static void isci_terminate_request_core(
694 * called from a thread that can wait. Note that the requests are all 689 * called from a thread that can wait. Note that the requests are all
695 * terminated and completed (back to the host, if started there). 690 * terminated and completed (back to the host, if started there).
696 * @isci_host: This parameter specifies SCU. 691 * @isci_host: This parameter specifies SCU.
697 * @isci_device: This parameter specifies the target. 692 * @idev: This parameter specifies the target.
698 * 693 *
699 */ 694 */
700void isci_terminate_pending_requests(struct isci_host *ihost, 695void isci_terminate_pending_requests(struct isci_host *ihost,
@@ -1521,7 +1516,7 @@ static int isci_reset_device(struct isci_host *ihost,
1521 dev_dbg(&ihost->pdev->dev, "%s: idev %p\n", __func__, idev); 1516 dev_dbg(&ihost->pdev->dev, "%s: idev %p\n", __func__, idev);
1522 1517
1523 spin_lock_irqsave(&ihost->scic_lock, flags); 1518 spin_lock_irqsave(&ihost->scic_lock, flags);
1524 status = scic_remote_device_reset(&idev->sci); 1519 status = scic_remote_device_reset(idev);
1525 if (status != SCI_SUCCESS) { 1520 if (status != SCI_SUCCESS) {
1526 spin_unlock_irqrestore(&ihost->scic_lock, flags); 1521 spin_unlock_irqrestore(&ihost->scic_lock, flags);
1527 1522
@@ -1547,7 +1542,7 @@ static int isci_reset_device(struct isci_host *ihost,
1547 1542
1548 /* Since all pending TCs have been cleaned, resume the RNC. */ 1543 /* Since all pending TCs have been cleaned, resume the RNC. */
1549 spin_lock_irqsave(&ihost->scic_lock, flags); 1544 spin_lock_irqsave(&ihost->scic_lock, flags);
1550 status = scic_remote_device_reset_complete(&idev->sci); 1545 status = scic_remote_device_reset_complete(idev);
1551 spin_unlock_irqrestore(&ihost->scic_lock, flags); 1546 spin_unlock_irqrestore(&ihost->scic_lock, flags);
1552 1547
1553 /* If this is a device on an expander, bring the phy back up. */ 1548 /* If this is a device on an expander, bring the phy back up. */