ehci-armada100.c 1.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263
  1. /*
  2. * (C) Copyright 2012
  3. * eInfochips Ltd. <www.einfochips.com>
  4. * Written-by: Ajay Bhargav <ajay.bhargav@einfochips.com>
  5. *
  6. * This driver is based on Kirkwood echi driver
  7. * (C) Copyright 2009
  8. * Marvell Semiconductor <www.marvell.com>
  9. * Written-by: Prafulla Wadaskar <prafulla@marvell.com>
  10. *
  11. * See file CREDITS for list of people who contributed to this
  12. * project.
  13. *
  14. * This program is free software; you can redistribute it and/or
  15. * modify it under the terms of the GNU General Public License as
  16. * published by the Free Software Foundation; either version 2 of
  17. * the License, or (at your option) any later version.
  18. *
  19. * This program is distributed in the hope that it will be useful,
  20. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  21. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  22. * GNU General Public License for more details.
  23. *
  24. * You should have received a copy of the GNU General Public License
  25. * along with this program; if not, write to the Free Software
  26. * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston,
  27. * MA 02110-1301 USA
  28. */
  29. #include <common.h>
  30. #include <asm/io.h>
  31. #include <usb.h>
  32. #include "ehci.h"
  33. #include <asm/arch/cpu.h>
  34. #include <asm/arch/armada100.h>
  35. #include <asm/arch/utmi-armada100.h>
  36. /*
  37. * EHCI host controller init
  38. */
  39. int ehci_hcd_init(int index, struct ehci_hccr **hccr, struct ehci_hcor **hcor)
  40. {
  41. if (utmi_init() < 0)
  42. return -1;
  43. *hccr = (struct ehci_hccr *)(ARMD1_USB_HOST_BASE + 0x100);
  44. *hcor = (struct ehci_hcor *)((uint32_t) *hccr
  45. + HC_LENGTH(ehci_readl(&(*hccr)->cr_capbase)));
  46. debug("armada100-ehci: init hccr %x and hcor %x hc_length %d\n",
  47. (uint32_t)*hccr, (uint32_t)*hcor,
  48. (uint32_t)HC_LENGTH(ehci_readl(&(*hccr)->cr_capbase)));
  49. return 0;
  50. }
  51. /*
  52. * EHCI host controller stop
  53. */
  54. int ehci_hcd_stop(int index)
  55. {
  56. return 0;
  57. }