diff options
| author | John Rigby <john.rigby@linaro.org> | 2011-04-18 05:50:08 +0000 | 
|---|---|---|
| committer | Andy Fleming <afleming@freescale.com> | 2011-04-29 03:21:54 -0500 | 
| commit | 8feafcc49c0b7a9c541904f95a43dbef2fecc38b (patch) | |
| tree | 0ba20c111634ddbb2513db50d3a3f05009f2cc08 /drivers/mmc/mmc.c | |
| parent | 28df15e0234a773cfec98c2775915abe1472db3c (diff) | |
| download | olio-uboot-2014.01-8feafcc49c0b7a9c541904f95a43dbef2fecc38b.tar.xz olio-uboot-2014.01-8feafcc49c0b7a9c541904f95a43dbef2fecc38b.zip | |
MMC: make b_max unconditional
Make existing field b_max field in struct mmc unconditional
and use it instead of CONFIG_SYS_MMC_MAX_BLK_COUNT in mmc_bread
and mmc_bwrite.
Initialize b_max to CONFIG_SYS_MMC_MAX_BLK_COUNT in mmc_register
if it has not been initialized by the hw driver.
Initialize b_max to 0 in all callers to mmc_register.
Signed-off-by: John Rigby <john.rigby@linaro.org>
Signed-off-by: Andy Fleming <afleming@freescale.com>
Diffstat (limited to 'drivers/mmc/mmc.c')
| -rw-r--r-- | drivers/mmc/mmc.c | 8 | 
1 files changed, 4 insertions, 4 deletions
| diff --git a/drivers/mmc/mmc.c b/drivers/mmc/mmc.c index f27b7c79e..f6d31f584 100644 --- a/drivers/mmc/mmc.c +++ b/drivers/mmc/mmc.c @@ -243,8 +243,7 @@ mmc_bwrite(int dev_num, ulong start, lbaint_t blkcnt, const void*src)  		return 0;  	do { -		cur = (blocks_todo > CONFIG_SYS_MMC_MAX_BLK_COUNT) ? -		       CONFIG_SYS_MMC_MAX_BLK_COUNT : blocks_todo; +		cur = (blocks_todo > mmc->b_max) ?  mmc->b_max : blocks_todo;  		if(mmc_write_blocks(mmc, start, cur, src) != cur)  			return 0;  		blocks_todo -= cur; @@ -320,8 +319,7 @@ static ulong mmc_bread(int dev_num, ulong start, lbaint_t blkcnt, void *dst)  		return 0;  	do { -		cur = (blocks_todo > CONFIG_SYS_MMC_MAX_BLK_COUNT) ? -		       CONFIG_SYS_MMC_MAX_BLK_COUNT : blocks_todo; +		cur = (blocks_todo > mmc->b_max) ?  mmc->b_max : blocks_todo;  		if(mmc_read_blocks(mmc, dst, start, cur) != cur)  			return 0;  		blocks_todo -= cur; @@ -1029,6 +1027,8 @@ int mmc_register(struct mmc *mmc)  	mmc->block_dev.removable = 1;  	mmc->block_dev.block_read = mmc_bread;  	mmc->block_dev.block_write = mmc_bwrite; +	if (!mmc->b_max) +		mmc->b_max = CONFIG_SYS_MMC_MAX_BLK_COUNT;  	INIT_LIST_HEAD (&mmc->link); |