aboutsummaryrefslogtreecommitdiffstats
path: root/drivers
diff options
context:
space:
mode:
authorChristof Schmitt <christof.schmitt@de.ibm.com>2010-04-30 12:09:35 -0400
committerJames Bottomley <James.Bottomley@suse.de>2010-05-02 15:42:32 -0400
commit6b9e1520094a8aa68009c265eb694e0be9f5be3f (patch)
treed6abee81a84fe8e43c26c0db75a9917599f0b835 /drivers
parent1674b4054744c2cfd6573e43eca45d86ff581d0e (diff)
[SCSI] zfcp: Move sbal_get function to zfcp_qdio.c
Waiting for a free sbal is a operation on the qdio queue. Move the code implementing the wait to zfcp_qdio.c and rename the functions accordingly. Reviewed-by: Swen Schillig <swen@vnet.ibm.com> Signed-off-by: Christof Schmitt <christof.schmitt@de.ibm.com> Signed-off-by: James Bottomley <James.Bottomley@suse.de>
Diffstat (limited to 'drivers')
-rw-r--r--drivers/s390/scsi/zfcp_ext.h1
-rw-r--r--drivers/s390/scsi/zfcp_fsf.c65
-rw-r--r--drivers/s390/scsi/zfcp_qdio.c40
3 files changed, 58 insertions, 48 deletions
diff --git a/drivers/s390/scsi/zfcp_ext.h b/drivers/s390/scsi/zfcp_ext.h
index 172da12a2d02..48a8f93b72f5 100644
--- a/drivers/s390/scsi/zfcp_ext.h
+++ b/drivers/s390/scsi/zfcp_ext.h
@@ -143,6 +143,7 @@ extern void zfcp_fsf_reqid_check(struct zfcp_qdio *, int);
143/* zfcp_qdio.c */ 143/* zfcp_qdio.c */
144extern int zfcp_qdio_setup(struct zfcp_adapter *); 144extern int zfcp_qdio_setup(struct zfcp_adapter *);
145extern void zfcp_qdio_destroy(struct zfcp_qdio *); 145extern void zfcp_qdio_destroy(struct zfcp_qdio *);
146extern int zfcp_qdio_sbal_get(struct zfcp_qdio *);
146extern int zfcp_qdio_send(struct zfcp_qdio *, struct zfcp_qdio_req *); 147extern int zfcp_qdio_send(struct zfcp_qdio *, struct zfcp_qdio_req *);
147extern int zfcp_qdio_sbals_from_sg(struct zfcp_qdio *, struct zfcp_qdio_req *, 148extern int zfcp_qdio_sbals_from_sg(struct zfcp_qdio *, struct zfcp_qdio_req *,
148 struct scatterlist *, int); 149 struct scatterlist *, int);
diff --git a/drivers/s390/scsi/zfcp_fsf.c b/drivers/s390/scsi/zfcp_fsf.c
index ec1b49a75532..3822f22b8150 100644
--- a/drivers/s390/scsi/zfcp_fsf.c
+++ b/drivers/s390/scsi/zfcp_fsf.c
@@ -640,37 +640,6 @@ static void zfcp_fsf_exchange_port_data_handler(struct zfcp_fsf_req *req)
640 } 640 }
641} 641}
642 642
643static int zfcp_fsf_sbal_check(struct zfcp_qdio *qdio)
644{
645 struct zfcp_qdio_queue *req_q = &qdio->req_q;
646
647 spin_lock_bh(&qdio->req_q_lock);
648 if (atomic_read(&req_q->count))
649 return 1;
650 spin_unlock_bh(&qdio->req_q_lock);
651 return 0;
652}
653
654static int zfcp_fsf_req_sbal_get(struct zfcp_qdio *qdio)
655{
656 struct zfcp_adapter *adapter = qdio->adapter;
657 long ret;
658
659 spin_unlock_bh(&qdio->req_q_lock);
660 ret = wait_event_interruptible_timeout(qdio->req_q_wq,
661 zfcp_fsf_sbal_check(qdio), 5 * HZ);
662 if (ret > 0)
663 return 0;
664 if (!ret) {
665 atomic_inc(&qdio->req_q_full);
666 /* assume hanging outbound queue, try queue recovery */
667 zfcp_erp_adapter_reopen(adapter, 0, "fsrsg_1", NULL);
668 }
669
670 spin_lock_bh(&qdio->req_q_lock);
671 return -EIO;
672}
673
674static struct zfcp_fsf_req *zfcp_fsf_alloc(mempool_t *pool) 643static struct zfcp_fsf_req *zfcp_fsf_alloc(mempool_t *pool)
675{ 644{
676 struct zfcp_fsf_req *req; 645 struct zfcp_fsf_req *req;
@@ -798,7 +767,7 @@ int zfcp_fsf_status_read(struct zfcp_qdio *qdio)
798 int retval = -EIO; 767 int retval = -EIO;
799 768
800 spin_lock_bh(&qdio->req_q_lock); 769 spin_lock_bh(&qdio->req_q_lock);
801 if (zfcp_fsf_req_sbal_get(qdio)) 770 if (zfcp_qdio_sbal_get(qdio))
802 goto out; 771 goto out;
803 772
804 req = zfcp_fsf_req_create(qdio, FSF_QTCB_UNSOLICITED_STATUS, 0, 773 req = zfcp_fsf_req_create(qdio, FSF_QTCB_UNSOLICITED_STATUS, 0,
@@ -898,7 +867,7 @@ struct zfcp_fsf_req *zfcp_fsf_abort_fcp_command(unsigned long old_req_id,
898 struct zfcp_qdio *qdio = unit->port->adapter->qdio; 867 struct zfcp_qdio *qdio = unit->port->adapter->qdio;
899 868
900 spin_lock_bh(&qdio->req_q_lock); 869 spin_lock_bh(&qdio->req_q_lock);
901 if (zfcp_fsf_req_sbal_get(qdio)) 870 if (zfcp_qdio_sbal_get(qdio))
902 goto out; 871 goto out;
903 req = zfcp_fsf_req_create(qdio, FSF_QTCB_ABORT_FCP_CMND, 872 req = zfcp_fsf_req_create(qdio, FSF_QTCB_ABORT_FCP_CMND,
904 SBAL_FLAGS0_TYPE_READ, 873 SBAL_FLAGS0_TYPE_READ,
@@ -1068,7 +1037,7 @@ int zfcp_fsf_send_ct(struct zfcp_fc_wka_port *wka_port,
1068 int ret = -EIO; 1037 int ret = -EIO;
1069 1038
1070 spin_lock_bh(&qdio->req_q_lock); 1039 spin_lock_bh(&qdio->req_q_lock);
1071 if (zfcp_fsf_req_sbal_get(qdio)) 1040 if (zfcp_qdio_sbal_get(qdio))
1072 goto out; 1041 goto out;
1073 1042
1074 req = zfcp_fsf_req_create(qdio, FSF_QTCB_SEND_GENERIC, 1043 req = zfcp_fsf_req_create(qdio, FSF_QTCB_SEND_GENERIC,
@@ -1165,7 +1134,7 @@ int zfcp_fsf_send_els(struct zfcp_adapter *adapter, u32 d_id,
1165 int ret = -EIO; 1134 int ret = -EIO;
1166 1135
1167 spin_lock_bh(&qdio->req_q_lock); 1136 spin_lock_bh(&qdio->req_q_lock);
1168 if (zfcp_fsf_req_sbal_get(qdio)) 1137 if (zfcp_qdio_sbal_get(qdio))
1169 goto out; 1138 goto out;
1170 1139
1171 req = zfcp_fsf_req_create(qdio, FSF_QTCB_SEND_ELS, 1140 req = zfcp_fsf_req_create(qdio, FSF_QTCB_SEND_ELS,
@@ -1208,7 +1177,7 @@ int zfcp_fsf_exchange_config_data(struct zfcp_erp_action *erp_action)
1208 int retval = -EIO; 1177 int retval = -EIO;
1209 1178
1210 spin_lock_bh(&qdio->req_q_lock); 1179 spin_lock_bh(&qdio->req_q_lock);
1211 if (zfcp_fsf_req_sbal_get(qdio)) 1180 if (zfcp_qdio_sbal_get(qdio))
1212 goto out; 1181 goto out;
1213 1182
1214 req = zfcp_fsf_req_create(qdio, FSF_QTCB_EXCHANGE_CONFIG_DATA, 1183 req = zfcp_fsf_req_create(qdio, FSF_QTCB_EXCHANGE_CONFIG_DATA,
@@ -1250,7 +1219,7 @@ int zfcp_fsf_exchange_config_data_sync(struct zfcp_qdio *qdio,
1250 int retval = -EIO; 1219 int retval = -EIO;
1251 1220
1252 spin_lock_bh(&qdio->req_q_lock); 1221 spin_lock_bh(&qdio->req_q_lock);
1253 if (zfcp_fsf_req_sbal_get(qdio)) 1222 if (zfcp_qdio_sbal_get(qdio))
1254 goto out_unlock; 1223 goto out_unlock;
1255 1224
1256 req = zfcp_fsf_req_create(qdio, FSF_QTCB_EXCHANGE_CONFIG_DATA, 1225 req = zfcp_fsf_req_create(qdio, FSF_QTCB_EXCHANGE_CONFIG_DATA,
@@ -1302,7 +1271,7 @@ int zfcp_fsf_exchange_port_data(struct zfcp_erp_action *erp_action)
1302 return -EOPNOTSUPP; 1271 return -EOPNOTSUPP;
1303 1272
1304 spin_lock_bh(&qdio->req_q_lock); 1273 spin_lock_bh(&qdio->req_q_lock);
1305 if (zfcp_fsf_req_sbal_get(qdio)) 1274 if (zfcp_qdio_sbal_get(qdio))
1306 goto out; 1275 goto out;
1307 1276
1308 req = zfcp_fsf_req_create(qdio, FSF_QTCB_EXCHANGE_PORT_DATA, 1277 req = zfcp_fsf_req_create(qdio, FSF_QTCB_EXCHANGE_PORT_DATA,
@@ -1348,7 +1317,7 @@ int zfcp_fsf_exchange_port_data_sync(struct zfcp_qdio *qdio,
1348 return -EOPNOTSUPP; 1317 return -EOPNOTSUPP;
1349 1318
1350 spin_lock_bh(&qdio->req_q_lock); 1319 spin_lock_bh(&qdio->req_q_lock);
1351 if (zfcp_fsf_req_sbal_get(qdio)) 1320 if (zfcp_qdio_sbal_get(qdio))
1352 goto out_unlock; 1321 goto out_unlock;
1353 1322
1354 req = zfcp_fsf_req_create(qdio, FSF_QTCB_EXCHANGE_PORT_DATA, 1323 req = zfcp_fsf_req_create(qdio, FSF_QTCB_EXCHANGE_PORT_DATA,
@@ -1462,7 +1431,7 @@ int zfcp_fsf_open_port(struct zfcp_erp_action *erp_action)
1462 int retval = -EIO; 1431 int retval = -EIO;
1463 1432
1464 spin_lock_bh(&qdio->req_q_lock); 1433 spin_lock_bh(&qdio->req_q_lock);
1465 if (zfcp_fsf_req_sbal_get(qdio)) 1434 if (zfcp_qdio_sbal_get(qdio))
1466 goto out; 1435 goto out;
1467 1436
1468 req = zfcp_fsf_req_create(qdio, FSF_QTCB_OPEN_PORT_WITH_DID, 1437 req = zfcp_fsf_req_create(qdio, FSF_QTCB_OPEN_PORT_WITH_DID,
@@ -1530,7 +1499,7 @@ int zfcp_fsf_close_port(struct zfcp_erp_action *erp_action)
1530 int retval = -EIO; 1499 int retval = -EIO;
1531 1500
1532 spin_lock_bh(&qdio->req_q_lock); 1501 spin_lock_bh(&qdio->req_q_lock);
1533 if (zfcp_fsf_req_sbal_get(qdio)) 1502 if (zfcp_qdio_sbal_get(qdio))
1534 goto out; 1503 goto out;
1535 1504
1536 req = zfcp_fsf_req_create(qdio, FSF_QTCB_CLOSE_PORT, 1505 req = zfcp_fsf_req_create(qdio, FSF_QTCB_CLOSE_PORT,
@@ -1605,7 +1574,7 @@ int zfcp_fsf_open_wka_port(struct zfcp_fc_wka_port *wka_port)
1605 int retval = -EIO; 1574 int retval = -EIO;
1606 1575
1607 spin_lock_bh(&qdio->req_q_lock); 1576 spin_lock_bh(&qdio->req_q_lock);
1608 if (zfcp_fsf_req_sbal_get(qdio)) 1577 if (zfcp_qdio_sbal_get(qdio))
1609 goto out; 1578 goto out;
1610 1579
1611 req = zfcp_fsf_req_create(qdio, FSF_QTCB_OPEN_PORT_WITH_DID, 1580 req = zfcp_fsf_req_create(qdio, FSF_QTCB_OPEN_PORT_WITH_DID,
@@ -1658,7 +1627,7 @@ int zfcp_fsf_close_wka_port(struct zfcp_fc_wka_port *wka_port)
1658 int retval = -EIO; 1627 int retval = -EIO;
1659 1628
1660 spin_lock_bh(&qdio->req_q_lock); 1629 spin_lock_bh(&qdio->req_q_lock);
1661 if (zfcp_fsf_req_sbal_get(qdio)) 1630 if (zfcp_qdio_sbal_get(qdio))
1662 goto out; 1631 goto out;
1663 1632
1664 req = zfcp_fsf_req_create(qdio, FSF_QTCB_CLOSE_PORT, 1633 req = zfcp_fsf_req_create(qdio, FSF_QTCB_CLOSE_PORT,
@@ -1750,7 +1719,7 @@ int zfcp_fsf_close_physical_port(struct zfcp_erp_action *erp_action)
1750 int retval = -EIO; 1719 int retval = -EIO;
1751 1720
1752 spin_lock_bh(&qdio->req_q_lock); 1721 spin_lock_bh(&qdio->req_q_lock);
1753 if (zfcp_fsf_req_sbal_get(qdio)) 1722 if (zfcp_qdio_sbal_get(qdio))
1754 goto out; 1723 goto out;
1755 1724
1756 req = zfcp_fsf_req_create(qdio, FSF_QTCB_CLOSE_PHYSICAL_PORT, 1725 req = zfcp_fsf_req_create(qdio, FSF_QTCB_CLOSE_PHYSICAL_PORT,
@@ -1921,7 +1890,7 @@ int zfcp_fsf_open_unit(struct zfcp_erp_action *erp_action)
1921 int retval = -EIO; 1890 int retval = -EIO;
1922 1891
1923 spin_lock_bh(&qdio->req_q_lock); 1892 spin_lock_bh(&qdio->req_q_lock);
1924 if (zfcp_fsf_req_sbal_get(qdio)) 1893 if (zfcp_qdio_sbal_get(qdio))
1925 goto out; 1894 goto out;
1926 1895
1927 req = zfcp_fsf_req_create(qdio, FSF_QTCB_OPEN_LUN, 1896 req = zfcp_fsf_req_create(qdio, FSF_QTCB_OPEN_LUN,
@@ -2005,7 +1974,7 @@ int zfcp_fsf_close_unit(struct zfcp_erp_action *erp_action)
2005 int retval = -EIO; 1974 int retval = -EIO;
2006 1975
2007 spin_lock_bh(&qdio->req_q_lock); 1976 spin_lock_bh(&qdio->req_q_lock);
2008 if (zfcp_fsf_req_sbal_get(qdio)) 1977 if (zfcp_qdio_sbal_get(qdio))
2009 goto out; 1978 goto out;
2010 1979
2011 req = zfcp_fsf_req_create(qdio, FSF_QTCB_CLOSE_LUN, 1980 req = zfcp_fsf_req_create(qdio, FSF_QTCB_CLOSE_LUN,
@@ -2340,7 +2309,7 @@ struct zfcp_fsf_req *zfcp_fsf_send_fcp_ctm(struct zfcp_unit *unit, u8 tm_flags)
2340 return NULL; 2309 return NULL;
2341 2310
2342 spin_lock_bh(&qdio->req_q_lock); 2311 spin_lock_bh(&qdio->req_q_lock);
2343 if (zfcp_fsf_req_sbal_get(qdio)) 2312 if (zfcp_qdio_sbal_get(qdio))
2344 goto out; 2313 goto out;
2345 2314
2346 req = zfcp_fsf_req_create(qdio, FSF_QTCB_FCP_CMND, 2315 req = zfcp_fsf_req_create(qdio, FSF_QTCB_FCP_CMND,
@@ -2410,7 +2379,7 @@ struct zfcp_fsf_req *zfcp_fsf_control_file(struct zfcp_adapter *adapter,
2410 } 2379 }
2411 2380
2412 spin_lock_bh(&qdio->req_q_lock); 2381 spin_lock_bh(&qdio->req_q_lock);
2413 if (zfcp_fsf_req_sbal_get(qdio)) 2382 if (zfcp_qdio_sbal_get(qdio))
2414 goto out; 2383 goto out;
2415 2384
2416 req = zfcp_fsf_req_create(qdio, fsf_cfdc->command, direction, NULL); 2385 req = zfcp_fsf_req_create(qdio, fsf_cfdc->command, direction, NULL);
diff --git a/drivers/s390/scsi/zfcp_qdio.c b/drivers/s390/scsi/zfcp_qdio.c
index 98d54a9cd563..28117e130e2c 100644
--- a/drivers/s390/scsi/zfcp_qdio.c
+++ b/drivers/s390/scsi/zfcp_qdio.c
@@ -246,6 +246,46 @@ int zfcp_qdio_sbals_from_sg(struct zfcp_qdio *qdio, struct zfcp_qdio_req *q_req,
246 return bytes; 246 return bytes;
247} 247}
248 248
249static int zfcp_qdio_sbal_check(struct zfcp_qdio *qdio)
250{
251 struct zfcp_qdio_queue *req_q = &qdio->req_q;
252
253 spin_lock_bh(&qdio->req_q_lock);
254 if (atomic_read(&req_q->count))
255 return 1;
256 spin_unlock_bh(&qdio->req_q_lock);
257 return 0;
258}
259
260/**
261 * zfcp_qdio_sbal_get - get free sbal in request queue, wait if necessary
262 * @qdio: pointer to struct zfcp_qdio
263 *
264 * The req_q_lock must be held by the caller of this function, and
265 * this function may only be called from process context; it will
266 * sleep when waiting for a free sbal.
267 *
268 * Returns: 0 on success, -EIO if there is no free sbal after waiting.
269 */
270int zfcp_qdio_sbal_get(struct zfcp_qdio *qdio)
271{
272 long ret;
273
274 spin_unlock_bh(&qdio->req_q_lock);
275 ret = wait_event_interruptible_timeout(qdio->req_q_wq,
276 zfcp_qdio_sbal_check(qdio), 5 * HZ);
277 if (ret > 0)
278 return 0;
279 if (!ret) {
280 atomic_inc(&qdio->req_q_full);
281 /* assume hanging outbound queue, try queue recovery */
282 zfcp_erp_adapter_reopen(qdio->adapter, 0, "qdsbg_1", NULL);
283 }
284
285 spin_lock_bh(&qdio->req_q_lock);
286 return -EIO;
287}
288
249/** 289/**
250 * zfcp_qdio_send - set PCI flag in first SBALE and send req to QDIO 290 * zfcp_qdio_send - set PCI flag in first SBALE and send req to QDIO
251 * @qdio: pointer to struct zfcp_qdio 291 * @qdio: pointer to struct zfcp_qdio