aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/mmc/sdhci.c
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/mmc/sdhci.c')
-rw-r--r--drivers/mmc/sdhci.c24
1 files changed, 6 insertions, 18 deletions
diff --git a/drivers/mmc/sdhci.c b/drivers/mmc/sdhci.c
index b57393c7f9b5..24803538570a 100644
--- a/drivers/mmc/sdhci.c
+++ b/drivers/mmc/sdhci.c
@@ -206,15 +206,9 @@ static void sdhci_deactivate_led(struct sdhci_host *host)
206 * * 206 * *
207\*****************************************************************************/ 207\*****************************************************************************/
208 208
209static inline char* sdhci_kmap_sg(struct sdhci_host* host) 209static inline char* sdhci_sg_to_buffer(struct sdhci_host* host)
210{ 210{
211 host->mapped_sg = kmap_atomic(host->cur_sg->page, KM_BIO_SRC_IRQ); 211 return page_address(host->cur_sg->page) + host->cur_sg->offset;
212 return host->mapped_sg + host->cur_sg->offset;
213}
214
215static inline void sdhci_kunmap_sg(struct sdhci_host* host)
216{
217 kunmap_atomic(host->mapped_sg, KM_BIO_SRC_IRQ);
218} 212}
219 213
220static inline int sdhci_next_sg(struct sdhci_host* host) 214static inline int sdhci_next_sg(struct sdhci_host* host)
@@ -249,7 +243,7 @@ static void sdhci_read_block_pio(struct sdhci_host *host)
249 chunk_remain = 0; 243 chunk_remain = 0;
250 data = 0; 244 data = 0;
251 245
252 buffer = sdhci_kmap_sg(host) + host->offset; 246 buffer = sdhci_sg_to_buffer(host) + host->offset;
253 247
254 while (blksize) { 248 while (blksize) {
255 if (chunk_remain == 0) { 249 if (chunk_remain == 0) {
@@ -273,16 +267,13 @@ static void sdhci_read_block_pio(struct sdhci_host *host)
273 } 267 }
274 268
275 if (host->remain == 0) { 269 if (host->remain == 0) {
276 sdhci_kunmap_sg(host);
277 if (sdhci_next_sg(host) == 0) { 270 if (sdhci_next_sg(host) == 0) {
278 BUG_ON(blksize != 0); 271 BUG_ON(blksize != 0);
279 return; 272 return;
280 } 273 }
281 buffer = sdhci_kmap_sg(host); 274 buffer = sdhci_sg_to_buffer(host);
282 } 275 }
283 } 276 }
284
285 sdhci_kunmap_sg(host);
286} 277}
287 278
288static void sdhci_write_block_pio(struct sdhci_host *host) 279static void sdhci_write_block_pio(struct sdhci_host *host)
@@ -299,7 +290,7 @@ static void sdhci_write_block_pio(struct sdhci_host *host)
299 data = 0; 290 data = 0;
300 291
301 bytes = 0; 292 bytes = 0;
302 buffer = sdhci_kmap_sg(host) + host->offset; 293 buffer = sdhci_sg_to_buffer(host) + host->offset;
303 294
304 while (blksize) { 295 while (blksize) {
305 size = min(host->size, host->remain); 296 size = min(host->size, host->remain);
@@ -323,16 +314,13 @@ static void sdhci_write_block_pio(struct sdhci_host *host)
323 } 314 }
324 315
325 if (host->remain == 0) { 316 if (host->remain == 0) {
326 sdhci_kunmap_sg(host);
327 if (sdhci_next_sg(host) == 0) { 317 if (sdhci_next_sg(host) == 0) {
328 BUG_ON(blksize != 0); 318 BUG_ON(blksize != 0);
329 return; 319 return;
330 } 320 }
331 buffer = sdhci_kmap_sg(host); 321 buffer = sdhci_sg_to_buffer(host);
332 } 322 }
333 } 323 }
334
335 sdhci_kunmap_sg(host);
336} 324}
337 325
338static void sdhci_transfer_pio(struct sdhci_host *host) 326static void sdhci_transfer_pio(struct sdhci_host *host)