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