1 // SPDX-License-Identifier: GPL-2.0+
3 * Copyright (C) 2015, Google, Inc
16 struct mmc_config cfg;
21 struct sdhci_host host;
25 static int pci_mmc_probe(struct udevice *dev)
27 struct mmc_uclass_priv *upriv = dev_get_uclass_priv(dev);
28 struct pci_mmc_plat *plat = dev_get_platdata(dev);
29 struct pci_mmc_priv *priv = dev_get_priv(dev);
30 struct sdhci_host *host = &priv->host;
33 host->ioaddr = (void *)dm_pci_map_bar(dev, PCI_BASE_ADDRESS_0,
35 host->name = dev->name;
36 ret = sdhci_setup_cfg(&plat->cfg, host, 0, 0);
39 host->mmc = &plat->mmc;
40 host->mmc->priv = &priv->host;
42 upriv->mmc = host->mmc;
44 return sdhci_probe(dev);
47 static int pci_mmc_bind(struct udevice *dev)
49 struct pci_mmc_plat *plat = dev_get_platdata(dev);
51 return sdhci_bind(dev, &plat->mmc, &plat->cfg);
54 U_BOOT_DRIVER(pci_mmc) = {
58 .probe = pci_mmc_probe,
60 .priv_auto_alloc_size = sizeof(struct pci_mmc_priv),
61 .platdata_auto_alloc_size = sizeof(struct pci_mmc_plat),
64 static struct pci_device_id mmc_supported[] = {
65 { PCI_DEVICE_CLASS(PCI_CLASS_SYSTEM_SDHCI << 8, 0xffff00) },
69 U_BOOT_PCI_DEVICE(pci_mmc, mmc_supported);