2017-11-03 17:28:30 +07:00
|
|
|
// SPDX-License-Identifier: GPL-2.0
|
usb: Introduce DesignWare USB3 DRD Driver
The DesignWare USB3 is a highly
configurable IP Core which can be
instantiated as Dual-Role Device (DRD),
Peripheral Only and Host Only (XHCI)
configurations.
Several other parameters can be configured
like amount of FIFO space, amount of TX and
RX endpoints, amount of Host Interrupters,
etc.
The current driver has been validated with
a virtual model of version 1.73a of that core
and with an FPGA burned with version 1.83a
of the DRD core. We have support for PCIe
bus, which is used on FPGA prototyping, and
for the OMAP5, more adaptation (or glue)
layers can be easily added and the driver
is half prepared to handle any possible
configuration the HW engineer has chosen
considering we have the information on
one of the GHWPARAMS registers to do
runtime checking of certain features.
More runtime checks can, and should, be added
in order to make this driver even more flexible
with regards to number of endpoints, FIFO sizes,
transfer types, etc.
While this supports only the device side, for
now, we will add support for Host side (xHCI -
see the updated series Sebastian has sent [1])
and OTG after we have it all stabilized.
[1] http://marc.info/?l=linux-usb&m=131341992020339&w=2
Signed-off-by: Felipe Balbi <balbi@ti.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
2011-08-19 22:10:58 +07:00
|
|
|
/**
|
|
|
|
* dwc3-pci.c - PCI Specific glue layer
|
|
|
|
*
|
|
|
|
* Copyright (C) 2010-2011 Texas Instruments Incorporated - http://www.ti.com
|
|
|
|
*
|
|
|
|
* Authors: Felipe Balbi <balbi@ti.com>,
|
|
|
|
* Sebastian Andrzej Siewior <bigeasy@linutronix.de>
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <linux/kernel.h>
|
2011-08-23 12:08:54 +07:00
|
|
|
#include <linux/module.h>
|
usb: Introduce DesignWare USB3 DRD Driver
The DesignWare USB3 is a highly
configurable IP Core which can be
instantiated as Dual-Role Device (DRD),
Peripheral Only and Host Only (XHCI)
configurations.
Several other parameters can be configured
like amount of FIFO space, amount of TX and
RX endpoints, amount of Host Interrupters,
etc.
The current driver has been validated with
a virtual model of version 1.73a of that core
and with an FPGA burned with version 1.83a
of the DRD core. We have support for PCIe
bus, which is used on FPGA prototyping, and
for the OMAP5, more adaptation (or glue)
layers can be easily added and the driver
is half prepared to handle any possible
configuration the HW engineer has chosen
considering we have the information on
one of the GHWPARAMS registers to do
runtime checking of certain features.
More runtime checks can, and should, be added
in order to make this driver even more flexible
with regards to number of endpoints, FIFO sizes,
transfer types, etc.
While this supports only the device side, for
now, we will add support for Host side (xHCI -
see the updated series Sebastian has sent [1])
and OTG after we have it all stabilized.
[1] http://marc.info/?l=linux-usb&m=131341992020339&w=2
Signed-off-by: Felipe Balbi <balbi@ti.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
2011-08-19 22:10:58 +07:00
|
|
|
#include <linux/slab.h>
|
|
|
|
#include <linux/pci.h>
|
2017-09-27 18:19:21 +07:00
|
|
|
#include <linux/workqueue.h>
|
2016-05-17 14:15:02 +07:00
|
|
|
#include <linux/pm_runtime.h>
|
usb: Introduce DesignWare USB3 DRD Driver
The DesignWare USB3 is a highly
configurable IP Core which can be
instantiated as Dual-Role Device (DRD),
Peripheral Only and Host Only (XHCI)
configurations.
Several other parameters can be configured
like amount of FIFO space, amount of TX and
RX endpoints, amount of Host Interrupters,
etc.
The current driver has been validated with
a virtual model of version 1.73a of that core
and with an FPGA burned with version 1.83a
of the DRD core. We have support for PCIe
bus, which is used on FPGA prototyping, and
for the OMAP5, more adaptation (or glue)
layers can be easily added and the driver
is half prepared to handle any possible
configuration the HW engineer has chosen
considering we have the information on
one of the GHWPARAMS registers to do
runtime checking of certain features.
More runtime checks can, and should, be added
in order to make this driver even more flexible
with regards to number of endpoints, FIFO sizes,
transfer types, etc.
While this supports only the device side, for
now, we will add support for Host side (xHCI -
see the updated series Sebastian has sent [1])
and OTG after we have it all stabilized.
[1] http://marc.info/?l=linux-usb&m=131341992020339&w=2
Signed-off-by: Felipe Balbi <balbi@ti.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
2011-08-19 22:10:58 +07:00
|
|
|
#include <linux/platform_device.h>
|
2015-05-13 19:26:50 +07:00
|
|
|
#include <linux/gpio/consumer.h>
|
2018-06-10 21:01:20 +07:00
|
|
|
#include <linux/gpio/machine.h>
|
2015-05-13 19:26:50 +07:00
|
|
|
#include <linux/acpi.h>
|
2016-04-22 15:17:39 +07:00
|
|
|
#include <linux/delay.h>
|
2014-10-28 18:54:24 +07:00
|
|
|
|
2015-09-26 13:47:53 +07:00
|
|
|
#define PCI_DEVICE_ID_INTEL_BYT 0x0f37
|
|
|
|
#define PCI_DEVICE_ID_INTEL_MRFLD 0x119e
|
|
|
|
#define PCI_DEVICE_ID_INTEL_BSW 0x22b7
|
|
|
|
#define PCI_DEVICE_ID_INTEL_SPTLP 0x9d30
|
|
|
|
#define PCI_DEVICE_ID_INTEL_SPTH 0xa130
|
2015-10-21 18:37:04 +07:00
|
|
|
#define PCI_DEVICE_ID_INTEL_BXT 0x0aaa
|
2016-04-01 21:13:10 +07:00
|
|
|
#define PCI_DEVICE_ID_INTEL_BXT_M 0x1aaa
|
2015-10-21 18:37:04 +07:00
|
|
|
#define PCI_DEVICE_ID_INTEL_APL 0x5aaa
|
2016-04-01 21:13:11 +07:00
|
|
|
#define PCI_DEVICE_ID_INTEL_KBP 0xa2b0
|
2019-12-12 16:37:13 +07:00
|
|
|
#define PCI_DEVICE_ID_INTEL_CMLLP 0x02ee
|
|
|
|
#define PCI_DEVICE_ID_INTEL_CMLH 0x06ee
|
2016-04-01 21:13:12 +07:00
|
|
|
#define PCI_DEVICE_ID_INTEL_GLK 0x31aa
|
2016-04-01 21:13:13 +07:00
|
|
|
#define PCI_DEVICE_ID_INTEL_CNPLP 0x9dee
|
|
|
|
#define PCI_DEVICE_ID_INTEL_CNPH 0xa36e
|
2020-01-17 16:30:33 +07:00
|
|
|
#define PCI_DEVICE_ID_INTEL_CNPV 0xa3b0
|
2017-06-15 16:57:30 +07:00
|
|
|
#define PCI_DEVICE_ID_INTEL_ICLLP 0x34ee
|
2018-06-11 15:21:12 +07:00
|
|
|
#define PCI_DEVICE_ID_INTEL_EHLLP 0x4b7e
|
2017-12-13 21:03:22 +07:00
|
|
|
#define PCI_DEVICE_ID_INTEL_TGPLP 0xa0ee
|
usb: Introduce DesignWare USB3 DRD Driver
The DesignWare USB3 is a highly
configurable IP Core which can be
instantiated as Dual-Role Device (DRD),
Peripheral Only and Host Only (XHCI)
configurations.
Several other parameters can be configured
like amount of FIFO space, amount of TX and
RX endpoints, amount of Host Interrupters,
etc.
The current driver has been validated with
a virtual model of version 1.73a of that core
and with an FPGA burned with version 1.83a
of the DRD core. We have support for PCIe
bus, which is used on FPGA prototyping, and
for the OMAP5, more adaptation (or glue)
layers can be easily added and the driver
is half prepared to handle any possible
configuration the HW engineer has chosen
considering we have the information on
one of the GHWPARAMS registers to do
runtime checking of certain features.
More runtime checks can, and should, be added
in order to make this driver even more flexible
with regards to number of endpoints, FIFO sizes,
transfer types, etc.
While this supports only the device side, for
now, we will add support for Host side (xHCI -
see the updated series Sebastian has sent [1])
and OTG after we have it all stabilized.
[1] http://marc.info/?l=linux-usb&m=131341992020339&w=2
Signed-off-by: Felipe Balbi <balbi@ti.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
2011-08-19 22:10:58 +07:00
|
|
|
|
2017-06-05 23:40:46 +07:00
|
|
|
#define PCI_INTEL_BXT_DSM_GUID "732b85d5-b7a7-4a1b-9ba0-4bbd00ffd511"
|
2016-10-24 14:40:18 +07:00
|
|
|
#define PCI_INTEL_BXT_FUNC_PMU_PWR 4
|
|
|
|
#define PCI_INTEL_BXT_STATE_D0 0
|
|
|
|
#define PCI_INTEL_BXT_STATE_D3 3
|
|
|
|
|
2018-06-10 21:01:21 +07:00
|
|
|
#define GP_RWBAR 1
|
|
|
|
#define GP_RWREG1 0xa0
|
|
|
|
#define GP_RWREG1_ULPI_REFCLK_DISABLE (1 << 17)
|
|
|
|
|
2016-10-24 14:29:01 +07:00
|
|
|
/**
|
|
|
|
* struct dwc3_pci - Driver private structure
|
|
|
|
* @dwc3: child dwc3 platform_device
|
|
|
|
* @pci: our link to PCI bus
|
2017-06-05 23:40:46 +07:00
|
|
|
* @guid: _DSM GUID
|
2016-10-24 14:40:18 +07:00
|
|
|
* @has_dsm_for_pm: true for devices which need to run _DSM on runtime PM
|
2018-07-20 23:54:01 +07:00
|
|
|
* @wakeup_work: work for asynchronous resume
|
2016-10-24 14:29:01 +07:00
|
|
|
*/
|
|
|
|
struct dwc3_pci {
|
|
|
|
struct platform_device *dwc3;
|
|
|
|
struct pci_dev *pci;
|
2016-10-24 14:40:18 +07:00
|
|
|
|
2017-06-05 23:40:46 +07:00
|
|
|
guid_t guid;
|
2016-10-24 14:40:18 +07:00
|
|
|
|
|
|
|
unsigned int has_dsm_for_pm:1;
|
2017-09-27 18:19:21 +07:00
|
|
|
struct work_struct wakeup_work;
|
2016-10-24 14:29:01 +07:00
|
|
|
};
|
|
|
|
|
2015-05-13 19:26:50 +07:00
|
|
|
static const struct acpi_gpio_params reset_gpios = { 0, 0, false };
|
|
|
|
static const struct acpi_gpio_params cs_gpios = { 1, 0, false };
|
|
|
|
|
|
|
|
static const struct acpi_gpio_mapping acpi_dwc3_byt_gpios[] = {
|
|
|
|
{ "reset-gpios", &reset_gpios, 1 },
|
|
|
|
{ "cs-gpios", &cs_gpios, 1 },
|
|
|
|
{ },
|
|
|
|
};
|
|
|
|
|
2018-06-10 21:01:20 +07:00
|
|
|
static struct gpiod_lookup_table platform_bytcr_gpios = {
|
|
|
|
.dev_id = "0000:00:16.0",
|
|
|
|
.table = {
|
|
|
|
GPIO_LOOKUP("INT33FC:00", 54, "reset", GPIO_ACTIVE_HIGH),
|
|
|
|
GPIO_LOOKUP("INT33FC:02", 14, "cs", GPIO_ACTIVE_HIGH),
|
|
|
|
{}
|
|
|
|
},
|
|
|
|
};
|
|
|
|
|
2018-06-10 21:01:21 +07:00
|
|
|
static int dwc3_byt_enable_ulpi_refclock(struct pci_dev *pci)
|
|
|
|
{
|
|
|
|
void __iomem *reg;
|
|
|
|
u32 value;
|
|
|
|
|
|
|
|
reg = pcim_iomap(pci, GP_RWBAR, 0);
|
2018-07-31 21:38:52 +07:00
|
|
|
if (!reg)
|
|
|
|
return -ENOMEM;
|
2018-06-10 21:01:21 +07:00
|
|
|
|
|
|
|
value = readl(reg + GP_RWREG1);
|
|
|
|
if (!(value & GP_RWREG1_ULPI_REFCLK_DISABLE))
|
|
|
|
goto unmap; /* ULPI refclk already enabled */
|
|
|
|
|
|
|
|
value &= ~GP_RWREG1_ULPI_REFCLK_DISABLE;
|
|
|
|
writel(value, reg + GP_RWREG1);
|
|
|
|
/* This comes from the Intel Android x86 tree w/o any explanation */
|
|
|
|
msleep(100);
|
|
|
|
unmap:
|
|
|
|
pcim_iounmap(pci, reg);
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2018-07-26 18:48:56 +07:00
|
|
|
static const struct property_entry dwc3_pci_intel_properties[] = {
|
|
|
|
PROPERTY_ENTRY_STRING("dr_mode", "peripheral"),
|
|
|
|
PROPERTY_ENTRY_BOOL("linux,sysdev_is_parent"),
|
|
|
|
{}
|
|
|
|
};
|
|
|
|
|
2018-07-26 18:48:57 +07:00
|
|
|
static const struct property_entry dwc3_pci_mrfld_properties[] = {
|
|
|
|
PROPERTY_ENTRY_STRING("dr_mode", "otg"),
|
2020-05-04 16:33:52 +07:00
|
|
|
PROPERTY_ENTRY_STRING("linux,extcon-name", "mrfld_bcove_pwrsrc"),
|
2018-07-26 18:48:57 +07:00
|
|
|
PROPERTY_ENTRY_BOOL("linux,sysdev_is_parent"),
|
|
|
|
{}
|
|
|
|
};
|
|
|
|
|
2018-07-26 18:48:56 +07:00
|
|
|
static const struct property_entry dwc3_pci_amd_properties[] = {
|
|
|
|
PROPERTY_ENTRY_BOOL("snps,has-lpm-erratum"),
|
|
|
|
PROPERTY_ENTRY_U8("snps,lpm-nyet-threshold", 0xf),
|
|
|
|
PROPERTY_ENTRY_BOOL("snps,u2exit_lfps_quirk"),
|
|
|
|
PROPERTY_ENTRY_BOOL("snps,u2ss_inp3_quirk"),
|
|
|
|
PROPERTY_ENTRY_BOOL("snps,req_p1p2p3_quirk"),
|
|
|
|
PROPERTY_ENTRY_BOOL("snps,del_p1p2p3_quirk"),
|
|
|
|
PROPERTY_ENTRY_BOOL("snps,del_phy_power_chg_quirk"),
|
|
|
|
PROPERTY_ENTRY_BOOL("snps,lfps_filter_quirk"),
|
|
|
|
PROPERTY_ENTRY_BOOL("snps,rx_detect_poll_quirk"),
|
|
|
|
PROPERTY_ENTRY_BOOL("snps,tx_de_emphasis_quirk"),
|
|
|
|
PROPERTY_ENTRY_U8("snps,tx_de_emphasis", 1),
|
|
|
|
/* FIXME these quirks should be removed when AMD NL tapes out */
|
|
|
|
PROPERTY_ENTRY_BOOL("snps,disable_scramble_quirk"),
|
|
|
|
PROPERTY_ENTRY_BOOL("snps,dis_u3_susphy_quirk"),
|
|
|
|
PROPERTY_ENTRY_BOOL("snps,dis_u2_susphy_quirk"),
|
|
|
|
PROPERTY_ENTRY_BOOL("linux,sysdev_is_parent"),
|
|
|
|
{}
|
|
|
|
};
|
|
|
|
|
2016-10-24 14:29:01 +07:00
|
|
|
static int dwc3_pci_quirks(struct dwc3_pci *dwc)
|
2015-01-12 19:20:14 +07:00
|
|
|
{
|
2016-10-24 14:29:01 +07:00
|
|
|
struct pci_dev *pdev = dwc->pci;
|
|
|
|
|
2016-06-07 16:49:52 +07:00
|
|
|
if (pdev->vendor == PCI_VENDOR_ID_INTEL) {
|
2016-10-24 14:40:18 +07:00
|
|
|
if (pdev->device == PCI_DEVICE_ID_INTEL_BXT ||
|
|
|
|
pdev->device == PCI_DEVICE_ID_INTEL_BXT_M) {
|
2017-06-05 23:40:46 +07:00
|
|
|
guid_parse(PCI_INTEL_BXT_DSM_GUID, &dwc->guid);
|
2016-10-24 14:40:18 +07:00
|
|
|
dwc->has_dsm_for_pm = true;
|
|
|
|
}
|
|
|
|
|
2016-06-07 16:49:52 +07:00
|
|
|
if (pdev->device == PCI_DEVICE_ID_INTEL_BYT) {
|
|
|
|
struct gpio_desc *gpio;
|
2018-07-26 18:48:56 +07:00
|
|
|
int ret;
|
2016-06-07 16:49:52 +07:00
|
|
|
|
2018-06-10 21:01:21 +07:00
|
|
|
/* On BYT the FW does not always enable the refclock */
|
|
|
|
ret = dwc3_byt_enable_ulpi_refclock(pdev);
|
|
|
|
if (ret)
|
|
|
|
return ret;
|
|
|
|
|
2017-03-22 21:08:07 +07:00
|
|
|
ret = devm_acpi_dev_add_driver_gpios(&pdev->dev,
|
2016-06-07 16:49:52 +07:00
|
|
|
acpi_dwc3_byt_gpios);
|
2017-03-22 21:08:07 +07:00
|
|
|
if (ret)
|
|
|
|
dev_dbg(&pdev->dev, "failed to add mapping table\n");
|
2016-06-07 16:49:52 +07:00
|
|
|
|
2018-06-10 21:01:20 +07:00
|
|
|
/*
|
|
|
|
* A lot of BYT devices lack ACPI resource entries for
|
|
|
|
* the GPIOs, add a fallback mapping to the reference
|
|
|
|
* design GPIOs which all boards seem to use.
|
|
|
|
*/
|
|
|
|
gpiod_add_lookup_table(&platform_bytcr_gpios);
|
|
|
|
|
2016-06-07 16:49:52 +07:00
|
|
|
/*
|
|
|
|
* These GPIOs will turn on the USB2 PHY. Note that we have to
|
|
|
|
* put the gpio descriptors again here because the phy driver
|
|
|
|
* might want to grab them, too.
|
|
|
|
*/
|
2018-12-07 01:42:28 +07:00
|
|
|
gpio = gpiod_get_optional(&pdev->dev, "cs", GPIOD_OUT_LOW);
|
2016-06-07 16:49:52 +07:00
|
|
|
if (IS_ERR(gpio))
|
|
|
|
return PTR_ERR(gpio);
|
|
|
|
|
2015-05-13 19:26:50 +07:00
|
|
|
gpiod_set_value_cansleep(gpio, 1);
|
2018-12-07 01:42:28 +07:00
|
|
|
gpiod_put(gpio);
|
2016-06-07 16:49:52 +07:00
|
|
|
|
2018-12-07 01:42:28 +07:00
|
|
|
gpio = gpiod_get_optional(&pdev->dev, "reset", GPIOD_OUT_LOW);
|
2016-06-07 16:49:52 +07:00
|
|
|
if (IS_ERR(gpio))
|
|
|
|
return PTR_ERR(gpio);
|
|
|
|
|
|
|
|
if (gpio) {
|
|
|
|
gpiod_set_value_cansleep(gpio, 1);
|
2018-12-07 01:42:28 +07:00
|
|
|
gpiod_put(gpio);
|
2016-06-07 16:49:52 +07:00
|
|
|
usleep_range(10000, 11000);
|
|
|
|
}
|
2015-05-13 19:26:50 +07:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2015-01-12 19:20:14 +07:00
|
|
|
return 0;
|
|
|
|
}
|
usb: Introduce DesignWare USB3 DRD Driver
The DesignWare USB3 is a highly
configurable IP Core which can be
instantiated as Dual-Role Device (DRD),
Peripheral Only and Host Only (XHCI)
configurations.
Several other parameters can be configured
like amount of FIFO space, amount of TX and
RX endpoints, amount of Host Interrupters,
etc.
The current driver has been validated with
a virtual model of version 1.73a of that core
and with an FPGA burned with version 1.83a
of the DRD core. We have support for PCIe
bus, which is used on FPGA prototyping, and
for the OMAP5, more adaptation (or glue)
layers can be easily added and the driver
is half prepared to handle any possible
configuration the HW engineer has chosen
considering we have the information on
one of the GHWPARAMS registers to do
runtime checking of certain features.
More runtime checks can, and should, be added
in order to make this driver even more flexible
with regards to number of endpoints, FIFO sizes,
transfer types, etc.
While this supports only the device side, for
now, we will add support for Host side (xHCI -
see the updated series Sebastian has sent [1])
and OTG after we have it all stabilized.
[1] http://marc.info/?l=linux-usb&m=131341992020339&w=2
Signed-off-by: Felipe Balbi <balbi@ti.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
2011-08-19 22:10:58 +07:00
|
|
|
|
2017-09-27 18:19:21 +07:00
|
|
|
#ifdef CONFIG_PM
|
|
|
|
static void dwc3_pci_resume_work(struct work_struct *work)
|
|
|
|
{
|
|
|
|
struct dwc3_pci *dwc = container_of(work, struct dwc3_pci, wakeup_work);
|
|
|
|
struct platform_device *dwc3 = dwc->dwc3;
|
|
|
|
int ret;
|
|
|
|
|
|
|
|
ret = pm_runtime_get_sync(&dwc3->dev);
|
2020-06-14 10:15:25 +07:00
|
|
|
if (ret) {
|
|
|
|
pm_runtime_put_sync_autosuspend(&dwc3->dev);
|
2017-09-27 18:19:21 +07:00
|
|
|
return;
|
2020-06-14 10:15:25 +07:00
|
|
|
}
|
2017-09-27 18:19:21 +07:00
|
|
|
|
|
|
|
pm_runtime_mark_last_busy(&dwc3->dev);
|
|
|
|
pm_runtime_put_sync_autosuspend(&dwc3->dev);
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2018-07-26 18:48:56 +07:00
|
|
|
static int dwc3_pci_probe(struct pci_dev *pci, const struct pci_device_id *id)
|
usb: Introduce DesignWare USB3 DRD Driver
The DesignWare USB3 is a highly
configurable IP Core which can be
instantiated as Dual-Role Device (DRD),
Peripheral Only and Host Only (XHCI)
configurations.
Several other parameters can be configured
like amount of FIFO space, amount of TX and
RX endpoints, amount of Host Interrupters,
etc.
The current driver has been validated with
a virtual model of version 1.73a of that core
and with an FPGA burned with version 1.83a
of the DRD core. We have support for PCIe
bus, which is used on FPGA prototyping, and
for the OMAP5, more adaptation (or glue)
layers can be easily added and the driver
is half prepared to handle any possible
configuration the HW engineer has chosen
considering we have the information on
one of the GHWPARAMS registers to do
runtime checking of certain features.
More runtime checks can, and should, be added
in order to make this driver even more flexible
with regards to number of endpoints, FIFO sizes,
transfer types, etc.
While this supports only the device side, for
now, we will add support for Host side (xHCI -
see the updated series Sebastian has sent [1])
and OTG after we have it all stabilized.
[1] http://marc.info/?l=linux-usb&m=131341992020339&w=2
Signed-off-by: Felipe Balbi <balbi@ti.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
2011-08-19 22:10:58 +07:00
|
|
|
{
|
2018-07-26 18:48:56 +07:00
|
|
|
struct property_entry *p = (struct property_entry *)id->driver_data;
|
2016-10-24 14:29:01 +07:00
|
|
|
struct dwc3_pci *dwc;
|
usb: Introduce DesignWare USB3 DRD Driver
The DesignWare USB3 is a highly
configurable IP Core which can be
instantiated as Dual-Role Device (DRD),
Peripheral Only and Host Only (XHCI)
configurations.
Several other parameters can be configured
like amount of FIFO space, amount of TX and
RX endpoints, amount of Host Interrupters,
etc.
The current driver has been validated with
a virtual model of version 1.73a of that core
and with an FPGA burned with version 1.83a
of the DRD core. We have support for PCIe
bus, which is used on FPGA prototyping, and
for the OMAP5, more adaptation (or glue)
layers can be easily added and the driver
is half prepared to handle any possible
configuration the HW engineer has chosen
considering we have the information on
one of the GHWPARAMS registers to do
runtime checking of certain features.
More runtime checks can, and should, be added
in order to make this driver even more flexible
with regards to number of endpoints, FIFO sizes,
transfer types, etc.
While this supports only the device side, for
now, we will add support for Host side (xHCI -
see the updated series Sebastian has sent [1])
and OTG after we have it all stabilized.
[1] http://marc.info/?l=linux-usb&m=131341992020339&w=2
Signed-off-by: Felipe Balbi <balbi@ti.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
2011-08-19 22:10:58 +07:00
|
|
|
struct resource res[2];
|
2014-05-15 19:53:32 +07:00
|
|
|
int ret;
|
2012-02-15 16:27:55 +07:00
|
|
|
struct device *dev = &pci->dev;
|
usb: Introduce DesignWare USB3 DRD Driver
The DesignWare USB3 is a highly
configurable IP Core which can be
instantiated as Dual-Role Device (DRD),
Peripheral Only and Host Only (XHCI)
configurations.
Several other parameters can be configured
like amount of FIFO space, amount of TX and
RX endpoints, amount of Host Interrupters,
etc.
The current driver has been validated with
a virtual model of version 1.73a of that core
and with an FPGA burned with version 1.83a
of the DRD core. We have support for PCIe
bus, which is used on FPGA prototyping, and
for the OMAP5, more adaptation (or glue)
layers can be easily added and the driver
is half prepared to handle any possible
configuration the HW engineer has chosen
considering we have the information on
one of the GHWPARAMS registers to do
runtime checking of certain features.
More runtime checks can, and should, be added
in order to make this driver even more flexible
with regards to number of endpoints, FIFO sizes,
transfer types, etc.
While this supports only the device side, for
now, we will add support for Host side (xHCI -
see the updated series Sebastian has sent [1])
and OTG after we have it all stabilized.
[1] http://marc.info/?l=linux-usb&m=131341992020339&w=2
Signed-off-by: Felipe Balbi <balbi@ti.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
2011-08-19 22:10:58 +07:00
|
|
|
|
2014-05-15 19:53:33 +07:00
|
|
|
ret = pcim_enable_device(pci);
|
usb: Introduce DesignWare USB3 DRD Driver
The DesignWare USB3 is a highly
configurable IP Core which can be
instantiated as Dual-Role Device (DRD),
Peripheral Only and Host Only (XHCI)
configurations.
Several other parameters can be configured
like amount of FIFO space, amount of TX and
RX endpoints, amount of Host Interrupters,
etc.
The current driver has been validated with
a virtual model of version 1.73a of that core
and with an FPGA burned with version 1.83a
of the DRD core. We have support for PCIe
bus, which is used on FPGA prototyping, and
for the OMAP5, more adaptation (or glue)
layers can be easily added and the driver
is half prepared to handle any possible
configuration the HW engineer has chosen
considering we have the information on
one of the GHWPARAMS registers to do
runtime checking of certain features.
More runtime checks can, and should, be added
in order to make this driver even more flexible
with regards to number of endpoints, FIFO sizes,
transfer types, etc.
While this supports only the device side, for
now, we will add support for Host side (xHCI -
see the updated series Sebastian has sent [1])
and OTG after we have it all stabilized.
[1] http://marc.info/?l=linux-usb&m=131341992020339&w=2
Signed-off-by: Felipe Balbi <balbi@ti.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
2011-08-19 22:10:58 +07:00
|
|
|
if (ret) {
|
2012-02-15 16:27:55 +07:00
|
|
|
dev_err(dev, "failed to enable pci device\n");
|
|
|
|
return -ENODEV;
|
usb: Introduce DesignWare USB3 DRD Driver
The DesignWare USB3 is a highly
configurable IP Core which can be
instantiated as Dual-Role Device (DRD),
Peripheral Only and Host Only (XHCI)
configurations.
Several other parameters can be configured
like amount of FIFO space, amount of TX and
RX endpoints, amount of Host Interrupters,
etc.
The current driver has been validated with
a virtual model of version 1.73a of that core
and with an FPGA burned with version 1.83a
of the DRD core. We have support for PCIe
bus, which is used on FPGA prototyping, and
for the OMAP5, more adaptation (or glue)
layers can be easily added and the driver
is half prepared to handle any possible
configuration the HW engineer has chosen
considering we have the information on
one of the GHWPARAMS registers to do
runtime checking of certain features.
More runtime checks can, and should, be added
in order to make this driver even more flexible
with regards to number of endpoints, FIFO sizes,
transfer types, etc.
While this supports only the device side, for
now, we will add support for Host side (xHCI -
see the updated series Sebastian has sent [1])
and OTG after we have it all stabilized.
[1] http://marc.info/?l=linux-usb&m=131341992020339&w=2
Signed-off-by: Felipe Balbi <balbi@ti.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
2011-08-19 22:10:58 +07:00
|
|
|
}
|
|
|
|
|
|
|
|
pci_set_master(pci);
|
|
|
|
|
2016-10-24 14:29:01 +07:00
|
|
|
dwc = devm_kzalloc(dev, sizeof(*dwc), GFP_KERNEL);
|
|
|
|
if (!dwc)
|
|
|
|
return -ENOMEM;
|
|
|
|
|
|
|
|
dwc->dwc3 = platform_device_alloc("dwc3", PLATFORM_DEVID_AUTO);
|
|
|
|
if (!dwc->dwc3)
|
2014-05-15 19:53:33 +07:00
|
|
|
return -ENOMEM;
|
usb: Introduce DesignWare USB3 DRD Driver
The DesignWare USB3 is a highly
configurable IP Core which can be
instantiated as Dual-Role Device (DRD),
Peripheral Only and Host Only (XHCI)
configurations.
Several other parameters can be configured
like amount of FIFO space, amount of TX and
RX endpoints, amount of Host Interrupters,
etc.
The current driver has been validated with
a virtual model of version 1.73a of that core
and with an FPGA burned with version 1.83a
of the DRD core. We have support for PCIe
bus, which is used on FPGA prototyping, and
for the OMAP5, more adaptation (or glue)
layers can be easily added and the driver
is half prepared to handle any possible
configuration the HW engineer has chosen
considering we have the information on
one of the GHWPARAMS registers to do
runtime checking of certain features.
More runtime checks can, and should, be added
in order to make this driver even more flexible
with regards to number of endpoints, FIFO sizes,
transfer types, etc.
While this supports only the device side, for
now, we will add support for Host side (xHCI -
see the updated series Sebastian has sent [1])
and OTG after we have it all stabilized.
[1] http://marc.info/?l=linux-usb&m=131341992020339&w=2
Signed-off-by: Felipe Balbi <balbi@ti.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
2011-08-19 22:10:58 +07:00
|
|
|
|
|
|
|
memset(res, 0x00, sizeof(struct resource) * ARRAY_SIZE(res));
|
|
|
|
|
|
|
|
res[0].start = pci_resource_start(pci, 0);
|
|
|
|
res[0].end = pci_resource_end(pci, 0);
|
|
|
|
res[0].name = "dwc_usb3";
|
|
|
|
res[0].flags = IORESOURCE_MEM;
|
|
|
|
|
|
|
|
res[1].start = pci->irq;
|
|
|
|
res[1].name = "dwc_usb3";
|
|
|
|
res[1].flags = IORESOURCE_IRQ;
|
|
|
|
|
2016-10-24 14:29:01 +07:00
|
|
|
ret = platform_device_add_resources(dwc->dwc3, res, ARRAY_SIZE(res));
|
usb: Introduce DesignWare USB3 DRD Driver
The DesignWare USB3 is a highly
configurable IP Core which can be
instantiated as Dual-Role Device (DRD),
Peripheral Only and Host Only (XHCI)
configurations.
Several other parameters can be configured
like amount of FIFO space, amount of TX and
RX endpoints, amount of Host Interrupters,
etc.
The current driver has been validated with
a virtual model of version 1.73a of that core
and with an FPGA burned with version 1.83a
of the DRD core. We have support for PCIe
bus, which is used on FPGA prototyping, and
for the OMAP5, more adaptation (or glue)
layers can be easily added and the driver
is half prepared to handle any possible
configuration the HW engineer has chosen
considering we have the information on
one of the GHWPARAMS registers to do
runtime checking of certain features.
More runtime checks can, and should, be added
in order to make this driver even more flexible
with regards to number of endpoints, FIFO sizes,
transfer types, etc.
While this supports only the device side, for
now, we will add support for Host side (xHCI -
see the updated series Sebastian has sent [1])
and OTG after we have it all stabilized.
[1] http://marc.info/?l=linux-usb&m=131341992020339&w=2
Signed-off-by: Felipe Balbi <balbi@ti.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
2011-08-19 22:10:58 +07:00
|
|
|
if (ret) {
|
2012-02-15 16:27:55 +07:00
|
|
|
dev_err(dev, "couldn't add resources to dwc3 device\n");
|
2018-03-20 03:07:35 +07:00
|
|
|
goto err;
|
usb: Introduce DesignWare USB3 DRD Driver
The DesignWare USB3 is a highly
configurable IP Core which can be
instantiated as Dual-Role Device (DRD),
Peripheral Only and Host Only (XHCI)
configurations.
Several other parameters can be configured
like amount of FIFO space, amount of TX and
RX endpoints, amount of Host Interrupters,
etc.
The current driver has been validated with
a virtual model of version 1.73a of that core
and with an FPGA burned with version 1.83a
of the DRD core. We have support for PCIe
bus, which is used on FPGA prototyping, and
for the OMAP5, more adaptation (or glue)
layers can be easily added and the driver
is half prepared to handle any possible
configuration the HW engineer has chosen
considering we have the information on
one of the GHWPARAMS registers to do
runtime checking of certain features.
More runtime checks can, and should, be added
in order to make this driver even more flexible
with regards to number of endpoints, FIFO sizes,
transfer types, etc.
While this supports only the device side, for
now, we will add support for Host side (xHCI -
see the updated series Sebastian has sent [1])
and OTG after we have it all stabilized.
[1] http://marc.info/?l=linux-usb&m=131341992020339&w=2
Signed-off-by: Felipe Balbi <balbi@ti.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
2011-08-19 22:10:58 +07:00
|
|
|
}
|
|
|
|
|
2016-10-24 14:29:01 +07:00
|
|
|
dwc->pci = pci;
|
|
|
|
dwc->dwc3->dev.parent = dev;
|
|
|
|
ACPI_COMPANION_SET(&dwc->dwc3->dev, ACPI_COMPANION(dev));
|
usb: Introduce DesignWare USB3 DRD Driver
The DesignWare USB3 is a highly
configurable IP Core which can be
instantiated as Dual-Role Device (DRD),
Peripheral Only and Host Only (XHCI)
configurations.
Several other parameters can be configured
like amount of FIFO space, amount of TX and
RX endpoints, amount of Host Interrupters,
etc.
The current driver has been validated with
a virtual model of version 1.73a of that core
and with an FPGA burned with version 1.83a
of the DRD core. We have support for PCIe
bus, which is used on FPGA prototyping, and
for the OMAP5, more adaptation (or glue)
layers can be easily added and the driver
is half prepared to handle any possible
configuration the HW engineer has chosen
considering we have the information on
one of the GHWPARAMS registers to do
runtime checking of certain features.
More runtime checks can, and should, be added
in order to make this driver even more flexible
with regards to number of endpoints, FIFO sizes,
transfer types, etc.
While this supports only the device side, for
now, we will add support for Host side (xHCI -
see the updated series Sebastian has sent [1])
and OTG after we have it all stabilized.
[1] http://marc.info/?l=linux-usb&m=131341992020339&w=2
Signed-off-by: Felipe Balbi <balbi@ti.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
2011-08-19 22:10:58 +07:00
|
|
|
|
2018-07-26 18:48:56 +07:00
|
|
|
ret = platform_device_add_properties(dwc->dwc3, p);
|
|
|
|
if (ret < 0)
|
2019-09-30 09:41:45 +07:00
|
|
|
goto err;
|
2018-07-26 18:48:56 +07:00
|
|
|
|
2016-10-24 14:29:01 +07:00
|
|
|
ret = dwc3_pci_quirks(dwc);
|
2016-04-22 15:17:37 +07:00
|
|
|
if (ret)
|
|
|
|
goto err;
|
|
|
|
|
2016-10-24 14:29:01 +07:00
|
|
|
ret = platform_device_add(dwc->dwc3);
|
usb: Introduce DesignWare USB3 DRD Driver
The DesignWare USB3 is a highly
configurable IP Core which can be
instantiated as Dual-Role Device (DRD),
Peripheral Only and Host Only (XHCI)
configurations.
Several other parameters can be configured
like amount of FIFO space, amount of TX and
RX endpoints, amount of Host Interrupters,
etc.
The current driver has been validated with
a virtual model of version 1.73a of that core
and with an FPGA burned with version 1.83a
of the DRD core. We have support for PCIe
bus, which is used on FPGA prototyping, and
for the OMAP5, more adaptation (or glue)
layers can be easily added and the driver
is half prepared to handle any possible
configuration the HW engineer has chosen
considering we have the information on
one of the GHWPARAMS registers to do
runtime checking of certain features.
More runtime checks can, and should, be added
in order to make this driver even more flexible
with regards to number of endpoints, FIFO sizes,
transfer types, etc.
While this supports only the device side, for
now, we will add support for Host side (xHCI -
see the updated series Sebastian has sent [1])
and OTG after we have it all stabilized.
[1] http://marc.info/?l=linux-usb&m=131341992020339&w=2
Signed-off-by: Felipe Balbi <balbi@ti.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
2011-08-19 22:10:58 +07:00
|
|
|
if (ret) {
|
2012-02-15 16:27:55 +07:00
|
|
|
dev_err(dev, "failed to register dwc3 device\n");
|
2015-01-12 19:20:14 +07:00
|
|
|
goto err;
|
usb: Introduce DesignWare USB3 DRD Driver
The DesignWare USB3 is a highly
configurable IP Core which can be
instantiated as Dual-Role Device (DRD),
Peripheral Only and Host Only (XHCI)
configurations.
Several other parameters can be configured
like amount of FIFO space, amount of TX and
RX endpoints, amount of Host Interrupters,
etc.
The current driver has been validated with
a virtual model of version 1.73a of that core
and with an FPGA burned with version 1.83a
of the DRD core. We have support for PCIe
bus, which is used on FPGA prototyping, and
for the OMAP5, more adaptation (or glue)
layers can be easily added and the driver
is half prepared to handle any possible
configuration the HW engineer has chosen
considering we have the information on
one of the GHWPARAMS registers to do
runtime checking of certain features.
More runtime checks can, and should, be added
in order to make this driver even more flexible
with regards to number of endpoints, FIFO sizes,
transfer types, etc.
While this supports only the device side, for
now, we will add support for Host side (xHCI -
see the updated series Sebastian has sent [1])
and OTG after we have it all stabilized.
[1] http://marc.info/?l=linux-usb&m=131341992020339&w=2
Signed-off-by: Felipe Balbi <balbi@ti.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
2011-08-19 22:10:58 +07:00
|
|
|
}
|
|
|
|
|
2016-05-17 14:15:02 +07:00
|
|
|
device_init_wakeup(dev, true);
|
2016-10-24 14:29:01 +07:00
|
|
|
pci_set_drvdata(pci, dwc);
|
2016-05-17 14:15:02 +07:00
|
|
|
pm_runtime_put(dev);
|
2017-09-27 18:19:21 +07:00
|
|
|
#ifdef CONFIG_PM
|
|
|
|
INIT_WORK(&dwc->wakeup_work, dwc3_pci_resume_work);
|
|
|
|
#endif
|
2016-05-17 14:15:02 +07:00
|
|
|
|
usb: Introduce DesignWare USB3 DRD Driver
The DesignWare USB3 is a highly
configurable IP Core which can be
instantiated as Dual-Role Device (DRD),
Peripheral Only and Host Only (XHCI)
configurations.
Several other parameters can be configured
like amount of FIFO space, amount of TX and
RX endpoints, amount of Host Interrupters,
etc.
The current driver has been validated with
a virtual model of version 1.73a of that core
and with an FPGA burned with version 1.83a
of the DRD core. We have support for PCIe
bus, which is used on FPGA prototyping, and
for the OMAP5, more adaptation (or glue)
layers can be easily added and the driver
is half prepared to handle any possible
configuration the HW engineer has chosen
considering we have the information on
one of the GHWPARAMS registers to do
runtime checking of certain features.
More runtime checks can, and should, be added
in order to make this driver even more flexible
with regards to number of endpoints, FIFO sizes,
transfer types, etc.
While this supports only the device side, for
now, we will add support for Host side (xHCI -
see the updated series Sebastian has sent [1])
and OTG after we have it all stabilized.
[1] http://marc.info/?l=linux-usb&m=131341992020339&w=2
Signed-off-by: Felipe Balbi <balbi@ti.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
2011-08-19 22:10:58 +07:00
|
|
|
return 0;
|
2015-01-12 19:20:14 +07:00
|
|
|
err:
|
2016-10-24 14:29:01 +07:00
|
|
|
platform_device_put(dwc->dwc3);
|
usb: Introduce DesignWare USB3 DRD Driver
The DesignWare USB3 is a highly
configurable IP Core which can be
instantiated as Dual-Role Device (DRD),
Peripheral Only and Host Only (XHCI)
configurations.
Several other parameters can be configured
like amount of FIFO space, amount of TX and
RX endpoints, amount of Host Interrupters,
etc.
The current driver has been validated with
a virtual model of version 1.73a of that core
and with an FPGA burned with version 1.83a
of the DRD core. We have support for PCIe
bus, which is used on FPGA prototyping, and
for the OMAP5, more adaptation (or glue)
layers can be easily added and the driver
is half prepared to handle any possible
configuration the HW engineer has chosen
considering we have the information on
one of the GHWPARAMS registers to do
runtime checking of certain features.
More runtime checks can, and should, be added
in order to make this driver even more flexible
with regards to number of endpoints, FIFO sizes,
transfer types, etc.
While this supports only the device side, for
now, we will add support for Host side (xHCI -
see the updated series Sebastian has sent [1])
and OTG after we have it all stabilized.
[1] http://marc.info/?l=linux-usb&m=131341992020339&w=2
Signed-off-by: Felipe Balbi <balbi@ti.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
2011-08-19 22:10:58 +07:00
|
|
|
return ret;
|
|
|
|
}
|
|
|
|
|
2012-11-20 01:26:20 +07:00
|
|
|
static void dwc3_pci_remove(struct pci_dev *pci)
|
usb: Introduce DesignWare USB3 DRD Driver
The DesignWare USB3 is a highly
configurable IP Core which can be
instantiated as Dual-Role Device (DRD),
Peripheral Only and Host Only (XHCI)
configurations.
Several other parameters can be configured
like amount of FIFO space, amount of TX and
RX endpoints, amount of Host Interrupters,
etc.
The current driver has been validated with
a virtual model of version 1.73a of that core
and with an FPGA burned with version 1.83a
of the DRD core. We have support for PCIe
bus, which is used on FPGA prototyping, and
for the OMAP5, more adaptation (or glue)
layers can be easily added and the driver
is half prepared to handle any possible
configuration the HW engineer has chosen
considering we have the information on
one of the GHWPARAMS registers to do
runtime checking of certain features.
More runtime checks can, and should, be added
in order to make this driver even more flexible
with regards to number of endpoints, FIFO sizes,
transfer types, etc.
While this supports only the device side, for
now, we will add support for Host side (xHCI -
see the updated series Sebastian has sent [1])
and OTG after we have it all stabilized.
[1] http://marc.info/?l=linux-usb&m=131341992020339&w=2
Signed-off-by: Felipe Balbi <balbi@ti.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
2011-08-19 22:10:58 +07:00
|
|
|
{
|
2016-10-24 14:29:01 +07:00
|
|
|
struct dwc3_pci *dwc = pci_get_drvdata(pci);
|
2018-10-18 01:40:26 +07:00
|
|
|
struct pci_dev *pdev = dwc->pci;
|
2016-10-24 14:29:01 +07:00
|
|
|
|
2018-10-18 01:40:26 +07:00
|
|
|
if (pdev->device == PCI_DEVICE_ID_INTEL_BYT)
|
|
|
|
gpiod_remove_lookup_table(&platform_bytcr_gpios);
|
2017-09-27 18:19:21 +07:00
|
|
|
#ifdef CONFIG_PM
|
|
|
|
cancel_work_sync(&dwc->wakeup_work);
|
|
|
|
#endif
|
2016-05-17 14:15:02 +07:00
|
|
|
device_init_wakeup(&pci->dev, false);
|
|
|
|
pm_runtime_get(&pci->dev);
|
2016-10-24 14:29:01 +07:00
|
|
|
platform_device_unregister(dwc->dwc3);
|
usb: Introduce DesignWare USB3 DRD Driver
The DesignWare USB3 is a highly
configurable IP Core which can be
instantiated as Dual-Role Device (DRD),
Peripheral Only and Host Only (XHCI)
configurations.
Several other parameters can be configured
like amount of FIFO space, amount of TX and
RX endpoints, amount of Host Interrupters,
etc.
The current driver has been validated with
a virtual model of version 1.73a of that core
and with an FPGA burned with version 1.83a
of the DRD core. We have support for PCIe
bus, which is used on FPGA prototyping, and
for the OMAP5, more adaptation (or glue)
layers can be easily added and the driver
is half prepared to handle any possible
configuration the HW engineer has chosen
considering we have the information on
one of the GHWPARAMS registers to do
runtime checking of certain features.
More runtime checks can, and should, be added
in order to make this driver even more flexible
with regards to number of endpoints, FIFO sizes,
transfer types, etc.
While this supports only the device side, for
now, we will add support for Host side (xHCI -
see the updated series Sebastian has sent [1])
and OTG after we have it all stabilized.
[1] http://marc.info/?l=linux-usb&m=131341992020339&w=2
Signed-off-by: Felipe Balbi <balbi@ti.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
2011-08-19 22:10:58 +07:00
|
|
|
}
|
|
|
|
|
2013-11-28 12:15:46 +07:00
|
|
|
static const struct pci_device_id dwc3_pci_id_table[] = {
|
2018-07-26 18:48:56 +07:00
|
|
|
{ PCI_VDEVICE(INTEL, PCI_DEVICE_ID_INTEL_BSW),
|
|
|
|
(kernel_ulong_t) &dwc3_pci_intel_properties },
|
|
|
|
|
|
|
|
{ PCI_VDEVICE(INTEL, PCI_DEVICE_ID_INTEL_BYT),
|
|
|
|
(kernel_ulong_t) &dwc3_pci_intel_properties, },
|
|
|
|
|
|
|
|
{ PCI_VDEVICE(INTEL, PCI_DEVICE_ID_INTEL_MRFLD),
|
2018-07-26 18:48:57 +07:00
|
|
|
(kernel_ulong_t) &dwc3_pci_mrfld_properties, },
|
2018-07-26 18:48:56 +07:00
|
|
|
|
2019-12-12 16:37:13 +07:00
|
|
|
{ PCI_VDEVICE(INTEL, PCI_DEVICE_ID_INTEL_CMLLP),
|
|
|
|
(kernel_ulong_t) &dwc3_pci_intel_properties, },
|
|
|
|
|
2019-01-31 16:04:19 +07:00
|
|
|
{ PCI_VDEVICE(INTEL, PCI_DEVICE_ID_INTEL_CMLH),
|
|
|
|
(kernel_ulong_t) &dwc3_pci_intel_properties, },
|
|
|
|
|
2018-07-26 18:48:56 +07:00
|
|
|
{ PCI_VDEVICE(INTEL, PCI_DEVICE_ID_INTEL_SPTLP),
|
|
|
|
(kernel_ulong_t) &dwc3_pci_intel_properties, },
|
|
|
|
|
|
|
|
{ PCI_VDEVICE(INTEL, PCI_DEVICE_ID_INTEL_SPTH),
|
|
|
|
(kernel_ulong_t) &dwc3_pci_intel_properties, },
|
|
|
|
|
|
|
|
{ PCI_VDEVICE(INTEL, PCI_DEVICE_ID_INTEL_BXT),
|
|
|
|
(kernel_ulong_t) &dwc3_pci_intel_properties, },
|
|
|
|
|
|
|
|
{ PCI_VDEVICE(INTEL, PCI_DEVICE_ID_INTEL_BXT_M),
|
|
|
|
(kernel_ulong_t) &dwc3_pci_intel_properties, },
|
|
|
|
|
|
|
|
{ PCI_VDEVICE(INTEL, PCI_DEVICE_ID_INTEL_APL),
|
|
|
|
(kernel_ulong_t) &dwc3_pci_intel_properties, },
|
|
|
|
|
|
|
|
{ PCI_VDEVICE(INTEL, PCI_DEVICE_ID_INTEL_KBP),
|
|
|
|
(kernel_ulong_t) &dwc3_pci_intel_properties, },
|
|
|
|
|
|
|
|
{ PCI_VDEVICE(INTEL, PCI_DEVICE_ID_INTEL_GLK),
|
|
|
|
(kernel_ulong_t) &dwc3_pci_intel_properties, },
|
|
|
|
|
|
|
|
{ PCI_VDEVICE(INTEL, PCI_DEVICE_ID_INTEL_CNPLP),
|
|
|
|
(kernel_ulong_t) &dwc3_pci_intel_properties, },
|
|
|
|
|
|
|
|
{ PCI_VDEVICE(INTEL, PCI_DEVICE_ID_INTEL_CNPH),
|
|
|
|
(kernel_ulong_t) &dwc3_pci_intel_properties, },
|
|
|
|
|
2020-01-17 16:30:33 +07:00
|
|
|
{ PCI_VDEVICE(INTEL, PCI_DEVICE_ID_INTEL_CNPV),
|
|
|
|
(kernel_ulong_t) &dwc3_pci_intel_properties, },
|
|
|
|
|
2018-07-26 18:48:56 +07:00
|
|
|
{ PCI_VDEVICE(INTEL, PCI_DEVICE_ID_INTEL_ICLLP),
|
|
|
|
(kernel_ulong_t) &dwc3_pci_intel_properties, },
|
|
|
|
|
2018-06-11 15:21:12 +07:00
|
|
|
{ PCI_VDEVICE(INTEL, PCI_DEVICE_ID_INTEL_EHLLP),
|
|
|
|
(kernel_ulong_t) &dwc3_pci_intel_properties, },
|
|
|
|
|
2017-12-13 21:03:22 +07:00
|
|
|
{ PCI_VDEVICE(INTEL, PCI_DEVICE_ID_INTEL_TGPLP),
|
|
|
|
(kernel_ulong_t) &dwc3_pci_intel_properties, },
|
|
|
|
|
2018-07-26 18:48:56 +07:00
|
|
|
{ PCI_VDEVICE(AMD, PCI_DEVICE_ID_AMD_NL_USB),
|
|
|
|
(kernel_ulong_t) &dwc3_pci_amd_properties, },
|
usb: Introduce DesignWare USB3 DRD Driver
The DesignWare USB3 is a highly
configurable IP Core which can be
instantiated as Dual-Role Device (DRD),
Peripheral Only and Host Only (XHCI)
configurations.
Several other parameters can be configured
like amount of FIFO space, amount of TX and
RX endpoints, amount of Host Interrupters,
etc.
The current driver has been validated with
a virtual model of version 1.73a of that core
and with an FPGA burned with version 1.83a
of the DRD core. We have support for PCIe
bus, which is used on FPGA prototyping, and
for the OMAP5, more adaptation (or glue)
layers can be easily added and the driver
is half prepared to handle any possible
configuration the HW engineer has chosen
considering we have the information on
one of the GHWPARAMS registers to do
runtime checking of certain features.
More runtime checks can, and should, be added
in order to make this driver even more flexible
with regards to number of endpoints, FIFO sizes,
transfer types, etc.
While this supports only the device side, for
now, we will add support for Host side (xHCI -
see the updated series Sebastian has sent [1])
and OTG after we have it all stabilized.
[1] http://marc.info/?l=linux-usb&m=131341992020339&w=2
Signed-off-by: Felipe Balbi <balbi@ti.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
2011-08-19 22:10:58 +07:00
|
|
|
{ } /* Terminating Entry */
|
|
|
|
};
|
|
|
|
MODULE_DEVICE_TABLE(pci, dwc3_pci_id_table);
|
|
|
|
|
2016-11-16 18:16:22 +07:00
|
|
|
#if defined(CONFIG_PM) || defined(CONFIG_PM_SLEEP)
|
|
|
|
static int dwc3_pci_dsm(struct dwc3_pci *dwc, int param)
|
|
|
|
{
|
|
|
|
union acpi_object *obj;
|
|
|
|
union acpi_object tmp;
|
|
|
|
union acpi_object argv4 = ACPI_INIT_DSM_ARGV4(1, &tmp);
|
|
|
|
|
|
|
|
if (!dwc->has_dsm_for_pm)
|
|
|
|
return 0;
|
|
|
|
|
|
|
|
tmp.type = ACPI_TYPE_INTEGER;
|
|
|
|
tmp.integer.value = param;
|
|
|
|
|
2017-06-05 23:40:46 +07:00
|
|
|
obj = acpi_evaluate_dsm(ACPI_HANDLE(&dwc->pci->dev), &dwc->guid,
|
2016-11-16 18:16:22 +07:00
|
|
|
1, PCI_INTEL_BXT_FUNC_PMU_PWR, &argv4);
|
|
|
|
if (!obj) {
|
|
|
|
dev_err(&dwc->pci->dev, "failed to evaluate _DSM\n");
|
|
|
|
return -EIO;
|
|
|
|
}
|
|
|
|
|
|
|
|
ACPI_FREE(obj);
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
#endif /* CONFIG_PM || CONFIG_PM_SLEEP */
|
|
|
|
|
2016-05-17 14:15:02 +07:00
|
|
|
#ifdef CONFIG_PM
|
|
|
|
static int dwc3_pci_runtime_suspend(struct device *dev)
|
|
|
|
{
|
2016-10-24 14:40:18 +07:00
|
|
|
struct dwc3_pci *dwc = dev_get_drvdata(dev);
|
|
|
|
|
2017-06-24 06:58:53 +07:00
|
|
|
if (device_can_wakeup(dev))
|
2016-10-24 14:40:18 +07:00
|
|
|
return dwc3_pci_dsm(dwc, PCI_INTEL_BXT_STATE_D3);
|
2016-05-17 14:15:02 +07:00
|
|
|
|
|
|
|
return -EBUSY;
|
|
|
|
}
|
|
|
|
|
2016-07-28 14:16:12 +07:00
|
|
|
static int dwc3_pci_runtime_resume(struct device *dev)
|
|
|
|
{
|
2016-10-24 14:29:01 +07:00
|
|
|
struct dwc3_pci *dwc = dev_get_drvdata(dev);
|
2016-10-24 14:40:18 +07:00
|
|
|
int ret;
|
|
|
|
|
|
|
|
ret = dwc3_pci_dsm(dwc, PCI_INTEL_BXT_STATE_D0);
|
|
|
|
if (ret)
|
|
|
|
return ret;
|
2016-07-28 14:16:12 +07:00
|
|
|
|
2017-09-27 18:19:21 +07:00
|
|
|
queue_work(pm_wq, &dwc->wakeup_work);
|
|
|
|
|
|
|
|
return 0;
|
2016-07-28 14:16:12 +07:00
|
|
|
}
|
2016-09-07 17:39:37 +07:00
|
|
|
#endif /* CONFIG_PM */
|
2016-07-28 14:16:12 +07:00
|
|
|
|
2016-09-07 17:39:37 +07:00
|
|
|
#ifdef CONFIG_PM_SLEEP
|
2016-10-24 14:40:18 +07:00
|
|
|
static int dwc3_pci_suspend(struct device *dev)
|
2016-05-17 14:15:02 +07:00
|
|
|
{
|
2016-10-24 14:40:18 +07:00
|
|
|
struct dwc3_pci *dwc = dev_get_drvdata(dev);
|
|
|
|
|
|
|
|
return dwc3_pci_dsm(dwc, PCI_INTEL_BXT_STATE_D3);
|
|
|
|
}
|
|
|
|
|
|
|
|
static int dwc3_pci_resume(struct device *dev)
|
|
|
|
{
|
|
|
|
struct dwc3_pci *dwc = dev_get_drvdata(dev);
|
|
|
|
|
|
|
|
return dwc3_pci_dsm(dwc, PCI_INTEL_BXT_STATE_D0);
|
2016-05-17 14:15:02 +07:00
|
|
|
}
|
2016-09-07 17:39:37 +07:00
|
|
|
#endif /* CONFIG_PM_SLEEP */
|
2016-05-17 14:15:02 +07:00
|
|
|
|
2017-08-08 18:20:16 +07:00
|
|
|
static const struct dev_pm_ops dwc3_pci_dev_pm_ops = {
|
2016-10-24 14:40:18 +07:00
|
|
|
SET_SYSTEM_SLEEP_PM_OPS(dwc3_pci_suspend, dwc3_pci_resume)
|
2016-07-28 14:16:12 +07:00
|
|
|
SET_RUNTIME_PM_OPS(dwc3_pci_runtime_suspend, dwc3_pci_runtime_resume,
|
2016-05-17 14:15:02 +07:00
|
|
|
NULL)
|
|
|
|
};
|
|
|
|
|
usb: Introduce DesignWare USB3 DRD Driver
The DesignWare USB3 is a highly
configurable IP Core which can be
instantiated as Dual-Role Device (DRD),
Peripheral Only and Host Only (XHCI)
configurations.
Several other parameters can be configured
like amount of FIFO space, amount of TX and
RX endpoints, amount of Host Interrupters,
etc.
The current driver has been validated with
a virtual model of version 1.73a of that core
and with an FPGA burned with version 1.83a
of the DRD core. We have support for PCIe
bus, which is used on FPGA prototyping, and
for the OMAP5, more adaptation (or glue)
layers can be easily added and the driver
is half prepared to handle any possible
configuration the HW engineer has chosen
considering we have the information on
one of the GHWPARAMS registers to do
runtime checking of certain features.
More runtime checks can, and should, be added
in order to make this driver even more flexible
with regards to number of endpoints, FIFO sizes,
transfer types, etc.
While this supports only the device side, for
now, we will add support for Host side (xHCI -
see the updated series Sebastian has sent [1])
and OTG after we have it all stabilized.
[1] http://marc.info/?l=linux-usb&m=131341992020339&w=2
Signed-off-by: Felipe Balbi <balbi@ti.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
2011-08-19 22:10:58 +07:00
|
|
|
static struct pci_driver dwc3_pci_driver = {
|
2011-10-12 14:44:56 +07:00
|
|
|
.name = "dwc3-pci",
|
usb: Introduce DesignWare USB3 DRD Driver
The DesignWare USB3 is a highly
configurable IP Core which can be
instantiated as Dual-Role Device (DRD),
Peripheral Only and Host Only (XHCI)
configurations.
Several other parameters can be configured
like amount of FIFO space, amount of TX and
RX endpoints, amount of Host Interrupters,
etc.
The current driver has been validated with
a virtual model of version 1.73a of that core
and with an FPGA burned with version 1.83a
of the DRD core. We have support for PCIe
bus, which is used on FPGA prototyping, and
for the OMAP5, more adaptation (or glue)
layers can be easily added and the driver
is half prepared to handle any possible
configuration the HW engineer has chosen
considering we have the information on
one of the GHWPARAMS registers to do
runtime checking of certain features.
More runtime checks can, and should, be added
in order to make this driver even more flexible
with regards to number of endpoints, FIFO sizes,
transfer types, etc.
While this supports only the device side, for
now, we will add support for Host side (xHCI -
see the updated series Sebastian has sent [1])
and OTG after we have it all stabilized.
[1] http://marc.info/?l=linux-usb&m=131341992020339&w=2
Signed-off-by: Felipe Balbi <balbi@ti.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
2011-08-19 22:10:58 +07:00
|
|
|
.id_table = dwc3_pci_id_table,
|
|
|
|
.probe = dwc3_pci_probe,
|
2012-11-20 01:21:08 +07:00
|
|
|
.remove = dwc3_pci_remove,
|
2016-05-17 14:15:02 +07:00
|
|
|
.driver = {
|
|
|
|
.pm = &dwc3_pci_dev_pm_ops,
|
|
|
|
}
|
usb: Introduce DesignWare USB3 DRD Driver
The DesignWare USB3 is a highly
configurable IP Core which can be
instantiated as Dual-Role Device (DRD),
Peripheral Only and Host Only (XHCI)
configurations.
Several other parameters can be configured
like amount of FIFO space, amount of TX and
RX endpoints, amount of Host Interrupters,
etc.
The current driver has been validated with
a virtual model of version 1.73a of that core
and with an FPGA burned with version 1.83a
of the DRD core. We have support for PCIe
bus, which is used on FPGA prototyping, and
for the OMAP5, more adaptation (or glue)
layers can be easily added and the driver
is half prepared to handle any possible
configuration the HW engineer has chosen
considering we have the information on
one of the GHWPARAMS registers to do
runtime checking of certain features.
More runtime checks can, and should, be added
in order to make this driver even more flexible
with regards to number of endpoints, FIFO sizes,
transfer types, etc.
While this supports only the device side, for
now, we will add support for Host side (xHCI -
see the updated series Sebastian has sent [1])
and OTG after we have it all stabilized.
[1] http://marc.info/?l=linux-usb&m=131341992020339&w=2
Signed-off-by: Felipe Balbi <balbi@ti.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
2011-08-19 22:10:58 +07:00
|
|
|
};
|
|
|
|
|
|
|
|
MODULE_AUTHOR("Felipe Balbi <balbi@ti.com>");
|
2013-06-30 18:15:11 +07:00
|
|
|
MODULE_LICENSE("GPL v2");
|
usb: Introduce DesignWare USB3 DRD Driver
The DesignWare USB3 is a highly
configurable IP Core which can be
instantiated as Dual-Role Device (DRD),
Peripheral Only and Host Only (XHCI)
configurations.
Several other parameters can be configured
like amount of FIFO space, amount of TX and
RX endpoints, amount of Host Interrupters,
etc.
The current driver has been validated with
a virtual model of version 1.73a of that core
and with an FPGA burned with version 1.83a
of the DRD core. We have support for PCIe
bus, which is used on FPGA prototyping, and
for the OMAP5, more adaptation (or glue)
layers can be easily added and the driver
is half prepared to handle any possible
configuration the HW engineer has chosen
considering we have the information on
one of the GHWPARAMS registers to do
runtime checking of certain features.
More runtime checks can, and should, be added
in order to make this driver even more flexible
with regards to number of endpoints, FIFO sizes,
transfer types, etc.
While this supports only the device side, for
now, we will add support for Host side (xHCI -
see the updated series Sebastian has sent [1])
and OTG after we have it all stabilized.
[1] http://marc.info/?l=linux-usb&m=131341992020339&w=2
Signed-off-by: Felipe Balbi <balbi@ti.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
2011-08-19 22:10:58 +07:00
|
|
|
MODULE_DESCRIPTION("DesignWare USB3 PCI Glue Layer");
|
|
|
|
|
2011-11-19 01:14:24 +07:00
|
|
|
module_pci_driver(dwc3_pci_driver);
|