diff options
Diffstat (limited to 'drivers/s390/scsi')
-rw-r--r-- | drivers/s390/scsi/zfcp_dbf.c | 4 | ||||
-rw-r--r-- | drivers/s390/scsi/zfcp_dbf.h | 2 | ||||
-rw-r--r-- | drivers/s390/scsi/zfcp_def.h | 3 | ||||
-rw-r--r-- | drivers/s390/scsi/zfcp_fsf.c | 36 | ||||
-rw-r--r-- | drivers/s390/scsi/zfcp_qdio.c | 16 |
5 files changed, 30 insertions, 31 deletions
diff --git a/drivers/s390/scsi/zfcp_dbf.c b/drivers/s390/scsi/zfcp_dbf.c index efd60c4af4c6..0a2ffc635c77 100644 --- a/drivers/s390/scsi/zfcp_dbf.c +++ b/drivers/s390/scsi/zfcp_dbf.c | |||
@@ -186,7 +186,7 @@ void zfcp_hba_dbf_event_fsf_response(struct zfcp_fsf_req *fsf_req) | |||
186 | fsf_status_qual, FSF_STATUS_QUALIFIER_SIZE); | 186 | fsf_status_qual, FSF_STATUS_QUALIFIER_SIZE); |
187 | response->fsf_req_status = fsf_req->status; | 187 | response->fsf_req_status = fsf_req->status; |
188 | response->sbal_first = fsf_req->sbal_first; | 188 | response->sbal_first = fsf_req->sbal_first; |
189 | response->sbal_curr = fsf_req->sbal_curr; | 189 | response->sbal_last = fsf_req->sbal_last; |
190 | response->pool = fsf_req->pool != NULL; | 190 | response->pool = fsf_req->pool != NULL; |
191 | response->erp_action = (unsigned long)fsf_req->erp_action; | 191 | response->erp_action = (unsigned long)fsf_req->erp_action; |
192 | 192 | ||
@@ -354,7 +354,7 @@ static void zfcp_hba_dbf_view_response(char **p, | |||
354 | FSF_STATUS_QUALIFIER_SIZE, 0, FSF_STATUS_QUALIFIER_SIZE); | 354 | FSF_STATUS_QUALIFIER_SIZE, 0, FSF_STATUS_QUALIFIER_SIZE); |
355 | zfcp_dbf_out(p, "fsf_req_status", "0x%08x", r->fsf_req_status); | 355 | zfcp_dbf_out(p, "fsf_req_status", "0x%08x", r->fsf_req_status); |
356 | zfcp_dbf_out(p, "sbal_first", "0x%02x", r->sbal_first); | 356 | zfcp_dbf_out(p, "sbal_first", "0x%02x", r->sbal_first); |
357 | zfcp_dbf_out(p, "sbal_curr", "0x%02x", r->sbal_curr); | 357 | zfcp_dbf_out(p, "sbal_last", "0x%02x", r->sbal_last); |
358 | zfcp_dbf_out(p, "pool", "0x%02x", r->pool); | 358 | zfcp_dbf_out(p, "pool", "0x%02x", r->pool); |
359 | 359 | ||
360 | switch (r->fsf_command) { | 360 | switch (r->fsf_command) { |
diff --git a/drivers/s390/scsi/zfcp_dbf.h b/drivers/s390/scsi/zfcp_dbf.h index 66b8754840b2..212622ca2e80 100644 --- a/drivers/s390/scsi/zfcp_dbf.h +++ b/drivers/s390/scsi/zfcp_dbf.h | |||
@@ -97,7 +97,7 @@ struct zfcp_hba_dbf_record_response { | |||
97 | u8 fsf_status_qual[FSF_STATUS_QUALIFIER_SIZE]; | 97 | u8 fsf_status_qual[FSF_STATUS_QUALIFIER_SIZE]; |
98 | u32 fsf_req_status; | 98 | u32 fsf_req_status; |
99 | u8 sbal_first; | 99 | u8 sbal_first; |
100 | u8 sbal_curr; | 100 | u8 sbal_last; |
101 | u8 pool; | 101 | u8 pool; |
102 | u64 erp_action; | 102 | u64 erp_action; |
103 | union { | 103 | union { |
diff --git a/drivers/s390/scsi/zfcp_def.h b/drivers/s390/scsi/zfcp_def.h index fdd5520eb3d2..210273d97f00 100644 --- a/drivers/s390/scsi/zfcp_def.h +++ b/drivers/s390/scsi/zfcp_def.h | |||
@@ -851,10 +851,9 @@ struct zfcp_fsf_req { | |||
851 | struct zfcp_adapter *adapter; /* adapter request belongs to */ | 851 | struct zfcp_adapter *adapter; /* adapter request belongs to */ |
852 | u8 sbal_number; /* nr of SBALs free for use */ | 852 | u8 sbal_number; /* nr of SBALs free for use */ |
853 | u8 sbal_first; /* first SBAL for this request */ | 853 | u8 sbal_first; /* first SBAL for this request */ |
854 | u8 sbal_last; /* last SBAL for this request */ | ||
854 | u8 sbal_limit; /* last possible SBAL for | 855 | u8 sbal_limit; /* last possible SBAL for |
855 | this reuest */ | 856 | this reuest */ |
856 | u8 sbal_curr; /* current SBAL during creation | ||
857 | of request */ | ||
858 | u8 sbale_curr; /* current SBALE during creation | 857 | u8 sbale_curr; /* current SBALE during creation |
859 | of request */ | 858 | of request */ |
860 | wait_queue_head_t completion_wq; /* can be used by a routine | 859 | wait_queue_head_t completion_wq; /* can be used by a routine |
diff --git a/drivers/s390/scsi/zfcp_fsf.c b/drivers/s390/scsi/zfcp_fsf.c index 2f27d03e61c2..01f9b27daa8c 100644 --- a/drivers/s390/scsi/zfcp_fsf.c +++ b/drivers/s390/scsi/zfcp_fsf.c | |||
@@ -726,7 +726,7 @@ zfcp_fsf_status_read(struct zfcp_adapter *adapter, int req_flags) | |||
726 | goto failed_req_create; | 726 | goto failed_req_create; |
727 | } | 727 | } |
728 | 728 | ||
729 | sbale = zfcp_qdio_sbale_req(fsf_req, fsf_req->sbal_curr, 0); | 729 | sbale = zfcp_qdio_sbale_req(fsf_req, fsf_req->sbal_last, 0); |
730 | sbale[0].flags |= SBAL_FLAGS0_TYPE_STATUS; | 730 | sbale[0].flags |= SBAL_FLAGS0_TYPE_STATUS; |
731 | sbale[2].flags |= SBAL_FLAGS_LAST_ENTRY; | 731 | sbale[2].flags |= SBAL_FLAGS_LAST_ENTRY; |
732 | fsf_req->sbale_curr = 2; | 732 | fsf_req->sbale_curr = 2; |
@@ -1075,7 +1075,7 @@ zfcp_fsf_abort_fcp_command(unsigned long old_req_id, | |||
1075 | &unit->status))) | 1075 | &unit->status))) |
1076 | goto unit_blocked; | 1076 | goto unit_blocked; |
1077 | 1077 | ||
1078 | sbale = zfcp_qdio_sbale_req(fsf_req, fsf_req->sbal_curr, 0); | 1078 | sbale = zfcp_qdio_sbale_req(fsf_req, fsf_req->sbal_last, 0); |
1079 | sbale[0].flags |= SBAL_FLAGS0_TYPE_READ; | 1079 | sbale[0].flags |= SBAL_FLAGS0_TYPE_READ; |
1080 | sbale[1].flags |= SBAL_FLAGS_LAST_ENTRY; | 1080 | sbale[1].flags |= SBAL_FLAGS_LAST_ENTRY; |
1081 | 1081 | ||
@@ -1295,7 +1295,7 @@ zfcp_fsf_send_ct(struct zfcp_send_ct *ct, mempool_t *pool, | |||
1295 | goto failed_req; | 1295 | goto failed_req; |
1296 | } | 1296 | } |
1297 | 1297 | ||
1298 | sbale = zfcp_qdio_sbale_req(fsf_req, fsf_req->sbal_curr, 0); | 1298 | sbale = zfcp_qdio_sbale_req(fsf_req, fsf_req->sbal_last, 0); |
1299 | if (zfcp_use_one_sbal(ct->req, ct->req_count, | 1299 | if (zfcp_use_one_sbal(ct->req, ct->req_count, |
1300 | ct->resp, ct->resp_count)){ | 1300 | ct->resp, ct->resp_count)){ |
1301 | /* both request buffer and response buffer | 1301 | /* both request buffer and response buffer |
@@ -1593,7 +1593,7 @@ zfcp_fsf_send_els(struct zfcp_send_els *els) | |||
1593 | goto port_blocked; | 1593 | goto port_blocked; |
1594 | } | 1594 | } |
1595 | 1595 | ||
1596 | sbale = zfcp_qdio_sbale_req(fsf_req, fsf_req->sbal_curr, 0); | 1596 | sbale = zfcp_qdio_sbale_req(fsf_req, fsf_req->sbal_last, 0); |
1597 | if (zfcp_use_one_sbal(els->req, els->req_count, | 1597 | if (zfcp_use_one_sbal(els->req, els->req_count, |
1598 | els->resp, els->resp_count)){ | 1598 | els->resp, els->resp_count)){ |
1599 | /* both request buffer and response buffer | 1599 | /* both request buffer and response buffer |
@@ -1657,7 +1657,7 @@ zfcp_fsf_send_els(struct zfcp_send_els *els) | |||
1657 | fsf_req->qtcb->bottom.support.timeout = ZFCP_ELS_TIMEOUT; | 1657 | fsf_req->qtcb->bottom.support.timeout = ZFCP_ELS_TIMEOUT; |
1658 | fsf_req->data = (unsigned long) els; | 1658 | fsf_req->data = (unsigned long) els; |
1659 | 1659 | ||
1660 | sbale = zfcp_qdio_sbale_req(fsf_req, fsf_req->sbal_curr, 0); | 1660 | sbale = zfcp_qdio_sbale_req(fsf_req, fsf_req->sbal_last, 0); |
1661 | 1661 | ||
1662 | zfcp_san_dbf_event_els_request(fsf_req); | 1662 | zfcp_san_dbf_event_els_request(fsf_req); |
1663 | 1663 | ||
@@ -1872,7 +1872,7 @@ zfcp_fsf_exchange_config_data(struct zfcp_erp_action *erp_action) | |||
1872 | return retval; | 1872 | return retval; |
1873 | } | 1873 | } |
1874 | 1874 | ||
1875 | sbale = zfcp_qdio_sbale_req(fsf_req, fsf_req->sbal_curr, 0); | 1875 | sbale = zfcp_qdio_sbale_req(fsf_req, fsf_req->sbal_last, 0); |
1876 | sbale[0].flags |= SBAL_FLAGS0_TYPE_READ; | 1876 | sbale[0].flags |= SBAL_FLAGS0_TYPE_READ; |
1877 | sbale[1].flags |= SBAL_FLAGS_LAST_ENTRY; | 1877 | sbale[1].flags |= SBAL_FLAGS_LAST_ENTRY; |
1878 | 1878 | ||
@@ -1925,7 +1925,7 @@ zfcp_fsf_exchange_config_data_sync(struct zfcp_adapter *adapter, | |||
1925 | return retval; | 1925 | return retval; |
1926 | } | 1926 | } |
1927 | 1927 | ||
1928 | sbale = zfcp_qdio_sbale_req(fsf_req, fsf_req->sbal_curr, 0); | 1928 | sbale = zfcp_qdio_sbale_req(fsf_req, fsf_req->sbal_last, 0); |
1929 | sbale[0].flags |= SBAL_FLAGS0_TYPE_READ; | 1929 | sbale[0].flags |= SBAL_FLAGS0_TYPE_READ; |
1930 | sbale[1].flags |= SBAL_FLAGS_LAST_ENTRY; | 1930 | sbale[1].flags |= SBAL_FLAGS_LAST_ENTRY; |
1931 | 1931 | ||
@@ -2187,7 +2187,7 @@ zfcp_fsf_exchange_port_data(struct zfcp_erp_action *erp_action) | |||
2187 | return retval; | 2187 | return retval; |
2188 | } | 2188 | } |
2189 | 2189 | ||
2190 | sbale = zfcp_qdio_sbale_req(fsf_req, fsf_req->sbal_curr, 0); | 2190 | sbale = zfcp_qdio_sbale_req(fsf_req, fsf_req->sbal_last, 0); |
2191 | sbale[0].flags |= SBAL_FLAGS0_TYPE_READ; | 2191 | sbale[0].flags |= SBAL_FLAGS0_TYPE_READ; |
2192 | sbale[1].flags |= SBAL_FLAGS_LAST_ENTRY; | 2192 | sbale[1].flags |= SBAL_FLAGS_LAST_ENTRY; |
2193 | 2193 | ||
@@ -2249,7 +2249,7 @@ zfcp_fsf_exchange_port_data_sync(struct zfcp_adapter *adapter, | |||
2249 | if (data) | 2249 | if (data) |
2250 | fsf_req->data = (unsigned long) data; | 2250 | fsf_req->data = (unsigned long) data; |
2251 | 2251 | ||
2252 | sbale = zfcp_qdio_sbale_req(fsf_req, fsf_req->sbal_curr, 0); | 2252 | sbale = zfcp_qdio_sbale_req(fsf_req, fsf_req->sbal_last, 0); |
2253 | sbale[0].flags |= SBAL_FLAGS0_TYPE_READ; | 2253 | sbale[0].flags |= SBAL_FLAGS0_TYPE_READ; |
2254 | sbale[1].flags |= SBAL_FLAGS_LAST_ENTRY; | 2254 | sbale[1].flags |= SBAL_FLAGS_LAST_ENTRY; |
2255 | 2255 | ||
@@ -2359,7 +2359,7 @@ zfcp_fsf_open_port(struct zfcp_erp_action *erp_action) | |||
2359 | goto out; | 2359 | goto out; |
2360 | } | 2360 | } |
2361 | 2361 | ||
2362 | sbale = zfcp_qdio_sbale_req(fsf_req, fsf_req->sbal_curr, 0); | 2362 | sbale = zfcp_qdio_sbale_req(fsf_req, fsf_req->sbal_last, 0); |
2363 | sbale[0].flags |= SBAL_FLAGS0_TYPE_READ; | 2363 | sbale[0].flags |= SBAL_FLAGS0_TYPE_READ; |
2364 | sbale[1].flags |= SBAL_FLAGS_LAST_ENTRY; | 2364 | sbale[1].flags |= SBAL_FLAGS_LAST_ENTRY; |
2365 | 2365 | ||
@@ -2591,7 +2591,7 @@ zfcp_fsf_close_port(struct zfcp_erp_action *erp_action) | |||
2591 | goto out; | 2591 | goto out; |
2592 | } | 2592 | } |
2593 | 2593 | ||
2594 | sbale = zfcp_qdio_sbale_req(fsf_req, fsf_req->sbal_curr, 0); | 2594 | sbale = zfcp_qdio_sbale_req(fsf_req, fsf_req->sbal_last, 0); |
2595 | sbale[0].flags |= SBAL_FLAGS0_TYPE_READ; | 2595 | sbale[0].flags |= SBAL_FLAGS0_TYPE_READ; |
2596 | sbale[1].flags |= SBAL_FLAGS_LAST_ENTRY; | 2596 | sbale[1].flags |= SBAL_FLAGS_LAST_ENTRY; |
2597 | 2597 | ||
@@ -2720,7 +2720,7 @@ zfcp_fsf_close_physical_port(struct zfcp_erp_action *erp_action) | |||
2720 | goto out; | 2720 | goto out; |
2721 | } | 2721 | } |
2722 | 2722 | ||
2723 | sbale = zfcp_qdio_sbale_req(fsf_req, fsf_req->sbal_curr, 0); | 2723 | sbale = zfcp_qdio_sbale_req(fsf_req, fsf_req->sbal_last, 0); |
2724 | sbale[0].flags |= SBAL_FLAGS0_TYPE_READ; | 2724 | sbale[0].flags |= SBAL_FLAGS0_TYPE_READ; |
2725 | sbale[1].flags |= SBAL_FLAGS_LAST_ENTRY; | 2725 | sbale[1].flags |= SBAL_FLAGS_LAST_ENTRY; |
2726 | 2726 | ||
@@ -2915,7 +2915,7 @@ zfcp_fsf_open_unit(struct zfcp_erp_action *erp_action) | |||
2915 | goto out; | 2915 | goto out; |
2916 | } | 2916 | } |
2917 | 2917 | ||
2918 | sbale = zfcp_qdio_sbale_req(fsf_req, fsf_req->sbal_curr, 0); | 2918 | sbale = zfcp_qdio_sbale_req(fsf_req, fsf_req->sbal_last, 0); |
2919 | sbale[0].flags |= SBAL_FLAGS0_TYPE_READ; | 2919 | sbale[0].flags |= SBAL_FLAGS0_TYPE_READ; |
2920 | sbale[1].flags |= SBAL_FLAGS_LAST_ENTRY; | 2920 | sbale[1].flags |= SBAL_FLAGS_LAST_ENTRY; |
2921 | 2921 | ||
@@ -3230,7 +3230,7 @@ zfcp_fsf_close_unit(struct zfcp_erp_action *erp_action) | |||
3230 | goto out; | 3230 | goto out; |
3231 | } | 3231 | } |
3232 | 3232 | ||
3233 | sbale = zfcp_qdio_sbale_req(fsf_req, fsf_req->sbal_curr, 0); | 3233 | sbale = zfcp_qdio_sbale_req(fsf_req, fsf_req->sbal_last, 0); |
3234 | sbale[0].flags |= SBAL_FLAGS0_TYPE_READ; | 3234 | sbale[0].flags |= SBAL_FLAGS0_TYPE_READ; |
3235 | sbale[1].flags |= SBAL_FLAGS_LAST_ENTRY; | 3235 | sbale[1].flags |= SBAL_FLAGS_LAST_ENTRY; |
3236 | 3236 | ||
@@ -3613,7 +3613,7 @@ zfcp_fsf_send_fcp_command_task_management(struct zfcp_adapter *adapter, | |||
3613 | fsf_req->qtcb->bottom.io.fcp_cmnd_length = | 3613 | fsf_req->qtcb->bottom.io.fcp_cmnd_length = |
3614 | sizeof (struct fcp_cmnd_iu) + sizeof (fcp_dl_t); | 3614 | sizeof (struct fcp_cmnd_iu) + sizeof (fcp_dl_t); |
3615 | 3615 | ||
3616 | sbale = zfcp_qdio_sbale_req(fsf_req, fsf_req->sbal_curr, 0); | 3616 | sbale = zfcp_qdio_sbale_req(fsf_req, fsf_req->sbal_last, 0); |
3617 | sbale[0].flags |= SBAL_FLAGS0_TYPE_WRITE; | 3617 | sbale[0].flags |= SBAL_FLAGS0_TYPE_WRITE; |
3618 | sbale[1].flags |= SBAL_FLAGS_LAST_ENTRY; | 3618 | sbale[1].flags |= SBAL_FLAGS_LAST_ENTRY; |
3619 | 3619 | ||
@@ -4238,7 +4238,7 @@ zfcp_fsf_control_file(struct zfcp_adapter *adapter, | |||
4238 | goto unlock_queue_lock; | 4238 | goto unlock_queue_lock; |
4239 | } | 4239 | } |
4240 | 4240 | ||
4241 | sbale = zfcp_qdio_sbale_req(fsf_req, fsf_req->sbal_curr, 0); | 4241 | sbale = zfcp_qdio_sbale_req(fsf_req, fsf_req->sbal_last, 0); |
4242 | sbale[0].flags |= direction; | 4242 | sbale[0].flags |= direction; |
4243 | 4243 | ||
4244 | bottom = &fsf_req->qtcb->bottom.support; | 4244 | bottom = &fsf_req->qtcb->bottom.support; |
@@ -4590,14 +4590,14 @@ zfcp_fsf_req_create(struct zfcp_adapter *adapter, u32 fsf_cmd, int req_flags, | |||
4590 | } | 4590 | } |
4591 | fsf_req->sbal_number = 1; | 4591 | fsf_req->sbal_number = 1; |
4592 | fsf_req->sbal_first = req_queue->free_index; | 4592 | fsf_req->sbal_first = req_queue->free_index; |
4593 | fsf_req->sbal_curr = req_queue->free_index; | 4593 | fsf_req->sbal_last = req_queue->free_index; |
4594 | fsf_req->sbale_curr = 1; | 4594 | fsf_req->sbale_curr = 1; |
4595 | 4595 | ||
4596 | if (likely(req_flags & ZFCP_REQ_AUTO_CLEANUP)) { | 4596 | if (likely(req_flags & ZFCP_REQ_AUTO_CLEANUP)) { |
4597 | fsf_req->status |= ZFCP_STATUS_FSFREQ_CLEANUP; | 4597 | fsf_req->status |= ZFCP_STATUS_FSFREQ_CLEANUP; |
4598 | } | 4598 | } |
4599 | 4599 | ||
4600 | sbale = zfcp_qdio_sbale_req(fsf_req, fsf_req->sbal_curr, 0); | 4600 | sbale = zfcp_qdio_sbale_req(fsf_req, fsf_req->sbal_last, 0); |
4601 | 4601 | ||
4602 | /* setup common SBALE fields */ | 4602 | /* setup common SBALE fields */ |
4603 | sbale[0].addr = (void *) fsf_req->req_id; | 4603 | sbale[0].addr = (void *) fsf_req->req_id; |
diff --git a/drivers/s390/scsi/zfcp_qdio.c b/drivers/s390/scsi/zfcp_qdio.c index b6b6b36c6f20..8c83cdc73d98 100644 --- a/drivers/s390/scsi/zfcp_qdio.c +++ b/drivers/s390/scsi/zfcp_qdio.c | |||
@@ -415,7 +415,7 @@ zfcp_qdio_sbale_resp(struct zfcp_fsf_req *fsf_req, int sbal, int sbale) | |||
415 | volatile struct qdio_buffer_element * | 415 | volatile struct qdio_buffer_element * |
416 | zfcp_qdio_sbale_curr(struct zfcp_fsf_req *fsf_req) | 416 | zfcp_qdio_sbale_curr(struct zfcp_fsf_req *fsf_req) |
417 | { | 417 | { |
418 | return zfcp_qdio_sbale_req(fsf_req, fsf_req->sbal_curr, | 418 | return zfcp_qdio_sbale_req(fsf_req, fsf_req->sbal_last, |
419 | fsf_req->sbale_curr); | 419 | fsf_req->sbale_curr); |
420 | } | 420 | } |
421 | 421 | ||
@@ -443,7 +443,7 @@ zfcp_qdio_sbal_limit(struct zfcp_fsf_req *fsf_req, int max_sbals) | |||
443 | * @fsf_req: zfcp_fsf_req to be processed | 443 | * @fsf_req: zfcp_fsf_req to be processed |
444 | * @sbtype: SBAL flags which have to be set in first SBALE of new SBAL | 444 | * @sbtype: SBAL flags which have to be set in first SBALE of new SBAL |
445 | * | 445 | * |
446 | * This function changes sbal_curr, sbale_curr, sbal_number of fsf_req. | 446 | * This function changes sbal_last, sbale_curr, sbal_number of fsf_req. |
447 | */ | 447 | */ |
448 | static volatile struct qdio_buffer_element * | 448 | static volatile struct qdio_buffer_element * |
449 | zfcp_qdio_sbal_chain(struct zfcp_fsf_req *fsf_req, unsigned long sbtype) | 449 | zfcp_qdio_sbal_chain(struct zfcp_fsf_req *fsf_req, unsigned long sbtype) |
@@ -455,16 +455,16 @@ zfcp_qdio_sbal_chain(struct zfcp_fsf_req *fsf_req, unsigned long sbtype) | |||
455 | sbale->flags |= SBAL_FLAGS_LAST_ENTRY; | 455 | sbale->flags |= SBAL_FLAGS_LAST_ENTRY; |
456 | 456 | ||
457 | /* don't exceed last allowed SBAL */ | 457 | /* don't exceed last allowed SBAL */ |
458 | if (fsf_req->sbal_curr == fsf_req->sbal_limit) | 458 | if (fsf_req->sbal_last == fsf_req->sbal_limit) |
459 | return NULL; | 459 | return NULL; |
460 | 460 | ||
461 | /* set chaining flag in first SBALE of current SBAL */ | 461 | /* set chaining flag in first SBALE of current SBAL */ |
462 | sbale = zfcp_qdio_sbale_req(fsf_req, fsf_req->sbal_curr, 0); | 462 | sbale = zfcp_qdio_sbale_req(fsf_req, fsf_req->sbal_last, 0); |
463 | sbale->flags |= SBAL_FLAGS0_MORE_SBALS; | 463 | sbale->flags |= SBAL_FLAGS0_MORE_SBALS; |
464 | 464 | ||
465 | /* calculate index of next SBAL */ | 465 | /* calculate index of next SBAL */ |
466 | fsf_req->sbal_curr++; | 466 | fsf_req->sbal_last++; |
467 | fsf_req->sbal_curr %= QDIO_MAX_BUFFERS_PER_Q; | 467 | fsf_req->sbal_last %= QDIO_MAX_BUFFERS_PER_Q; |
468 | 468 | ||
469 | /* keep this requests number of SBALs up-to-date */ | 469 | /* keep this requests number of SBALs up-to-date */ |
470 | fsf_req->sbal_number++; | 470 | fsf_req->sbal_number++; |
@@ -523,7 +523,7 @@ static inline int | |||
523 | zfcp_qdio_sbals_wipe(struct zfcp_fsf_req *fsf_req) | 523 | zfcp_qdio_sbals_wipe(struct zfcp_fsf_req *fsf_req) |
524 | { | 524 | { |
525 | return zfcp_qdio_sbals_zero(&fsf_req->adapter->request_queue, | 525 | return zfcp_qdio_sbals_zero(&fsf_req->adapter->request_queue, |
526 | fsf_req->sbal_first, fsf_req->sbal_curr); | 526 | fsf_req->sbal_first, fsf_req->sbal_last); |
527 | } | 527 | } |
528 | 528 | ||
529 | 529 | ||
@@ -601,7 +601,7 @@ zfcp_qdio_sbals_from_sg(struct zfcp_fsf_req *fsf_req, unsigned long sbtype, | |||
601 | zfcp_qdio_sbal_limit(fsf_req, max_sbals); | 601 | zfcp_qdio_sbal_limit(fsf_req, max_sbals); |
602 | 602 | ||
603 | /* set storage-block type for current SBAL */ | 603 | /* set storage-block type for current SBAL */ |
604 | sbale = zfcp_qdio_sbale_req(fsf_req, fsf_req->sbal_curr, 0); | 604 | sbale = zfcp_qdio_sbale_req(fsf_req, fsf_req->sbal_last, 0); |
605 | sbale->flags |= sbtype; | 605 | sbale->flags |= sbtype; |
606 | 606 | ||
607 | /* process all segements of scatter-gather list */ | 607 | /* process all segements of scatter-gather list */ |