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