logicvc_drm.h 1.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667
  1. /* SPDX-License-Identifier: GPL-2.0+ */
  2. /*
  3. * Copyright (C) 2019-2022 Bootlin
  4. * Author: Paul Kocialkowski <[email protected]>
  5. */
  6. #ifndef _LOGICVC_DRM_H_
  7. #define _LOGICVC_DRM_H_
  8. #include <linux/regmap.h>
  9. #include <linux/types.h>
  10. #include <drm/drm_device.h>
  11. #define LOGICVC_DISPLAY_INTERFACE_RGB 0
  12. #define LOGICVC_DISPLAY_INTERFACE_ITU656 1
  13. #define LOGICVC_DISPLAY_INTERFACE_LVDS_4BITS 2
  14. #define LOGICVC_DISPLAY_INTERFACE_LVDS_4BITS_CAMERA 3
  15. #define LOGICVC_DISPLAY_INTERFACE_LVDS_3BITS 4
  16. #define LOGICVC_DISPLAY_INTERFACE_DVI 5
  17. #define LOGICVC_DISPLAY_COLORSPACE_RGB 0
  18. #define LOGICVC_DISPLAY_COLORSPACE_YUV422 1
  19. #define LOGICVC_DISPLAY_COLORSPACE_YUV444 2
  20. #define logicvc_drm(d) \
  21. container_of(d, struct logicvc_drm, drm_dev)
  22. struct logicvc_crtc;
  23. struct logicvc_interface;
  24. struct logicvc_drm_config {
  25. u32 display_interface;
  26. u32 display_colorspace;
  27. u32 display_depth;
  28. u32 row_stride;
  29. bool dithering;
  30. bool background_layer;
  31. bool layers_configurable;
  32. u32 layers_count;
  33. };
  34. struct logicvc_drm_caps {
  35. unsigned int major;
  36. unsigned int minor;
  37. char level;
  38. bool layer_address;
  39. };
  40. struct logicvc_drm {
  41. const struct logicvc_drm_caps *caps;
  42. struct logicvc_drm_config config;
  43. struct drm_device drm_dev;
  44. phys_addr_t reserved_mem_base;
  45. struct regmap *regmap;
  46. struct clk *vclk;
  47. struct clk *vclk2;
  48. struct clk *lvdsclk;
  49. struct clk *lvdsclkn;
  50. struct list_head layers_list;
  51. struct logicvc_crtc *crtc;
  52. struct logicvc_interface *interface;
  53. };
  54. #endif