diff options
author | Lokesh Vutla <lokeshvutla@ti.com> | 2019-09-09 14:40:36 +0530 |
---|---|---|
committer | Peng Fan <peng.fan@nxp.com> | 2019-10-10 10:59:48 +0800 |
commit | 80f02019ee6901a7fb0979677030f33fb9b1fa69 (patch) | |
tree | 41d71e2e3ef6f3faaa9e3c746852944898c585ad /include/mmc.h | |
parent | 548aefa5b9e5c31681e0a8bd78e96b66eedd1137 (diff) | |
download | u-boot-80f02019ee6901a7fb0979677030f33fb9b1fa69.tar.gz |
spl: dm_mmc: Initialize only the required mmc device
In SPL, all the available mmc devices gets initialized during boot.
This might not work in cases where clocks are not available for
certain mmc devices(other than boot device) and the support for
enabling device might not be ready.
Texas Instruments' K3 J721E device having a central system controller
(dmsc) is one such example falling in this category. Below is the
sequence for the failing scenario:
- ROM comes up in SD mode and loads SPL by just initialing SD card.
- SPL loads dmsc firmware from SD Card.
Since ROM has enabled SD, SPL need not enable the SD, just need
to re initialize the card. But SPL is trying to initialize other MMC
instances which are in disabled state. Since dmsc firmware is not yet
available, devices cannot be enabled. So in SPL, initialize only the
mmc device that is needed.
Signed-off-by: Lokesh Vutla <lokeshvutla@ti.com>
Reviewed-by: Peng Fan <peng.fan@nxp.com>
Diffstat (limited to 'include/mmc.h')
-rw-r--r-- | include/mmc.h | 1 |
1 files changed, 1 insertions, 0 deletions
diff --git a/include/mmc.h b/include/mmc.h index 686ba00656..8c29c8d4ab 100644 --- a/include/mmc.h +++ b/include/mmc.h @@ -698,6 +698,7 @@ void mmc_destroy(struct mmc *mmc); */ int mmc_unbind(struct udevice *dev); int mmc_initialize(bd_t *bis); +int mmc_init_device(int num); int mmc_init(struct mmc *mmc); int mmc_send_tuning(struct mmc *mmc, u32 opcode, int *cmd_error); |