aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--drivers/scsi/qla4xxx/ql4_iocb.c97
-rw-r--r--drivers/scsi/qla4xxx/ql4_isr.c10
-rw-r--r--drivers/scsi/qla4xxx/ql4_os.c9
3 files changed, 40 insertions, 76 deletions
diff --git a/drivers/scsi/qla4xxx/ql4_iocb.c b/drivers/scsi/qla4xxx/ql4_iocb.c
index 6e3c8c81def3..5006ecb3ef5e 100644
--- a/drivers/scsi/qla4xxx/ql4_iocb.c
+++ b/drivers/scsi/qla4xxx/ql4_iocb.c
@@ -145,11 +145,13 @@ static void qla4xxx_build_scsi_iocbs(struct srb *srb,
145 uint16_t avail_dsds; 145 uint16_t avail_dsds;
146 struct data_seg_a64 *cur_dsd; 146 struct data_seg_a64 *cur_dsd;
147 struct scsi_cmnd *cmd; 147 struct scsi_cmnd *cmd;
148 struct scatterlist *sg;
149 int i;
148 150
149 cmd = srb->cmd; 151 cmd = srb->cmd;
150 ha = srb->ha; 152 ha = srb->ha;
151 153
152 if (cmd->request_bufflen == 0 || cmd->sc_data_direction == DMA_NONE) { 154 if (!scsi_bufflen(cmd) || cmd->sc_data_direction == DMA_NONE) {
153 /* No data being transferred */ 155 /* No data being transferred */
154 cmd_entry->ttlByteCnt = __constant_cpu_to_le32(0); 156 cmd_entry->ttlByteCnt = __constant_cpu_to_le32(0);
155 return; 157 return;
@@ -158,40 +160,27 @@ static void qla4xxx_build_scsi_iocbs(struct srb *srb,
158 avail_dsds = COMMAND_SEG; 160 avail_dsds = COMMAND_SEG;
159 cur_dsd = (struct data_seg_a64 *) & (cmd_entry->dataseg[0]); 161 cur_dsd = (struct data_seg_a64 *) & (cmd_entry->dataseg[0]);
160 162
161 /* Load data segments */ 163 scsi_for_each_sg(cmd, sg, tot_dsds, i) {
162 if (cmd->use_sg) { 164 dma_addr_t sle_dma;
163 struct scatterlist *cur_seg; 165
164 struct scatterlist *end_seg; 166 /* Allocate additional continuation packets? */
165 167 if (avail_dsds == 0) {
166 cur_seg = (struct scatterlist *)cmd->request_buffer; 168 struct continuation_t1_entry *cont_entry;
167 end_seg = cur_seg + tot_dsds; 169
168 while (cur_seg < end_seg) { 170 cont_entry = qla4xxx_alloc_cont_entry(ha);
169 dma_addr_t sle_dma; 171 cur_dsd =
170 172 (struct data_seg_a64 *)
171 /* Allocate additional continuation packets? */ 173 &cont_entry->dataseg[0];
172 if (avail_dsds == 0) { 174 avail_dsds = CONTINUE_SEG;
173 struct continuation_t1_entry *cont_entry;
174
175 cont_entry = qla4xxx_alloc_cont_entry(ha);
176 cur_dsd =
177 (struct data_seg_a64 *)
178 &cont_entry->dataseg[0];
179 avail_dsds = CONTINUE_SEG;
180 }
181
182 sle_dma = sg_dma_address(cur_seg);
183 cur_dsd->base.addrLow = cpu_to_le32(LSDW(sle_dma));
184 cur_dsd->base.addrHigh = cpu_to_le32(MSDW(sle_dma));
185 cur_dsd->count = cpu_to_le32(sg_dma_len(cur_seg));
186 avail_dsds--;
187
188 cur_dsd++;
189 cur_seg++;
190 } 175 }
191 } else { 176
192 cur_dsd->base.addrLow = cpu_to_le32(LSDW(srb->dma_handle)); 177 sle_dma = sg_dma_address(sg);
193 cur_dsd->base.addrHigh = cpu_to_le32(MSDW(srb->dma_handle)); 178 cur_dsd->base.addrLow = cpu_to_le32(LSDW(sle_dma));
194 cur_dsd->count = cpu_to_le32(cmd->request_bufflen); 179 cur_dsd->base.addrHigh = cpu_to_le32(MSDW(sle_dma));
180 cur_dsd->count = cpu_to_le32(sg_dma_len(sg));
181 avail_dsds--;
182
183 cur_dsd++;
195 } 184 }
196} 185}
197 186
@@ -208,8 +197,8 @@ int qla4xxx_send_command_to_isp(struct scsi_qla_host *ha, struct srb * srb)
208 struct scsi_cmnd *cmd = srb->cmd; 197 struct scsi_cmnd *cmd = srb->cmd;
209 struct ddb_entry *ddb_entry; 198 struct ddb_entry *ddb_entry;
210 struct command_t3_entry *cmd_entry; 199 struct command_t3_entry *cmd_entry;
211 struct scatterlist *sg = NULL;
212 200
201 int nseg;
213 uint16_t tot_dsds; 202 uint16_t tot_dsds;
214 uint16_t req_cnt; 203 uint16_t req_cnt;
215 204
@@ -237,24 +226,11 @@ int qla4xxx_send_command_to_isp(struct scsi_qla_host *ha, struct srb * srb)
237 index = (uint32_t)cmd->request->tag; 226 index = (uint32_t)cmd->request->tag;
238 227
239 /* Calculate the number of request entries needed. */ 228 /* Calculate the number of request entries needed. */
240 if (cmd->use_sg) { 229 nseg = scsi_dma_map(cmd);
241 sg = (struct scatterlist *)cmd->request_buffer; 230 if (nseg < 0)
242 tot_dsds = pci_map_sg(ha->pdev, sg, cmd->use_sg, 231 goto queuing_error;
243 cmd->sc_data_direction); 232 tot_dsds = nseg;
244 if (tot_dsds == 0) 233
245 goto queuing_error;
246 } else if (cmd->request_bufflen) {
247 dma_addr_t req_dma;
248
249 req_dma = pci_map_single(ha->pdev, cmd->request_buffer,
250 cmd->request_bufflen,
251 cmd->sc_data_direction);
252 if (dma_mapping_error(req_dma))
253 goto queuing_error;
254
255 srb->dma_handle = req_dma;
256 tot_dsds = 1;
257 }
258 req_cnt = qla4xxx_calc_request_entries(tot_dsds); 234 req_cnt = qla4xxx_calc_request_entries(tot_dsds);
259 235
260 if (ha->req_q_count < (req_cnt + 2)) { 236 if (ha->req_q_count < (req_cnt + 2)) {
@@ -283,7 +259,7 @@ int qla4xxx_send_command_to_isp(struct scsi_qla_host *ha, struct srb * srb)
283 259
284 int_to_scsilun(cmd->device->lun, &cmd_entry->lun); 260 int_to_scsilun(cmd->device->lun, &cmd_entry->lun);
285 cmd_entry->cmdSeqNum = cpu_to_le32(ddb_entry->CmdSn); 261 cmd_entry->cmdSeqNum = cpu_to_le32(ddb_entry->CmdSn);
286 cmd_entry->ttlByteCnt = cpu_to_le32(cmd->request_bufflen); 262 cmd_entry->ttlByteCnt = cpu_to_le32(scsi_bufflen(cmd));
287 memcpy(cmd_entry->cdb, cmd->cmnd, cmd->cmd_len); 263 memcpy(cmd_entry->cdb, cmd->cmnd, cmd->cmd_len);
288 cmd_entry->dataSegCnt = cpu_to_le16(tot_dsds); 264 cmd_entry->dataSegCnt = cpu_to_le16(tot_dsds);
289 cmd_entry->hdr.entryCount = req_cnt; 265 cmd_entry->hdr.entryCount = req_cnt;
@@ -293,13 +269,13 @@ int qla4xxx_send_command_to_isp(struct scsi_qla_host *ha, struct srb * srb)
293 * transferred, as the data direction bit is sometimed filled 269 * transferred, as the data direction bit is sometimed filled
294 * in when there is no data to be transferred */ 270 * in when there is no data to be transferred */
295 cmd_entry->control_flags = CF_NO_DATA; 271 cmd_entry->control_flags = CF_NO_DATA;
296 if (cmd->request_bufflen) { 272 if (scsi_bufflen(cmd)) {
297 if (cmd->sc_data_direction == DMA_TO_DEVICE) 273 if (cmd->sc_data_direction == DMA_TO_DEVICE)
298 cmd_entry->control_flags = CF_WRITE; 274 cmd_entry->control_flags = CF_WRITE;
299 else if (cmd->sc_data_direction == DMA_FROM_DEVICE) 275 else if (cmd->sc_data_direction == DMA_FROM_DEVICE)
300 cmd_entry->control_flags = CF_READ; 276 cmd_entry->control_flags = CF_READ;
301 277
302 ha->bytes_xfered += cmd->request_bufflen; 278 ha->bytes_xfered += scsi_bufflen(cmd);
303 if (ha->bytes_xfered & ~0xFFFFF){ 279 if (ha->bytes_xfered & ~0xFFFFF){
304 ha->total_mbytes_xferred += ha->bytes_xfered >> 20; 280 ha->total_mbytes_xferred += ha->bytes_xfered >> 20;
305 ha->bytes_xfered &= 0xFFFFF; 281 ha->bytes_xfered &= 0xFFFFF;
@@ -363,14 +339,9 @@ int qla4xxx_send_command_to_isp(struct scsi_qla_host *ha, struct srb * srb)
363 return QLA_SUCCESS; 339 return QLA_SUCCESS;
364 340
365queuing_error: 341queuing_error:
342 if (tot_dsds)
343 scsi_dma_unmap(cmd);
366 344
367 if (cmd->use_sg && tot_dsds) {
368 sg = (struct scatterlist *) cmd->request_buffer;
369 pci_unmap_sg(ha->pdev, sg, cmd->use_sg,
370 cmd->sc_data_direction);
371 } else if (tot_dsds)
372 pci_unmap_single(ha->pdev, srb->dma_handle,
373 cmd->request_bufflen, cmd->sc_data_direction);
374 spin_unlock_irqrestore(&ha->hardware_lock, flags); 345 spin_unlock_irqrestore(&ha->hardware_lock, flags);
375 346
376 return QLA_ERROR; 347 return QLA_ERROR;
diff --git a/drivers/scsi/qla4xxx/ql4_isr.c b/drivers/scsi/qla4xxx/ql4_isr.c
index 946e22b1e4b8..b47bd85f114d 100644
--- a/drivers/scsi/qla4xxx/ql4_isr.c
+++ b/drivers/scsi/qla4xxx/ql4_isr.c
@@ -95,7 +95,7 @@ static void qla4xxx_status_entry(struct scsi_qla_host *ha,
95 95
96 if (sts_entry->iscsiFlags & 96 if (sts_entry->iscsiFlags &
97 (ISCSI_FLAG_RESIDUAL_OVER|ISCSI_FLAG_RESIDUAL_UNDER)) 97 (ISCSI_FLAG_RESIDUAL_OVER|ISCSI_FLAG_RESIDUAL_UNDER))
98 cmd->resid = residual; 98 scsi_set_resid(cmd, residual);
99 99
100 cmd->result = DID_OK << 16 | scsi_status; 100 cmd->result = DID_OK << 16 | scsi_status;
101 101
@@ -179,14 +179,14 @@ static void qla4xxx_status_entry(struct scsi_qla_host *ha,
179 * Firmware detected a SCSI transport underrun 179 * Firmware detected a SCSI transport underrun
180 * condition 180 * condition
181 */ 181 */
182 cmd->resid = residual; 182 scsi_set_resid(cmd, residual);
183 DEBUG2(printk("scsi%ld:%d:%d:%d: %s: UNDERRUN status " 183 DEBUG2(printk("scsi%ld:%d:%d:%d: %s: UNDERRUN status "
184 "detected, xferlen = 0x%x, residual = " 184 "detected, xferlen = 0x%x, residual = "
185 "0x%x\n", 185 "0x%x\n",
186 ha->host_no, cmd->device->channel, 186 ha->host_no, cmd->device->channel,
187 cmd->device->id, 187 cmd->device->id,
188 cmd->device->lun, __func__, 188 cmd->device->lun, __func__,
189 cmd->request_bufflen, 189 scsi_bufflen(cmd),
190 residual)); 190 residual));
191 } 191 }
192 192
@@ -230,7 +230,7 @@ static void qla4xxx_status_entry(struct scsi_qla_host *ha,
230 if ((sts_entry->iscsiFlags & 230 if ((sts_entry->iscsiFlags &
231 ISCSI_FLAG_RESIDUAL_UNDER) == 0) { 231 ISCSI_FLAG_RESIDUAL_UNDER) == 0) {
232 cmd->result = DID_BUS_BUSY << 16; 232 cmd->result = DID_BUS_BUSY << 16;
233 } else if ((cmd->request_bufflen - residual) < 233 } else if ((scsi_bufflen(cmd) - residual) <
234 cmd->underflow) { 234 cmd->underflow) {
235 /* 235 /*
236 * Handle mid-layer underflow??? 236 * Handle mid-layer underflow???
@@ -251,7 +251,7 @@ static void qla4xxx_status_entry(struct scsi_qla_host *ha,
251 cmd->device->channel, 251 cmd->device->channel,
252 cmd->device->id, 252 cmd->device->id,
253 cmd->device->lun, __func__, 253 cmd->device->lun, __func__,
254 cmd->request_bufflen, residual)); 254 scsi_bufflen(cmd), residual));
255 255
256 cmd->result = DID_ERROR << 16; 256 cmd->result = DID_ERROR << 16;
257 } else { 257 } else {
diff --git a/drivers/scsi/qla4xxx/ql4_os.c b/drivers/scsi/qla4xxx/ql4_os.c
index 0e4688c9e0a2..e09fc4241970 100644
--- a/drivers/scsi/qla4xxx/ql4_os.c
+++ b/drivers/scsi/qla4xxx/ql4_os.c
@@ -373,14 +373,7 @@ static void qla4xxx_srb_free_dma(struct scsi_qla_host *ha, struct srb *srb)
373 struct scsi_cmnd *cmd = srb->cmd; 373 struct scsi_cmnd *cmd = srb->cmd;
374 374
375 if (srb->flags & SRB_DMA_VALID) { 375 if (srb->flags & SRB_DMA_VALID) {
376 if (cmd->use_sg) { 376 scsi_dma_unmap(cmd);
377 pci_unmap_sg(ha->pdev, cmd->request_buffer,
378 cmd->use_sg, cmd->sc_data_direction);
379 } else if (cmd->request_bufflen) {
380 pci_unmap_single(ha->pdev, srb->dma_handle,
381 cmd->request_bufflen,
382 cmd->sc_data_direction);
383 }
384 srb->flags &= ~SRB_DMA_VALID; 377 srb->flags &= ~SRB_DMA_VALID;
385 } 378 }
386 cmd->SCp.ptr = NULL; 379 cmd->SCp.ptr = NULL;