diff options
Diffstat (limited to 'drivers/s390/scsi/zfcp_def.h')
-rw-r--r-- | drivers/s390/scsi/zfcp_def.h | 47 |
1 files changed, 6 insertions, 41 deletions
diff --git a/drivers/s390/scsi/zfcp_def.h b/drivers/s390/scsi/zfcp_def.h index 362af4d95352..e93272f18827 100644 --- a/drivers/s390/scsi/zfcp_def.h +++ b/drivers/s390/scsi/zfcp_def.h | |||
@@ -39,7 +39,6 @@ | |||
39 | #include <scsi/scsi_host.h> | 39 | #include <scsi/scsi_host.h> |
40 | #include <scsi/scsi_transport.h> | 40 | #include <scsi/scsi_transport.h> |
41 | #include <scsi/scsi_transport_fc.h> | 41 | #include <scsi/scsi_transport_fc.h> |
42 | #include "../../fc4/fc.h" | ||
43 | #include "zfcp_fsf.h" | 42 | #include "zfcp_fsf.h" |
44 | #include <asm/ccwdev.h> | 43 | #include <asm/ccwdev.h> |
45 | #include <asm/qdio.h> | 44 | #include <asm/qdio.h> |
@@ -78,13 +77,9 @@ zfcp_address_to_sg(void *address, struct scatterlist *list) | |||
78 | list->offset = ((unsigned long) address) & (PAGE_SIZE - 1); | 77 | list->offset = ((unsigned long) address) & (PAGE_SIZE - 1); |
79 | } | 78 | } |
80 | 79 | ||
81 | /********************* SCSI SPECIFIC DEFINES *********************************/ | 80 | #define REQUEST_LIST_SIZE 128 |
82 | |||
83 | /* 32 bit for SCSI ID and LUN as long as the SCSI stack uses this type */ | ||
84 | typedef u32 scsi_id_t; | ||
85 | typedef u32 scsi_lun_t; | ||
86 | 81 | ||
87 | #define ZFCP_ERP_SCSI_LOW_MEM_TIMEOUT (100*HZ) | 82 | /********************* SCSI SPECIFIC DEFINES *********************************/ |
88 | #define ZFCP_SCSI_ER_TIMEOUT (100*HZ) | 83 | #define ZFCP_SCSI_ER_TIMEOUT (100*HZ) |
89 | 84 | ||
90 | /********************* CIO/QDIO SPECIFIC DEFINES *****************************/ | 85 | /********************* CIO/QDIO SPECIFIC DEFINES *****************************/ |
@@ -222,8 +217,9 @@ struct fcp_rsp_iu { | |||
222 | #define RSP_CODE_TASKMAN_FAILED 5 | 217 | #define RSP_CODE_TASKMAN_FAILED 5 |
223 | 218 | ||
224 | /* see fc-fs */ | 219 | /* see fc-fs */ |
225 | #define LS_FAN 0x60000000 | 220 | #define LS_RSCN 0x61040000 |
226 | #define LS_RSCN 0x61040000 | 221 | #define LS_LOGO 0x05000000 |
222 | #define LS_PLOGI 0x03000000 | ||
227 | 223 | ||
228 | struct fcp_rscn_head { | 224 | struct fcp_rscn_head { |
229 | u8 command; | 225 | u8 command; |
@@ -252,13 +248,6 @@ struct fcp_rscn_element { | |||
252 | #define ZFCP_NO_PORTS_PER_DOMAIN 0x10000 | 248 | #define ZFCP_NO_PORTS_PER_DOMAIN 0x10000 |
253 | #define ZFCP_NO_PORTS_PER_FABRIC 0x1000000 | 249 | #define ZFCP_NO_PORTS_PER_FABRIC 0x1000000 |
254 | 250 | ||
255 | struct fcp_fan { | ||
256 | u32 command; | ||
257 | u32 fport_did; | ||
258 | wwn_t fport_wwpn; | ||
259 | wwn_t fport_wwname; | ||
260 | } __attribute__((packed)); | ||
261 | |||
262 | /* see fc-ph */ | 251 | /* see fc-ph */ |
263 | struct fcp_logo { | 252 | struct fcp_logo { |
264 | u32 command; | 253 | u32 command; |
@@ -496,9 +485,6 @@ struct zfcp_rc_entry { | |||
496 | 485 | ||
497 | #define ZFCP_NAME "zfcp" | 486 | #define ZFCP_NAME "zfcp" |
498 | 487 | ||
499 | /* read-only LUN sharing switch initial value */ | ||
500 | #define ZFCP_RO_LUN_SHARING_DEFAULTS 0 | ||
501 | |||
502 | /* independent log areas */ | 488 | /* independent log areas */ |
503 | #define ZFCP_LOG_AREA_OTHER 0 | 489 | #define ZFCP_LOG_AREA_OTHER 0 |
504 | #define ZFCP_LOG_AREA_SCSI 1 | 490 | #define ZFCP_LOG_AREA_SCSI 1 |
@@ -597,7 +583,6 @@ do { \ | |||
597 | * and unit | 583 | * and unit |
598 | */ | 584 | */ |
599 | #define ZFCP_COMMON_FLAGS 0xfff00000 | 585 | #define ZFCP_COMMON_FLAGS 0xfff00000 |
600 | #define ZFCP_SPECIFIC_FLAGS 0x000fffff | ||
601 | 586 | ||
602 | /* common status bits */ | 587 | /* common status bits */ |
603 | #define ZFCP_STATUS_COMMON_REMOVE 0x80000000 | 588 | #define ZFCP_STATUS_COMMON_REMOVE 0x80000000 |
@@ -622,11 +607,6 @@ do { \ | |||
622 | #define ZFCP_STATUS_ADAPTER_LINK_UNPLUGGED 0x00000200 | 607 | #define ZFCP_STATUS_ADAPTER_LINK_UNPLUGGED 0x00000200 |
623 | #define ZFCP_STATUS_ADAPTER_XPORT_OK 0x00000800 | 608 | #define ZFCP_STATUS_ADAPTER_XPORT_OK 0x00000800 |
624 | 609 | ||
625 | #define ZFCP_STATUS_ADAPTER_SCSI_UP \ | ||
626 | (ZFCP_STATUS_COMMON_UNBLOCKED | \ | ||
627 | ZFCP_STATUS_ADAPTER_REGISTERED) | ||
628 | |||
629 | |||
630 | /* FC-PH/FC-GS well-known address identifiers for generic services */ | 610 | /* FC-PH/FC-GS well-known address identifiers for generic services */ |
631 | #define ZFCP_DID_MANAGEMENT_SERVICE 0xFFFFFA | 611 | #define ZFCP_DID_MANAGEMENT_SERVICE 0xFFFFFA |
632 | #define ZFCP_DID_TIME_SERVICE 0xFFFFFB | 612 | #define ZFCP_DID_TIME_SERVICE 0xFFFFFB |
@@ -641,7 +621,6 @@ do { \ | |||
641 | #define ZFCP_STATUS_PORT_NO_WWPN 0x00000008 | 621 | #define ZFCP_STATUS_PORT_NO_WWPN 0x00000008 |
642 | #define ZFCP_STATUS_PORT_NO_SCSI_ID 0x00000010 | 622 | #define ZFCP_STATUS_PORT_NO_SCSI_ID 0x00000010 |
643 | #define ZFCP_STATUS_PORT_INVALID_WWPN 0x00000020 | 623 | #define ZFCP_STATUS_PORT_INVALID_WWPN 0x00000020 |
644 | #define ZFCP_STATUS_PORT_ACCESS_DENIED 0x00000040 | ||
645 | 624 | ||
646 | /* for ports with well known addresses */ | 625 | /* for ports with well known addresses */ |
647 | #define ZFCP_STATUS_PORT_WKA \ | 626 | #define ZFCP_STATUS_PORT_WKA \ |
@@ -897,15 +876,12 @@ struct zfcp_adapter { | |||
897 | wwn_t peer_wwpn; /* P2P peer WWPN */ | 876 | wwn_t peer_wwpn; /* P2P peer WWPN */ |
898 | u32 peer_d_id; /* P2P peer D_ID */ | 877 | u32 peer_d_id; /* P2P peer D_ID */ |
899 | struct ccw_device *ccw_device; /* S/390 ccw device */ | 878 | struct ccw_device *ccw_device; /* S/390 ccw device */ |
900 | u8 fc_service_class; | ||
901 | u32 hydra_version; /* Hydra version */ | 879 | u32 hydra_version; /* Hydra version */ |
902 | u32 fsf_lic_version; | 880 | u32 fsf_lic_version; |
903 | u32 adapter_features; /* FCP channel features */ | 881 | u32 adapter_features; /* FCP channel features */ |
904 | u32 connection_features; /* host connection features */ | 882 | u32 connection_features; /* host connection features */ |
905 | u32 hardware_version; /* of FCP channel */ | 883 | u32 hardware_version; /* of FCP channel */ |
906 | struct Scsi_Host *scsi_host; /* Pointer to mid-layer */ | 884 | struct Scsi_Host *scsi_host; /* Pointer to mid-layer */ |
907 | unsigned short scsi_host_no; /* Assigned host number */ | ||
908 | unsigned char name[9]; | ||
909 | struct list_head port_list_head; /* remote port list */ | 885 | struct list_head port_list_head; /* remote port list */ |
910 | struct list_head port_remove_lh; /* head of ports to be | 886 | struct list_head port_remove_lh; /* head of ports to be |
911 | removed */ | 887 | removed */ |
@@ -997,7 +973,7 @@ struct zfcp_unit { | |||
997 | refcount drop to zero */ | 973 | refcount drop to zero */ |
998 | struct zfcp_port *port; /* remote port of unit */ | 974 | struct zfcp_port *port; /* remote port of unit */ |
999 | atomic_t status; /* status of this logical unit */ | 975 | atomic_t status; /* status of this logical unit */ |
1000 | scsi_lun_t scsi_lun; /* own SCSI LUN */ | 976 | unsigned int scsi_lun; /* own SCSI LUN */ |
1001 | fcp_lun_t fcp_lun; /* own FCP_LUN */ | 977 | fcp_lun_t fcp_lun; /* own FCP_LUN */ |
1002 | u32 handle; /* handle assigned by FSF */ | 978 | u32 handle; /* handle assigned by FSF */ |
1003 | struct scsi_device *device; /* scsi device struct pointer */ | 979 | struct scsi_device *device; /* scsi device struct pointer */ |
@@ -1041,11 +1017,6 @@ struct zfcp_data { | |||
1041 | struct list_head adapter_list_head; /* head of adapter list */ | 1017 | struct list_head adapter_list_head; /* head of adapter list */ |
1042 | struct list_head adapter_remove_lh; /* head of adapters to be | 1018 | struct list_head adapter_remove_lh; /* head of adapters to be |
1043 | removed */ | 1019 | removed */ |
1044 | rwlock_t status_read_lock; /* for status read thread */ | ||
1045 | struct list_head status_read_receive_head; | ||
1046 | struct list_head status_read_send_head; | ||
1047 | struct semaphore status_read_sema; | ||
1048 | wait_queue_head_t status_read_thread_wqh; | ||
1049 | u32 adapters; /* # of adapters in list */ | 1020 | u32 adapters; /* # of adapters in list */ |
1050 | rwlock_t config_lock; /* serialises changes | 1021 | rwlock_t config_lock; /* serialises changes |
1051 | to adapter/port/unit | 1022 | to adapter/port/unit |
@@ -1084,9 +1055,6 @@ struct zfcp_fsf_req_pool_element { | |||
1084 | 1055 | ||
1085 | /********************** ZFCP SPECIFIC DEFINES ********************************/ | 1056 | /********************** ZFCP SPECIFIC DEFINES ********************************/ |
1086 | 1057 | ||
1087 | #define ZFCP_FSFREQ_CLEANUP_TIMEOUT HZ/10 | ||
1088 | |||
1089 | #define ZFCP_KNOWN 0x00000001 | ||
1090 | #define ZFCP_REQ_AUTO_CLEANUP 0x00000002 | 1058 | #define ZFCP_REQ_AUTO_CLEANUP 0x00000002 |
1091 | #define ZFCP_WAIT_FOR_SBAL 0x00000004 | 1059 | #define ZFCP_WAIT_FOR_SBAL 0x00000004 |
1092 | #define ZFCP_REQ_NO_QTCB 0x00000008 | 1060 | #define ZFCP_REQ_NO_QTCB 0x00000008 |
@@ -1094,9 +1062,6 @@ struct zfcp_fsf_req_pool_element { | |||
1094 | #define ZFCP_SET 0x00000100 | 1062 | #define ZFCP_SET 0x00000100 |
1095 | #define ZFCP_CLEAR 0x00000200 | 1063 | #define ZFCP_CLEAR 0x00000200 |
1096 | 1064 | ||
1097 | #define ZFCP_INTERRUPTIBLE 1 | ||
1098 | #define ZFCP_UNINTERRUPTIBLE 0 | ||
1099 | |||
1100 | #ifndef atomic_test_mask | 1065 | #ifndef atomic_test_mask |
1101 | #define atomic_test_mask(mask, target) \ | 1066 | #define atomic_test_mask(mask, target) \ |
1102 | ((atomic_read(target) & mask) == mask) | 1067 | ((atomic_read(target) & mask) == mask) |