18c2ecf20Sopenharmony_ci/* SPDX-License-Identifier: GPL-2.0 */ 28c2ecf20Sopenharmony_ci/* 38c2ecf20Sopenharmony_ci * Copyright 2019 NXP. 48c2ecf20Sopenharmony_ci */ 58c2ecf20Sopenharmony_ci 68c2ecf20Sopenharmony_ci#ifndef __DCSS_PRV_H__ 78c2ecf20Sopenharmony_ci#define __DCSS_PRV_H__ 88c2ecf20Sopenharmony_ci 98c2ecf20Sopenharmony_ci#include <drm/drm_fourcc.h> 108c2ecf20Sopenharmony_ci#include <linux/io.h> 118c2ecf20Sopenharmony_ci#include <video/videomode.h> 128c2ecf20Sopenharmony_ci 138c2ecf20Sopenharmony_ci#define SET 0x04 148c2ecf20Sopenharmony_ci#define CLR 0x08 158c2ecf20Sopenharmony_ci#define TGL 0x0C 168c2ecf20Sopenharmony_ci 178c2ecf20Sopenharmony_ci#define dcss_writel(v, c) writel((v), (c)) 188c2ecf20Sopenharmony_ci#define dcss_readl(c) readl(c) 198c2ecf20Sopenharmony_ci#define dcss_set(v, c) writel((v), (c) + SET) 208c2ecf20Sopenharmony_ci#define dcss_clr(v, c) writel((v), (c) + CLR) 218c2ecf20Sopenharmony_ci#define dcss_toggle(v, c) writel((v), (c) + TGL) 228c2ecf20Sopenharmony_ci 238c2ecf20Sopenharmony_cistatic inline void dcss_update(u32 v, u32 m, void __iomem *c) 248c2ecf20Sopenharmony_ci{ 258c2ecf20Sopenharmony_ci writel((readl(c) & ~(m)) | (v), (c)); 268c2ecf20Sopenharmony_ci} 278c2ecf20Sopenharmony_ci 288c2ecf20Sopenharmony_ci#define DCSS_DBG_REG(reg) {.name = #reg, .ofs = reg} 298c2ecf20Sopenharmony_ci 308c2ecf20Sopenharmony_cienum { 318c2ecf20Sopenharmony_ci DCSS_IMX8MQ = 0, 328c2ecf20Sopenharmony_ci}; 338c2ecf20Sopenharmony_ci 348c2ecf20Sopenharmony_cistruct dcss_type_data { 358c2ecf20Sopenharmony_ci const char *name; 368c2ecf20Sopenharmony_ci u32 blkctl_ofs; 378c2ecf20Sopenharmony_ci u32 ctxld_ofs; 388c2ecf20Sopenharmony_ci u32 rdsrc_ofs; 398c2ecf20Sopenharmony_ci u32 wrscl_ofs; 408c2ecf20Sopenharmony_ci u32 dtg_ofs; 418c2ecf20Sopenharmony_ci u32 scaler_ofs; 428c2ecf20Sopenharmony_ci u32 ss_ofs; 438c2ecf20Sopenharmony_ci u32 dpr_ofs; 448c2ecf20Sopenharmony_ci u32 dtrc_ofs; 458c2ecf20Sopenharmony_ci u32 dec400d_ofs; 468c2ecf20Sopenharmony_ci u32 hdr10_ofs; 478c2ecf20Sopenharmony_ci}; 488c2ecf20Sopenharmony_ci 498c2ecf20Sopenharmony_cistruct dcss_debug_reg { 508c2ecf20Sopenharmony_ci char *name; 518c2ecf20Sopenharmony_ci u32 ofs; 528c2ecf20Sopenharmony_ci}; 538c2ecf20Sopenharmony_ci 548c2ecf20Sopenharmony_cienum dcss_ctxld_ctx_type { 558c2ecf20Sopenharmony_ci CTX_DB, 568c2ecf20Sopenharmony_ci CTX_SB_HP, /* high-priority */ 578c2ecf20Sopenharmony_ci CTX_SB_LP, /* low-priority */ 588c2ecf20Sopenharmony_ci}; 598c2ecf20Sopenharmony_ci 608c2ecf20Sopenharmony_cistruct dcss_dev { 618c2ecf20Sopenharmony_ci struct device *dev; 628c2ecf20Sopenharmony_ci const struct dcss_type_data *devtype; 638c2ecf20Sopenharmony_ci struct device_node *of_port; 648c2ecf20Sopenharmony_ci 658c2ecf20Sopenharmony_ci u32 start_addr; 668c2ecf20Sopenharmony_ci 678c2ecf20Sopenharmony_ci struct dcss_blkctl *blkctl; 688c2ecf20Sopenharmony_ci struct dcss_ctxld *ctxld; 698c2ecf20Sopenharmony_ci struct dcss_dpr *dpr; 708c2ecf20Sopenharmony_ci struct dcss_dtg *dtg; 718c2ecf20Sopenharmony_ci struct dcss_ss *ss; 728c2ecf20Sopenharmony_ci struct dcss_hdr10 *hdr10; 738c2ecf20Sopenharmony_ci struct dcss_scaler *scaler; 748c2ecf20Sopenharmony_ci struct dcss_dtrc *dtrc; 758c2ecf20Sopenharmony_ci struct dcss_dec400d *dec400d; 768c2ecf20Sopenharmony_ci struct dcss_wrscl *wrscl; 778c2ecf20Sopenharmony_ci struct dcss_rdsrc *rdsrc; 788c2ecf20Sopenharmony_ci 798c2ecf20Sopenharmony_ci struct clk *apb_clk; 808c2ecf20Sopenharmony_ci struct clk *axi_clk; 818c2ecf20Sopenharmony_ci struct clk *pix_clk; 828c2ecf20Sopenharmony_ci struct clk *rtrm_clk; 838c2ecf20Sopenharmony_ci struct clk *dtrc_clk; 848c2ecf20Sopenharmony_ci struct clk *pll_src_clk; 858c2ecf20Sopenharmony_ci struct clk *pll_phy_ref_clk; 868c2ecf20Sopenharmony_ci 878c2ecf20Sopenharmony_ci bool hdmi_output; 888c2ecf20Sopenharmony_ci 898c2ecf20Sopenharmony_ci void (*disable_callback)(void *data); 908c2ecf20Sopenharmony_ci struct completion disable_completion; 918c2ecf20Sopenharmony_ci}; 928c2ecf20Sopenharmony_ci 938c2ecf20Sopenharmony_cistruct dcss_dev *dcss_drv_dev_to_dcss(struct device *dev); 948c2ecf20Sopenharmony_cistruct drm_device *dcss_drv_dev_to_drm(struct device *dev); 958c2ecf20Sopenharmony_cistruct dcss_dev *dcss_dev_create(struct device *dev, bool hdmi_output); 968c2ecf20Sopenharmony_civoid dcss_dev_destroy(struct dcss_dev *dcss); 978c2ecf20Sopenharmony_ciint dcss_dev_runtime_suspend(struct device *dev); 988c2ecf20Sopenharmony_ciint dcss_dev_runtime_resume(struct device *dev); 998c2ecf20Sopenharmony_ciint dcss_dev_suspend(struct device *dev); 1008c2ecf20Sopenharmony_ciint dcss_dev_resume(struct device *dev); 1018c2ecf20Sopenharmony_civoid dcss_enable_dtg_and_ss(struct dcss_dev *dcss); 1028c2ecf20Sopenharmony_civoid dcss_disable_dtg_and_ss(struct dcss_dev *dcss); 1038c2ecf20Sopenharmony_ci 1048c2ecf20Sopenharmony_ci/* BLKCTL */ 1058c2ecf20Sopenharmony_ciint dcss_blkctl_init(struct dcss_dev *dcss, unsigned long blkctl_base); 1068c2ecf20Sopenharmony_civoid dcss_blkctl_cfg(struct dcss_blkctl *blkctl); 1078c2ecf20Sopenharmony_civoid dcss_blkctl_exit(struct dcss_blkctl *blkctl); 1088c2ecf20Sopenharmony_ci 1098c2ecf20Sopenharmony_ci/* CTXLD */ 1108c2ecf20Sopenharmony_ciint dcss_ctxld_init(struct dcss_dev *dcss, unsigned long ctxld_base); 1118c2ecf20Sopenharmony_civoid dcss_ctxld_exit(struct dcss_ctxld *ctxld); 1128c2ecf20Sopenharmony_civoid dcss_ctxld_write(struct dcss_ctxld *ctxld, u32 ctx_id, 1138c2ecf20Sopenharmony_ci u32 val, u32 reg_idx); 1148c2ecf20Sopenharmony_ciint dcss_ctxld_resume(struct dcss_ctxld *dcss_ctxld); 1158c2ecf20Sopenharmony_ciint dcss_ctxld_suspend(struct dcss_ctxld *dcss_ctxld); 1168c2ecf20Sopenharmony_civoid dcss_ctxld_write_irqsafe(struct dcss_ctxld *ctlxd, u32 ctx_id, u32 val, 1178c2ecf20Sopenharmony_ci u32 reg_ofs); 1188c2ecf20Sopenharmony_civoid dcss_ctxld_kick(struct dcss_ctxld *ctxld); 1198c2ecf20Sopenharmony_cibool dcss_ctxld_is_flushed(struct dcss_ctxld *ctxld); 1208c2ecf20Sopenharmony_ciint dcss_ctxld_enable(struct dcss_ctxld *ctxld); 1218c2ecf20Sopenharmony_civoid dcss_ctxld_register_completion(struct dcss_ctxld *ctxld, 1228c2ecf20Sopenharmony_ci struct completion *dis_completion); 1238c2ecf20Sopenharmony_civoid dcss_ctxld_assert_locked(struct dcss_ctxld *ctxld); 1248c2ecf20Sopenharmony_ci 1258c2ecf20Sopenharmony_ci/* DPR */ 1268c2ecf20Sopenharmony_ciint dcss_dpr_init(struct dcss_dev *dcss, unsigned long dpr_base); 1278c2ecf20Sopenharmony_civoid dcss_dpr_exit(struct dcss_dpr *dpr); 1288c2ecf20Sopenharmony_civoid dcss_dpr_write_sysctrl(struct dcss_dpr *dpr); 1298c2ecf20Sopenharmony_civoid dcss_dpr_set_res(struct dcss_dpr *dpr, int ch_num, u32 xres, u32 yres); 1308c2ecf20Sopenharmony_civoid dcss_dpr_addr_set(struct dcss_dpr *dpr, int ch_num, u32 luma_base_addr, 1318c2ecf20Sopenharmony_ci u32 chroma_base_addr, u16 pitch); 1328c2ecf20Sopenharmony_civoid dcss_dpr_enable(struct dcss_dpr *dpr, int ch_num, bool en); 1338c2ecf20Sopenharmony_civoid dcss_dpr_format_set(struct dcss_dpr *dpr, int ch_num, 1348c2ecf20Sopenharmony_ci const struct drm_format_info *format, u64 modifier); 1358c2ecf20Sopenharmony_civoid dcss_dpr_set_rotation(struct dcss_dpr *dpr, int ch_num, u32 rotation); 1368c2ecf20Sopenharmony_ci 1378c2ecf20Sopenharmony_ci/* DTG */ 1388c2ecf20Sopenharmony_ciint dcss_dtg_init(struct dcss_dev *dcss, unsigned long dtg_base); 1398c2ecf20Sopenharmony_civoid dcss_dtg_exit(struct dcss_dtg *dtg); 1408c2ecf20Sopenharmony_cibool dcss_dtg_vblank_irq_valid(struct dcss_dtg *dtg); 1418c2ecf20Sopenharmony_civoid dcss_dtg_vblank_irq_enable(struct dcss_dtg *dtg, bool en); 1428c2ecf20Sopenharmony_civoid dcss_dtg_vblank_irq_clear(struct dcss_dtg *dtg); 1438c2ecf20Sopenharmony_civoid dcss_dtg_sync_set(struct dcss_dtg *dtg, struct videomode *vm); 1448c2ecf20Sopenharmony_civoid dcss_dtg_css_set(struct dcss_dtg *dtg); 1458c2ecf20Sopenharmony_civoid dcss_dtg_enable(struct dcss_dtg *dtg); 1468c2ecf20Sopenharmony_civoid dcss_dtg_shutoff(struct dcss_dtg *dtg); 1478c2ecf20Sopenharmony_cibool dcss_dtg_is_enabled(struct dcss_dtg *dtg); 1488c2ecf20Sopenharmony_civoid dcss_dtg_ctxld_kick_irq_enable(struct dcss_dtg *dtg, bool en); 1498c2ecf20Sopenharmony_cibool dcss_dtg_global_alpha_changed(struct dcss_dtg *dtg, int ch_num, int alpha); 1508c2ecf20Sopenharmony_civoid dcss_dtg_plane_alpha_set(struct dcss_dtg *dtg, int ch_num, 1518c2ecf20Sopenharmony_ci const struct drm_format_info *format, int alpha); 1528c2ecf20Sopenharmony_civoid dcss_dtg_plane_pos_set(struct dcss_dtg *dtg, int ch_num, 1538c2ecf20Sopenharmony_ci int px, int py, int pw, int ph); 1548c2ecf20Sopenharmony_civoid dcss_dtg_ch_enable(struct dcss_dtg *dtg, int ch_num, bool en); 1558c2ecf20Sopenharmony_ci 1568c2ecf20Sopenharmony_ci/* SUBSAM */ 1578c2ecf20Sopenharmony_ciint dcss_ss_init(struct dcss_dev *dcss, unsigned long subsam_base); 1588c2ecf20Sopenharmony_civoid dcss_ss_exit(struct dcss_ss *ss); 1598c2ecf20Sopenharmony_civoid dcss_ss_enable(struct dcss_ss *ss); 1608c2ecf20Sopenharmony_civoid dcss_ss_shutoff(struct dcss_ss *ss); 1618c2ecf20Sopenharmony_civoid dcss_ss_subsam_set(struct dcss_ss *ss); 1628c2ecf20Sopenharmony_civoid dcss_ss_sync_set(struct dcss_ss *ss, struct videomode *vm, 1638c2ecf20Sopenharmony_ci bool phsync, bool pvsync); 1648c2ecf20Sopenharmony_ci 1658c2ecf20Sopenharmony_ci/* SCALER */ 1668c2ecf20Sopenharmony_ciint dcss_scaler_init(struct dcss_dev *dcss, unsigned long scaler_base); 1678c2ecf20Sopenharmony_civoid dcss_scaler_exit(struct dcss_scaler *scl); 1688c2ecf20Sopenharmony_civoid dcss_scaler_setup(struct dcss_scaler *scl, int ch_num, 1698c2ecf20Sopenharmony_ci const struct drm_format_info *format, 1708c2ecf20Sopenharmony_ci int src_xres, int src_yres, int dst_xres, int dst_yres, 1718c2ecf20Sopenharmony_ci u32 vrefresh_hz); 1728c2ecf20Sopenharmony_civoid dcss_scaler_ch_enable(struct dcss_scaler *scl, int ch_num, bool en); 1738c2ecf20Sopenharmony_ciint dcss_scaler_get_min_max_ratios(struct dcss_scaler *scl, int ch_num, 1748c2ecf20Sopenharmony_ci int *min, int *max); 1758c2ecf20Sopenharmony_civoid dcss_scaler_write_sclctrl(struct dcss_scaler *scl); 1768c2ecf20Sopenharmony_ci 1778c2ecf20Sopenharmony_ci#endif /* __DCSS_PRV_H__ */ 178