mirror of
https://github.com/torvalds/linux.git
synced 2024-11-21 19:46:16 +00:00
mmc: sdhci-pci: add UHS-II support framework
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@genesyslogic.com.tw> Signed-off-by: AKASHI Takahiro <takahiro.akashi@linaro.org> Signed-off-by: Victor Shih <victor.shih@genesyslogic.com.tw> Acked-by: Adrian Hunter <adrian.hunter@intel.com> Message-ID: <20241018105333.4569-15-victorshihgli@gmail.com> Signed-off-by: Ulf Hansson <ulf.hansson@linaro.org>
This commit is contained in:
parent
379e4dc5b6
commit
2daf64308d
@ -111,6 +111,7 @@ config MMC_SDHCI_PCI
|
||||
tristate "SDHCI support on PCI bus"
|
||||
depends on MMC_SDHCI && PCI
|
||||
select MMC_CQHCI
|
||||
select MMC_SDHCI_UHS2
|
||||
select IOSF_MBI if X86
|
||||
select MMC_SDHCI_IO_ACCESSORS
|
||||
help
|
||||
|
@ -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);
|
||||
|
||||
@ -2181,7 +2182,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);
|
||||
@ -2189,6 +2193,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);
|
||||
}
|
||||
|
||||
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);
|
||||
|
@ -145,6 +145,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 *);
|
||||
@ -189,6 +190,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
|
||||
|
Loading…
Reference in New Issue
Block a user