dcss-dev.h 5.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180
  1. /* SPDX-License-Identifier: GPL-2.0 */
  2. /*
  3. * Copyright 2019 NXP.
  4. */
  5. #ifndef __DCSS_PRV_H__
  6. #define __DCSS_PRV_H__
  7. #include <drm/drm_fourcc.h>
  8. #include <drm/drm_plane.h>
  9. #include <linux/io.h>
  10. #include <video/videomode.h>
  11. #define SET 0x04
  12. #define CLR 0x08
  13. #define TGL 0x0C
  14. #define dcss_writel(v, c) writel((v), (c))
  15. #define dcss_readl(c) readl(c)
  16. #define dcss_set(v, c) writel((v), (c) + SET)
  17. #define dcss_clr(v, c) writel((v), (c) + CLR)
  18. #define dcss_toggle(v, c) writel((v), (c) + TGL)
  19. static inline void dcss_update(u32 v, u32 m, void __iomem *c)
  20. {
  21. writel((readl(c) & ~(m)) | (v), (c));
  22. }
  23. #define DCSS_DBG_REG(reg) {.name = #reg, .ofs = reg}
  24. enum {
  25. DCSS_IMX8MQ = 0,
  26. };
  27. struct dcss_type_data {
  28. const char *name;
  29. u32 blkctl_ofs;
  30. u32 ctxld_ofs;
  31. u32 rdsrc_ofs;
  32. u32 wrscl_ofs;
  33. u32 dtg_ofs;
  34. u32 scaler_ofs;
  35. u32 ss_ofs;
  36. u32 dpr_ofs;
  37. u32 dtrc_ofs;
  38. u32 dec400d_ofs;
  39. u32 hdr10_ofs;
  40. };
  41. struct dcss_debug_reg {
  42. char *name;
  43. u32 ofs;
  44. };
  45. enum dcss_ctxld_ctx_type {
  46. CTX_DB,
  47. CTX_SB_HP, /* high-priority */
  48. CTX_SB_LP, /* low-priority */
  49. };
  50. struct dcss_dev {
  51. struct device *dev;
  52. const struct dcss_type_data *devtype;
  53. struct device_node *of_port;
  54. u32 start_addr;
  55. struct dcss_blkctl *blkctl;
  56. struct dcss_ctxld *ctxld;
  57. struct dcss_dpr *dpr;
  58. struct dcss_dtg *dtg;
  59. struct dcss_ss *ss;
  60. struct dcss_hdr10 *hdr10;
  61. struct dcss_scaler *scaler;
  62. struct dcss_dtrc *dtrc;
  63. struct dcss_dec400d *dec400d;
  64. struct dcss_wrscl *wrscl;
  65. struct dcss_rdsrc *rdsrc;
  66. struct clk *apb_clk;
  67. struct clk *axi_clk;
  68. struct clk *pix_clk;
  69. struct clk *rtrm_clk;
  70. struct clk *dtrc_clk;
  71. struct clk *pll_src_clk;
  72. struct clk *pll_phy_ref_clk;
  73. bool hdmi_output;
  74. void (*disable_callback)(void *data);
  75. struct completion disable_completion;
  76. };
  77. struct dcss_dev *dcss_drv_dev_to_dcss(struct device *dev);
  78. struct drm_device *dcss_drv_dev_to_drm(struct device *dev);
  79. struct dcss_dev *dcss_dev_create(struct device *dev, bool hdmi_output);
  80. void dcss_dev_destroy(struct dcss_dev *dcss);
  81. int dcss_dev_runtime_suspend(struct device *dev);
  82. int dcss_dev_runtime_resume(struct device *dev);
  83. int dcss_dev_suspend(struct device *dev);
  84. int dcss_dev_resume(struct device *dev);
  85. void dcss_enable_dtg_and_ss(struct dcss_dev *dcss);
  86. void dcss_disable_dtg_and_ss(struct dcss_dev *dcss);
  87. /* BLKCTL */
  88. int dcss_blkctl_init(struct dcss_dev *dcss, unsigned long blkctl_base);
  89. void dcss_blkctl_cfg(struct dcss_blkctl *blkctl);
  90. void dcss_blkctl_exit(struct dcss_blkctl *blkctl);
  91. /* CTXLD */
  92. int dcss_ctxld_init(struct dcss_dev *dcss, unsigned long ctxld_base);
  93. void dcss_ctxld_exit(struct dcss_ctxld *ctxld);
  94. void dcss_ctxld_write(struct dcss_ctxld *ctxld, u32 ctx_id,
  95. u32 val, u32 reg_idx);
  96. int dcss_ctxld_resume(struct dcss_ctxld *dcss_ctxld);
  97. int dcss_ctxld_suspend(struct dcss_ctxld *dcss_ctxld);
  98. void dcss_ctxld_write_irqsafe(struct dcss_ctxld *ctlxd, u32 ctx_id, u32 val,
  99. u32 reg_ofs);
  100. void dcss_ctxld_kick(struct dcss_ctxld *ctxld);
  101. bool dcss_ctxld_is_flushed(struct dcss_ctxld *ctxld);
  102. int dcss_ctxld_enable(struct dcss_ctxld *ctxld);
  103. void dcss_ctxld_register_completion(struct dcss_ctxld *ctxld,
  104. struct completion *dis_completion);
  105. void dcss_ctxld_assert_locked(struct dcss_ctxld *ctxld);
  106. /* DPR */
  107. int dcss_dpr_init(struct dcss_dev *dcss, unsigned long dpr_base);
  108. void dcss_dpr_exit(struct dcss_dpr *dpr);
  109. void dcss_dpr_write_sysctrl(struct dcss_dpr *dpr);
  110. void dcss_dpr_set_res(struct dcss_dpr *dpr, int ch_num, u32 xres, u32 yres);
  111. void dcss_dpr_addr_set(struct dcss_dpr *dpr, int ch_num, u32 luma_base_addr,
  112. u32 chroma_base_addr, u16 pitch);
  113. void dcss_dpr_enable(struct dcss_dpr *dpr, int ch_num, bool en);
  114. void dcss_dpr_format_set(struct dcss_dpr *dpr, int ch_num,
  115. const struct drm_format_info *format, u64 modifier);
  116. void dcss_dpr_set_rotation(struct dcss_dpr *dpr, int ch_num, u32 rotation);
  117. /* DTG */
  118. int dcss_dtg_init(struct dcss_dev *dcss, unsigned long dtg_base);
  119. void dcss_dtg_exit(struct dcss_dtg *dtg);
  120. bool dcss_dtg_vblank_irq_valid(struct dcss_dtg *dtg);
  121. void dcss_dtg_vblank_irq_enable(struct dcss_dtg *dtg, bool en);
  122. void dcss_dtg_vblank_irq_clear(struct dcss_dtg *dtg);
  123. void dcss_dtg_sync_set(struct dcss_dtg *dtg, struct videomode *vm);
  124. void dcss_dtg_css_set(struct dcss_dtg *dtg);
  125. void dcss_dtg_enable(struct dcss_dtg *dtg);
  126. void dcss_dtg_shutoff(struct dcss_dtg *dtg);
  127. bool dcss_dtg_is_enabled(struct dcss_dtg *dtg);
  128. void dcss_dtg_ctxld_kick_irq_enable(struct dcss_dtg *dtg, bool en);
  129. bool dcss_dtg_global_alpha_changed(struct dcss_dtg *dtg, int ch_num, int alpha);
  130. void dcss_dtg_plane_alpha_set(struct dcss_dtg *dtg, int ch_num,
  131. const struct drm_format_info *format, int alpha);
  132. void dcss_dtg_plane_pos_set(struct dcss_dtg *dtg, int ch_num,
  133. int px, int py, int pw, int ph);
  134. void dcss_dtg_ch_enable(struct dcss_dtg *dtg, int ch_num, bool en);
  135. /* SUBSAM */
  136. int dcss_ss_init(struct dcss_dev *dcss, unsigned long subsam_base);
  137. void dcss_ss_exit(struct dcss_ss *ss);
  138. void dcss_ss_enable(struct dcss_ss *ss);
  139. void dcss_ss_shutoff(struct dcss_ss *ss);
  140. void dcss_ss_subsam_set(struct dcss_ss *ss);
  141. void dcss_ss_sync_set(struct dcss_ss *ss, struct videomode *vm,
  142. bool phsync, bool pvsync);
  143. /* SCALER */
  144. int dcss_scaler_init(struct dcss_dev *dcss, unsigned long scaler_base);
  145. void dcss_scaler_exit(struct dcss_scaler *scl);
  146. void dcss_scaler_set_filter(struct dcss_scaler *scl, int ch_num,
  147. enum drm_scaling_filter scaling_filter);
  148. void dcss_scaler_setup(struct dcss_scaler *scl, int ch_num,
  149. const struct drm_format_info *format,
  150. int src_xres, int src_yres, int dst_xres, int dst_yres,
  151. u32 vrefresh_hz);
  152. void dcss_scaler_ch_enable(struct dcss_scaler *scl, int ch_num, bool en);
  153. int dcss_scaler_get_min_max_ratios(struct dcss_scaler *scl, int ch_num,
  154. int *min, int *max);
  155. void dcss_scaler_write_sclctrl(struct dcss_scaler *scl);
  156. #endif /* __DCSS_PRV_H__ */