diff options
Diffstat (limited to 'drivers')
-rw-r--r-- | drivers/ieee1394/sbp2.c | 300 |
1 files changed, 20 insertions, 280 deletions
diff --git a/drivers/ieee1394/sbp2.c b/drivers/ieee1394/sbp2.c index ecbb5ee500ab..6bd26a91111e 100644 --- a/drivers/ieee1394/sbp2.c +++ b/drivers/ieee1394/sbp2.c | |||
@@ -179,54 +179,9 @@ MODULE_PARM_DESC(workarounds, "Work around device bugs (default = 0" | |||
179 | ", override internal blacklist = " __stringify(SBP2_WORKAROUND_OVERRIDE) | 179 | ", override internal blacklist = " __stringify(SBP2_WORKAROUND_OVERRIDE) |
180 | ", or a combination)"); | 180 | ", or a combination)"); |
181 | 181 | ||
182 | /* | ||
183 | * Debug levels, configured via kernel config, or enable here. | ||
184 | */ | ||
185 | |||
186 | #define CONFIG_IEEE1394_SBP2_DEBUG 0 | ||
187 | /* #define CONFIG_IEEE1394_SBP2_DEBUG_ORBS */ | ||
188 | /* #define CONFIG_IEEE1394_SBP2_DEBUG_DMA */ | ||
189 | /* #define CONFIG_IEEE1394_SBP2_DEBUG 1 */ | ||
190 | /* #define CONFIG_IEEE1394_SBP2_DEBUG 2 */ | ||
191 | /* #define CONFIG_IEEE1394_SBP2_PACKET_DUMP */ | ||
192 | |||
193 | #ifdef CONFIG_IEEE1394_SBP2_DEBUG_ORBS | ||
194 | #define SBP2_ORB_DEBUG(fmt, args...) HPSB_ERR("sbp2(%s): "fmt, __FUNCTION__, ## args) | ||
195 | static u32 global_outstanding_command_orbs = 0; | ||
196 | #define outstanding_orb_incr global_outstanding_command_orbs++ | ||
197 | #define outstanding_orb_decr global_outstanding_command_orbs-- | ||
198 | #else | ||
199 | #define SBP2_ORB_DEBUG(fmt, args...) do {} while (0) | ||
200 | #define outstanding_orb_incr do {} while (0) | ||
201 | #define outstanding_orb_decr do {} while (0) | ||
202 | #endif | ||
203 | |||
204 | #ifdef CONFIG_IEEE1394_SBP2_DEBUG_DMA | ||
205 | #define SBP2_DMA_ALLOC(fmt, args...) \ | ||
206 | HPSB_ERR("sbp2(%s)alloc(%d): "fmt, __FUNCTION__, \ | ||
207 | ++global_outstanding_dmas, ## args) | ||
208 | #define SBP2_DMA_FREE(fmt, args...) \ | ||
209 | HPSB_ERR("sbp2(%s)free(%d): "fmt, __FUNCTION__, \ | ||
210 | --global_outstanding_dmas, ## args) | ||
211 | static u32 global_outstanding_dmas = 0; | ||
212 | #else | ||
213 | #define SBP2_DMA_ALLOC(fmt, args...) do {} while (0) | ||
214 | #define SBP2_DMA_FREE(fmt, args...) do {} while (0) | ||
215 | #endif | ||
216 | 182 | ||
217 | #if CONFIG_IEEE1394_SBP2_DEBUG >= 2 | 183 | #define SBP2_INFO(fmt, args...) HPSB_INFO("sbp2: "fmt, ## args) |
218 | #define SBP2_DEBUG(fmt, args...) HPSB_ERR("sbp2: "fmt, ## args) | 184 | #define SBP2_ERR(fmt, args...) HPSB_ERR("sbp2: "fmt, ## args) |
219 | #define SBP2_INFO(fmt, args...) HPSB_ERR("sbp2: "fmt, ## args) | ||
220 | #elif CONFIG_IEEE1394_SBP2_DEBUG == 1 | ||
221 | #define SBP2_DEBUG(fmt, args...) HPSB_DEBUG("sbp2: "fmt, ## args) | ||
222 | #define SBP2_INFO(fmt, args...) HPSB_INFO("sbp2: "fmt, ## args) | ||
223 | #else | ||
224 | #define SBP2_DEBUG(fmt, args...) do {} while (0) | ||
225 | #define SBP2_INFO(fmt, args...) HPSB_INFO("sbp2: "fmt, ## args) | ||
226 | #endif | ||
227 | |||
228 | #define SBP2_ERR(fmt, args...) HPSB_ERR("sbp2: "fmt, ## args) | ||
229 | #define SBP2_DEBUG_ENTER() SBP2_DEBUG("%s", __FUNCTION__) | ||
230 | 185 | ||
231 | /* | 186 | /* |
232 | * Globals | 187 | * Globals |
@@ -433,42 +388,6 @@ static inline void sbp2util_cpu_to_be32_buffer(void *buffer, int length) | |||
433 | #define sbp2util_cpu_to_be32_buffer(x,y) do {} while (0) | 388 | #define sbp2util_cpu_to_be32_buffer(x,y) do {} while (0) |
434 | #endif | 389 | #endif |
435 | 390 | ||
436 | #ifdef CONFIG_IEEE1394_SBP2_PACKET_DUMP | ||
437 | /* | ||
438 | * Debug packet dump routine. Length is in bytes. | ||
439 | */ | ||
440 | static void sbp2util_packet_dump(void *buffer, int length, char *dump_name, | ||
441 | u32 dump_phys_addr) | ||
442 | { | ||
443 | int i; | ||
444 | unsigned char *dump = buffer; | ||
445 | |||
446 | if (!dump || !length || !dump_name) | ||
447 | return; | ||
448 | |||
449 | if (dump_phys_addr) | ||
450 | printk("[%s, 0x%x]", dump_name, dump_phys_addr); | ||
451 | else | ||
452 | printk("[%s]", dump_name); | ||
453 | for (i = 0; i < length; i++) { | ||
454 | if (i > 0x3f) { | ||
455 | printk("\n ..."); | ||
456 | break; | ||
457 | } | ||
458 | if ((i & 0x3) == 0) | ||
459 | printk(" "); | ||
460 | if ((i & 0xf) == 0) | ||
461 | printk("\n "); | ||
462 | printk("%02x ", (int)dump[i]); | ||
463 | } | ||
464 | printk("\n"); | ||
465 | |||
466 | return; | ||
467 | } | ||
468 | #else | ||
469 | #define sbp2util_packet_dump(w,x,y,z) do {} while (0) | ||
470 | #endif | ||
471 | |||
472 | static DECLARE_WAIT_QUEUE_HEAD(access_wq); | 391 | static DECLARE_WAIT_QUEUE_HEAD(access_wq); |
473 | 392 | ||
474 | /* | 393 | /* |
@@ -587,13 +506,11 @@ static int sbp2util_create_command_orb_pool(struct scsi_id_instance_data *scsi_i | |||
587 | pci_map_single(hi->host->pdev, &command->command_orb, | 506 | pci_map_single(hi->host->pdev, &command->command_orb, |
588 | sizeof(struct sbp2_command_orb), | 507 | sizeof(struct sbp2_command_orb), |
589 | PCI_DMA_TODEVICE); | 508 | PCI_DMA_TODEVICE); |
590 | SBP2_DMA_ALLOC("single command orb DMA"); | ||
591 | command->sge_dma = | 509 | command->sge_dma = |
592 | pci_map_single(hi->host->pdev, | 510 | pci_map_single(hi->host->pdev, |
593 | &command->scatter_gather_element, | 511 | &command->scatter_gather_element, |
594 | sizeof(command->scatter_gather_element), | 512 | sizeof(command->scatter_gather_element), |
595 | PCI_DMA_BIDIRECTIONAL); | 513 | PCI_DMA_BIDIRECTIONAL); |
596 | SBP2_DMA_ALLOC("scatter_gather_element"); | ||
597 | INIT_LIST_HEAD(&command->list); | 514 | INIT_LIST_HEAD(&command->list); |
598 | list_add_tail(&command->list, &scsi_id->sbp2_command_orb_completed); | 515 | list_add_tail(&command->list, &scsi_id->sbp2_command_orb_completed); |
599 | } | 516 | } |
@@ -620,12 +537,9 @@ static void sbp2util_remove_command_orb_pool(struct scsi_id_instance_data *scsi_ | |||
620 | pci_unmap_single(host->pdev, command->command_orb_dma, | 537 | pci_unmap_single(host->pdev, command->command_orb_dma, |
621 | sizeof(struct sbp2_command_orb), | 538 | sizeof(struct sbp2_command_orb), |
622 | PCI_DMA_TODEVICE); | 539 | PCI_DMA_TODEVICE); |
623 | SBP2_DMA_FREE("single command orb DMA"); | ||
624 | pci_unmap_single(host->pdev, command->sge_dma, | 540 | pci_unmap_single(host->pdev, command->sge_dma, |
625 | sizeof(command->scatter_gather_element), | 541 | sizeof(command->scatter_gather_element), |
626 | PCI_DMA_BIDIRECTIONAL); | 542 | PCI_DMA_BIDIRECTIONAL); |
627 | SBP2_DMA_FREE("scatter_gather_element"); | ||
628 | |||
629 | kfree(command); | 543 | kfree(command); |
630 | } | 544 | } |
631 | } | 545 | } |
@@ -653,9 +567,6 @@ static struct sbp2_command_info *sbp2util_find_command_for_orb( | |||
653 | } | 567 | } |
654 | } | 568 | } |
655 | spin_unlock_irqrestore(&scsi_id->sbp2_command_orb_lock, flags); | 569 | spin_unlock_irqrestore(&scsi_id->sbp2_command_orb_lock, flags); |
656 | |||
657 | SBP2_ORB_DEBUG("could not match command orb %x", (unsigned int)orb); | ||
658 | |||
659 | return NULL; | 570 | return NULL; |
660 | } | 571 | } |
661 | 572 | ||
@@ -718,15 +629,13 @@ static void sbp2util_free_command_dma(struct sbp2_command_info *command) | |||
718 | host = scsi_id->ud->ne->host; | 629 | host = scsi_id->ud->ne->host; |
719 | 630 | ||
720 | if (command->cmd_dma) { | 631 | if (command->cmd_dma) { |
721 | if (command->dma_type == CMD_DMA_SINGLE) { | 632 | if (command->dma_type == CMD_DMA_SINGLE) |
722 | pci_unmap_single(host->pdev, command->cmd_dma, | 633 | pci_unmap_single(host->pdev, command->cmd_dma, |
723 | command->dma_size, command->dma_dir); | 634 | command->dma_size, command->dma_dir); |
724 | SBP2_DMA_FREE("single bulk"); | 635 | else if (command->dma_type == CMD_DMA_PAGE) |
725 | } else if (command->dma_type == CMD_DMA_PAGE) { | ||
726 | pci_unmap_page(host->pdev, command->cmd_dma, | 636 | pci_unmap_page(host->pdev, command->cmd_dma, |
727 | command->dma_size, command->dma_dir); | 637 | command->dma_size, command->dma_dir); |
728 | SBP2_DMA_FREE("single page"); | 638 | /* XXX: Check for CMD_DMA_NONE bug */ |
729 | } /* XXX: Check for CMD_DMA_NONE bug */ | ||
730 | command->dma_type = CMD_DMA_NONE; | 639 | command->dma_type = CMD_DMA_NONE; |
731 | command->cmd_dma = 0; | 640 | command->cmd_dma = 0; |
732 | } | 641 | } |
@@ -734,7 +643,6 @@ static void sbp2util_free_command_dma(struct sbp2_command_info *command) | |||
734 | if (command->sge_buffer) { | 643 | if (command->sge_buffer) { |
735 | pci_unmap_sg(host->pdev, command->sge_buffer, | 644 | pci_unmap_sg(host->pdev, command->sge_buffer, |
736 | command->dma_size, command->dma_dir); | 645 | command->dma_size, command->dma_dir); |
737 | SBP2_DMA_FREE("scatter list"); | ||
738 | command->sge_buffer = NULL; | 646 | command->sge_buffer = NULL; |
739 | } | 647 | } |
740 | } | 648 | } |
@@ -769,8 +677,6 @@ static int sbp2_probe(struct device *dev) | |||
769 | struct unit_directory *ud; | 677 | struct unit_directory *ud; |
770 | struct scsi_id_instance_data *scsi_id; | 678 | struct scsi_id_instance_data *scsi_id; |
771 | 679 | ||
772 | SBP2_DEBUG_ENTER(); | ||
773 | |||
774 | ud = container_of(dev, struct unit_directory, device); | 680 | ud = container_of(dev, struct unit_directory, device); |
775 | 681 | ||
776 | /* Don't probe UD's that have the LUN flag. We'll probe the LUN(s) | 682 | /* Don't probe UD's that have the LUN flag. We'll probe the LUN(s) |
@@ -794,8 +700,6 @@ static int sbp2_remove(struct device *dev) | |||
794 | struct scsi_id_instance_data *scsi_id; | 700 | struct scsi_id_instance_data *scsi_id; |
795 | struct scsi_device *sdev; | 701 | struct scsi_device *sdev; |
796 | 702 | ||
797 | SBP2_DEBUG_ENTER(); | ||
798 | |||
799 | ud = container_of(dev, struct unit_directory, device); | 703 | ud = container_of(dev, struct unit_directory, device); |
800 | scsi_id = ud->device.driver_data; | 704 | scsi_id = ud->device.driver_data; |
801 | if (!scsi_id) | 705 | if (!scsi_id) |
@@ -827,8 +731,6 @@ static int sbp2_update(struct unit_directory *ud) | |||
827 | { | 731 | { |
828 | struct scsi_id_instance_data *scsi_id = ud->device.driver_data; | 732 | struct scsi_id_instance_data *scsi_id = ud->device.driver_data; |
829 | 733 | ||
830 | SBP2_DEBUG_ENTER(); | ||
831 | |||
832 | if (sbp2_reconnect_device(scsi_id)) { | 734 | if (sbp2_reconnect_device(scsi_id)) { |
833 | 735 | ||
834 | /* | 736 | /* |
@@ -877,8 +779,6 @@ static struct scsi_id_instance_data *sbp2_alloc_device(struct unit_directory *ud | |||
877 | struct Scsi_Host *scsi_host = NULL; | 779 | struct Scsi_Host *scsi_host = NULL; |
878 | struct scsi_id_instance_data *scsi_id = NULL; | 780 | struct scsi_id_instance_data *scsi_id = NULL; |
879 | 781 | ||
880 | SBP2_DEBUG_ENTER(); | ||
881 | |||
882 | scsi_id = kzalloc(sizeof(*scsi_id), GFP_KERNEL); | 782 | scsi_id = kzalloc(sizeof(*scsi_id), GFP_KERNEL); |
883 | if (!scsi_id) { | 783 | if (!scsi_id) { |
884 | SBP2_ERR("failed to create scsi_id"); | 784 | SBP2_ERR("failed to create scsi_id"); |
@@ -906,7 +806,6 @@ static struct scsi_id_instance_data *sbp2_alloc_device(struct unit_directory *ud | |||
906 | SBP2_ERR("failed to allocate hostinfo"); | 806 | SBP2_ERR("failed to allocate hostinfo"); |
907 | goto failed_alloc; | 807 | goto failed_alloc; |
908 | } | 808 | } |
909 | SBP2_DEBUG("sbp2_alloc_device: allocated hostinfo"); | ||
910 | hi->host = ud->ne->host; | 809 | hi->host = ud->ne->host; |
911 | INIT_LIST_HEAD(&hi->scsi_ids); | 810 | INIT_LIST_HEAD(&hi->scsi_ids); |
912 | 811 | ||
@@ -997,8 +896,6 @@ static int sbp2_start_device(struct scsi_id_instance_data *scsi_id) | |||
997 | struct sbp2scsi_host_info *hi = scsi_id->hi; | 896 | struct sbp2scsi_host_info *hi = scsi_id->hi; |
998 | int error; | 897 | int error; |
999 | 898 | ||
1000 | SBP2_DEBUG_ENTER(); | ||
1001 | |||
1002 | /* Login FIFO DMA */ | 899 | /* Login FIFO DMA */ |
1003 | scsi_id->login_response = | 900 | scsi_id->login_response = |
1004 | pci_alloc_consistent(hi->host->pdev, | 901 | pci_alloc_consistent(hi->host->pdev, |
@@ -1006,7 +903,6 @@ static int sbp2_start_device(struct scsi_id_instance_data *scsi_id) | |||
1006 | &scsi_id->login_response_dma); | 903 | &scsi_id->login_response_dma); |
1007 | if (!scsi_id->login_response) | 904 | if (!scsi_id->login_response) |
1008 | goto alloc_fail; | 905 | goto alloc_fail; |
1009 | SBP2_DMA_ALLOC("consistent DMA region for login FIFO"); | ||
1010 | 906 | ||
1011 | /* Query logins ORB DMA */ | 907 | /* Query logins ORB DMA */ |
1012 | scsi_id->query_logins_orb = | 908 | scsi_id->query_logins_orb = |
@@ -1015,7 +911,6 @@ static int sbp2_start_device(struct scsi_id_instance_data *scsi_id) | |||
1015 | &scsi_id->query_logins_orb_dma); | 911 | &scsi_id->query_logins_orb_dma); |
1016 | if (!scsi_id->query_logins_orb) | 912 | if (!scsi_id->query_logins_orb) |
1017 | goto alloc_fail; | 913 | goto alloc_fail; |
1018 | SBP2_DMA_ALLOC("consistent DMA region for query logins ORB"); | ||
1019 | 914 | ||
1020 | /* Query logins response DMA */ | 915 | /* Query logins response DMA */ |
1021 | scsi_id->query_logins_response = | 916 | scsi_id->query_logins_response = |
@@ -1024,7 +919,6 @@ static int sbp2_start_device(struct scsi_id_instance_data *scsi_id) | |||
1024 | &scsi_id->query_logins_response_dma); | 919 | &scsi_id->query_logins_response_dma); |
1025 | if (!scsi_id->query_logins_response) | 920 | if (!scsi_id->query_logins_response) |
1026 | goto alloc_fail; | 921 | goto alloc_fail; |
1027 | SBP2_DMA_ALLOC("consistent DMA region for query logins response"); | ||
1028 | 922 | ||
1029 | /* Reconnect ORB DMA */ | 923 | /* Reconnect ORB DMA */ |
1030 | scsi_id->reconnect_orb = | 924 | scsi_id->reconnect_orb = |
@@ -1033,7 +927,6 @@ static int sbp2_start_device(struct scsi_id_instance_data *scsi_id) | |||
1033 | &scsi_id->reconnect_orb_dma); | 927 | &scsi_id->reconnect_orb_dma); |
1034 | if (!scsi_id->reconnect_orb) | 928 | if (!scsi_id->reconnect_orb) |
1035 | goto alloc_fail; | 929 | goto alloc_fail; |
1036 | SBP2_DMA_ALLOC("consistent DMA region for reconnect ORB"); | ||
1037 | 930 | ||
1038 | /* Logout ORB DMA */ | 931 | /* Logout ORB DMA */ |
1039 | scsi_id->logout_orb = | 932 | scsi_id->logout_orb = |
@@ -1042,7 +935,6 @@ static int sbp2_start_device(struct scsi_id_instance_data *scsi_id) | |||
1042 | &scsi_id->logout_orb_dma); | 935 | &scsi_id->logout_orb_dma); |
1043 | if (!scsi_id->logout_orb) | 936 | if (!scsi_id->logout_orb) |
1044 | goto alloc_fail; | 937 | goto alloc_fail; |
1045 | SBP2_DMA_ALLOC("consistent DMA region for logout ORB"); | ||
1046 | 938 | ||
1047 | /* Login ORB DMA */ | 939 | /* Login ORB DMA */ |
1048 | scsi_id->login_orb = | 940 | scsi_id->login_orb = |
@@ -1051,9 +943,6 @@ static int sbp2_start_device(struct scsi_id_instance_data *scsi_id) | |||
1051 | &scsi_id->login_orb_dma); | 943 | &scsi_id->login_orb_dma); |
1052 | if (!scsi_id->login_orb) | 944 | if (!scsi_id->login_orb) |
1053 | goto alloc_fail; | 945 | goto alloc_fail; |
1054 | SBP2_DMA_ALLOC("consistent DMA region for login ORB"); | ||
1055 | |||
1056 | SBP2_DEBUG("New SBP-2 device inserted, SCSI ID = %x", scsi_id->ud->id); | ||
1057 | 946 | ||
1058 | /* | 947 | /* |
1059 | * Create our command orb pool | 948 | * Create our command orb pool |
@@ -1123,8 +1012,6 @@ static void sbp2_remove_device(struct scsi_id_instance_data *scsi_id) | |||
1123 | { | 1012 | { |
1124 | struct sbp2scsi_host_info *hi; | 1013 | struct sbp2scsi_host_info *hi; |
1125 | 1014 | ||
1126 | SBP2_DEBUG_ENTER(); | ||
1127 | |||
1128 | if (!scsi_id) | 1015 | if (!scsi_id) |
1129 | return; | 1016 | return; |
1130 | 1017 | ||
@@ -1140,53 +1027,36 @@ static void sbp2_remove_device(struct scsi_id_instance_data *scsi_id) | |||
1140 | 1027 | ||
1141 | list_del(&scsi_id->scsi_list); | 1028 | list_del(&scsi_id->scsi_list); |
1142 | 1029 | ||
1143 | if (scsi_id->login_response) { | 1030 | if (scsi_id->login_response) |
1144 | pci_free_consistent(hi->host->pdev, | 1031 | pci_free_consistent(hi->host->pdev, |
1145 | sizeof(struct sbp2_login_response), | 1032 | sizeof(struct sbp2_login_response), |
1146 | scsi_id->login_response, | 1033 | scsi_id->login_response, |
1147 | scsi_id->login_response_dma); | 1034 | scsi_id->login_response_dma); |
1148 | SBP2_DMA_FREE("single login FIFO"); | 1035 | if (scsi_id->login_orb) |
1149 | } | ||
1150 | |||
1151 | if (scsi_id->login_orb) { | ||
1152 | pci_free_consistent(hi->host->pdev, | 1036 | pci_free_consistent(hi->host->pdev, |
1153 | sizeof(struct sbp2_login_orb), | 1037 | sizeof(struct sbp2_login_orb), |
1154 | scsi_id->login_orb, | 1038 | scsi_id->login_orb, |
1155 | scsi_id->login_orb_dma); | 1039 | scsi_id->login_orb_dma); |
1156 | SBP2_DMA_FREE("single login ORB"); | 1040 | if (scsi_id->reconnect_orb) |
1157 | } | ||
1158 | |||
1159 | if (scsi_id->reconnect_orb) { | ||
1160 | pci_free_consistent(hi->host->pdev, | 1041 | pci_free_consistent(hi->host->pdev, |
1161 | sizeof(struct sbp2_reconnect_orb), | 1042 | sizeof(struct sbp2_reconnect_orb), |
1162 | scsi_id->reconnect_orb, | 1043 | scsi_id->reconnect_orb, |
1163 | scsi_id->reconnect_orb_dma); | 1044 | scsi_id->reconnect_orb_dma); |
1164 | SBP2_DMA_FREE("single reconnect orb"); | 1045 | if (scsi_id->logout_orb) |
1165 | } | ||
1166 | |||
1167 | if (scsi_id->logout_orb) { | ||
1168 | pci_free_consistent(hi->host->pdev, | 1046 | pci_free_consistent(hi->host->pdev, |
1169 | sizeof(struct sbp2_logout_orb), | 1047 | sizeof(struct sbp2_logout_orb), |
1170 | scsi_id->logout_orb, | 1048 | scsi_id->logout_orb, |
1171 | scsi_id->logout_orb_dma); | 1049 | scsi_id->logout_orb_dma); |
1172 | SBP2_DMA_FREE("single logout orb"); | 1050 | if (scsi_id->query_logins_orb) |
1173 | } | ||
1174 | |||
1175 | if (scsi_id->query_logins_orb) { | ||
1176 | pci_free_consistent(hi->host->pdev, | 1051 | pci_free_consistent(hi->host->pdev, |
1177 | sizeof(struct sbp2_query_logins_orb), | 1052 | sizeof(struct sbp2_query_logins_orb), |
1178 | scsi_id->query_logins_orb, | 1053 | scsi_id->query_logins_orb, |
1179 | scsi_id->query_logins_orb_dma); | 1054 | scsi_id->query_logins_orb_dma); |
1180 | SBP2_DMA_FREE("single query logins orb"); | 1055 | if (scsi_id->query_logins_response) |
1181 | } | ||
1182 | |||
1183 | if (scsi_id->query_logins_response) { | ||
1184 | pci_free_consistent(hi->host->pdev, | 1056 | pci_free_consistent(hi->host->pdev, |
1185 | sizeof(struct sbp2_query_logins_response), | 1057 | sizeof(struct sbp2_query_logins_response), |
1186 | scsi_id->query_logins_response, | 1058 | scsi_id->query_logins_response, |
1187 | scsi_id->query_logins_response_dma); | 1059 | scsi_id->query_logins_response_dma); |
1188 | SBP2_DMA_FREE("single query logins data"); | ||
1189 | } | ||
1190 | 1060 | ||
1191 | if (scsi_id->status_fifo_addr != CSR1212_INVALID_ADDR_SPACE) | 1061 | if (scsi_id->status_fifo_addr != CSR1212_INVALID_ADDR_SPACE) |
1192 | hpsb_unregister_addrspace(&sbp2_highlevel, hi->host, | 1062 | hpsb_unregister_addrspace(&sbp2_highlevel, hi->host, |
@@ -1197,8 +1067,6 @@ static void sbp2_remove_device(struct scsi_id_instance_data *scsi_id) | |||
1197 | if (hi) | 1067 | if (hi) |
1198 | module_put(hi->host->driver->owner); | 1068 | module_put(hi->host->driver->owner); |
1199 | 1069 | ||
1200 | SBP2_DEBUG("SBP-2 device removed, SCSI ID = %d", scsi_id->ud->id); | ||
1201 | |||
1202 | kfree(scsi_id); | 1070 | kfree(scsi_id); |
1203 | } | 1071 | } |
1204 | 1072 | ||
@@ -1216,8 +1084,6 @@ static int sbp2_handle_physdma_write(struct hpsb_host *host, int nodeid, | |||
1216 | * Manually put the data in the right place. | 1084 | * Manually put the data in the right place. |
1217 | */ | 1085 | */ |
1218 | memcpy(bus_to_virt((u32) addr), data, length); | 1086 | memcpy(bus_to_virt((u32) addr), data, length); |
1219 | sbp2util_packet_dump(data, length, "sbp2 phys dma write by device", | ||
1220 | (u32) addr); | ||
1221 | return RCODE_COMPLETE; | 1087 | return RCODE_COMPLETE; |
1222 | } | 1088 | } |
1223 | 1089 | ||
@@ -1234,8 +1100,6 @@ static int sbp2_handle_physdma_read(struct hpsb_host *host, int nodeid, | |||
1234 | * Grab data from memory and send a read response. | 1100 | * Grab data from memory and send a read response. |
1235 | */ | 1101 | */ |
1236 | memcpy(data, bus_to_virt((u32) addr), length); | 1102 | memcpy(data, bus_to_virt((u32) addr), length); |
1237 | sbp2util_packet_dump(data, length, "sbp2 phys dma read by device", | ||
1238 | (u32) addr); | ||
1239 | return RCODE_COMPLETE; | 1103 | return RCODE_COMPLETE; |
1240 | } | 1104 | } |
1241 | #endif | 1105 | #endif |
@@ -1255,8 +1119,6 @@ static int sbp2_query_logins(struct scsi_id_instance_data *scsi_id) | |||
1255 | int max_logins; | 1119 | int max_logins; |
1256 | int active_logins; | 1120 | int active_logins; |
1257 | 1121 | ||
1258 | SBP2_DEBUG_ENTER(); | ||
1259 | |||
1260 | scsi_id->query_logins_orb->reserved1 = 0x0; | 1122 | scsi_id->query_logins_orb->reserved1 = 0x0; |
1261 | scsi_id->query_logins_orb->reserved2 = 0x0; | 1123 | scsi_id->query_logins_orb->reserved2 = 0x0; |
1262 | 1124 | ||
@@ -1277,9 +1139,6 @@ static int sbp2_query_logins(struct scsi_id_instance_data *scsi_id) | |||
1277 | 1139 | ||
1278 | sbp2util_cpu_to_be32_buffer(scsi_id->query_logins_orb, sizeof(struct sbp2_query_logins_orb)); | 1140 | sbp2util_cpu_to_be32_buffer(scsi_id->query_logins_orb, sizeof(struct sbp2_query_logins_orb)); |
1279 | 1141 | ||
1280 | sbp2util_packet_dump(scsi_id->query_logins_orb, sizeof(struct sbp2_query_logins_orb), | ||
1281 | "sbp2 query logins orb", scsi_id->query_logins_orb_dma); | ||
1282 | |||
1283 | memset(scsi_id->query_logins_response, 0, sizeof(struct sbp2_query_logins_response)); | 1142 | memset(scsi_id->query_logins_response, 0, sizeof(struct sbp2_query_logins_response)); |
1284 | 1143 | ||
1285 | data[0] = ORB_SET_NODE_ID(hi->host->node_id); | 1144 | data[0] = ORB_SET_NODE_ID(hi->host->node_id); |
@@ -1305,9 +1164,6 @@ static int sbp2_query_logins(struct scsi_id_instance_data *scsi_id) | |||
1305 | 1164 | ||
1306 | sbp2util_cpu_to_be32_buffer(scsi_id->query_logins_response, sizeof(struct sbp2_query_logins_response)); | 1165 | sbp2util_cpu_to_be32_buffer(scsi_id->query_logins_response, sizeof(struct sbp2_query_logins_response)); |
1307 | 1166 | ||
1308 | SBP2_DEBUG("length_max_logins = %x", | ||
1309 | (unsigned int)scsi_id->query_logins_response->length_max_logins); | ||
1310 | |||
1311 | max_logins = RESPONSE_GET_MAX_LOGINS(scsi_id->query_logins_response->length_max_logins); | 1167 | max_logins = RESPONSE_GET_MAX_LOGINS(scsi_id->query_logins_response->length_max_logins); |
1312 | SBP2_INFO("Maximum concurrent logins supported: %d", max_logins); | 1168 | SBP2_INFO("Maximum concurrent logins supported: %d", max_logins); |
1313 | 1169 | ||
@@ -1330,12 +1186,8 @@ static int sbp2_login_device(struct scsi_id_instance_data *scsi_id) | |||
1330 | struct sbp2scsi_host_info *hi = scsi_id->hi; | 1186 | struct sbp2scsi_host_info *hi = scsi_id->hi; |
1331 | quadlet_t data[2]; | 1187 | quadlet_t data[2]; |
1332 | 1188 | ||
1333 | SBP2_DEBUG_ENTER(); | 1189 | if (!scsi_id->login_orb) |
1334 | |||
1335 | if (!scsi_id->login_orb) { | ||
1336 | SBP2_DEBUG("%s: login_orb not alloc'd!", __FUNCTION__); | ||
1337 | return -EIO; | 1190 | return -EIO; |
1338 | } | ||
1339 | 1191 | ||
1340 | if (!exclusive_login) { | 1192 | if (!exclusive_login) { |
1341 | if (sbp2_query_logins(scsi_id)) { | 1193 | if (sbp2_query_logins(scsi_id)) { |
@@ -1367,9 +1219,6 @@ static int sbp2_login_device(struct scsi_id_instance_data *scsi_id) | |||
1367 | 1219 | ||
1368 | sbp2util_cpu_to_be32_buffer(scsi_id->login_orb, sizeof(struct sbp2_login_orb)); | 1220 | sbp2util_cpu_to_be32_buffer(scsi_id->login_orb, sizeof(struct sbp2_login_orb)); |
1369 | 1221 | ||
1370 | sbp2util_packet_dump(scsi_id->login_orb, sizeof(struct sbp2_login_orb), | ||
1371 | "sbp2 login orb", scsi_id->login_orb_dma); | ||
1372 | |||
1373 | memset(scsi_id->login_response, 0, sizeof(struct sbp2_login_response)); | 1222 | memset(scsi_id->login_response, 0, sizeof(struct sbp2_login_response)); |
1374 | 1223 | ||
1375 | data[0] = ORB_SET_NODE_ID(hi->host->node_id); | 1224 | data[0] = ORB_SET_NODE_ID(hi->host->node_id); |
@@ -1408,11 +1257,6 @@ static int sbp2_login_device(struct scsi_id_instance_data *scsi_id) | |||
1408 | /* | 1257 | /* |
1409 | * Grab our command block agent address from the login response. | 1258 | * Grab our command block agent address from the login response. |
1410 | */ | 1259 | */ |
1411 | SBP2_DEBUG("command_block_agent_hi = %x", | ||
1412 | (unsigned int)scsi_id->login_response->command_block_agent_hi); | ||
1413 | SBP2_DEBUG("command_block_agent_lo = %x", | ||
1414 | (unsigned int)scsi_id->login_response->command_block_agent_lo); | ||
1415 | |||
1416 | scsi_id->sbp2_command_block_agent_addr = | 1260 | scsi_id->sbp2_command_block_agent_addr = |
1417 | ((u64)scsi_id->login_response->command_block_agent_hi) << 32; | 1261 | ((u64)scsi_id->login_response->command_block_agent_hi) << 32; |
1418 | scsi_id->sbp2_command_block_agent_addr |= ((u64)scsi_id->login_response->command_block_agent_lo); | 1262 | scsi_id->sbp2_command_block_agent_addr |= ((u64)scsi_id->login_response->command_block_agent_lo); |
@@ -1432,8 +1276,6 @@ static int sbp2_logout_device(struct scsi_id_instance_data *scsi_id) | |||
1432 | quadlet_t data[2]; | 1276 | quadlet_t data[2]; |
1433 | int error; | 1277 | int error; |
1434 | 1278 | ||
1435 | SBP2_DEBUG_ENTER(); | ||
1436 | |||
1437 | /* | 1279 | /* |
1438 | * Set-up logout ORB | 1280 | * Set-up logout ORB |
1439 | */ | 1281 | */ |
@@ -1459,9 +1301,6 @@ static int sbp2_logout_device(struct scsi_id_instance_data *scsi_id) | |||
1459 | */ | 1301 | */ |
1460 | sbp2util_cpu_to_be32_buffer(scsi_id->logout_orb, sizeof(struct sbp2_logout_orb)); | 1302 | sbp2util_cpu_to_be32_buffer(scsi_id->logout_orb, sizeof(struct sbp2_logout_orb)); |
1461 | 1303 | ||
1462 | sbp2util_packet_dump(scsi_id->logout_orb, sizeof(struct sbp2_logout_orb), | ||
1463 | "sbp2 logout orb", scsi_id->logout_orb_dma); | ||
1464 | |||
1465 | /* | 1304 | /* |
1466 | * Ok, let's write to the target's management agent register | 1305 | * Ok, let's write to the target's management agent register |
1467 | */ | 1306 | */ |
@@ -1492,8 +1331,6 @@ static int sbp2_reconnect_device(struct scsi_id_instance_data *scsi_id) | |||
1492 | quadlet_t data[2]; | 1331 | quadlet_t data[2]; |
1493 | int error; | 1332 | int error; |
1494 | 1333 | ||
1495 | SBP2_DEBUG_ENTER(); | ||
1496 | |||
1497 | /* | 1334 | /* |
1498 | * Set-up reconnect ORB | 1335 | * Set-up reconnect ORB |
1499 | */ | 1336 | */ |
@@ -1520,9 +1357,6 @@ static int sbp2_reconnect_device(struct scsi_id_instance_data *scsi_id) | |||
1520 | */ | 1357 | */ |
1521 | sbp2util_cpu_to_be32_buffer(scsi_id->reconnect_orb, sizeof(struct sbp2_reconnect_orb)); | 1358 | sbp2util_cpu_to_be32_buffer(scsi_id->reconnect_orb, sizeof(struct sbp2_reconnect_orb)); |
1522 | 1359 | ||
1523 | sbp2util_packet_dump(scsi_id->reconnect_orb, sizeof(struct sbp2_reconnect_orb), | ||
1524 | "sbp2 reconnect orb", scsi_id->reconnect_orb_dma); | ||
1525 | |||
1526 | data[0] = ORB_SET_NODE_ID(hi->host->node_id); | 1360 | data[0] = ORB_SET_NODE_ID(hi->host->node_id); |
1527 | data[1] = scsi_id->reconnect_orb_dma; | 1361 | data[1] = scsi_id->reconnect_orb_dma; |
1528 | sbp2util_cpu_to_be32_buffer(data, 8); | 1362 | sbp2util_cpu_to_be32_buffer(data, 8); |
@@ -1565,8 +1399,6 @@ static int sbp2_set_busy_timeout(struct scsi_id_instance_data *scsi_id) | |||
1565 | { | 1399 | { |
1566 | quadlet_t data; | 1400 | quadlet_t data; |
1567 | 1401 | ||
1568 | SBP2_DEBUG_ENTER(); | ||
1569 | |||
1570 | data = cpu_to_be32(SBP2_BUSY_TIMEOUT_VALUE); | 1402 | data = cpu_to_be32(SBP2_BUSY_TIMEOUT_VALUE); |
1571 | if (hpsb_node_write(scsi_id->ne, SBP2_BUSY_TIMEOUT_ADDRESS, &data, 4)) | 1403 | if (hpsb_node_write(scsi_id->ne, SBP2_BUSY_TIMEOUT_ADDRESS, &data, 4)) |
1572 | SBP2_ERR("%s error", __FUNCTION__); | 1404 | SBP2_ERR("%s error", __FUNCTION__); |
@@ -1589,8 +1421,6 @@ static void sbp2_parse_unit_directory(struct scsi_id_instance_data *scsi_id, | |||
1589 | unsigned workarounds; | 1421 | unsigned workarounds; |
1590 | int i; | 1422 | int i; |
1591 | 1423 | ||
1592 | SBP2_DEBUG_ENTER(); | ||
1593 | |||
1594 | management_agent_addr = 0x0; | 1424 | management_agent_addr = 0x0; |
1595 | command_set_spec_id = 0x0; | 1425 | command_set_spec_id = 0x0; |
1596 | command_set = 0x0; | 1426 | command_set = 0x0; |
@@ -1601,32 +1431,25 @@ static void sbp2_parse_unit_directory(struct scsi_id_instance_data *scsi_id, | |||
1601 | csr1212_for_each_dir_entry(ud->ne->csr, kv, ud->ud_kv, dentry) { | 1431 | csr1212_for_each_dir_entry(ud->ne->csr, kv, ud->ud_kv, dentry) { |
1602 | switch (kv->key.id) { | 1432 | switch (kv->key.id) { |
1603 | case CSR1212_KV_ID_DEPENDENT_INFO: | 1433 | case CSR1212_KV_ID_DEPENDENT_INFO: |
1604 | if (kv->key.type == CSR1212_KV_TYPE_CSR_OFFSET) { | 1434 | if (kv->key.type == CSR1212_KV_TYPE_CSR_OFFSET) |
1605 | /* Save off the management agent address */ | 1435 | /* Save off the management agent address */ |
1606 | management_agent_addr = | 1436 | management_agent_addr = |
1607 | CSR1212_REGISTER_SPACE_BASE + | 1437 | CSR1212_REGISTER_SPACE_BASE + |
1608 | (kv->value.csr_offset << 2); | 1438 | (kv->value.csr_offset << 2); |
1609 | 1439 | ||
1610 | SBP2_DEBUG("sbp2_management_agent_addr = %x", | 1440 | else if (kv->key.type == CSR1212_KV_TYPE_IMMEDIATE) |
1611 | (unsigned int)management_agent_addr); | ||
1612 | } else if (kv->key.type == CSR1212_KV_TYPE_IMMEDIATE) { | ||
1613 | scsi_id->sbp2_lun = | 1441 | scsi_id->sbp2_lun = |
1614 | ORB_SET_LUN(kv->value.immediate); | 1442 | ORB_SET_LUN(kv->value.immediate); |
1615 | } | ||
1616 | break; | 1443 | break; |
1617 | 1444 | ||
1618 | case SBP2_COMMAND_SET_SPEC_ID_KEY: | 1445 | case SBP2_COMMAND_SET_SPEC_ID_KEY: |
1619 | /* Command spec organization */ | 1446 | /* Command spec organization */ |
1620 | command_set_spec_id = kv->value.immediate; | 1447 | command_set_spec_id = kv->value.immediate; |
1621 | SBP2_DEBUG("sbp2_command_set_spec_id = %x", | ||
1622 | (unsigned int)command_set_spec_id); | ||
1623 | break; | 1448 | break; |
1624 | 1449 | ||
1625 | case SBP2_COMMAND_SET_KEY: | 1450 | case SBP2_COMMAND_SET_KEY: |
1626 | /* Command set used by sbp2 device */ | 1451 | /* Command set used by sbp2 device */ |
1627 | command_set = kv->value.immediate; | 1452 | command_set = kv->value.immediate; |
1628 | SBP2_DEBUG("sbp2_command_set = %x", | ||
1629 | (unsigned int)command_set); | ||
1630 | break; | 1453 | break; |
1631 | 1454 | ||
1632 | case SBP2_UNIT_CHARACTERISTICS_KEY: | 1455 | case SBP2_UNIT_CHARACTERISTICS_KEY: |
@@ -1635,15 +1458,11 @@ static void sbp2_parse_unit_directory(struct scsi_id_instance_data *scsi_id, | |||
1635 | * that I'm not yet paying attention to) | 1458 | * that I'm not yet paying attention to) |
1636 | */ | 1459 | */ |
1637 | unit_characteristics = kv->value.immediate; | 1460 | unit_characteristics = kv->value.immediate; |
1638 | SBP2_DEBUG("sbp2_unit_characteristics = %x", | ||
1639 | (unsigned int)unit_characteristics); | ||
1640 | break; | 1461 | break; |
1641 | 1462 | ||
1642 | case SBP2_FIRMWARE_REVISION_KEY: | 1463 | case SBP2_FIRMWARE_REVISION_KEY: |
1643 | /* Firmware revision */ | 1464 | /* Firmware revision */ |
1644 | firmware_revision = kv->value.immediate; | 1465 | firmware_revision = kv->value.immediate; |
1645 | SBP2_DEBUG("sbp2_firmware_revision = %x", | ||
1646 | (unsigned int)firmware_revision); | ||
1647 | break; | 1466 | break; |
1648 | 1467 | ||
1649 | default: | 1468 | default: |
@@ -1719,8 +1538,6 @@ static int sbp2_max_speed_and_size(struct scsi_id_instance_data *scsi_id) | |||
1719 | struct sbp2scsi_host_info *hi = scsi_id->hi; | 1538 | struct sbp2scsi_host_info *hi = scsi_id->hi; |
1720 | u8 payload; | 1539 | u8 payload; |
1721 | 1540 | ||
1722 | SBP2_DEBUG_ENTER(); | ||
1723 | |||
1724 | scsi_id->speed_code = | 1541 | scsi_id->speed_code = |
1725 | hi->host->speed[NODEID_TO_NODE(scsi_id->ne->nodeid)]; | 1542 | hi->host->speed[NODEID_TO_NODE(scsi_id->ne->nodeid)]; |
1726 | 1543 | ||
@@ -1761,8 +1578,6 @@ static int sbp2_agent_reset(struct scsi_id_instance_data *scsi_id, int wait) | |||
1761 | int retval; | 1578 | int retval; |
1762 | unsigned long flags; | 1579 | unsigned long flags; |
1763 | 1580 | ||
1764 | SBP2_DEBUG_ENTER(); | ||
1765 | |||
1766 | cancel_delayed_work(&scsi_id->protocol_work); | 1581 | cancel_delayed_work(&scsi_id->protocol_work); |
1767 | if (wait) | 1582 | if (wait) |
1768 | flush_scheduled_work(); | 1583 | flush_scheduled_work(); |
@@ -1806,7 +1621,6 @@ static void sbp2_prep_command_orb_sg(struct sbp2_command_orb *orb, | |||
1806 | if ((scsi_use_sg == 1) && | 1621 | if ((scsi_use_sg == 1) && |
1807 | (sgpnt[0].length <= SBP2_MAX_SG_ELEMENT_LENGTH)) { | 1622 | (sgpnt[0].length <= SBP2_MAX_SG_ELEMENT_LENGTH)) { |
1808 | 1623 | ||
1809 | SBP2_DEBUG("Only one s/g element"); | ||
1810 | command->dma_size = sgpnt[0].length; | 1624 | command->dma_size = sgpnt[0].length; |
1811 | command->dma_type = CMD_DMA_PAGE; | 1625 | command->dma_type = CMD_DMA_PAGE; |
1812 | command->cmd_dma = pci_map_page(hi->host->pdev, | 1626 | command->cmd_dma = pci_map_page(hi->host->pdev, |
@@ -1814,7 +1628,6 @@ static void sbp2_prep_command_orb_sg(struct sbp2_command_orb *orb, | |||
1814 | sgpnt[0].offset, | 1628 | sgpnt[0].offset, |
1815 | command->dma_size, | 1629 | command->dma_size, |
1816 | command->dma_dir); | 1630 | command->dma_dir); |
1817 | SBP2_DMA_ALLOC("single page scatter element"); | ||
1818 | 1631 | ||
1819 | orb->data_descriptor_lo = command->cmd_dma; | 1632 | orb->data_descriptor_lo = command->cmd_dma; |
1820 | orb->misc |= ORB_SET_DATA_SIZE(command->dma_size); | 1633 | orb->misc |= ORB_SET_DATA_SIZE(command->dma_size); |
@@ -1827,8 +1640,6 @@ static void sbp2_prep_command_orb_sg(struct sbp2_command_orb *orb, | |||
1827 | int i, count = pci_map_sg(hi->host->pdev, sgpnt, scsi_use_sg, | 1640 | int i, count = pci_map_sg(hi->host->pdev, sgpnt, scsi_use_sg, |
1828 | dma_dir); | 1641 | dma_dir); |
1829 | 1642 | ||
1830 | SBP2_DMA_ALLOC("scatter list"); | ||
1831 | |||
1832 | command->dma_size = scsi_use_sg; | 1643 | command->dma_size = scsi_use_sg; |
1833 | command->sge_buffer = sgpnt; | 1644 | command->sge_buffer = sgpnt; |
1834 | 1645 | ||
@@ -1862,10 +1673,6 @@ static void sbp2_prep_command_orb_sg(struct sbp2_command_orb *orb, | |||
1862 | /* Number of page table (s/g) elements */ | 1673 | /* Number of page table (s/g) elements */ |
1863 | orb->misc |= ORB_SET_DATA_SIZE(sg_count); | 1674 | orb->misc |= ORB_SET_DATA_SIZE(sg_count); |
1864 | 1675 | ||
1865 | sbp2util_packet_dump(sg_element, | ||
1866 | (sizeof(struct sbp2_unrestricted_page_table)) * sg_count, | ||
1867 | "sbp2 s/g list", command->sge_dma); | ||
1868 | |||
1869 | /* Byte swap page tables if necessary */ | 1676 | /* Byte swap page tables if necessary */ |
1870 | sbp2util_cpu_to_be32_buffer(sg_element, | 1677 | sbp2util_cpu_to_be32_buffer(sg_element, |
1871 | (sizeof(struct sbp2_unrestricted_page_table)) * | 1678 | (sizeof(struct sbp2_unrestricted_page_table)) * |
@@ -1890,8 +1697,6 @@ static void sbp2_prep_command_orb_no_sg(struct sbp2_command_orb *orb, | |||
1890 | orb->data_descriptor_hi = ORB_SET_NODE_ID(hi->host->node_id); | 1697 | orb->data_descriptor_hi = ORB_SET_NODE_ID(hi->host->node_id); |
1891 | orb->misc |= ORB_SET_DIRECTION(orb_direction); | 1698 | orb->misc |= ORB_SET_DIRECTION(orb_direction); |
1892 | 1699 | ||
1893 | SBP2_DMA_ALLOC("single bulk"); | ||
1894 | |||
1895 | /* | 1700 | /* |
1896 | * Handle case where we get a command w/o s/g enabled (but | 1701 | * Handle case where we get a command w/o s/g enabled (but |
1897 | * check for transfers larger than 64K) | 1702 | * check for transfers larger than 64K) |
@@ -1941,10 +1746,6 @@ static void sbp2_prep_command_orb_no_sg(struct sbp2_command_orb *orb, | |||
1941 | /* Number of page table (s/g) elements */ | 1746 | /* Number of page table (s/g) elements */ |
1942 | orb->misc |= ORB_SET_DATA_SIZE(sg_count); | 1747 | orb->misc |= ORB_SET_DATA_SIZE(sg_count); |
1943 | 1748 | ||
1944 | sbp2util_packet_dump(sg_element, | ||
1945 | (sizeof(struct sbp2_unrestricted_page_table)) * sg_count, | ||
1946 | "sbp2 s/g list", command->sge_dma); | ||
1947 | |||
1948 | /* Byte swap page tables if necessary */ | 1749 | /* Byte swap page tables if necessary */ |
1949 | sbp2util_cpu_to_be32_buffer(sg_element, | 1750 | sbp2util_cpu_to_be32_buffer(sg_element, |
1950 | (sizeof(struct sbp2_unrestricted_page_table)) * | 1751 | (sizeof(struct sbp2_unrestricted_page_table)) * |
@@ -1996,20 +1797,16 @@ static void sbp2_create_command_orb(struct scsi_id_instance_data *scsi_id, | |||
1996 | 1797 | ||
1997 | /* Set-up our pagetable stuff */ | 1798 | /* Set-up our pagetable stuff */ |
1998 | if (orb_direction == ORB_DIRECTION_NO_DATA_TRANSFER) { | 1799 | if (orb_direction == ORB_DIRECTION_NO_DATA_TRANSFER) { |
1999 | SBP2_DEBUG("No data transfer"); | ||
2000 | command_orb->data_descriptor_hi = 0x0; | 1800 | command_orb->data_descriptor_hi = 0x0; |
2001 | command_orb->data_descriptor_lo = 0x0; | 1801 | command_orb->data_descriptor_lo = 0x0; |
2002 | command_orb->misc |= ORB_SET_DIRECTION(1); | 1802 | command_orb->misc |= ORB_SET_DIRECTION(1); |
2003 | } else if (scsi_use_sg) { | 1803 | } else if (scsi_use_sg) |
2004 | SBP2_DEBUG("Use scatter/gather"); | ||
2005 | sbp2_prep_command_orb_sg(command_orb, hi, command, scsi_use_sg, | 1804 | sbp2_prep_command_orb_sg(command_orb, hi, command, scsi_use_sg, |
2006 | sgpnt, orb_direction, dma_dir); | 1805 | sgpnt, orb_direction, dma_dir); |
2007 | } else { | 1806 | else |
2008 | SBP2_DEBUG("No scatter/gather"); | ||
2009 | sbp2_prep_command_orb_no_sg(command_orb, hi, command, sgpnt, | 1807 | sbp2_prep_command_orb_no_sg(command_orb, hi, command, sgpnt, |
2010 | orb_direction, scsi_request_bufflen, | 1808 | orb_direction, scsi_request_bufflen, |
2011 | scsi_request_buffer, dma_dir); | 1809 | scsi_request_buffer, dma_dir); |
2012 | } | ||
2013 | 1810 | ||
2014 | /* Byte swap command ORB if necessary */ | 1811 | /* Byte swap command ORB if necessary */ |
2015 | sbp2util_cpu_to_be32_buffer(command_orb, sizeof(struct sbp2_command_orb)); | 1812 | sbp2util_cpu_to_be32_buffer(command_orb, sizeof(struct sbp2_command_orb)); |
@@ -2034,10 +1831,6 @@ static void sbp2_link_orb_command(struct scsi_id_instance_data *scsi_id, | |||
2034 | size_t length; | 1831 | size_t length; |
2035 | unsigned long flags; | 1832 | unsigned long flags; |
2036 | 1833 | ||
2037 | outstanding_orb_incr; | ||
2038 | SBP2_ORB_DEBUG("sending command orb %p, total orbs = %x", | ||
2039 | command_orb, global_outstanding_command_orbs); | ||
2040 | |||
2041 | pci_dma_sync_single_for_device(hi->host->pdev, command->command_orb_dma, | 1834 | pci_dma_sync_single_for_device(hi->host->pdev, command->command_orb_dma, |
2042 | sizeof(struct sbp2_command_orb), | 1835 | sizeof(struct sbp2_command_orb), |
2043 | PCI_DMA_TODEVICE); | 1836 | PCI_DMA_TODEVICE); |
@@ -2086,8 +1879,6 @@ static void sbp2_link_orb_command(struct scsi_id_instance_data *scsi_id, | |||
2086 | scsi_id->last_orb_dma = command->command_orb_dma; | 1879 | scsi_id->last_orb_dma = command->command_orb_dma; |
2087 | spin_unlock_irqrestore(&scsi_id->sbp2_command_orb_lock, flags); | 1880 | spin_unlock_irqrestore(&scsi_id->sbp2_command_orb_lock, flags); |
2088 | 1881 | ||
2089 | SBP2_ORB_DEBUG("write to %s register, command orb %p", | ||
2090 | last_orb ? "DOORBELL" : "ORB_POINTER", command_orb); | ||
2091 | if (sbp2util_node_write_no_wait(scsi_id->ne, addr, data, length)) { | 1882 | if (sbp2util_node_write_no_wait(scsi_id->ne, addr, data, length)) { |
2092 | /* | 1883 | /* |
2093 | * sbp2util_node_write_no_wait failed. We certainly ran out | 1884 | * sbp2util_node_write_no_wait failed. We certainly ran out |
@@ -2116,17 +1907,12 @@ static int sbp2_send_command(struct scsi_id_instance_data *scsi_id, | |||
2116 | unsigned int request_bufflen = SCpnt->request_bufflen; | 1907 | unsigned int request_bufflen = SCpnt->request_bufflen; |
2117 | struct sbp2_command_info *command; | 1908 | struct sbp2_command_info *command; |
2118 | 1909 | ||
2119 | SBP2_DEBUG_ENTER(); | ||
2120 | SBP2_DEBUG("SCSI transfer size = %x", request_bufflen); | ||
2121 | SBP2_DEBUG("SCSI s/g elements = %x", (unsigned int)SCpnt->use_sg); | ||
2122 | |||
2123 | /* | 1910 | /* |
2124 | * Allocate a command orb and s/g structure | 1911 | * Allocate a command orb and s/g structure |
2125 | */ | 1912 | */ |
2126 | command = sbp2util_allocate_command_orb(scsi_id, SCpnt, done); | 1913 | command = sbp2util_allocate_command_orb(scsi_id, SCpnt, done); |
2127 | if (!command) { | 1914 | if (!command) |
2128 | return -EIO; | 1915 | return -EIO; |
2129 | } | ||
2130 | 1916 | ||
2131 | /* | 1917 | /* |
2132 | * Now actually fill in the comamnd orb and sbp2 s/g list | 1918 | * Now actually fill in the comamnd orb and sbp2 s/g list |
@@ -2135,9 +1921,6 @@ static int sbp2_send_command(struct scsi_id_instance_data *scsi_id, | |||
2135 | request_bufflen, SCpnt->request_buffer, | 1921 | request_bufflen, SCpnt->request_buffer, |
2136 | SCpnt->sc_data_direction); | 1922 | SCpnt->sc_data_direction); |
2137 | 1923 | ||
2138 | sbp2util_packet_dump(&command->command_orb, sizeof(struct sbp2_command_orb), | ||
2139 | "sbp2 command orb", command->command_orb_dma); | ||
2140 | |||
2141 | /* | 1924 | /* |
2142 | * Link up the orb, and ring the doorbell if needed | 1925 | * Link up the orb, and ring the doorbell if needed |
2143 | */ | 1926 | */ |
@@ -2151,8 +1934,6 @@ static int sbp2_send_command(struct scsi_id_instance_data *scsi_id, | |||
2151 | */ | 1934 | */ |
2152 | static unsigned int sbp2_status_to_sense_data(unchar *sbp2_status, unchar *sense_data) | 1935 | static unsigned int sbp2_status_to_sense_data(unchar *sbp2_status, unchar *sense_data) |
2153 | { | 1936 | { |
2154 | SBP2_DEBUG_ENTER(); | ||
2155 | |||
2156 | /* | 1937 | /* |
2157 | * Ok, it's pretty ugly... ;-) | 1938 | * Ok, it's pretty ugly... ;-) |
2158 | */ | 1939 | */ |
@@ -2191,10 +1972,6 @@ static int sbp2_handle_status_write(struct hpsb_host *host, int nodeid, | |||
2191 | struct sbp2_command_info *command; | 1972 | struct sbp2_command_info *command; |
2192 | unsigned long flags; | 1973 | unsigned long flags; |
2193 | 1974 | ||
2194 | SBP2_DEBUG_ENTER(); | ||
2195 | |||
2196 | sbp2util_packet_dump(data, length, "sbp2 status write by device", (u32)addr); | ||
2197 | |||
2198 | if (unlikely(length < 8 || length > sizeof(struct sbp2_status_block))) { | 1975 | if (unlikely(length < 8 || length > sizeof(struct sbp2_status_block))) { |
2199 | SBP2_ERR("Wrong size of status block"); | 1976 | SBP2_ERR("Wrong size of status block"); |
2200 | return RCODE_ADDRESS_ERROR; | 1977 | return RCODE_ADDRESS_ERROR; |
@@ -2244,17 +2021,12 @@ static int sbp2_handle_status_write(struct hpsb_host *host, int nodeid, | |||
2244 | command = sbp2util_find_command_for_orb(scsi_id, | 2021 | command = sbp2util_find_command_for_orb(scsi_id, |
2245 | sb->ORB_offset_lo); | 2022 | sb->ORB_offset_lo); |
2246 | if (command) { | 2023 | if (command) { |
2247 | SBP2_DEBUG("Found status for command ORB"); | ||
2248 | pci_dma_sync_single_for_cpu(hi->host->pdev, command->command_orb_dma, | 2024 | pci_dma_sync_single_for_cpu(hi->host->pdev, command->command_orb_dma, |
2249 | sizeof(struct sbp2_command_orb), | 2025 | sizeof(struct sbp2_command_orb), |
2250 | PCI_DMA_TODEVICE); | 2026 | PCI_DMA_TODEVICE); |
2251 | pci_dma_sync_single_for_cpu(hi->host->pdev, command->sge_dma, | 2027 | pci_dma_sync_single_for_cpu(hi->host->pdev, command->sge_dma, |
2252 | sizeof(command->scatter_gather_element), | 2028 | sizeof(command->scatter_gather_element), |
2253 | PCI_DMA_BIDIRECTIONAL); | 2029 | PCI_DMA_BIDIRECTIONAL); |
2254 | |||
2255 | SBP2_ORB_DEBUG("matched command orb %p", &command->command_orb); | ||
2256 | outstanding_orb_decr; | ||
2257 | |||
2258 | /* | 2030 | /* |
2259 | * Matched status with command, now grab scsi command pointers | 2031 | * Matched status with command, now grab scsi command pointers |
2260 | * and check status. | 2032 | * and check status. |
@@ -2283,21 +2055,15 @@ static int sbp2_handle_status_write(struct hpsb_host *host, int nodeid, | |||
2283 | /* | 2055 | /* |
2284 | * See if the target stored any scsi status information. | 2056 | * See if the target stored any scsi status information. |
2285 | */ | 2057 | */ |
2286 | if (STATUS_GET_LEN(h) > 1) { | 2058 | if (STATUS_GET_LEN(h) > 1) |
2287 | SBP2_DEBUG("CHECK CONDITION"); | ||
2288 | scsi_status = sbp2_status_to_sense_data( | 2059 | scsi_status = sbp2_status_to_sense_data( |
2289 | (unchar *)sb, SCpnt->sense_buffer); | 2060 | (unchar *)sb, SCpnt->sense_buffer); |
2290 | } | ||
2291 | /* | 2061 | /* |
2292 | * Check to see if the dead bit is set. If so, we'll | 2062 | * Check to see if the dead bit is set. If so, we'll |
2293 | * have to initiate a fetch agent reset. | 2063 | * have to initiate a fetch agent reset. |
2294 | */ | 2064 | */ |
2295 | if (STATUS_TEST_DEAD(h)) { | 2065 | if (STATUS_TEST_DEAD(h)) |
2296 | SBP2_DEBUG("Dead bit set - " | ||
2297 | "initiating fetch agent reset"); | ||
2298 | sbp2_agent_reset(scsi_id, 0); | 2066 | sbp2_agent_reset(scsi_id, 0); |
2299 | } | ||
2300 | SBP2_ORB_DEBUG("completing command orb %p", &command->command_orb); | ||
2301 | } | 2067 | } |
2302 | 2068 | ||
2303 | /* | 2069 | /* |
@@ -2326,13 +2092,9 @@ static int sbp2_handle_status_write(struct hpsb_host *host, int nodeid, | |||
2326 | } | 2092 | } |
2327 | } | 2093 | } |
2328 | 2094 | ||
2329 | if (SCpnt) { | 2095 | if (SCpnt) |
2330 | SBP2_DEBUG("Completing SCSI command"); | ||
2331 | sbp2scsi_complete_command(scsi_id, scsi_status, SCpnt, | 2096 | sbp2scsi_complete_command(scsi_id, scsi_status, SCpnt, |
2332 | command->Current_done); | 2097 | command->Current_done); |
2333 | SBP2_ORB_DEBUG("command orb completed"); | ||
2334 | } | ||
2335 | |||
2336 | return RCODE_COMPLETE; | 2098 | return RCODE_COMPLETE; |
2337 | } | 2099 | } |
2338 | 2100 | ||
@@ -2352,11 +2114,6 @@ static int sbp2scsi_queuecommand(struct scsi_cmnd *SCpnt, | |||
2352 | struct sbp2scsi_host_info *hi; | 2114 | struct sbp2scsi_host_info *hi; |
2353 | int result = DID_NO_CONNECT << 16; | 2115 | int result = DID_NO_CONNECT << 16; |
2354 | 2116 | ||
2355 | SBP2_DEBUG_ENTER(); | ||
2356 | #if (CONFIG_IEEE1394_SBP2_DEBUG >= 2) || defined(CONFIG_IEEE1394_SBP2_PACKET_DUMP) | ||
2357 | scsi_print_command(SCpnt); | ||
2358 | #endif | ||
2359 | |||
2360 | if (!sbp2util_node_is_available(scsi_id)) | 2117 | if (!sbp2util_node_is_available(scsi_id)) |
2361 | goto done; | 2118 | goto done; |
2362 | 2119 | ||
@@ -2379,7 +2136,6 @@ static int sbp2scsi_queuecommand(struct scsi_cmnd *SCpnt, | |||
2379 | * (autorequest sense) | 2136 | * (autorequest sense) |
2380 | */ | 2137 | */ |
2381 | if (SCpnt->cmnd[0] == REQUEST_SENSE) { | 2138 | if (SCpnt->cmnd[0] == REQUEST_SENSE) { |
2382 | SBP2_DEBUG("REQUEST_SENSE"); | ||
2383 | memcpy(SCpnt->request_buffer, SCpnt->sense_buffer, SCpnt->request_bufflen); | 2139 | memcpy(SCpnt->request_buffer, SCpnt->sense_buffer, SCpnt->request_bufflen); |
2384 | memset(SCpnt->sense_buffer, 0, sizeof(SCpnt->sense_buffer)); | 2140 | memset(SCpnt->sense_buffer, 0, sizeof(SCpnt->sense_buffer)); |
2385 | sbp2scsi_complete_command(scsi_id, SBP2_SCSI_STATUS_GOOD, SCpnt, done); | 2141 | sbp2scsi_complete_command(scsi_id, SBP2_SCSI_STATUS_GOOD, SCpnt, done); |
@@ -2433,11 +2189,8 @@ static void sbp2scsi_complete_all_commands(struct scsi_id_instance_data *scsi_id | |||
2433 | struct sbp2_command_info *command; | 2189 | struct sbp2_command_info *command; |
2434 | unsigned long flags; | 2190 | unsigned long flags; |
2435 | 2191 | ||
2436 | SBP2_DEBUG_ENTER(); | ||
2437 | |||
2438 | spin_lock_irqsave(&scsi_id->sbp2_command_orb_lock, flags); | 2192 | spin_lock_irqsave(&scsi_id->sbp2_command_orb_lock, flags); |
2439 | while (!list_empty(&scsi_id->sbp2_command_orb_inuse)) { | 2193 | while (!list_empty(&scsi_id->sbp2_command_orb_inuse)) { |
2440 | SBP2_DEBUG("Found pending command to complete"); | ||
2441 | lh = scsi_id->sbp2_command_orb_inuse.next; | 2194 | lh = scsi_id->sbp2_command_orb_inuse.next; |
2442 | command = list_entry(lh, struct sbp2_command_info, list); | 2195 | command = list_entry(lh, struct sbp2_command_info, list); |
2443 | pci_dma_sync_single_for_cpu(hi->host->pdev, command->command_orb_dma, | 2196 | pci_dma_sync_single_for_cpu(hi->host->pdev, command->command_orb_dma, |
@@ -2466,8 +2219,6 @@ static void sbp2scsi_complete_command(struct scsi_id_instance_data *scsi_id, | |||
2466 | u32 scsi_status, struct scsi_cmnd *SCpnt, | 2219 | u32 scsi_status, struct scsi_cmnd *SCpnt, |
2467 | void (*done)(struct scsi_cmnd *)) | 2220 | void (*done)(struct scsi_cmnd *)) |
2468 | { | 2221 | { |
2469 | SBP2_DEBUG_ENTER(); | ||
2470 | |||
2471 | /* | 2222 | /* |
2472 | * Sanity | 2223 | * Sanity |
2473 | */ | 2224 | */ |
@@ -2490,12 +2241,7 @@ static void sbp2scsi_complete_command(struct scsi_id_instance_data *scsi_id, | |||
2490 | break; | 2241 | break; |
2491 | 2242 | ||
2492 | case SBP2_SCSI_STATUS_CHECK_CONDITION: | 2243 | case SBP2_SCSI_STATUS_CHECK_CONDITION: |
2493 | SBP2_DEBUG("SBP2_SCSI_STATUS_CHECK_CONDITION"); | ||
2494 | SCpnt->result = CHECK_CONDITION << 1 | DID_OK << 16; | 2244 | SCpnt->result = CHECK_CONDITION << 1 | DID_OK << 16; |
2495 | #if CONFIG_IEEE1394_SBP2_DEBUG >= 1 | ||
2496 | scsi_print_command(SCpnt); | ||
2497 | scsi_print_sense(SBP2_DEVICE_NAME, SCpnt); | ||
2498 | #endif | ||
2499 | break; | 2245 | break; |
2500 | 2246 | ||
2501 | case SBP2_SCSI_STATUS_SELECTION_TIMEOUT: | 2247 | case SBP2_SCSI_STATUS_SELECTION_TIMEOUT: |
@@ -2590,7 +2336,6 @@ static int sbp2scsi_abort(struct scsi_cmnd *SCpnt) | |||
2590 | spin_lock_irqsave(&scsi_id->sbp2_command_orb_lock, flags); | 2336 | spin_lock_irqsave(&scsi_id->sbp2_command_orb_lock, flags); |
2591 | command = sbp2util_find_command_for_SCpnt(scsi_id, SCpnt); | 2337 | command = sbp2util_find_command_for_SCpnt(scsi_id, SCpnt); |
2592 | if (command) { | 2338 | if (command) { |
2593 | SBP2_DEBUG("Found command to abort"); | ||
2594 | pci_dma_sync_single_for_cpu(hi->host->pdev, | 2339 | pci_dma_sync_single_for_cpu(hi->host->pdev, |
2595 | command->command_orb_dma, | 2340 | command->command_orb_dma, |
2596 | sizeof(struct sbp2_command_orb), | 2341 | sizeof(struct sbp2_command_orb), |
@@ -2660,8 +2405,6 @@ static int sbp2_module_init(void) | |||
2660 | { | 2405 | { |
2661 | int ret; | 2406 | int ret; |
2662 | 2407 | ||
2663 | SBP2_DEBUG_ENTER(); | ||
2664 | |||
2665 | /* Module load debug option to force one command at a time (serializing I/O) */ | 2408 | /* Module load debug option to force one command at a time (serializing I/O) */ |
2666 | if (serialize_io) { | 2409 | if (serialize_io) { |
2667 | scsi_driver_template.can_queue = 1; | 2410 | scsi_driver_template.can_queue = 1; |
@@ -2688,10 +2431,7 @@ static int sbp2_module_init(void) | |||
2688 | 2431 | ||
2689 | static void __exit sbp2_module_exit(void) | 2432 | static void __exit sbp2_module_exit(void) |
2690 | { | 2433 | { |
2691 | SBP2_DEBUG_ENTER(); | ||
2692 | |||
2693 | hpsb_unregister_protocol(&sbp2_driver); | 2434 | hpsb_unregister_protocol(&sbp2_driver); |
2694 | |||
2695 | hpsb_unregister_highlevel(&sbp2_highlevel); | 2435 | hpsb_unregister_highlevel(&sbp2_highlevel); |
2696 | } | 2436 | } |
2697 | 2437 | ||