mipi-phy.h 2.2 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465
  1. /*
  2. * Copyright (C) 2013 NVIDIA Corporation
  3. *
  4. * Permission to use, copy, modify, distribute, and sell this software and its
  5. * documentation for any purpose is hereby granted without fee, provided that
  6. * the above copyright notice appear in all copies and that both that copyright
  7. * notice and this permission notice appear in supporting documentation, and
  8. * that the name of the copyright holders not be used in advertising or
  9. * publicity pertaining to distribution of the software without specific,
  10. * written prior permission. The copyright holders make no representations
  11. * about the suitability of this software for any purpose. It is provided "as
  12. * is" without express or implied warranty.
  13. *
  14. * THE COPYRIGHT HOLDERS DISCLAIM ALL WARRANTIES WITH REGARD TO THIS SOFTWARE,
  15. * INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS, IN NO
  16. * EVENT SHALL THE COPYRIGHT HOLDERS BE LIABLE FOR ANY SPECIAL, INDIRECT OR
  17. * CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE,
  18. * DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER
  19. * TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE
  20. * OF THIS SOFTWARE.
  21. */
  22. #ifndef DRM_TEGRA_MIPI_PHY_H
  23. #define DRM_TEGRA_MIPI_PHY_H
  24. /*
  25. * D-PHY timing parameters
  26. *
  27. * A detailed description of these parameters can be found in the MIPI
  28. * Alliance Specification for D-PHY, Section 5.9 "Global Operation Timing
  29. * Parameters".
  30. *
  31. * All parameters are specified in nanoseconds.
  32. */
  33. struct mipi_dphy_timing {
  34. unsigned int clkmiss;
  35. unsigned int clkpost;
  36. unsigned int clkpre;
  37. unsigned int clkprepare;
  38. unsigned int clksettle;
  39. unsigned int clktermen;
  40. unsigned int clktrail;
  41. unsigned int clkzero;
  42. unsigned int dtermen;
  43. unsigned int eot;
  44. unsigned int hsexit;
  45. unsigned int hsprepare;
  46. unsigned int hszero;
  47. unsigned int hssettle;
  48. unsigned int hsskip;
  49. unsigned int hstrail;
  50. unsigned int init;
  51. unsigned int lpx;
  52. unsigned int taget;
  53. unsigned int tago;
  54. unsigned int tasure;
  55. unsigned int wakeup;
  56. };
  57. int mipi_dphy_timing_get_default(struct mipi_dphy_timing *timing,
  58. unsigned long period);
  59. int mipi_dphy_timing_validate(struct mipi_dphy_timing *timing,
  60. unsigned long period);
  61. #endif