Commit fb00bda705cd983bc261fba66ca4b7f5f056fdeb

Authored by Peng Fan
Committed by Stefano Babic
1 parent 5a3d63c5cd

imx:mx6qarm2 add board level support for usb

Add pinmux settings and implement board_ehci_hcd_init

Signed-off-by: Peng Fan <Peng.Fan@freescale.com>

Showing 2 changed files with 56 additions and 0 deletions Side-by-side Diff

board/freescale/mx6qarm2/mx6qarm2.c
... ... @@ -16,6 +16,7 @@
16 16 #include <fsl_esdhc.h>
17 17 #include <miiphy.h>
18 18 #include <netdev.h>
  19 +#include <usb.h>
19 20  
20 21 DECLARE_GLOBAL_DATA_PTR;
21 22  
... ... @@ -213,6 +214,43 @@
213 214 return 0;
214 215 }
215 216  
  217 +#ifdef CONFIG_USB_EHCI_MX6
  218 +#define USB_OTHERREGS_OFFSET 0x800
  219 +#define UCTRL_PWR_POL (1 << 9)
  220 +
  221 +static iomux_v3_cfg_t const usb_otg_pads[] = {
  222 + MX6_PAD_EIM_D22__USB_OTG_PWR | MUX_PAD_CTRL(NO_PAD_CTRL),
  223 + MX6_PAD_GPIO_1__USB_OTG_ID | MUX_PAD_CTRL(NO_PAD_CTRL),
  224 +};
  225 +
  226 +static void setup_usb(void)
  227 +{
  228 + imx_iomux_v3_setup_multiple_pads(usb_otg_pads,
  229 + ARRAY_SIZE(usb_otg_pads));
  230 +
  231 + /*
  232 + * set daisy chain for otg_pin_id on 6q.
  233 + * for 6dl, this bit is reserved
  234 + */
  235 + imx_iomux_set_gpr_register(1, 13, 1, 1);
  236 +}
  237 +
  238 +int board_ehci_hcd_init(int port)
  239 +{
  240 + u32 *usbnc_usb_ctrl;
  241 +
  242 + if (port > 0)
  243 + return -EINVAL;
  244 +
  245 + usbnc_usb_ctrl = (u32 *)(USB_BASE_ADDR + USB_OTHERREGS_OFFSET +
  246 + port * 4);
  247 +
  248 + setbits_le32(usbnc_usb_ctrl, UCTRL_PWR_POL);
  249 +
  250 + return 0;
  251 +}
  252 +#endif
  253 +
216 254 int board_early_init_f(void)
217 255 {
218 256 setup_iomux_uart();
... ... @@ -225,6 +263,10 @@
225 263 {
226 264 /* address of boot parameters */
227 265 gd->bd->bi_boot_params = PHYS_SDRAM + 0x100;
  266 +
  267 +#ifdef CONFIG_USB_EHCI_MX6
  268 + setup_usb();
  269 +#endif
228 270  
229 271 return 0;
230 272 }
include/configs/mx6qarm2.h
... ... @@ -189,5 +189,19 @@
189 189 #define CONFIG_OF_LIBFDT
190 190 #define CONFIG_CMD_BOOTZ
191 191  
  192 +/* USB Configs */
  193 +#define CONFIG_CMD_USB
  194 +#ifdef CONFIG_CMD_USB
  195 +#define CONFIG_USB_EHCI
  196 +#define CONFIG_USB_EHCI_MX6
  197 +#define CONFIG_USB_STORAGE
  198 +#define CONFIG_EHCI_HCD_INIT_AFTER_RESET
  199 +#define CONFIG_USB_HOST_ETHER
  200 +#define CONFIG_USB_ETHER_ASIX
  201 +#define CONFIG_MXC_USB_PORTSC (PORT_PTS_UTMI | PORT_PTS_PTW)
  202 +#define CONFIG_MXC_USB_FLAGS 0
  203 +#define CONFIG_USB_MAX_CONTROLLER_COUNT 1
  204 +#endif
  205 +
192 206 #endif /* __CONFIG_H */