提交 a2260323 编写于 作者: N Nikola Pajkovsky 提交者: Martin K. Petersen

scsi: aacraid: get rid of one level of indentation

  unsigned long byte_count = 0;
  nseg = scsi_dma_map(scsicmd);
  if (nseg < 0)
     return nseg;
  if (nseg) {
     ...
  }
  return byte_count;

is equal to

  unsigned long byte_count = 0;
  nseg = scsi_dma_map(scsicmd);
  if (nseg <= 0)
     return nseg;
  ...
  return byte_count;

No other code has changed.

[mkp: fix checkpatch complaints]
Signed-off-by: NNikola Pajkovsky <npajkovsky@suse.cz>
Reviewed-by: NRaghava Aditya Renukunta <RaghavaAditya.Renukunta@microsemi.com>
Signed-off-by: NMartin K. Petersen <martin.petersen@oracle.com>
上级 913e00a5
...@@ -3757,6 +3757,8 @@ static long aac_build_sg(struct scsi_cmnd *scsicmd, struct sgmap *psg) ...@@ -3757,6 +3757,8 @@ static long aac_build_sg(struct scsi_cmnd *scsicmd, struct sgmap *psg)
struct aac_dev *dev; struct aac_dev *dev;
unsigned long byte_count = 0; unsigned long byte_count = 0;
int nseg; int nseg;
struct scatterlist *sg;
int i;
dev = (struct aac_dev *)scsicmd->device->host->hostdata; dev = (struct aac_dev *)scsicmd->device->host->hostdata;
// Get rid of old data // Get rid of old data
...@@ -3765,32 +3767,29 @@ static long aac_build_sg(struct scsi_cmnd *scsicmd, struct sgmap *psg) ...@@ -3765,32 +3767,29 @@ static long aac_build_sg(struct scsi_cmnd *scsicmd, struct sgmap *psg)
psg->sg[0].count = 0; psg->sg[0].count = 0;
nseg = scsi_dma_map(scsicmd); nseg = scsi_dma_map(scsicmd);
if (nseg < 0) if (nseg <= 0)
return nseg; return nseg;
if (nseg) {
struct scatterlist *sg;
int i;
psg->count = cpu_to_le32(nseg); psg->count = cpu_to_le32(nseg);
scsi_for_each_sg(scsicmd, sg, nseg, i) { scsi_for_each_sg(scsicmd, sg, nseg, i) {
psg->sg[i].addr = cpu_to_le32(sg_dma_address(sg)); psg->sg[i].addr = cpu_to_le32(sg_dma_address(sg));
psg->sg[i].count = cpu_to_le32(sg_dma_len(sg)); psg->sg[i].count = cpu_to_le32(sg_dma_len(sg));
byte_count += sg_dma_len(sg); byte_count += sg_dma_len(sg);
} }
/* hba wants the size to be exact */ /* hba wants the size to be exact */
if (byte_count > scsi_bufflen(scsicmd)) { if (byte_count > scsi_bufflen(scsicmd)) {
u32 temp = le32_to_cpu(psg->sg[i-1].count) - u32 temp = le32_to_cpu(psg->sg[i-1].count) -
(byte_count - scsi_bufflen(scsicmd)); (byte_count - scsi_bufflen(scsicmd));
psg->sg[i-1].count = cpu_to_le32(temp); psg->sg[i-1].count = cpu_to_le32(temp);
byte_count = scsi_bufflen(scsicmd); byte_count = scsi_bufflen(scsicmd);
}
/* Check for command underflow */
if(scsicmd->underflow && (byte_count < scsicmd->underflow)){
printk(KERN_WARNING"aacraid: cmd len %08lX cmd underflow %08X\n",
byte_count, scsicmd->underflow);
}
} }
/* Check for command underflow */
if (scsicmd->underflow && (byte_count < scsicmd->underflow)) {
printk(KERN_WARNING"aacraid: cmd len %08lX cmd underflow %08X\n",
byte_count, scsicmd->underflow);
}
return byte_count; return byte_count;
} }
...@@ -3801,6 +3800,8 @@ static long aac_build_sg64(struct scsi_cmnd *scsicmd, struct sgmap64 *psg) ...@@ -3801,6 +3800,8 @@ static long aac_build_sg64(struct scsi_cmnd *scsicmd, struct sgmap64 *psg)
unsigned long byte_count = 0; unsigned long byte_count = 0;
u64 addr; u64 addr;
int nseg; int nseg;
struct scatterlist *sg;
int i;
dev = (struct aac_dev *)scsicmd->device->host->hostdata; dev = (struct aac_dev *)scsicmd->device->host->hostdata;
// Get rid of old data // Get rid of old data
...@@ -3810,34 +3811,31 @@ static long aac_build_sg64(struct scsi_cmnd *scsicmd, struct sgmap64 *psg) ...@@ -3810,34 +3811,31 @@ static long aac_build_sg64(struct scsi_cmnd *scsicmd, struct sgmap64 *psg)
psg->sg[0].count = 0; psg->sg[0].count = 0;
nseg = scsi_dma_map(scsicmd); nseg = scsi_dma_map(scsicmd);
if (nseg < 0) if (nseg <= 0)
return nseg; return nseg;
if (nseg) {
struct scatterlist *sg; scsi_for_each_sg(scsicmd, sg, nseg, i) {
int i; int count = sg_dma_len(sg);
addr = sg_dma_address(sg);
scsi_for_each_sg(scsicmd, sg, nseg, i) { psg->sg[i].addr[0] = cpu_to_le32(addr & 0xffffffff);
int count = sg_dma_len(sg); psg->sg[i].addr[1] = cpu_to_le32(addr>>32);
addr = sg_dma_address(sg); psg->sg[i].count = cpu_to_le32(count);
psg->sg[i].addr[0] = cpu_to_le32(addr & 0xffffffff); byte_count += count;
psg->sg[i].addr[1] = cpu_to_le32(addr>>32); }
psg->sg[i].count = cpu_to_le32(count); psg->count = cpu_to_le32(nseg);
byte_count += count; /* hba wants the size to be exact */
} if (byte_count > scsi_bufflen(scsicmd)) {
psg->count = cpu_to_le32(nseg); u32 temp = le32_to_cpu(psg->sg[i-1].count) -
/* hba wants the size to be exact */ (byte_count - scsi_bufflen(scsicmd));
if (byte_count > scsi_bufflen(scsicmd)) { psg->sg[i-1].count = cpu_to_le32(temp);
u32 temp = le32_to_cpu(psg->sg[i-1].count) - byte_count = scsi_bufflen(scsicmd);
(byte_count - scsi_bufflen(scsicmd)); }
psg->sg[i-1].count = cpu_to_le32(temp); /* Check for command underflow */
byte_count = scsi_bufflen(scsicmd); if (scsicmd->underflow && (byte_count < scsicmd->underflow)) {
} printk(KERN_WARNING"aacraid: cmd len %08lX cmd underflow %08X\n",
/* Check for command underflow */ byte_count, scsicmd->underflow);
if(scsicmd->underflow && (byte_count < scsicmd->underflow)){
printk(KERN_WARNING"aacraid: cmd len %08lX cmd underflow %08X\n",
byte_count, scsicmd->underflow);
}
} }
return byte_count; return byte_count;
} }
...@@ -3845,6 +3843,8 @@ static long aac_build_sgraw(struct scsi_cmnd *scsicmd, struct sgmapraw *psg) ...@@ -3845,6 +3843,8 @@ static long aac_build_sgraw(struct scsi_cmnd *scsicmd, struct sgmapraw *psg)
{ {
unsigned long byte_count = 0; unsigned long byte_count = 0;
int nseg; int nseg;
struct scatterlist *sg;
int i;
// Get rid of old data // Get rid of old data
psg->count = 0; psg->count = 0;
...@@ -3856,37 +3856,34 @@ static long aac_build_sgraw(struct scsi_cmnd *scsicmd, struct sgmapraw *psg) ...@@ -3856,37 +3856,34 @@ static long aac_build_sgraw(struct scsi_cmnd *scsicmd, struct sgmapraw *psg)
psg->sg[0].flags = 0; psg->sg[0].flags = 0;
nseg = scsi_dma_map(scsicmd); nseg = scsi_dma_map(scsicmd);
if (nseg < 0) if (nseg <= 0)
return nseg; return nseg;
if (nseg) {
struct scatterlist *sg; scsi_for_each_sg(scsicmd, sg, nseg, i) {
int i; int count = sg_dma_len(sg);
u64 addr = sg_dma_address(sg);
scsi_for_each_sg(scsicmd, sg, nseg, i) { psg->sg[i].next = 0;
int count = sg_dma_len(sg); psg->sg[i].prev = 0;
u64 addr = sg_dma_address(sg); psg->sg[i].addr[1] = cpu_to_le32((u32)(addr>>32));
psg->sg[i].next = 0; psg->sg[i].addr[0] = cpu_to_le32((u32)(addr & 0xffffffff));
psg->sg[i].prev = 0; psg->sg[i].count = cpu_to_le32(count);
psg->sg[i].addr[1] = cpu_to_le32((u32)(addr>>32)); psg->sg[i].flags = 0;
psg->sg[i].addr[0] = cpu_to_le32((u32)(addr & 0xffffffff)); byte_count += count;
psg->sg[i].count = cpu_to_le32(count); }
psg->sg[i].flags = 0; psg->count = cpu_to_le32(nseg);
byte_count += count; /* hba wants the size to be exact */
} if (byte_count > scsi_bufflen(scsicmd)) {
psg->count = cpu_to_le32(nseg); u32 temp = le32_to_cpu(psg->sg[i-1].count) -
/* hba wants the size to be exact */ (byte_count - scsi_bufflen(scsicmd));
if (byte_count > scsi_bufflen(scsicmd)) { psg->sg[i-1].count = cpu_to_le32(temp);
u32 temp = le32_to_cpu(psg->sg[i-1].count) - byte_count = scsi_bufflen(scsicmd);
(byte_count - scsi_bufflen(scsicmd)); }
psg->sg[i-1].count = cpu_to_le32(temp); /* Check for command underflow */
byte_count = scsi_bufflen(scsicmd); if (scsicmd->underflow && (byte_count < scsicmd->underflow)) {
} printk(KERN_WARNING"aacraid: cmd len %08lX cmd underflow %08X\n",
/* Check for command underflow */ byte_count, scsicmd->underflow);
if(scsicmd->underflow && (byte_count < scsicmd->underflow)){
printk(KERN_WARNING"aacraid: cmd len %08lX cmd underflow %08X\n",
byte_count, scsicmd->underflow);
}
} }
return byte_count; return byte_count;
} }
...@@ -3895,75 +3892,73 @@ static long aac_build_sgraw2(struct scsi_cmnd *scsicmd, ...@@ -3895,75 +3892,73 @@ static long aac_build_sgraw2(struct scsi_cmnd *scsicmd,
{ {
unsigned long byte_count = 0; unsigned long byte_count = 0;
int nseg; int nseg;
struct scatterlist *sg;
int i, conformable = 0;
u32 min_size = PAGE_SIZE, cur_size;
nseg = scsi_dma_map(scsicmd); nseg = scsi_dma_map(scsicmd);
if (nseg < 0) if (nseg <= 0)
return nseg; return nseg;
if (nseg) {
struct scatterlist *sg; scsi_for_each_sg(scsicmd, sg, nseg, i) {
int i, conformable = 0; int count = sg_dma_len(sg);
u32 min_size = PAGE_SIZE, cur_size; u64 addr = sg_dma_address(sg);
scsi_for_each_sg(scsicmd, sg, nseg, i) { BUG_ON(i >= sg_max);
int count = sg_dma_len(sg); rio2->sge[i].addrHigh = cpu_to_le32((u32)(addr>>32));
u64 addr = sg_dma_address(sg); rio2->sge[i].addrLow = cpu_to_le32((u32)(addr & 0xffffffff));
cur_size = cpu_to_le32(count);
BUG_ON(i >= sg_max); rio2->sge[i].length = cur_size;
rio2->sge[i].addrHigh = cpu_to_le32((u32)(addr>>32)); rio2->sge[i].flags = 0;
rio2->sge[i].addrLow = cpu_to_le32((u32)(addr & 0xffffffff)); if (i == 0) {
cur_size = cpu_to_le32(count); conformable = 1;
rio2->sge[i].length = cur_size; rio2->sgeFirstSize = cur_size;
rio2->sge[i].flags = 0; } else if (i == 1) {
if (i == 0) { rio2->sgeNominalSize = cur_size;
conformable = 1; min_size = cur_size;
rio2->sgeFirstSize = cur_size; } else if ((i+1) < nseg && cur_size != rio2->sgeNominalSize) {
} else if (i == 1) { conformable = 0;
rio2->sgeNominalSize = cur_size; if (cur_size < min_size)
min_size = cur_size; min_size = cur_size;
} else if ((i+1) < nseg && cur_size != rio2->sgeNominalSize) {
conformable = 0;
if (cur_size < min_size)
min_size = cur_size;
}
byte_count += count;
} }
byte_count += count;
}
/* hba wants the size to be exact */ /* hba wants the size to be exact */
if (byte_count > scsi_bufflen(scsicmd)) { if (byte_count > scsi_bufflen(scsicmd)) {
u32 temp = le32_to_cpu(rio2->sge[i-1].length) - u32 temp = le32_to_cpu(rio2->sge[i-1].length) -
(byte_count - scsi_bufflen(scsicmd)); (byte_count - scsi_bufflen(scsicmd));
rio2->sge[i-1].length = cpu_to_le32(temp); rio2->sge[i-1].length = cpu_to_le32(temp);
byte_count = scsi_bufflen(scsicmd); byte_count = scsi_bufflen(scsicmd);
} }
rio2->sgeCnt = cpu_to_le32(nseg); rio2->sgeCnt = cpu_to_le32(nseg);
rio2->flags |= cpu_to_le16(RIO2_SG_FORMAT_IEEE1212); rio2->flags |= cpu_to_le16(RIO2_SG_FORMAT_IEEE1212);
/* not conformable: evaluate required sg elements */ /* not conformable: evaluate required sg elements */
if (!conformable) { if (!conformable) {
int j, nseg_new = nseg, err_found; int j, nseg_new = nseg, err_found;
for (i = min_size / PAGE_SIZE; i >= 1; --i) { for (i = min_size / PAGE_SIZE; i >= 1; --i) {
err_found = 0; err_found = 0;
nseg_new = 2; nseg_new = 2;
for (j = 1; j < nseg - 1; ++j) { for (j = 1; j < nseg - 1; ++j) {
if (rio2->sge[j].length % (i*PAGE_SIZE)) { if (rio2->sge[j].length % (i*PAGE_SIZE)) {
err_found = 1; err_found = 1;
break;
}
nseg_new += (rio2->sge[j].length / (i*PAGE_SIZE));
}
if (!err_found)
break; break;
}
nseg_new += (rio2->sge[j].length / (i*PAGE_SIZE));
} }
if (i > 0 && nseg_new <= sg_max) if (!err_found)
aac_convert_sgraw2(rio2, i, nseg, nseg_new); break;
} else
rio2->flags |= cpu_to_le16(RIO2_SGL_CONFORMANT);
/* Check for command underflow */
if (scsicmd->underflow && (byte_count < scsicmd->underflow)) {
printk(KERN_WARNING"aacraid: cmd len %08lX cmd underflow %08X\n",
byte_count, scsicmd->underflow);
} }
if (i > 0 && nseg_new <= sg_max)
aac_convert_sgraw2(rio2, i, nseg, nseg_new);
} else
rio2->flags |= cpu_to_le16(RIO2_SGL_CONFORMANT);
/* Check for command underflow */
if (scsicmd->underflow && (byte_count < scsicmd->underflow)) {
printk(KERN_WARNING"aacraid: cmd len %08lX cmd underflow %08X\n",
byte_count, scsicmd->underflow);
} }
return byte_count; return byte_count;
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册