162306a36Sopenharmony_ci/* SPDX-License-Identifier: GPL-2.0 */
262306a36Sopenharmony_ci/*
362306a36Sopenharmony_ci * Copyright 2019 NXP.
462306a36Sopenharmony_ci */
562306a36Sopenharmony_ci
662306a36Sopenharmony_ci#ifndef __DCSS_PRV_H__
762306a36Sopenharmony_ci#define __DCSS_PRV_H__
862306a36Sopenharmony_ci
962306a36Sopenharmony_ci#include <drm/drm_fourcc.h>
1062306a36Sopenharmony_ci#include <drm/drm_plane.h>
1162306a36Sopenharmony_ci#include <linux/io.h>
1262306a36Sopenharmony_ci#include <linux/pm.h>
1362306a36Sopenharmony_ci#include <video/videomode.h>
1462306a36Sopenharmony_ci
1562306a36Sopenharmony_ci#define SET			0x04
1662306a36Sopenharmony_ci#define CLR			0x08
1762306a36Sopenharmony_ci#define TGL			0x0C
1862306a36Sopenharmony_ci
1962306a36Sopenharmony_ci#define dcss_writel(v, c)	writel((v), (c))
2062306a36Sopenharmony_ci#define dcss_readl(c)		readl(c)
2162306a36Sopenharmony_ci#define dcss_set(v, c)		writel((v), (c) + SET)
2262306a36Sopenharmony_ci#define dcss_clr(v, c)		writel((v), (c) + CLR)
2362306a36Sopenharmony_ci#define dcss_toggle(v, c)	writel((v), (c) + TGL)
2462306a36Sopenharmony_ci
2562306a36Sopenharmony_cistatic inline void dcss_update(u32 v, u32 m, void __iomem *c)
2662306a36Sopenharmony_ci{
2762306a36Sopenharmony_ci	writel((readl(c) & ~(m)) | (v), (c));
2862306a36Sopenharmony_ci}
2962306a36Sopenharmony_ci
3062306a36Sopenharmony_ci#define DCSS_DBG_REG(reg)	{.name = #reg, .ofs = reg}
3162306a36Sopenharmony_ci
3262306a36Sopenharmony_cienum {
3362306a36Sopenharmony_ci	DCSS_IMX8MQ = 0,
3462306a36Sopenharmony_ci};
3562306a36Sopenharmony_ci
3662306a36Sopenharmony_cistruct dcss_type_data {
3762306a36Sopenharmony_ci	const char *name;
3862306a36Sopenharmony_ci	u32 blkctl_ofs;
3962306a36Sopenharmony_ci	u32 ctxld_ofs;
4062306a36Sopenharmony_ci	u32 rdsrc_ofs;
4162306a36Sopenharmony_ci	u32 wrscl_ofs;
4262306a36Sopenharmony_ci	u32 dtg_ofs;
4362306a36Sopenharmony_ci	u32 scaler_ofs;
4462306a36Sopenharmony_ci	u32 ss_ofs;
4562306a36Sopenharmony_ci	u32 dpr_ofs;
4662306a36Sopenharmony_ci	u32 dtrc_ofs;
4762306a36Sopenharmony_ci	u32 dec400d_ofs;
4862306a36Sopenharmony_ci	u32 hdr10_ofs;
4962306a36Sopenharmony_ci};
5062306a36Sopenharmony_ci
5162306a36Sopenharmony_cistruct dcss_debug_reg {
5262306a36Sopenharmony_ci	char *name;
5362306a36Sopenharmony_ci	u32 ofs;
5462306a36Sopenharmony_ci};
5562306a36Sopenharmony_ci
5662306a36Sopenharmony_cienum dcss_ctxld_ctx_type {
5762306a36Sopenharmony_ci	CTX_DB,
5862306a36Sopenharmony_ci	CTX_SB_HP, /* high-priority */
5962306a36Sopenharmony_ci	CTX_SB_LP, /* low-priority  */
6062306a36Sopenharmony_ci};
6162306a36Sopenharmony_ci
6262306a36Sopenharmony_cistruct dcss_dev {
6362306a36Sopenharmony_ci	struct device *dev;
6462306a36Sopenharmony_ci	const struct dcss_type_data *devtype;
6562306a36Sopenharmony_ci	struct device_node *of_port;
6662306a36Sopenharmony_ci
6762306a36Sopenharmony_ci	u32 start_addr;
6862306a36Sopenharmony_ci
6962306a36Sopenharmony_ci	struct dcss_blkctl *blkctl;
7062306a36Sopenharmony_ci	struct dcss_ctxld *ctxld;
7162306a36Sopenharmony_ci	struct dcss_dpr *dpr;
7262306a36Sopenharmony_ci	struct dcss_dtg *dtg;
7362306a36Sopenharmony_ci	struct dcss_ss *ss;
7462306a36Sopenharmony_ci	struct dcss_hdr10 *hdr10;
7562306a36Sopenharmony_ci	struct dcss_scaler *scaler;
7662306a36Sopenharmony_ci	struct dcss_dtrc *dtrc;
7762306a36Sopenharmony_ci	struct dcss_dec400d *dec400d;
7862306a36Sopenharmony_ci	struct dcss_wrscl *wrscl;
7962306a36Sopenharmony_ci	struct dcss_rdsrc *rdsrc;
8062306a36Sopenharmony_ci
8162306a36Sopenharmony_ci	struct clk *apb_clk;
8262306a36Sopenharmony_ci	struct clk *axi_clk;
8362306a36Sopenharmony_ci	struct clk *pix_clk;
8462306a36Sopenharmony_ci	struct clk *rtrm_clk;
8562306a36Sopenharmony_ci	struct clk *dtrc_clk;
8662306a36Sopenharmony_ci	struct clk *pll_src_clk;
8762306a36Sopenharmony_ci	struct clk *pll_phy_ref_clk;
8862306a36Sopenharmony_ci
8962306a36Sopenharmony_ci	bool hdmi_output;
9062306a36Sopenharmony_ci
9162306a36Sopenharmony_ci	void (*disable_callback)(void *data);
9262306a36Sopenharmony_ci	struct completion disable_completion;
9362306a36Sopenharmony_ci};
9462306a36Sopenharmony_ci
9562306a36Sopenharmony_cistruct dcss_dev *dcss_drv_dev_to_dcss(struct device *dev);
9662306a36Sopenharmony_cistruct drm_device *dcss_drv_dev_to_drm(struct device *dev);
9762306a36Sopenharmony_cistruct dcss_dev *dcss_dev_create(struct device *dev, bool hdmi_output);
9862306a36Sopenharmony_civoid dcss_dev_destroy(struct dcss_dev *dcss);
9962306a36Sopenharmony_civoid dcss_enable_dtg_and_ss(struct dcss_dev *dcss);
10062306a36Sopenharmony_civoid dcss_disable_dtg_and_ss(struct dcss_dev *dcss);
10162306a36Sopenharmony_ci
10262306a36Sopenharmony_ciextern const struct dev_pm_ops dcss_dev_pm_ops;
10362306a36Sopenharmony_ci
10462306a36Sopenharmony_ci/* BLKCTL */
10562306a36Sopenharmony_ciint dcss_blkctl_init(struct dcss_dev *dcss, unsigned long blkctl_base);
10662306a36Sopenharmony_civoid dcss_blkctl_cfg(struct dcss_blkctl *blkctl);
10762306a36Sopenharmony_civoid dcss_blkctl_exit(struct dcss_blkctl *blkctl);
10862306a36Sopenharmony_ci
10962306a36Sopenharmony_ci/* CTXLD */
11062306a36Sopenharmony_ciint dcss_ctxld_init(struct dcss_dev *dcss, unsigned long ctxld_base);
11162306a36Sopenharmony_civoid dcss_ctxld_exit(struct dcss_ctxld *ctxld);
11262306a36Sopenharmony_civoid dcss_ctxld_write(struct dcss_ctxld *ctxld, u32 ctx_id,
11362306a36Sopenharmony_ci		      u32 val, u32 reg_idx);
11462306a36Sopenharmony_ciint dcss_ctxld_resume(struct dcss_ctxld *dcss_ctxld);
11562306a36Sopenharmony_ciint dcss_ctxld_suspend(struct dcss_ctxld *dcss_ctxld);
11662306a36Sopenharmony_civoid dcss_ctxld_write_irqsafe(struct dcss_ctxld *ctlxd, u32 ctx_id, u32 val,
11762306a36Sopenharmony_ci			      u32 reg_ofs);
11862306a36Sopenharmony_civoid dcss_ctxld_kick(struct dcss_ctxld *ctxld);
11962306a36Sopenharmony_cibool dcss_ctxld_is_flushed(struct dcss_ctxld *ctxld);
12062306a36Sopenharmony_ciint dcss_ctxld_enable(struct dcss_ctxld *ctxld);
12162306a36Sopenharmony_civoid dcss_ctxld_register_completion(struct dcss_ctxld *ctxld,
12262306a36Sopenharmony_ci				    struct completion *dis_completion);
12362306a36Sopenharmony_civoid dcss_ctxld_assert_locked(struct dcss_ctxld *ctxld);
12462306a36Sopenharmony_ci
12562306a36Sopenharmony_ci/* DPR */
12662306a36Sopenharmony_ciint dcss_dpr_init(struct dcss_dev *dcss, unsigned long dpr_base);
12762306a36Sopenharmony_civoid dcss_dpr_exit(struct dcss_dpr *dpr);
12862306a36Sopenharmony_civoid dcss_dpr_write_sysctrl(struct dcss_dpr *dpr);
12962306a36Sopenharmony_civoid dcss_dpr_set_res(struct dcss_dpr *dpr, int ch_num, u32 xres, u32 yres);
13062306a36Sopenharmony_civoid dcss_dpr_addr_set(struct dcss_dpr *dpr, int ch_num, u32 luma_base_addr,
13162306a36Sopenharmony_ci		       u32 chroma_base_addr, u16 pitch);
13262306a36Sopenharmony_civoid dcss_dpr_enable(struct dcss_dpr *dpr, int ch_num, bool en);
13362306a36Sopenharmony_civoid dcss_dpr_format_set(struct dcss_dpr *dpr, int ch_num,
13462306a36Sopenharmony_ci			 const struct drm_format_info *format, u64 modifier);
13562306a36Sopenharmony_civoid dcss_dpr_set_rotation(struct dcss_dpr *dpr, int ch_num, u32 rotation);
13662306a36Sopenharmony_ci
13762306a36Sopenharmony_ci/* DTG */
13862306a36Sopenharmony_ciint dcss_dtg_init(struct dcss_dev *dcss, unsigned long dtg_base);
13962306a36Sopenharmony_civoid dcss_dtg_exit(struct dcss_dtg *dtg);
14062306a36Sopenharmony_cibool dcss_dtg_vblank_irq_valid(struct dcss_dtg *dtg);
14162306a36Sopenharmony_civoid dcss_dtg_vblank_irq_enable(struct dcss_dtg *dtg, bool en);
14262306a36Sopenharmony_civoid dcss_dtg_vblank_irq_clear(struct dcss_dtg *dtg);
14362306a36Sopenharmony_civoid dcss_dtg_sync_set(struct dcss_dtg *dtg, struct videomode *vm);
14462306a36Sopenharmony_civoid dcss_dtg_css_set(struct dcss_dtg *dtg);
14562306a36Sopenharmony_civoid dcss_dtg_enable(struct dcss_dtg *dtg);
14662306a36Sopenharmony_civoid dcss_dtg_shutoff(struct dcss_dtg *dtg);
14762306a36Sopenharmony_cibool dcss_dtg_is_enabled(struct dcss_dtg *dtg);
14862306a36Sopenharmony_civoid dcss_dtg_ctxld_kick_irq_enable(struct dcss_dtg *dtg, bool en);
14962306a36Sopenharmony_cibool dcss_dtg_global_alpha_changed(struct dcss_dtg *dtg, int ch_num, int alpha);
15062306a36Sopenharmony_civoid dcss_dtg_plane_alpha_set(struct dcss_dtg *dtg, int ch_num,
15162306a36Sopenharmony_ci			      const struct drm_format_info *format, int alpha);
15262306a36Sopenharmony_civoid dcss_dtg_plane_pos_set(struct dcss_dtg *dtg, int ch_num,
15362306a36Sopenharmony_ci			    int px, int py, int pw, int ph);
15462306a36Sopenharmony_civoid dcss_dtg_ch_enable(struct dcss_dtg *dtg, int ch_num, bool en);
15562306a36Sopenharmony_ci
15662306a36Sopenharmony_ci/* SUBSAM */
15762306a36Sopenharmony_ciint dcss_ss_init(struct dcss_dev *dcss, unsigned long subsam_base);
15862306a36Sopenharmony_civoid dcss_ss_exit(struct dcss_ss *ss);
15962306a36Sopenharmony_civoid dcss_ss_enable(struct dcss_ss *ss);
16062306a36Sopenharmony_civoid dcss_ss_shutoff(struct dcss_ss *ss);
16162306a36Sopenharmony_civoid dcss_ss_subsam_set(struct dcss_ss *ss);
16262306a36Sopenharmony_civoid dcss_ss_sync_set(struct dcss_ss *ss, struct videomode *vm,
16362306a36Sopenharmony_ci		      bool phsync, bool pvsync);
16462306a36Sopenharmony_ci
16562306a36Sopenharmony_ci/* SCALER */
16662306a36Sopenharmony_ciint dcss_scaler_init(struct dcss_dev *dcss, unsigned long scaler_base);
16762306a36Sopenharmony_civoid dcss_scaler_exit(struct dcss_scaler *scl);
16862306a36Sopenharmony_civoid dcss_scaler_set_filter(struct dcss_scaler *scl, int ch_num,
16962306a36Sopenharmony_ci			    enum drm_scaling_filter scaling_filter);
17062306a36Sopenharmony_civoid dcss_scaler_setup(struct dcss_scaler *scl, int ch_num,
17162306a36Sopenharmony_ci		       const struct drm_format_info *format,
17262306a36Sopenharmony_ci		       int src_xres, int src_yres, int dst_xres, int dst_yres,
17362306a36Sopenharmony_ci		       u32 vrefresh_hz);
17462306a36Sopenharmony_civoid dcss_scaler_ch_enable(struct dcss_scaler *scl, int ch_num, bool en);
17562306a36Sopenharmony_ciint dcss_scaler_get_min_max_ratios(struct dcss_scaler *scl, int ch_num,
17662306a36Sopenharmony_ci				   int *min, int *max);
17762306a36Sopenharmony_civoid dcss_scaler_write_sclctrl(struct dcss_scaler *scl);
17862306a36Sopenharmony_ci
17962306a36Sopenharmony_ci#endif /* __DCSS_PRV_H__ */
180