3d82904559
This patch introduces the main part of Cadence USBSSP DRD driver to Linux kernel. To reduce the patch size a little bit, the header file gadget.h was intentionally added as separate patch. The Cadence USBSSP DRD Controller is a highly configurable IP Core which can be instantiated as Dual-Role Device (DRD), Peripheral Only and Host Only (XHCI)configurations. The current driver has been validated with FPGA platform. We have support for PCIe bus, which is used on FPGA prototyping. The host side of USBSS DRD controller is compliant with XHCI. The architecture for device side is almost the same as for host side, and most of the XHCI specification can be used to understand how this controller operates. Signed-off-by: Pawel Laszczak <pawell@cadence.com> Signed-off-by: Peter Chen <peter.chen@nxp.com>
38 lines
736 B
C
38 lines
736 B
C
/* SPDX-License-Identifier: GPL-2.0 */
|
|
/*
|
|
* Cadence USBSS and USBSSP DRD Driver - Gadget Export APIs.
|
|
*
|
|
* Copyright (C) 2017 NXP
|
|
* Copyright (C) 2017-2018 NXP
|
|
*
|
|
* Authors: Peter Chen <peter.chen@nxp.com>
|
|
*/
|
|
#ifndef __LINUX_CDNS3_GADGET_EXPORT
|
|
#define __LINUX_CDNS3_GADGET_EXPORT
|
|
|
|
#if IS_ENABLED(CONFIG_USB_CDNSP_GADGET)
|
|
|
|
int cdnsp_gadget_init(struct cdns *cdns);
|
|
#else
|
|
|
|
static inline int cdnsp_gadget_init(struct cdns *cdns)
|
|
{
|
|
return -ENXIO;
|
|
}
|
|
|
|
#endif /* CONFIG_USB_CDNSP_GADGET */
|
|
|
|
#if IS_ENABLED(CONFIG_USB_CDNS3_GADGET)
|
|
|
|
int cdns3_gadget_init(struct cdns *cdns);
|
|
#else
|
|
|
|
static inline int cdns3_gadget_init(struct cdns *cdns)
|
|
{
|
|
return -ENXIO;
|
|
}
|
|
|
|
#endif /* CONFIG_USB_CDNS3_GADGET */
|
|
|
|
#endif /* __LINUX_CDNS3_GADGET_EXPORT */
|