This patch add board_usb_init() and interrupt callback for dwc3 gadget. Signed-off-by: Kever Yang <kever.y...@rock-chips.com> ---
Changes in v4: - parse DT for quirk, base address and maximum speed Changes in v3: - remove utmi width DT parse from borad init Changes in v2: - parse dt for utmi width board/rockchip/evb_rk3399/evb-rk3399.c | 51 ++++++++++++++++++++++++++++++++++ 1 file changed, 51 insertions(+) diff --git a/board/rockchip/evb_rk3399/evb-rk3399.c b/board/rockchip/evb_rk3399/evb-rk3399.c index d394276..58bfa78 100644 --- a/board/rockchip/evb_rk3399/evb-rk3399.c +++ b/board/rockchip/evb_rk3399/evb-rk3399.c @@ -7,6 +7,8 @@ #include <dm.h> #include <dm/pinctrl.h> #include <asm/arch/periph.h> +#include <usb.h> +#include <dwc3-uboot.h> DECLARE_GLOBAL_DATA_PTR; @@ -54,3 +56,52 @@ void dram_init_banksize(void) gd->bd->bi_dram[0].start = 0x200000; gd->bd->bi_dram[0].size = 0x80000000; } + +#ifdef CONFIG_USB_DWC3 +static struct dwc3_device dwc3_device_data = { + .index = 0, +}; + +int usb_gadget_handle_interrupts(void) +{ + dwc3_uboot_handle_interrupt(0); + return 0; +} + +int board_usb_init(int index, enum usb_init_type init) +{ + const void *blob = gd->fdt_blob; + int node; + const char *string; + + node = fdt_node_offset_by_compatible(blob, -1, + "rockchip,rk3399-xhci"); + if (node < 0) { + debug("%s dwc3 node not found\n", __func__); + } else { + dwc3_device_data.base = fdtdec_get_addr(blob, node, "reg"); + dwc3_device_data.dis_u2_susphy_quirk = + fdtdec_get_int(blob, node, + "snps,dis-u2-susphy-quirk", -1); + + string = fdt_getprop(blob, node, "maximum-speed", NULL); + if (string) { + if (0 == strcmp(string, "super-speed")) + dwc3_device_data.maximum_speed = USB_SPEED_SUPER; + else if (0 == strcmp(string, "high-speed")) + dwc3_device_data.maximum_speed = USB_SPEED_HIGH; + else if (0 == strcmp(string, "full-speed")) + dwc3_device_data.maximum_speed = USB_SPEED_FULL; + else + debug("%s: Cannot decode speed'%s'\n", __func__, + string); + } else { + dwc3_device_data.maximum_speed = USB_SPEED_HIGH; + } + /* Hardcode controller in peripheral mode */ + dwc3_device_data.dr_mode = USB_DR_MODE_PERIPHERAL; + } + + return dwc3_uboot_init(&dwc3_device_data); +} +#endif -- 1.9.1 _______________________________________________ U-Boot mailing list U-Boot@lists.denx.de http://lists.denx.de/mailman/listinfo/u-boot