diff options
author | Linus Torvalds <torvalds@woody.linux-foundation.org> | 2007-10-03 18:44:10 -0400 |
---|---|---|
committer | Linus Torvalds <torvalds@woody.linux-foundation.org> | 2007-10-03 18:44:10 -0400 |
commit | 804b3f9a16e446cb023417faec58b6506c834052 (patch) | |
tree | a8886d723dc968c71cc69fcbd37b393bcf135740 /drivers/ata/sata_mv.c | |
parent | 3e0ca2f148f97c5748f52bcf2a69dd17cb2b1d13 (diff) | |
parent | 991bf528f602882580d0918842b125255d246a19 (diff) |
Merge branch 'upstream-linus' of master.kernel.org:/pub/scm/linux/kernel/git/jgarzik/libata-dev
* 'upstream-linus' of master.kernel.org:/pub/scm/linux/kernel/git/jgarzik/libata-dev:
drivers/ata/pata_ixp4xx_cf.c: ioremap return code check
Ata: pata_marvell, use ioread* for iomap-ped memory
libata: fix for sata_mv >64KB DMA segments
Diffstat (limited to 'drivers/ata/sata_mv.c')
-rw-r--r-- | drivers/ata/sata_mv.c | 26 |
1 files changed, 19 insertions, 7 deletions
diff --git a/drivers/ata/sata_mv.c b/drivers/ata/sata_mv.c index 11bf6c7ac122..1a82e22b3efd 100644 --- a/drivers/ata/sata_mv.c +++ b/drivers/ata/sata_mv.c | |||
@@ -1139,15 +1139,27 @@ static unsigned int mv_fill_sg(struct ata_queued_cmd *qc) | |||
1139 | dma_addr_t addr = sg_dma_address(sg); | 1139 | dma_addr_t addr = sg_dma_address(sg); |
1140 | u32 sg_len = sg_dma_len(sg); | 1140 | u32 sg_len = sg_dma_len(sg); |
1141 | 1141 | ||
1142 | mv_sg->addr = cpu_to_le32(addr & 0xffffffff); | 1142 | while (sg_len) { |
1143 | mv_sg->addr_hi = cpu_to_le32((addr >> 16) >> 16); | 1143 | u32 offset = addr & 0xffff; |
1144 | mv_sg->flags_size = cpu_to_le32(sg_len & 0xffff); | 1144 | u32 len = sg_len; |
1145 | 1145 | ||
1146 | if (ata_sg_is_last(sg, qc)) | 1146 | if ((offset + sg_len > 0x10000)) |
1147 | mv_sg->flags_size |= cpu_to_le32(EPRD_FLAG_END_OF_TBL); | 1147 | len = 0x10000 - offset; |
1148 | |||
1149 | mv_sg->addr = cpu_to_le32(addr & 0xffffffff); | ||
1150 | mv_sg->addr_hi = cpu_to_le32((addr >> 16) >> 16); | ||
1151 | mv_sg->flags_size = cpu_to_le32(len); | ||
1152 | |||
1153 | sg_len -= len; | ||
1154 | addr += len; | ||
1155 | |||
1156 | if (!sg_len && ata_sg_is_last(sg, qc)) | ||
1157 | mv_sg->flags_size |= cpu_to_le32(EPRD_FLAG_END_OF_TBL); | ||
1158 | |||
1159 | mv_sg++; | ||
1160 | n_sg++; | ||
1161 | } | ||
1148 | 1162 | ||
1149 | mv_sg++; | ||
1150 | n_sg++; | ||
1151 | } | 1163 | } |
1152 | 1164 | ||
1153 | return n_sg; | 1165 | return n_sg; |