mirror of
https://github.com/AsahiLinux/u-boot
synced 2024-11-25 14:10:43 +00:00
fsl_esdhc: Only modify the field we are changing in WML
When we set the read or write watermark in WML we should maintain the rest of the register as is, rather than using some hard coded value. Signed-off-by: Roy Zang <tie-fei.zang@freescale.com> Acked-by: Stefano Babic <sbabic@denx.de> Signed-off-by: Kumar Gala <galak@kernel.crashing.org>
This commit is contained in:
parent
48bb3bb5ac
commit
ab467c512e
2 changed files with 6 additions and 5 deletions
|
@ -110,8 +110,7 @@ static int esdhc_setup_data(struct mmc *mmc, struct mmc_data *data)
|
|||
if (wml_value > 0x10)
|
||||
wml_value = 0x10;
|
||||
|
||||
wml_value = 0x100000 | wml_value;
|
||||
|
||||
esdhc_clrsetbits32(®s->wml, WML_RD_WML_MASK, wml_value);
|
||||
esdhc_write32(®s->dsaddr, (u32)data->dest);
|
||||
} else {
|
||||
if (wml_value > 0x80)
|
||||
|
@ -120,12 +119,12 @@ static int esdhc_setup_data(struct mmc *mmc, struct mmc_data *data)
|
|||
printf("\nThe SD card is locked. Can not write to a locked card.\n\n");
|
||||
return TIMEOUT;
|
||||
}
|
||||
wml_value = wml_value << 16 | 0x10;
|
||||
|
||||
esdhc_clrsetbits32(®s->wml, WML_WR_WML_MASK,
|
||||
wml_value << 16);
|
||||
esdhc_write32(®s->dsaddr, (u32)data->src);
|
||||
}
|
||||
|
||||
esdhc_write32(®s->wml, wml_value);
|
||||
|
||||
esdhc_write32(®s->blkattr, data->blocks << 16 | data->blocksize);
|
||||
|
||||
/* Calculate the timeout period for data transactions */
|
||||
|
|
|
@ -133,6 +133,8 @@
|
|||
|
||||
#define WML 0x2e044
|
||||
#define WML_WRITE 0x00010000
|
||||
#define WML_RD_WML_MASK 0xff
|
||||
#define WML_WR_WML_MASK 0xff0000
|
||||
|
||||
#define BLKATTR 0x2e004
|
||||
#define BLKATTR_CNT(x) ((x & 0xffff) << 16)
|
||||
|
|
Loading…
Reference in a new issue