phy-ulpi-viewport.c 1.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374
  1. // SPDX-License-Identifier: GPL-2.0
  2. /*
  3. * Copyright (C) 2011 Google, Inc.
  4. */
  5. #include <linux/export.h>
  6. #include <linux/kernel.h>
  7. #include <linux/usb.h>
  8. #include <linux/io.h>
  9. #include <linux/usb/otg.h>
  10. #include <linux/usb/ulpi.h>
  11. #define ULPI_VIEW_WAKEUP (1 << 31)
  12. #define ULPI_VIEW_RUN (1 << 30)
  13. #define ULPI_VIEW_WRITE (1 << 29)
  14. #define ULPI_VIEW_READ (0 << 29)
  15. #define ULPI_VIEW_ADDR(x) (((x) & 0xff) << 16)
  16. #define ULPI_VIEW_DATA_READ(x) (((x) >> 8) & 0xff)
  17. #define ULPI_VIEW_DATA_WRITE(x) ((x) & 0xff)
  18. static int ulpi_viewport_wait(void __iomem *view, u32 mask)
  19. {
  20. unsigned long usec = 2000;
  21. while (usec--) {
  22. if (!(readl(view) & mask))
  23. return 0;
  24. udelay(1);
  25. }
  26. return -ETIMEDOUT;
  27. }
  28. static int ulpi_viewport_read(struct usb_phy *otg, u32 reg)
  29. {
  30. int ret;
  31. void __iomem *view = otg->io_priv;
  32. writel(ULPI_VIEW_WAKEUP | ULPI_VIEW_WRITE, view);
  33. ret = ulpi_viewport_wait(view, ULPI_VIEW_WAKEUP);
  34. if (ret)
  35. return ret;
  36. writel(ULPI_VIEW_RUN | ULPI_VIEW_READ | ULPI_VIEW_ADDR(reg), view);
  37. ret = ulpi_viewport_wait(view, ULPI_VIEW_RUN);
  38. if (ret)
  39. return ret;
  40. return ULPI_VIEW_DATA_READ(readl(view));
  41. }
  42. static int ulpi_viewport_write(struct usb_phy *otg, u32 val, u32 reg)
  43. {
  44. int ret;
  45. void __iomem *view = otg->io_priv;
  46. writel(ULPI_VIEW_WAKEUP | ULPI_VIEW_WRITE, view);
  47. ret = ulpi_viewport_wait(view, ULPI_VIEW_WAKEUP);
  48. if (ret)
  49. return ret;
  50. writel(ULPI_VIEW_RUN | ULPI_VIEW_WRITE | ULPI_VIEW_DATA_WRITE(val) |
  51. ULPI_VIEW_ADDR(reg), view);
  52. return ulpi_viewport_wait(view, ULPI_VIEW_RUN);
  53. }
  54. struct usb_phy_io_ops ulpi_viewport_access_ops = {
  55. .read = ulpi_viewport_read,
  56. .write = ulpi_viewport_write,
  57. };
  58. EXPORT_SYMBOL_GPL(ulpi_viewport_access_ops);