Re: [PATCH V7 22/23] mmc: sdhci-pci: add UHS-II support framework

From: Adrian Hunter
Date: Wed Apr 12 2023 - 09:13:16 EST


On 31/03/23 13:55, Victor Shih wrote:
> From: AKASHI Takahiro <takahiro.akashi@xxxxxxxxxx>
>
> This patch prepares for adding UHS-II support at a specific UHS-II
> capable sdhci-pci controller, GL9755 for now.
>
> Signed-off-by: Ben Chuang <ben.chuang@xxxxxxxxxxxxxxxxxxx>
> Signed-off-by: AKASHI Takahiro <takahiro.akashi@xxxxxxxxxx>
> ---
> drivers/mmc/host/sdhci-pci-core.c | 16 +++++++++++++++-
> drivers/mmc/host/sdhci-pci.h | 3 +++
> 2 files changed, 18 insertions(+), 1 deletion(-)
>
> diff --git a/drivers/mmc/host/sdhci-pci-core.c b/drivers/mmc/host/sdhci-pci-core.c
> index 01975d145200..6b5109f7feef 100644
> --- a/drivers/mmc/host/sdhci-pci-core.c
> +++ b/drivers/mmc/host/sdhci-pci-core.c
> @@ -40,6 +40,7 @@
> #include "sdhci.h"
> #include "sdhci-cqhci.h"
> #include "sdhci-pci.h"
> +#include "sdhci-uhs2.h"
>
> static void sdhci_pci_hw_reset(struct sdhci_host *host);
>
> @@ -2155,7 +2156,10 @@ static void sdhci_pci_remove_slot(struct sdhci_pci_slot *slot)
> if (scratch == (u32)-1)
> dead = 1;
>
> - sdhci_remove_host(slot->host, dead);
> + if (slot->chip->fixes && slot->chip->fixes->remove_host)
> + slot->chip->fixes->remove_host(slot, dead);
> + else
> + sdhci_remove_host(slot->host, dead);
>
> if (slot->chip->fixes && slot->chip->fixes->remove_slot)
> slot->chip->fixes->remove_slot(slot, dead);
> @@ -2163,6 +2167,16 @@ static void sdhci_pci_remove_slot(struct sdhci_pci_slot *slot)
> sdhci_free_host(slot->host);
> }
>
> +int sdhci_pci_uhs2_add_host(struct sdhci_pci_slot *slot)
> +{
> + return sdhci_uhs2_add_host(slot->host);

This patch does not compile because uhs2 functions
cannot be called yet because config MMC_SDHCI_UHS2
is not yet selected.

Please ensure all patches compile before submitting.

> +}
> +
> +void sdhci_pci_uhs2_remove_host(struct sdhci_pci_slot *slot, int dead)
> +{
> + sdhci_uhs2_remove_host(slot->host, dead);
> +}
> +
> static void sdhci_pci_runtime_pm_allow(struct device *dev)
> {
> pm_suspend_ignore_children(dev, 1);
> diff --git a/drivers/mmc/host/sdhci-pci.h b/drivers/mmc/host/sdhci-pci.h
> index 3661a224fb04..7f4a981c0e63 100644
> --- a/drivers/mmc/host/sdhci-pci.h
> +++ b/drivers/mmc/host/sdhci-pci.h
> @@ -140,6 +140,7 @@ struct sdhci_pci_fixes {
> int (*probe_slot) (struct sdhci_pci_slot *);
> int (*add_host) (struct sdhci_pci_slot *);
> void (*remove_slot) (struct sdhci_pci_slot *, int);
> + void (*remove_host) (struct sdhci_pci_slot *, int);
>
> #ifdef CONFIG_PM_SLEEP
> int (*suspend) (struct sdhci_pci_chip *);
> @@ -184,6 +185,8 @@ static inline void *sdhci_pci_priv(struct sdhci_pci_slot *slot)
> return (void *)slot->private;
> }
>
> +int sdhci_pci_uhs2_add_host(struct sdhci_pci_slot *slot);
> +void sdhci_pci_uhs2_remove_host(struct sdhci_pci_slot *slot, int dead);
> #ifdef CONFIG_PM_SLEEP
> int sdhci_pci_resume_host(struct sdhci_pci_chip *chip);
> #endif