|
@@ -27,6 +27,11 @@
|
|
|
#include <asm/gpio.h>
|
|
|
#include <asm/mach-types.h>
|
|
|
#include <linux/mtd/nand.h>
|
|
|
+#include <asm/omap_musb.h>
|
|
|
+#include <asm/errno.h>
|
|
|
+#include <linux/usb/ch9.h>
|
|
|
+#include <linux/usb/gadget.h>
|
|
|
+#include <linux/usb/musb.h>
|
|
|
#include "omap3logic.h"
|
|
|
|
|
|
DECLARE_GLOBAL_DATA_PTR;
|
|
@@ -105,6 +110,34 @@ void get_board_mem_timings(struct board_sdrc_timings *timings)
|
|
|
}
|
|
|
#endif
|
|
|
|
|
|
+#ifdef CONFIG_USB_MUSB_OMAP2PLUS
|
|
|
+static struct musb_hdrc_config musb_config = {
|
|
|
+ .multipoint = 1,
|
|
|
+ .dyn_fifo = 1,
|
|
|
+ .num_eps = 16,
|
|
|
+ .ram_bits = 12,
|
|
|
+};
|
|
|
+
|
|
|
+static struct omap_musb_board_data musb_board_data = {
|
|
|
+ .interface_type = MUSB_INTERFACE_ULPI,
|
|
|
+};
|
|
|
+
|
|
|
+static struct musb_hdrc_platform_data musb_plat = {
|
|
|
+#if defined(CONFIG_USB_MUSB_HOST)
|
|
|
+ .mode = MUSB_HOST,
|
|
|
+#elif defined(CONFIG_USB_MUSB_GADGET)
|
|
|
+ .mode = MUSB_PERIPHERAL,
|
|
|
+#else
|
|
|
+#error "Please define either CONFIG_USB_MUSB_HOST or CONFIG_USB_MUSB_GADGET"
|
|
|
+#endif
|
|
|
+ .config = &musb_config,
|
|
|
+ .power = 100,
|
|
|
+ .platform_ops = &omap2430_ops,
|
|
|
+ .board_data = &musb_board_data,
|
|
|
+};
|
|
|
+#endif
|
|
|
+
|
|
|
+
|
|
|
/*
|
|
|
* Routine: misc_init_r
|
|
|
* Description: Configure board specific parts
|
|
@@ -126,6 +159,10 @@ int misc_init_r(void)
|
|
|
omap_die_id_display();
|
|
|
putc('\n');
|
|
|
|
|
|
+#ifdef CONFIG_USB_MUSB_OMAP2PLUS
|
|
|
+ musb_register(&musb_plat, &musb_board_data, (void *)MUSB_BASE);
|
|
|
+#endif
|
|
|
+
|
|
|
return 0;
|
|
|
}
|
|
|
|