summaryrefslogtreecommitdiff
path: root/drivers/mmc
diff options
context:
space:
mode:
authorChander Kashyap <chander.kashyap@linaro.org>2011-03-22 01:40:50 +0000
committerAlbert Aribaud <albert.aribaud@free.fr>2011-03-27 19:20:26 +0200
commitf69bb511455513a61c25783414240258f13f3371 (patch)
treefb3e653fcc61d9b3fe4bae639df3444b59698385 /drivers/mmc
parentbef5f8565ff87d048df352a891953805db84417c (diff)
downloadu-boot-imx-f69bb511455513a61c25783414240258f13f3371.zip
u-boot-imx-f69bb511455513a61c25783414240258f13f3371.tar.gz
u-boot-imx-f69bb511455513a61c25783414240258f13f3371.tar.bz2
S5P: mmc: Resolved interrupt error during mmc_init
Blocksize was hardcoded to 512 bytes. But the blocksize varies depeding on various mmc subsystem commands (between 8 and 512). This hardcoding was resulting in interrupt error during data transfer. It is now calculated based upon the request sent by mmc subsystem. Signed-off-by: Chander Kashyap <chander.kashyap@linaro.org> Signed-off-by: Minkyu Kang <mk7.kang@samsung.com>
Diffstat (limited to 'drivers/mmc')
-rw-r--r--drivers/mmc/s5p_mmc.c2
1 files changed, 1 insertions, 1 deletions
diff --git a/drivers/mmc/s5p_mmc.c b/drivers/mmc/s5p_mmc.c
index 195b5be..0323800 100644
--- a/drivers/mmc/s5p_mmc.c
+++ b/drivers/mmc/s5p_mmc.c
@@ -51,7 +51,7 @@ static void mmc_prepare_data(struct mmc_host *host, struct mmc_data *data)
writeb(ctrl, &host->reg->hostctl);
/* We do not handle DMA boundaries, so set it to max (512 KiB) */
- writew((7 << 12) | (512 << 0), &host->reg->blksize);
+ writew((7 << 12) | (data->blocksize & 0xFFF), &host->reg->blksize);
writew(data->blocks, &host->reg->blkcnt);
}