19021c317SLaurentiu Palcu /* SPDX-License-Identifier: GPL-2.0 */
29021c317SLaurentiu Palcu /*
39021c317SLaurentiu Palcu * Copyright 2019 NXP.
49021c317SLaurentiu Palcu */
59021c317SLaurentiu Palcu
69021c317SLaurentiu Palcu #ifndef __DCSS_PRV_H__
79021c317SLaurentiu Palcu #define __DCSS_PRV_H__
89021c317SLaurentiu Palcu
99021c317SLaurentiu Palcu #include <drm/drm_fourcc.h>
1005faf155SLaurentiu Palcu #include <drm/drm_plane.h>
119021c317SLaurentiu Palcu #include <linux/io.h>
12*10709aa8SPaul Cercueil #include <linux/pm.h>
139021c317SLaurentiu Palcu #include <video/videomode.h>
149021c317SLaurentiu Palcu
159021c317SLaurentiu Palcu #define SET 0x04
169021c317SLaurentiu Palcu #define CLR 0x08
179021c317SLaurentiu Palcu #define TGL 0x0C
189021c317SLaurentiu Palcu
199021c317SLaurentiu Palcu #define dcss_writel(v, c) writel((v), (c))
209021c317SLaurentiu Palcu #define dcss_readl(c) readl(c)
219021c317SLaurentiu Palcu #define dcss_set(v, c) writel((v), (c) + SET)
229021c317SLaurentiu Palcu #define dcss_clr(v, c) writel((v), (c) + CLR)
239021c317SLaurentiu Palcu #define dcss_toggle(v, c) writel((v), (c) + TGL)
249021c317SLaurentiu Palcu
dcss_update(u32 v,u32 m,void __iomem * c)259021c317SLaurentiu Palcu static inline void dcss_update(u32 v, u32 m, void __iomem *c)
269021c317SLaurentiu Palcu {
279021c317SLaurentiu Palcu writel((readl(c) & ~(m)) | (v), (c));
289021c317SLaurentiu Palcu }
299021c317SLaurentiu Palcu
309021c317SLaurentiu Palcu #define DCSS_DBG_REG(reg) {.name = #reg, .ofs = reg}
319021c317SLaurentiu Palcu
329021c317SLaurentiu Palcu enum {
339021c317SLaurentiu Palcu DCSS_IMX8MQ = 0,
349021c317SLaurentiu Palcu };
359021c317SLaurentiu Palcu
369021c317SLaurentiu Palcu struct dcss_type_data {
379021c317SLaurentiu Palcu const char *name;
389021c317SLaurentiu Palcu u32 blkctl_ofs;
399021c317SLaurentiu Palcu u32 ctxld_ofs;
409021c317SLaurentiu Palcu u32 rdsrc_ofs;
419021c317SLaurentiu Palcu u32 wrscl_ofs;
429021c317SLaurentiu Palcu u32 dtg_ofs;
439021c317SLaurentiu Palcu u32 scaler_ofs;
449021c317SLaurentiu Palcu u32 ss_ofs;
459021c317SLaurentiu Palcu u32 dpr_ofs;
469021c317SLaurentiu Palcu u32 dtrc_ofs;
479021c317SLaurentiu Palcu u32 dec400d_ofs;
489021c317SLaurentiu Palcu u32 hdr10_ofs;
499021c317SLaurentiu Palcu };
509021c317SLaurentiu Palcu
519021c317SLaurentiu Palcu struct dcss_debug_reg {
529021c317SLaurentiu Palcu char *name;
539021c317SLaurentiu Palcu u32 ofs;
549021c317SLaurentiu Palcu };
559021c317SLaurentiu Palcu
569021c317SLaurentiu Palcu enum dcss_ctxld_ctx_type {
579021c317SLaurentiu Palcu CTX_DB,
589021c317SLaurentiu Palcu CTX_SB_HP, /* high-priority */
599021c317SLaurentiu Palcu CTX_SB_LP, /* low-priority */
609021c317SLaurentiu Palcu };
619021c317SLaurentiu Palcu
629021c317SLaurentiu Palcu struct dcss_dev {
639021c317SLaurentiu Palcu struct device *dev;
649021c317SLaurentiu Palcu const struct dcss_type_data *devtype;
659021c317SLaurentiu Palcu struct device_node *of_port;
669021c317SLaurentiu Palcu
679021c317SLaurentiu Palcu u32 start_addr;
689021c317SLaurentiu Palcu
699021c317SLaurentiu Palcu struct dcss_blkctl *blkctl;
709021c317SLaurentiu Palcu struct dcss_ctxld *ctxld;
719021c317SLaurentiu Palcu struct dcss_dpr *dpr;
729021c317SLaurentiu Palcu struct dcss_dtg *dtg;
739021c317SLaurentiu Palcu struct dcss_ss *ss;
749021c317SLaurentiu Palcu struct dcss_hdr10 *hdr10;
759021c317SLaurentiu Palcu struct dcss_scaler *scaler;
769021c317SLaurentiu Palcu struct dcss_dtrc *dtrc;
779021c317SLaurentiu Palcu struct dcss_dec400d *dec400d;
789021c317SLaurentiu Palcu struct dcss_wrscl *wrscl;
799021c317SLaurentiu Palcu struct dcss_rdsrc *rdsrc;
809021c317SLaurentiu Palcu
819021c317SLaurentiu Palcu struct clk *apb_clk;
829021c317SLaurentiu Palcu struct clk *axi_clk;
839021c317SLaurentiu Palcu struct clk *pix_clk;
849021c317SLaurentiu Palcu struct clk *rtrm_clk;
859021c317SLaurentiu Palcu struct clk *dtrc_clk;
869021c317SLaurentiu Palcu struct clk *pll_src_clk;
879021c317SLaurentiu Palcu struct clk *pll_phy_ref_clk;
889021c317SLaurentiu Palcu
899021c317SLaurentiu Palcu bool hdmi_output;
909021c317SLaurentiu Palcu
919021c317SLaurentiu Palcu void (*disable_callback)(void *data);
929021c317SLaurentiu Palcu struct completion disable_completion;
939021c317SLaurentiu Palcu };
949021c317SLaurentiu Palcu
959021c317SLaurentiu Palcu struct dcss_dev *dcss_drv_dev_to_dcss(struct device *dev);
969021c317SLaurentiu Palcu struct drm_device *dcss_drv_dev_to_drm(struct device *dev);
979021c317SLaurentiu Palcu struct dcss_dev *dcss_dev_create(struct device *dev, bool hdmi_output);
989021c317SLaurentiu Palcu void dcss_dev_destroy(struct dcss_dev *dcss);
999021c317SLaurentiu Palcu void dcss_enable_dtg_and_ss(struct dcss_dev *dcss);
1009021c317SLaurentiu Palcu void dcss_disable_dtg_and_ss(struct dcss_dev *dcss);
1019021c317SLaurentiu Palcu
102*10709aa8SPaul Cercueil extern const struct dev_pm_ops dcss_dev_pm_ops;
103*10709aa8SPaul Cercueil
1049021c317SLaurentiu Palcu /* BLKCTL */
1059021c317SLaurentiu Palcu int dcss_blkctl_init(struct dcss_dev *dcss, unsigned long blkctl_base);
1069021c317SLaurentiu Palcu void dcss_blkctl_cfg(struct dcss_blkctl *blkctl);
1079021c317SLaurentiu Palcu void dcss_blkctl_exit(struct dcss_blkctl *blkctl);
1089021c317SLaurentiu Palcu
1099021c317SLaurentiu Palcu /* CTXLD */
1109021c317SLaurentiu Palcu int dcss_ctxld_init(struct dcss_dev *dcss, unsigned long ctxld_base);
1119021c317SLaurentiu Palcu void dcss_ctxld_exit(struct dcss_ctxld *ctxld);
1129021c317SLaurentiu Palcu void dcss_ctxld_write(struct dcss_ctxld *ctxld, u32 ctx_id,
1139021c317SLaurentiu Palcu u32 val, u32 reg_idx);
1149021c317SLaurentiu Palcu int dcss_ctxld_resume(struct dcss_ctxld *dcss_ctxld);
1159021c317SLaurentiu Palcu int dcss_ctxld_suspend(struct dcss_ctxld *dcss_ctxld);
1169021c317SLaurentiu Palcu void dcss_ctxld_write_irqsafe(struct dcss_ctxld *ctlxd, u32 ctx_id, u32 val,
1179021c317SLaurentiu Palcu u32 reg_ofs);
1189021c317SLaurentiu Palcu void dcss_ctxld_kick(struct dcss_ctxld *ctxld);
1199021c317SLaurentiu Palcu bool dcss_ctxld_is_flushed(struct dcss_ctxld *ctxld);
1209021c317SLaurentiu Palcu int dcss_ctxld_enable(struct dcss_ctxld *ctxld);
1219021c317SLaurentiu Palcu void dcss_ctxld_register_completion(struct dcss_ctxld *ctxld,
1229021c317SLaurentiu Palcu struct completion *dis_completion);
1239021c317SLaurentiu Palcu void dcss_ctxld_assert_locked(struct dcss_ctxld *ctxld);
1249021c317SLaurentiu Palcu
1259021c317SLaurentiu Palcu /* DPR */
1269021c317SLaurentiu Palcu int dcss_dpr_init(struct dcss_dev *dcss, unsigned long dpr_base);
1279021c317SLaurentiu Palcu void dcss_dpr_exit(struct dcss_dpr *dpr);
1289021c317SLaurentiu Palcu void dcss_dpr_write_sysctrl(struct dcss_dpr *dpr);
1299021c317SLaurentiu Palcu void dcss_dpr_set_res(struct dcss_dpr *dpr, int ch_num, u32 xres, u32 yres);
1309021c317SLaurentiu Palcu void dcss_dpr_addr_set(struct dcss_dpr *dpr, int ch_num, u32 luma_base_addr,
1319021c317SLaurentiu Palcu u32 chroma_base_addr, u16 pitch);
1329021c317SLaurentiu Palcu void dcss_dpr_enable(struct dcss_dpr *dpr, int ch_num, bool en);
1339021c317SLaurentiu Palcu void dcss_dpr_format_set(struct dcss_dpr *dpr, int ch_num,
1349021c317SLaurentiu Palcu const struct drm_format_info *format, u64 modifier);
1359021c317SLaurentiu Palcu void dcss_dpr_set_rotation(struct dcss_dpr *dpr, int ch_num, u32 rotation);
1369021c317SLaurentiu Palcu
1379021c317SLaurentiu Palcu /* DTG */
1389021c317SLaurentiu Palcu int dcss_dtg_init(struct dcss_dev *dcss, unsigned long dtg_base);
1399021c317SLaurentiu Palcu void dcss_dtg_exit(struct dcss_dtg *dtg);
1409021c317SLaurentiu Palcu bool dcss_dtg_vblank_irq_valid(struct dcss_dtg *dtg);
1419021c317SLaurentiu Palcu void dcss_dtg_vblank_irq_enable(struct dcss_dtg *dtg, bool en);
1429021c317SLaurentiu Palcu void dcss_dtg_vblank_irq_clear(struct dcss_dtg *dtg);
1439021c317SLaurentiu Palcu void dcss_dtg_sync_set(struct dcss_dtg *dtg, struct videomode *vm);
1449021c317SLaurentiu Palcu void dcss_dtg_css_set(struct dcss_dtg *dtg);
1459021c317SLaurentiu Palcu void dcss_dtg_enable(struct dcss_dtg *dtg);
1469021c317SLaurentiu Palcu void dcss_dtg_shutoff(struct dcss_dtg *dtg);
1479021c317SLaurentiu Palcu bool dcss_dtg_is_enabled(struct dcss_dtg *dtg);
1489021c317SLaurentiu Palcu void dcss_dtg_ctxld_kick_irq_enable(struct dcss_dtg *dtg, bool en);
1499021c317SLaurentiu Palcu bool dcss_dtg_global_alpha_changed(struct dcss_dtg *dtg, int ch_num, int alpha);
1509021c317SLaurentiu Palcu void dcss_dtg_plane_alpha_set(struct dcss_dtg *dtg, int ch_num,
1519021c317SLaurentiu Palcu const struct drm_format_info *format, int alpha);
1529021c317SLaurentiu Palcu void dcss_dtg_plane_pos_set(struct dcss_dtg *dtg, int ch_num,
1539021c317SLaurentiu Palcu int px, int py, int pw, int ph);
1549021c317SLaurentiu Palcu void dcss_dtg_ch_enable(struct dcss_dtg *dtg, int ch_num, bool en);
1559021c317SLaurentiu Palcu
1569021c317SLaurentiu Palcu /* SUBSAM */
1579021c317SLaurentiu Palcu int dcss_ss_init(struct dcss_dev *dcss, unsigned long subsam_base);
1589021c317SLaurentiu Palcu void dcss_ss_exit(struct dcss_ss *ss);
1599021c317SLaurentiu Palcu void dcss_ss_enable(struct dcss_ss *ss);
1609021c317SLaurentiu Palcu void dcss_ss_shutoff(struct dcss_ss *ss);
1619021c317SLaurentiu Palcu void dcss_ss_subsam_set(struct dcss_ss *ss);
1629021c317SLaurentiu Palcu void dcss_ss_sync_set(struct dcss_ss *ss, struct videomode *vm,
1639021c317SLaurentiu Palcu bool phsync, bool pvsync);
1649021c317SLaurentiu Palcu
1659021c317SLaurentiu Palcu /* SCALER */
1669021c317SLaurentiu Palcu int dcss_scaler_init(struct dcss_dev *dcss, unsigned long scaler_base);
1679021c317SLaurentiu Palcu void dcss_scaler_exit(struct dcss_scaler *scl);
16805faf155SLaurentiu Palcu void dcss_scaler_set_filter(struct dcss_scaler *scl, int ch_num,
16905faf155SLaurentiu Palcu enum drm_scaling_filter scaling_filter);
1709021c317SLaurentiu Palcu void dcss_scaler_setup(struct dcss_scaler *scl, int ch_num,
1719021c317SLaurentiu Palcu const struct drm_format_info *format,
1729021c317SLaurentiu Palcu int src_xres, int src_yres, int dst_xres, int dst_yres,
1739021c317SLaurentiu Palcu u32 vrefresh_hz);
1749021c317SLaurentiu Palcu void dcss_scaler_ch_enable(struct dcss_scaler *scl, int ch_num, bool en);
1759021c317SLaurentiu Palcu int dcss_scaler_get_min_max_ratios(struct dcss_scaler *scl, int ch_num,
1769021c317SLaurentiu Palcu int *min, int *max);
1779021c317SLaurentiu Palcu void dcss_scaler_write_sclctrl(struct dcss_scaler *scl);
1789021c317SLaurentiu Palcu
1799021c317SLaurentiu Palcu #endif /* __DCSS_PRV_H__ */
180