aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/s390/scsi/zfcp_fsf.c
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/s390/scsi/zfcp_fsf.c')
-rw-r--r--drivers/s390/scsi/zfcp_fsf.c65
1 files changed, 35 insertions, 30 deletions
diff --git a/drivers/s390/scsi/zfcp_fsf.c b/drivers/s390/scsi/zfcp_fsf.c
index f994f453e2d2..3b0fc1163f5f 100644
--- a/drivers/s390/scsi/zfcp_fsf.c
+++ b/drivers/s390/scsi/zfcp_fsf.c
@@ -1617,7 +1617,7 @@ zfcp_fsf_send_els(struct zfcp_send_els *els)
1617{ 1617{
1618 volatile struct qdio_buffer_element *sbale; 1618 volatile struct qdio_buffer_element *sbale;
1619 struct zfcp_fsf_req *fsf_req; 1619 struct zfcp_fsf_req *fsf_req;
1620 fc_id_t d_id; 1620 u32 d_id;
1621 struct zfcp_adapter *adapter; 1621 struct zfcp_adapter *adapter;
1622 unsigned long lock_flags; 1622 unsigned long lock_flags;
1623 int bytes; 1623 int bytes;
@@ -1740,7 +1740,7 @@ static int zfcp_fsf_send_els_handler(struct zfcp_fsf_req *fsf_req)
1740{ 1740{
1741 struct zfcp_adapter *adapter; 1741 struct zfcp_adapter *adapter;
1742 struct zfcp_port *port; 1742 struct zfcp_port *port;
1743 fc_id_t d_id; 1743 u32 d_id;
1744 struct fsf_qtcb_header *header; 1744 struct fsf_qtcb_header *header;
1745 struct fsf_qtcb_bottom_support *bottom; 1745 struct fsf_qtcb_bottom_support *bottom;
1746 struct zfcp_send_els *send_els; 1746 struct zfcp_send_els *send_els;
@@ -1978,6 +1978,7 @@ zfcp_fsf_exchange_config_evaluate(struct zfcp_fsf_req *fsf_req, int xchg_ok)
1978{ 1978{
1979 struct fsf_qtcb_bottom_config *bottom; 1979 struct fsf_qtcb_bottom_config *bottom;
1980 struct zfcp_adapter *adapter = fsf_req->adapter; 1980 struct zfcp_adapter *adapter = fsf_req->adapter;
1981 struct Scsi_Host *shost = adapter->scsi_host;
1981 1982
1982 bottom = &fsf_req->qtcb->bottom.config; 1983 bottom = &fsf_req->qtcb->bottom.config;
1983 ZFCP_LOG_DEBUG("low/high QTCB version 0x%x/0x%x of FSF\n", 1984 ZFCP_LOG_DEBUG("low/high QTCB version 0x%x/0x%x of FSF\n",
@@ -1990,22 +1991,23 @@ zfcp_fsf_exchange_config_evaluate(struct zfcp_fsf_req *fsf_req, int xchg_ok)
1990 adapter->peer_d_id = 0; 1991 adapter->peer_d_id = 0;
1991 1992
1992 if (xchg_ok) { 1993 if (xchg_ok) {
1993 adapter->wwnn = bottom->nport_serv_param.wwnn; 1994 fc_host_node_name(shost) = bottom->nport_serv_param.wwnn;
1994 adapter->wwpn = bottom->nport_serv_param.wwpn; 1995 fc_host_port_name(shost) = bottom->nport_serv_param.wwpn;
1995 adapter->s_id = bottom->s_id & ZFCP_DID_MASK; 1996 fc_host_port_id(shost) = bottom->s_id & ZFCP_DID_MASK;
1997 fc_host_speed(shost) = bottom->fc_link_speed;
1998 fc_host_supported_classes(shost) = FC_COS_CLASS2 | FC_COS_CLASS3;
1996 adapter->fc_topology = bottom->fc_topology; 1999 adapter->fc_topology = bottom->fc_topology;
1997 adapter->fc_link_speed = bottom->fc_link_speed;
1998 adapter->hydra_version = bottom->adapter_type; 2000 adapter->hydra_version = bottom->adapter_type;
1999 if (adapter->physical_wwpn == 0) 2001 if (adapter->physical_wwpn == 0)
2000 adapter->physical_wwpn = adapter->wwpn; 2002 adapter->physical_wwpn = fc_host_port_name(shost);
2001 if (adapter->physical_s_id == 0) 2003 if (adapter->physical_s_id == 0)
2002 adapter->physical_s_id = adapter->s_id; 2004 adapter->physical_s_id = fc_host_port_id(shost);
2003 } else { 2005 } else {
2004 adapter->wwnn = 0; 2006 fc_host_node_name(shost) = 0;
2005 adapter->wwpn = 0; 2007 fc_host_port_name(shost) = 0;
2006 adapter->s_id = 0; 2008 fc_host_port_id(shost) = 0;
2009 fc_host_speed(shost) = FC_PORTSPEED_UNKNOWN;
2007 adapter->fc_topology = 0; 2010 adapter->fc_topology = 0;
2008 adapter->fc_link_speed = 0;
2009 adapter->hydra_version = 0; 2011 adapter->hydra_version = 0;
2010 } 2012 }
2011 2013
@@ -2017,24 +2019,26 @@ zfcp_fsf_exchange_config_evaluate(struct zfcp_fsf_req *fsf_req, int xchg_ok)
2017 2019
2018 if (adapter->adapter_features & FSF_FEATURE_HBAAPI_MANAGEMENT) { 2020 if (adapter->adapter_features & FSF_FEATURE_HBAAPI_MANAGEMENT) {
2019 adapter->hardware_version = bottom->hardware_version; 2021 adapter->hardware_version = bottom->hardware_version;
2020 memcpy(adapter->serial_number, bottom->serial_number, 17); 2022 memcpy(fc_host_serial_number(shost), bottom->serial_number,
2021 EBCASC(adapter->serial_number, sizeof(adapter->serial_number)); 2023 min(FC_SERIAL_NUMBER_SIZE, 17));
2024 EBCASC(fc_host_serial_number(shost),
2025 min(FC_SERIAL_NUMBER_SIZE, 17));
2022 } 2026 }
2023 2027
2024 ZFCP_LOG_NORMAL("The adapter %s reported the following characteristics:\n" 2028 ZFCP_LOG_NORMAL("The adapter %s reported the following characteristics:\n"
2025 "WWNN 0x%016Lx, " 2029 "WWNN 0x%016Lx, "
2026 "WWPN 0x%016Lx, " 2030 "WWPN 0x%016Lx, "
2027 "S_ID 0x%08x,\n" 2031 "S_ID 0x%08x,\n"
2028 "adapter version 0x%x, " 2032 "adapter version 0x%x, "
2029 "LIC version 0x%x, " 2033 "LIC version 0x%x, "
2030 "FC link speed %d Gb/s\n", 2034 "FC link speed %d Gb/s\n",
2031 zfcp_get_busid_by_adapter(adapter), 2035 zfcp_get_busid_by_adapter(adapter),
2032 adapter->wwnn, 2036 (wwn_t) fc_host_node_name(shost),
2033 adapter->wwpn, 2037 (wwn_t) fc_host_port_name(shost),
2034 (unsigned int) adapter->s_id, 2038 fc_host_port_id(shost),
2035 adapter->hydra_version, 2039 adapter->hydra_version,
2036 adapter->fsf_lic_version, 2040 adapter->fsf_lic_version,
2037 adapter->fc_link_speed); 2041 fc_host_speed(shost));
2038 if (ZFCP_QTCB_VERSION < bottom->low_qtcb_version) { 2042 if (ZFCP_QTCB_VERSION < bottom->low_qtcb_version) {
2039 ZFCP_LOG_NORMAL("error: the adapter %s " 2043 ZFCP_LOG_NORMAL("error: the adapter %s "
2040 "only supports newer control block " 2044 "only supports newer control block "
@@ -2055,7 +2059,6 @@ zfcp_fsf_exchange_config_evaluate(struct zfcp_fsf_req *fsf_req, int xchg_ok)
2055 zfcp_erp_adapter_shutdown(adapter, 0); 2059 zfcp_erp_adapter_shutdown(adapter, 0);
2056 return -EIO; 2060 return -EIO;
2057 } 2061 }
2058 zfcp_set_fc_host_attrs(adapter);
2059 return 0; 2062 return 0;
2060} 2063}
2061 2064
@@ -2259,6 +2262,7 @@ static void
2259zfcp_fsf_exchange_port_data_handler(struct zfcp_fsf_req *fsf_req) 2262zfcp_fsf_exchange_port_data_handler(struct zfcp_fsf_req *fsf_req)
2260{ 2263{
2261 struct zfcp_adapter *adapter = fsf_req->adapter; 2264 struct zfcp_adapter *adapter = fsf_req->adapter;
2265 struct Scsi_Host *shost = adapter->scsi_host;
2262 struct fsf_qtcb *qtcb = fsf_req->qtcb; 2266 struct fsf_qtcb *qtcb = fsf_req->qtcb;
2263 struct fsf_qtcb_bottom_port *bottom, *data; 2267 struct fsf_qtcb_bottom_port *bottom, *data;
2264 2268
@@ -2277,9 +2281,10 @@ zfcp_fsf_exchange_port_data_handler(struct zfcp_fsf_req *fsf_req)
2277 adapter->physical_wwpn = bottom->wwpn; 2281 adapter->physical_wwpn = bottom->wwpn;
2278 adapter->physical_s_id = bottom->fc_port_id; 2282 adapter->physical_s_id = bottom->fc_port_id;
2279 } else { 2283 } else {
2280 adapter->physical_wwpn = adapter->wwpn; 2284 adapter->physical_wwpn = fc_host_port_name(shost);
2281 adapter->physical_s_id = adapter->s_id; 2285 adapter->physical_s_id = fc_host_port_id(shost);
2282 } 2286 }
2287 fc_host_maxframe_size(shost) = bottom->maximum_frame_size;
2283 break; 2288 break;
2284 2289
2285 case FSF_EXCHANGE_CONFIG_DATA_INCOMPLETE: 2290 case FSF_EXCHANGE_CONFIG_DATA_INCOMPLETE: