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=2Signed-off-by: Felipe Balbi <balbi@ti.com> Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
Showing
Documentation/usb/dwc3.txt
0 → 100644
drivers/usb/dwc3/Kconfig
0 → 100644
drivers/usb/dwc3/Makefile
0 → 100644
drivers/usb/dwc3/core.c
0 → 100644
This diff is collapsed.
drivers/usb/dwc3/core.h
0 → 100644
This diff is collapsed.
drivers/usb/dwc3/debug.h
0 → 100644
drivers/usb/dwc3/debugfs.c
0 → 100644
This diff is collapsed.
drivers/usb/dwc3/dwc3-omap.c
0 → 100644
This diff is collapsed.
drivers/usb/dwc3/dwc3-pci.c
0 → 100644
drivers/usb/dwc3/ep0.c
0 → 100644
This diff is collapsed.
drivers/usb/dwc3/gadget.c
0 → 100644
This diff is collapsed.
drivers/usb/dwc3/gadget.h
0 → 100644
drivers/usb/dwc3/io.h
0 → 100644