soc/intel/alderlake: Add ADL-P 4+4 with 28W TDP
[coreboot.git] / src / commonlib / storage / pci_sdhci.c
blobde9dd1b55c04269fd462c1c9fef6676f5087341b
1 /* SPDX-License-Identifier: GPL-2.0-or-later */
3 #include <commonlib/sdhci.h>
4 #include <device/pci.h>
5 #include <device/pci_ops.h>
6 #include <stdint.h>
7 #include <string.h>
9 #include "sd_mmc.h"
10 #include "storage.h"
12 /* Initialize an SDHCI port */
13 int sdhci_controller_init(struct sdhci_ctrlr *sdhci_ctrlr, void *ioaddr)
15 sdhci_ctrlr->ioaddr = ioaddr;
16 return add_sdhci(sdhci_ctrlr);
19 struct sd_mmc_ctrlr *new_mem_sdhci_controller(void *ioaddr,
20 int (*pre_init_func)(struct sdhci_ctrlr *host))
22 static bool sdhci_init_done;
23 static struct sdhci_ctrlr sdhci_ctrlr = {0};
25 if (sdhci_init_done == true) {
26 sdhc_error("Error: SDHCI is already initialized.\n");
27 return NULL;
30 sdhci_ctrlr.attach = pre_init_func;
32 if (sdhci_controller_init(&sdhci_ctrlr, ioaddr)) {
33 sdhc_error("Error: SDHCI initialization failed.\n");
34 return NULL;
37 sdhci_init_done = true;
39 return &sdhci_ctrlr.sd_mmc_ctrlr;
42 struct sd_mmc_ctrlr *new_pci_sdhci_controller(pci_devfn_t dev)
44 uintptr_t addr;
46 addr = pci_s_read_config32(dev, PCI_BASE_ADDRESS_0);
47 if (addr == ((uint32_t)~0)) {
48 sdhc_error("Error: PCI SDHCI not found\n");
49 return NULL;
52 addr &= ~0xf;
53 return new_mem_sdhci_controller((void *)addr, NULL);