aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--src/soc/amd/phoenix/xhci.c24
1 files changed, 22 insertions, 2 deletions
diff --git a/src/soc/amd/phoenix/xhci.c b/src/soc/amd/phoenix/xhci.c
index 8bb446f9f9..99033f94c6 100644
--- a/src/soc/amd/phoenix/xhci.c
+++ b/src/soc/amd/phoenix/xhci.c
@@ -1,7 +1,5 @@
/* SPDX-License-Identifier: GPL-2.0-only */
-/* TODO: Update for Phoenix */
-
#include <amdblocks/gpio.h>
#include <amdblocks/smi.h>
#include <amdblocks/xhci.h>
@@ -24,6 +22,18 @@ static const struct sci_source xhci_sci_sources[] = {
.gpe = XHCI_GEVENT,
.direction = SMI_SCI_LVL_HIGH,
.level = SMI_SCI_EDG
+ },
+ {
+ .scimap = SMITYPE_XHC3_PME,
+ .gpe = XHCI_GEVENT,
+ .direction = SMI_SCI_LVL_HIGH,
+ .level = SMI_SCI_EDG
+ },
+ {
+ .scimap = SMITYPE_XHC4_PME,
+ .gpe = XHCI_GEVENT,
+ .direction = SMI_SCI_LVL_HIGH,
+ .level = SMI_SCI_EDG
}
};
@@ -45,6 +55,16 @@ enum cb_err pci_xhci_get_wake_gpe(const struct device *dev, int *gpe)
}
}
+ if (dev->bus->dev->path.pci.devfn == PCIE_ABC_C_DEVFN) {
+ if (dev->path.pci.devfn == USB4_XHCI0_DEVFN) {
+ *gpe = xhci_sci_sources[2].gpe;
+ return CB_SUCCESS;
+ } else if (dev->path.pci.devfn == USB4_XHCI1_DEVFN) {
+ *gpe = xhci_sci_sources[3].gpe;
+ return CB_SUCCESS;
+ }
+ }
+
return CB_ERR_ARG;
}