提交 a60eec02 编写于 作者: K Kevin Barnett 提交者: Martin K. Petersen

scsi: smartpqi: change aio sg processing

Take advantage of controller improvements.
Reviewed-by: NScott Teel <scott.teel@microsemi.com>
Reviewed-by: NScott Benesh <scott.benesh@microsemi.com>
Reviewed-by: NJohannes Thumshirn <jthumshirn@suse.de>
Reviewed-by: NTomas Henzl <thenzl@redhat.com>
Signed-off-by: NKevin Barnett <kevin.barnett@microsemi.com>
Signed-off-by: NDon Brace <don.brace@microsemi.com>
Signed-off-by: NMartin K. Petersen <martin.petersen@oracle.com>
上级 b2990536
...@@ -4263,48 +4263,58 @@ static int pqi_build_aio_sg_list(struct pqi_ctrl_info *ctrl_info, ...@@ -4263,48 +4263,58 @@ static int pqi_build_aio_sg_list(struct pqi_ctrl_info *ctrl_info,
int i; int i;
u16 iu_length; u16 iu_length;
int sg_count; int sg_count;
unsigned int num_sg_in_iu = 0; bool chained;
unsigned int num_sg_in_iu;
unsigned int max_sg_per_iu;
struct scatterlist *sg; struct scatterlist *sg;
struct pqi_sg_descriptor *sg_descriptor; struct pqi_sg_descriptor *sg_descriptor;
sg_count = scsi_dma_map(scmd); sg_count = scsi_dma_map(scmd);
if (sg_count < 0) if (sg_count < 0)
return sg_count; return sg_count;
iu_length = offsetof(struct pqi_aio_path_request, sg_descriptors) -
PQI_REQUEST_HEADER_LENGTH;
num_sg_in_iu = 0;
if (sg_count == 0) if (sg_count == 0)
goto out; goto out;
if (sg_count <= ctrl_info->max_sg_per_iu) { sg = scsi_sglist(scmd);
sg_descriptor = &request->sg_descriptors[0]; sg_descriptor = request->sg_descriptors;
scsi_for_each_sg(scmd, sg, sg_count, i) { max_sg_per_iu = ctrl_info->max_sg_per_iu - 1;
chained = false;
i = 0;
while (1) {
pqi_set_sg_descriptor(sg_descriptor, sg); pqi_set_sg_descriptor(sg_descriptor, sg);
if (!chained)
num_sg_in_iu++;
i++;
if (i == sg_count)
break;
sg_descriptor++; sg_descriptor++;
} if (i == max_sg_per_iu) {
put_unaligned_le32(CISS_SG_LAST, put_unaligned_le64(
&request->sg_descriptors[sg_count - 1].flags); (u64)io_request->sg_chain_buffer_dma_handle,
num_sg_in_iu = sg_count;
} else {
sg_descriptor = &request->sg_descriptors[0];
put_unaligned_le64((u64)io_request->sg_chain_buffer_dma_handle,
&sg_descriptor->address); &sg_descriptor->address);
put_unaligned_le32(sg_count * sizeof(*sg_descriptor), put_unaligned_le32((sg_count - num_sg_in_iu)
* sizeof(*sg_descriptor),
&sg_descriptor->length); &sg_descriptor->length);
put_unaligned_le32(CISS_SG_CHAIN, &sg_descriptor->flags); put_unaligned_le32(CISS_SG_CHAIN,
&sg_descriptor->flags);
chained = true;
num_sg_in_iu++;
sg_descriptor = io_request->sg_chain_buffer; sg_descriptor = io_request->sg_chain_buffer;
scsi_for_each_sg(scmd, sg, sg_count, i) {
pqi_set_sg_descriptor(sg_descriptor, sg);
sg_descriptor++;
} }
put_unaligned_le32(CISS_SG_LAST, sg = sg_next(sg);
&io_request->sg_chain_buffer[sg_count - 1].flags);
num_sg_in_iu = 1;
request->partial = 1;
} }
out: put_unaligned_le32(CISS_SG_LAST, &sg_descriptor->flags);
iu_length = offsetof(struct pqi_aio_path_request, sg_descriptors) - request->partial = chained;
PQI_REQUEST_HEADER_LENGTH;
iu_length += num_sg_in_iu * sizeof(*sg_descriptor); iu_length += num_sg_in_iu * sizeof(*sg_descriptor);
out:
put_unaligned_le16(iu_length, &request->header.iu_length); put_unaligned_le16(iu_length, &request->header.iu_length);
request->num_sg_descriptors = num_sg_in_iu; request->num_sg_descriptors = num_sg_in_iu;
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册