diff options
Diffstat (limited to 'drivers/ata/libata-core.c')
-rw-r--r-- | drivers/ata/libata-core.c | 14 |
1 files changed, 7 insertions, 7 deletions
diff --git a/drivers/ata/libata-core.c b/drivers/ata/libata-core.c index 89f3cf57b677..c1444d8f92c6 100644 --- a/drivers/ata/libata-core.c +++ b/drivers/ata/libata-core.c | |||
@@ -1249,7 +1249,6 @@ unsigned ata_exec_internal_sg(struct ata_device *dev, | |||
1249 | buflen += sg[i].length; | 1249 | buflen += sg[i].length; |
1250 | 1250 | ||
1251 | ata_sg_init(qc, sg, n_elem); | 1251 | ata_sg_init(qc, sg, n_elem); |
1252 | qc->nsect = buflen / ATA_SECT_SIZE; | ||
1253 | qc->nbytes = buflen; | 1252 | qc->nbytes = buflen; |
1254 | } | 1253 | } |
1255 | 1254 | ||
@@ -4006,11 +4005,11 @@ static void ata_pio_sector(struct ata_queued_cmd *qc) | |||
4006 | unsigned int offset; | 4005 | unsigned int offset; |
4007 | unsigned char *buf; | 4006 | unsigned char *buf; |
4008 | 4007 | ||
4009 | if (qc->cursect == (qc->nsect - 1)) | 4008 | if (qc->curbytes == qc->nbytes - ATA_SECT_SIZE) |
4010 | ap->hsm_task_state = HSM_ST_LAST; | 4009 | ap->hsm_task_state = HSM_ST_LAST; |
4011 | 4010 | ||
4012 | page = sg[qc->cursg].page; | 4011 | page = sg[qc->cursg].page; |
4013 | offset = sg[qc->cursg].offset + qc->cursg_ofs * ATA_SECT_SIZE; | 4012 | offset = sg[qc->cursg].offset + qc->cursg_ofs; |
4014 | 4013 | ||
4015 | /* get the current page and offset */ | 4014 | /* get the current page and offset */ |
4016 | page = nth_page(page, (offset >> PAGE_SHIFT)); | 4015 | page = nth_page(page, (offset >> PAGE_SHIFT)); |
@@ -4035,10 +4034,10 @@ static void ata_pio_sector(struct ata_queued_cmd *qc) | |||
4035 | ap->ops->data_xfer(qc->dev, buf + offset, ATA_SECT_SIZE, do_write); | 4034 | ap->ops->data_xfer(qc->dev, buf + offset, ATA_SECT_SIZE, do_write); |
4036 | } | 4035 | } |
4037 | 4036 | ||
4038 | qc->cursect++; | 4037 | qc->curbytes += ATA_SECT_SIZE; |
4039 | qc->cursg_ofs++; | 4038 | qc->cursg_ofs += ATA_SECT_SIZE; |
4040 | 4039 | ||
4041 | if ((qc->cursg_ofs * ATA_SECT_SIZE) == (&sg[qc->cursg])->length) { | 4040 | if (qc->cursg_ofs == (&sg[qc->cursg])->length) { |
4042 | qc->cursg++; | 4041 | qc->cursg++; |
4043 | qc->cursg_ofs = 0; | 4042 | qc->cursg_ofs = 0; |
4044 | } | 4043 | } |
@@ -4063,7 +4062,8 @@ static void ata_pio_sectors(struct ata_queued_cmd *qc) | |||
4063 | 4062 | ||
4064 | WARN_ON(qc->dev->multi_count == 0); | 4063 | WARN_ON(qc->dev->multi_count == 0); |
4065 | 4064 | ||
4066 | nsect = min(qc->nsect - qc->cursect, qc->dev->multi_count); | 4065 | nsect = min((qc->nbytes - qc->curbytes) / ATA_SECT_SIZE, |
4066 | qc->dev->multi_count); | ||
4067 | while (nsect--) | 4067 | while (nsect--) |
4068 | ata_pio_sector(qc); | 4068 | ata_pio_sector(qc); |
4069 | } else | 4069 | } else |