On 12/9/20 7:25 PM, Pali Rohár wrote:
> On Wednesday 09 December 2020 19:01:19 Jaehoon Chung wrote:
>> Hi,
>>
>> On 12/8/20 7:08 PM, Pali Rohár wrote:
>>> Hello! I looked at what is initialized and enabled for sd/emmc slots and
>>> I found out that comphy mmc needs to be enabled if at least one slot is
>>> used (e.g. SD card) and then remaining part is slot initialization in
>>> xenon driver.
>>>
>>> I wrote quick patch to disable slot when unregistering mmc device from
>>> U-Boot and also unregister emmc on A3720 from U-Boot when it is not
>>> present. But I have not tested it yet.
>>>> What do you think about it?
>>
>> Logically, it's possible to disable slot. But i'm not sure because of not 
>> having its board.
>> Just minor question.. Does it support multi slot per one IP?
> 
> A3720 has only one slot with index XENON_MMC_SLOT_ID_HYPERION.
> 
> A3720 has two mmc/sd IPs at two different address spaces, so uSD and
> eMMC do not share config address space.

Thanks for explanation kindly. I asked because didn't see a real case that 
multi slot is supported. 

Best Regards,
Jaehoon Chung

> 
>> Best Regards,
>> Jaehoon Chung
>>
>>>
>>> diff --git a/board/Marvell/mvebu_armada-37xx/board.c 
>>> b/board/Marvell/mvebu_armada-37xx/board.c
>>> index f67b04b78c..1b9e7520cc 100644
>>> --- a/board/Marvell/mvebu_armada-37xx/board.c
>>> +++ b/board/Marvell/mvebu_armada-37xx/board.c
>>> @@ -5,6 +5,7 @@
>>>  
>>>  #include <common.h>
>>>  #include <dm.h>
>>> +#include <dm/device-internal.h>
>>>  #include <env.h>
>>>  #include <i2c.h>
>>>  #include <init.h>
>>> @@ -84,12 +85,10 @@ int board_init(void)
>>>  #ifdef CONFIG_BOARD_LATE_INIT
>>>  int board_late_init(void)
>>>  {
>>> +   struct udevice *dev;
>>>     struct mmc *mmc_dev;
>>>     bool ddr4, emmc;
>>>  
>>> -   if (env_get("fdtfile"))
>>> -           return 0;
>>> -
>>>     if (!of_machine_is_compatible("globalscale,espressobin"))
>>>             return 0;
>>>  
>>> @@ -101,6 +100,16 @@ int board_late_init(void)
>>>     mmc_dev = find_mmc_device(1);
>>>     emmc = (mmc_dev && mmc_init(mmc_dev) == 0);
>>>  
>>> +   /* if eMMC is not present then remove it from DM */
>>> +   if (!emmc && mmc_dev) {
>>> +           dev = mmc_dev->dev;
>>> +           device_remove(dev, DM_REMOVE_NORMAL);
>>> +           device_unbind(dev);
>>> +   }
>>> +
>>> +   if (env_get("fdtfile"))
>>> +           return 0;
>>> +
>>>     if (ddr4 && emmc)
>>>             env_set("fdtfile", 
>>> "marvell/armada-3720-espressobin-v7-emmc.dtb");
>>>     else if (ddr4)
>>> diff --git a/drivers/mmc/xenon_sdhci.c b/drivers/mmc/xenon_sdhci.c
>>> index 6ce9d00d0a..da9882cbf6 100644
>>> --- a/drivers/mmc/xenon_sdhci.c
>>> +++ b/drivers/mmc/xenon_sdhci.c
>>> @@ -350,6 +350,16 @@ static void xenon_mmc_enable_slot(struct sdhci_host 
>>> *host, u8 slot)
>>>     sdhci_writel(host, var, SDHC_SYS_OP_CTRL);
>>>  }
>>>  
>>> +/* Disable specific slot */
>>> +static void xenon_mmc_disable_slot(struct sdhci_host *host, u8 slot)
>>> +{
>>> +   u32 var;
>>> +
>>> +   var = sdhci_readl(host, SDHC_SYS_OP_CTRL);
>>> +   var &= ~(SLOT_MASK(slot) << SLOT_ENABLE_SHIFT);
>>> +   sdhci_writel(host, var, SDHC_SYS_OP_CTRL);
>>> +}
>>> +
>>>  /* Enable Parallel Transfer Mode */
>>>  static void xenon_mmc_enable_parallel_tran(struct sdhci_host *host, u8 
>>> slot)
>>>  {
>>> @@ -515,6 +525,14 @@ static int xenon_sdhci_probe(struct udevice *dev)
>>>     return ret;
>>>  }
>>>  
>>> +static int xenon_sdhci_remove(struct udevice *dev)
>>> +{
>>> +   struct sdhci_host *host = dev_get_priv(dev);
>>> +
>>> +   xenon_mmc_disable_slot(host, XENON_MMC_SLOT_ID_HYPERION);
>>> +   return 0;
>>> +}
>>> +
>>>  static int xenon_sdhci_ofdata_to_platdata(struct udevice *dev)
>>>  {
>>>     struct sdhci_host *host = dev_get_priv(dev);
>>> @@ -564,6 +582,7 @@ U_BOOT_DRIVER(xenon_sdhci_drv) = {
>>>     .ops            = &sdhci_ops,
>>>     .bind           = xenon_sdhci_bind,
>>>     .probe          = xenon_sdhci_probe,
>>> +   .remove         = xenon_sdhci_remove,
>>>     .priv_auto_alloc_size = sizeof(struct xenon_sdhci_priv),
>>>     .platdata_auto_alloc_size = sizeof(struct xenon_sdhci_plat),
>>>  };
>>>
>>>
>>
> 

Reply via email to