aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMike Christie <michaelc@cs.wisc.edu>2007-05-30 13:57:15 -0400
committerJames Bottomley <jejb@mulgrave.(none)>2007-06-01 12:58:22 -0400
commit857ae0bdb72999936a28ce621e38e2e288c485da (patch)
treecf1b9272c6c5bdb5448d016390bc2b07d435f5b3
parentd473cc7f15f64ab8a90c3d7288ef30f46785d8d5 (diff)
[SCSI] iscsi: Some fixes in preparation for bidirectional support - total_length
- Remove shadow of request length from struct iscsi_cmd_task. - change all users to use scsi_cmnd->request_bufflen directly (With bidi we will use scsi-ml API to retrieve in/out length) Signed-off-by: Boaz Harrosh <bharrosh@panasas.com> Signed-off-by: Benny Halevy <bhalevy@panasas.com> Signed-off-by: Mike Christie <michaelc@cs.wisc.edu> Cc: Roland Dreier <rdreier@cisco.com> Signed-off-by: James Bottomley <James.Bottomley@SteelEye.com>
-rw-r--r--drivers/infiniband/ulp/iser/iscsi_iser.c4
-rw-r--r--drivers/scsi/iscsi_tcp.c21
-rw-r--r--drivers/scsi/libiscsi.c9
-rw-r--r--include/scsi/libiscsi.h21
4 files changed, 28 insertions, 27 deletions
diff --git a/drivers/infiniband/ulp/iser/iscsi_iser.c b/drivers/infiniband/ulp/iser/iscsi_iser.c
index e39d9a07bc5d..568f88bf7c91 100644
--- a/drivers/infiniband/ulp/iser/iscsi_iser.c
+++ b/drivers/infiniband/ulp/iser/iscsi_iser.c
@@ -140,10 +140,10 @@ iscsi_iser_cmd_init(struct iscsi_cmd_task *ctask)
140 iser_ctask->iser_conn = iser_conn; 140 iser_ctask->iser_conn = iser_conn;
141 141
142 if (sc->sc_data_direction == DMA_TO_DEVICE) { 142 if (sc->sc_data_direction == DMA_TO_DEVICE) {
143 BUG_ON(ctask->total_length == 0); 143 BUG_ON(sc->request_bufflen == 0);
144 144
145 debug_scsi("cmd [itt %x total %d imm %d unsol_data %d\n", 145 debug_scsi("cmd [itt %x total %d imm %d unsol_data %d\n",
146 ctask->itt, ctask->total_length, ctask->imm_count, 146 ctask->itt, sc->request_bufflen, ctask->imm_count,
147 ctask->unsol_count); 147 ctask->unsol_count);
148 } 148 }
149 149
diff --git a/drivers/scsi/iscsi_tcp.c b/drivers/scsi/iscsi_tcp.c
index 17fc79c408a2..b2827d112cb0 100644
--- a/drivers/scsi/iscsi_tcp.c
+++ b/drivers/scsi/iscsi_tcp.c
@@ -216,6 +216,7 @@ iscsi_data_rsp(struct iscsi_conn *conn, struct iscsi_cmd_task *ctask)
216 struct iscsi_tcp_cmd_task *tcp_ctask = ctask->dd_data; 216 struct iscsi_tcp_cmd_task *tcp_ctask = ctask->dd_data;
217 struct iscsi_data_rsp *rhdr = (struct iscsi_data_rsp *)tcp_conn->in.hdr; 217 struct iscsi_data_rsp *rhdr = (struct iscsi_data_rsp *)tcp_conn->in.hdr;
218 struct iscsi_session *session = conn->session; 218 struct iscsi_session *session = conn->session;
219 struct scsi_cmnd *sc = ctask->sc;
219 int datasn = be32_to_cpu(rhdr->datasn); 220 int datasn = be32_to_cpu(rhdr->datasn);
220 221
221 rc = iscsi_check_assign_cmdsn(session, (struct iscsi_nopin*)rhdr); 222 rc = iscsi_check_assign_cmdsn(session, (struct iscsi_nopin*)rhdr);
@@ -238,12 +239,14 @@ iscsi_data_rsp(struct iscsi_conn *conn, struct iscsi_cmd_task *ctask)
238 tcp_ctask->exp_datasn++; 239 tcp_ctask->exp_datasn++;
239 240
240 tcp_ctask->data_offset = be32_to_cpu(rhdr->offset); 241 tcp_ctask->data_offset = be32_to_cpu(rhdr->offset);
241 if (tcp_ctask->data_offset + tcp_conn->in.datalen > ctask->total_length) 242 if (tcp_ctask->data_offset + tcp_conn->in.datalen > sc->request_bufflen) {
243 debug_tcp("%s: data_offset(%d) + data_len(%d) > total_length_in(%d)\n",
244 __FUNCTION__, tcp_ctask->data_offset,
245 tcp_conn->in.datalen, sc->request_bufflen);
242 return ISCSI_ERR_DATA_OFFSET; 246 return ISCSI_ERR_DATA_OFFSET;
247 }
243 248
244 if (rhdr->flags & ISCSI_FLAG_DATA_STATUS) { 249 if (rhdr->flags & ISCSI_FLAG_DATA_STATUS) {
245 struct scsi_cmnd *sc = ctask->sc;
246
247 conn->exp_statsn = be32_to_cpu(rhdr->statsn) + 1; 250 conn->exp_statsn = be32_to_cpu(rhdr->statsn) + 1;
248 if (rhdr->flags & ISCSI_FLAG_DATA_UNDERFLOW) { 251 if (rhdr->flags & ISCSI_FLAG_DATA_UNDERFLOW) {
249 int res_count = be32_to_cpu(rhdr->residual_count); 252 int res_count = be32_to_cpu(rhdr->residual_count);
@@ -405,11 +408,11 @@ iscsi_r2t_rsp(struct iscsi_conn *conn, struct iscsi_cmd_task *ctask)
405 r2t->data_length, session->max_burst); 408 r2t->data_length, session->max_burst);
406 409
407 r2t->data_offset = be32_to_cpu(rhdr->data_offset); 410 r2t->data_offset = be32_to_cpu(rhdr->data_offset);
408 if (r2t->data_offset + r2t->data_length > ctask->total_length) { 411 if (r2t->data_offset + r2t->data_length > ctask->sc->request_bufflen) {
409 spin_unlock(&session->lock); 412 spin_unlock(&session->lock);
410 printk(KERN_ERR "iscsi_tcp: invalid R2T with data len %u at " 413 printk(KERN_ERR "iscsi_tcp: invalid R2T with data len %u at "
411 "offset %u and total length %d\n", r2t->data_length, 414 "offset %u and total length %d\n", r2t->data_length,
412 r2t->data_offset, ctask->total_length); 415 r2t->data_offset, ctask->sc->request_bufflen);
413 return ISCSI_ERR_DATALEN; 416 return ISCSI_ERR_DATALEN;
414 } 417 }
415 418
@@ -604,7 +607,7 @@ iscsi_ctask_copy(struct iscsi_tcp_conn *tcp_conn, struct iscsi_cmd_task *ctask,
604{ 607{
605 struct iscsi_tcp_cmd_task *tcp_ctask = ctask->dd_data; 608 struct iscsi_tcp_cmd_task *tcp_ctask = ctask->dd_data;
606 int buf_left = buf_size - (tcp_conn->data_copied + offset); 609 int buf_left = buf_size - (tcp_conn->data_copied + offset);
607 int size = min(tcp_conn->in.copy, buf_left); 610 unsigned size = min(tcp_conn->in.copy, buf_left);
608 int rc; 611 int rc;
609 612
610 size = min(size, ctask->data_count); 613 size = min(size, ctask->data_count);
@@ -613,7 +616,7 @@ iscsi_ctask_copy(struct iscsi_tcp_conn *tcp_conn, struct iscsi_cmd_task *ctask,
613 size, tcp_conn->in.offset, tcp_conn->in.copied); 616 size, tcp_conn->in.offset, tcp_conn->in.copied);
614 617
615 BUG_ON(size <= 0); 618 BUG_ON(size <= 0);
616 BUG_ON(tcp_ctask->sent + size > ctask->total_length); 619 BUG_ON(tcp_ctask->sent + size > ctask->sc->request_bufflen);
617 620
618 rc = skb_copy_bits(tcp_conn->in.skb, tcp_conn->in.offset, 621 rc = skb_copy_bits(tcp_conn->in.skb, tcp_conn->in.offset,
619 (char*)buf + (offset + tcp_conn->data_copied), size); 622 (char*)buf + (offset + tcp_conn->data_copied), size);
@@ -1292,7 +1295,7 @@ iscsi_tcp_cmd_init(struct iscsi_cmd_task *ctask)
1292 1295
1293 if (sc->sc_data_direction == DMA_TO_DEVICE) { 1296 if (sc->sc_data_direction == DMA_TO_DEVICE) {
1294 tcp_ctask->xmstate = XMSTATE_W_HDR; 1297 tcp_ctask->xmstate = XMSTATE_W_HDR;
1295 BUG_ON(ctask->total_length == 0); 1298 BUG_ON(sc->request_bufflen == 0);
1296 1299
1297 if (sc->use_sg) { 1300 if (sc->use_sg) {
1298 struct scatterlist *sg = sc->request_buffer; 1301 struct scatterlist *sg = sc->request_buffer;
@@ -1309,7 +1312,7 @@ iscsi_tcp_cmd_init(struct iscsi_cmd_task *ctask)
1309 } 1312 }
1310 debug_scsi("cmd [itt 0x%x total %d imm_data %d " 1313 debug_scsi("cmd [itt 0x%x total %d imm_data %d "
1311 "unsol count %d, unsol offset %d]\n", 1314 "unsol count %d, unsol offset %d]\n",
1312 ctask->itt, ctask->total_length, ctask->imm_count, 1315 ctask->itt, sc->request_bufflen, ctask->imm_count,
1313 ctask->unsol_count, ctask->unsol_offset); 1316 ctask->unsol_count, ctask->unsol_offset);
1314 } else 1317 } else
1315 tcp_ctask->xmstate = XMSTATE_R_HDR; 1318 tcp_ctask->xmstate = XMSTATE_R_HDR;
diff --git a/drivers/scsi/libiscsi.c b/drivers/scsi/libiscsi.c
index eb5113607958..0a9c64e9ce8b 100644
--- a/drivers/scsi/libiscsi.c
+++ b/drivers/scsi/libiscsi.c
@@ -147,19 +147,19 @@ static void iscsi_prep_scsi_cmd_pdu(struct iscsi_cmd_task *ctask)
147 ctask->unsol_datasn = 0; 147 ctask->unsol_datasn = 0;
148 148
149 if (session->imm_data_en) { 149 if (session->imm_data_en) {
150 if (ctask->total_length >= session->first_burst) 150 if (sc->request_bufflen >= session->first_burst)
151 ctask->imm_count = min(session->first_burst, 151 ctask->imm_count = min(session->first_burst,
152 conn->max_xmit_dlength); 152 conn->max_xmit_dlength);
153 else 153 else
154 ctask->imm_count = min(ctask->total_length, 154 ctask->imm_count = min(sc->request_bufflen,
155 conn->max_xmit_dlength); 155 conn->max_xmit_dlength);
156 hton24(ctask->hdr->dlength, ctask->imm_count); 156 hton24(ctask->hdr->dlength, ctask->imm_count);
157 } else 157 } else
158 zero_data(ctask->hdr->dlength); 158 zero_data(ctask->hdr->dlength);
159 159
160 if (!session->initial_r2t_en) { 160 if (!session->initial_r2t_en) {
161 ctask->unsol_count = min(session->first_burst, 161 ctask->unsol_count = min((session->first_burst),
162 ctask->total_length) - ctask->imm_count; 162 (sc->request_bufflen)) - ctask->imm_count;
163 ctask->unsol_offset = ctask->imm_count; 163 ctask->unsol_offset = ctask->imm_count;
164 } 164 }
165 165
@@ -815,7 +815,6 @@ int iscsi_queuecommand(struct scsi_cmnd *sc, void (*done)(struct scsi_cmnd *))
815 ctask->conn = conn; 815 ctask->conn = conn;
816 ctask->sc = sc; 816 ctask->sc = sc;
817 INIT_LIST_HEAD(&ctask->running); 817 INIT_LIST_HEAD(&ctask->running);
818 ctask->total_length = sc->request_bufflen;
819 iscsi_prep_scsi_cmd_pdu(ctask); 818 iscsi_prep_scsi_cmd_pdu(ctask);
820 819
821 session->tt->init_cmd_task(ctask); 820 session->tt->init_cmd_task(ctask);
diff --git a/include/scsi/libiscsi.h b/include/scsi/libiscsi.h
index 61e069206ac5..348265d4a27e 100644
--- a/include/scsi/libiscsi.h
+++ b/include/scsi/libiscsi.h
@@ -80,7 +80,7 @@ struct iscsi_mgmt_task {
80 */ 80 */
81 struct iscsi_hdr *hdr; 81 struct iscsi_hdr *hdr;
82 char *data; /* mgmt payload */ 82 char *data; /* mgmt payload */
83 int data_count; /* counts data to be sent */ 83 unsigned data_count; /* counts data to be sent */
84 uint32_t itt; /* this ITT */ 84 uint32_t itt; /* this ITT */
85 void *dd_data; /* driver/transport data */ 85 void *dd_data; /* driver/transport data */
86 struct list_head running; 86 struct list_head running;
@@ -101,13 +101,12 @@ struct iscsi_cmd_task {
101 int itt; /* this ITT */ 101 int itt; /* this ITT */
102 102
103 uint32_t unsol_datasn; 103 uint32_t unsol_datasn;
104 int imm_count; /* imm-data (bytes) */ 104 unsigned imm_count; /* imm-data (bytes) */
105 int unsol_count; /* unsolicited (bytes)*/ 105 unsigned unsol_count; /* unsolicited (bytes)*/
106 /* offset in unsolicited stream (bytes); */ 106 /* offset in unsolicited stream (bytes); */
107 int unsol_offset; 107 unsigned unsol_offset;
108 int data_count; /* remaining Data-Out */ 108 unsigned data_count; /* remaining Data-Out */
109 struct scsi_cmnd *sc; /* associated SCSI cmd*/ 109 struct scsi_cmnd *sc; /* associated SCSI cmd*/
110 int total_length;
111 struct iscsi_conn *conn; /* used connection */ 110 struct iscsi_conn *conn; /* used connection */
112 struct iscsi_mgmt_task *mtask; /* tmf mtask in progr */ 111 struct iscsi_mgmt_task *mtask; /* tmf mtask in progr */
113 112
@@ -173,8 +172,8 @@ struct iscsi_conn {
173 int tmabort_state; /* see TMABORT_INITIAL, etc.*/ 172 int tmabort_state; /* see TMABORT_INITIAL, etc.*/
174 173
175 /* negotiated params */ 174 /* negotiated params */
176 int max_recv_dlength; /* initiator_max_recv_dsl*/ 175 unsigned max_recv_dlength; /* initiator_max_recv_dsl*/
177 int max_xmit_dlength; /* target_max_recv_dsl */ 176 unsigned max_xmit_dlength; /* target_max_recv_dsl */
178 int hdrdgst_en; 177 int hdrdgst_en;
179 int datadgst_en; 178 int datadgst_en;
180 int ifmarker_en; 179 int ifmarker_en;
@@ -212,10 +211,10 @@ struct iscsi_session {
212 211
213 /* configuration */ 212 /* configuration */
214 int initial_r2t_en; 213 int initial_r2t_en;
215 int max_r2t; 214 unsigned max_r2t;
216 int imm_data_en; 215 int imm_data_en;
217 int first_burst; 216 unsigned first_burst;
218 int max_burst; 217 unsigned max_burst;
219 int time2wait; 218 int time2wait;
220 int time2retain; 219 int time2retain;
221 int pdu_inorder_en; 220 int pdu_inorder_en;