platform-fsl-usb2-udc.c 1.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657
  1. /*
  2. * Copyright (C) 2010 Pengutronix
  3. * Uwe Kleine-Koenig <u.kleine-koenig@pengutronix.de>
  4. *
  5. * This program is free software; you can redistribute it and/or modify it under
  6. * the terms of the GNU General Public License version 2 as published by the
  7. * Free Software Foundation.
  8. */
  9. #include <linux/dma-mapping.h>
  10. #include <mach/hardware.h>
  11. #include <mach/devices-common.h>
  12. #define imx_fsl_usb2_udc_data_entry_single(soc) \
  13. { \
  14. .iobase = soc ## _USB_OTG_BASE_ADDR, \
  15. .irq = soc ## _INT_USB_OTG, \
  16. }
  17. #ifdef CONFIG_SOC_IMX25
  18. const struct imx_fsl_usb2_udc_data imx25_fsl_usb2_udc_data __initconst =
  19. imx_fsl_usb2_udc_data_entry_single(MX25);
  20. #endif /* ifdef CONFIG_SOC_IMX25 */
  21. #ifdef CONFIG_SOC_IMX27
  22. const struct imx_fsl_usb2_udc_data imx27_fsl_usb2_udc_data __initconst =
  23. imx_fsl_usb2_udc_data_entry_single(MX27);
  24. #endif /* ifdef CONFIG_SOC_IMX27 */
  25. #ifdef CONFIG_SOC_IMX31
  26. const struct imx_fsl_usb2_udc_data imx31_fsl_usb2_udc_data __initconst =
  27. imx_fsl_usb2_udc_data_entry_single(MX31);
  28. #endif /* ifdef CONFIG_SOC_IMX31 */
  29. #ifdef CONFIG_SOC_IMX35
  30. const struct imx_fsl_usb2_udc_data imx35_fsl_usb2_udc_data __initconst =
  31. imx_fsl_usb2_udc_data_entry_single(MX35);
  32. #endif /* ifdef CONFIG_SOC_IMX35 */
  33. struct platform_device *__init imx_add_fsl_usb2_udc(
  34. const struct imx_fsl_usb2_udc_data *data,
  35. const struct fsl_usb2_platform_data *pdata)
  36. {
  37. struct resource res[] = {
  38. {
  39. .start = data->iobase,
  40. .end = data->iobase + SZ_512 - 1,
  41. .flags = IORESOURCE_MEM,
  42. }, {
  43. .start = data->irq,
  44. .end = data->irq,
  45. .flags = IORESOURCE_IRQ,
  46. },
  47. };
  48. return imx_add_platform_device_dmamask("fsl-usb2-udc", -1,
  49. res, ARRAY_SIZE(res),
  50. pdata, sizeof(*pdata), DMA_BIT_MASK(32));
  51. }