blob: e1d880975fecc6b1c663d8663c8839a44c51069b [file] [log] [blame]
Angel Pons0612b272020-04-05 15:46:56 +02001/* SPDX-License-Identifier: GPL-2.0-only */
Subrata Banik23ccb0d2017-04-24 11:28:40 +05302
Subrata Banik23ccb0d2017-04-24 11:28:40 +05303#include <device/device.h>
4#include <device/pci.h>
5#include <device/pci_ids.h>
6#include <intelblocks/xdci.h>
Duncan Laurie4df7d2c2018-03-26 02:17:33 -07007#include <security/vboot/vboot_common.h>
Subrata Banik23ccb0d2017-04-24 11:28:40 +05308
Aaron Durbin64031672018-04-21 14:45:32 -06009__weak void soc_xdci_init(struct device *dev) { /* no-op */ }
Subrata Banik23ccb0d2017-04-24 11:28:40 +053010
Angel Ponsc7cfe0b2021-06-23 12:39:22 +020011bool xdci_can_enable(unsigned int xdci_devfn)
Duncan Laurie4df7d2c2018-03-26 02:17:33 -070012{
Angel Ponsc7cfe0b2021-06-23 12:39:22 +020013 /* Enable xDCI controller if enabled in devicetree and allowed */
14 if (!vboot_can_enable_udc()) {
15 devfn_disable(pci_root_bus(), xdci_devfn);
16 return false;
17 }
18 return is_devfn_enabled(xdci_devfn);
Duncan Laurie4df7d2c2018-03-26 02:17:33 -070019}
20
Subrata Banik23ccb0d2017-04-24 11:28:40 +053021static struct device_operations usb_xdci_ops = {
Elyes HAOUAS1d191272018-11-27 12:23:48 +010022 .read_resources = pci_dev_read_resources,
23 .set_resources = pci_dev_set_resources,
24 .enable_resources = pci_dev_enable_resources,
Subrata Banik23ccb0d2017-04-24 11:28:40 +053025 .init = soc_xdci_init,
Subrata Banik6bbc91a2017-12-07 14:55:51 +053026 .ops_pci = &pci_dev_ops_pci,
Subrata Banik23ccb0d2017-04-24 11:28:40 +053027};
28
29static const unsigned short pci_device_ids[] = {
Aaron Durbinf27d98f2017-05-05 16:52:52 -050030 PCI_DEVICE_ID_INTEL_APL_XDCI,
Lijian Zhaobbedef92017-07-29 16:38:38 -070031 PCI_DEVICE_ID_INTEL_CNL_LP_XDCI,
Subrata Banik23ccb0d2017-04-24 11:28:40 +053032 PCI_DEVICE_ID_INTEL_GLK_XDCI,
33 PCI_DEVICE_ID_INTEL_SPT_LP_XDCI,
praveen hodagatta praneshe26c4a42018-09-20 03:49:45 +080034 PCI_DEVICE_ID_INTEL_CNP_H_XDCI,
Aamir Bohra9eac0392018-06-30 12:07:04 +053035 PCI_DEVICE_ID_INTEL_ICP_LP_XDCI,
Ronak Kanabarda7ffb482019-02-05 01:51:13 +053036 PCI_DEVICE_ID_INTEL_CMP_LP_XDCI,
Gaggery Tsai12a651c2019-12-05 11:23:20 -080037 PCI_DEVICE_ID_INTEL_CMP_H_XDCI,
Ravi Sarawadi6b5bf402019-10-21 22:25:04 -070038 PCI_DEVICE_ID_INTEL_TGP_LP_XDCI,
Tan, Lean Sheng26136092020-01-20 19:13:56 -080039 PCI_DEVICE_ID_INTEL_MCC_XDCI,
Meera Ravindranath3f4af0d2020-02-12 16:01:22 +053040 PCI_DEVICE_ID_INTEL_JSP_XDCI,
Subrata Banikf672f7f2020-08-03 14:29:25 +053041 PCI_DEVICE_ID_INTEL_ADP_P_XDCI,
42 PCI_DEVICE_ID_INTEL_ADP_S_XDCI,
Varshit Pandyaf4d98fdd22021-01-17 18:39:29 +053043 PCI_DEVICE_ID_INTEL_ADP_M_XDCI,
Subrata Banik23ccb0d2017-04-24 11:28:40 +053044 0
45};
46
47static const struct pci_driver pch_usb_xdci __pci_driver = {
48 .ops = &usb_xdci_ops,
49 .vendor = PCI_VENDOR_ID_INTEL,
50 .devices = pci_device_ids,
51};