xref: /rk3399_rockchip-uboot/drivers/video/drm/rockchip_display.h (revision 80cb05967d52e4e952b491003cf47df56dd17b96)
1186f8572SMark Yao /*
2186f8572SMark Yao  * (C) Copyright 2008-2017 Fuzhou Rockchip Electronics Co., Ltd
3186f8572SMark Yao  *
4186f8572SMark Yao  * SPDX-License-Identifier:	GPL-2.0+
5186f8572SMark Yao  */
6186f8572SMark Yao 
7186f8572SMark Yao #ifndef _ROCKCHIP_DISPLAY_H
8186f8572SMark Yao #define _ROCKCHIP_DISPLAY_H
9186f8572SMark Yao 
10690e9ed1SSandy Huang #ifdef CONFIG_SPL_BUILD
11690e9ed1SSandy Huang #include <linux/hdmi.h>
12690e9ed1SSandy Huang #include <linux/media-bus-format.h>
13690e9ed1SSandy Huang #else
14186f8572SMark Yao #include <bmp_layout.h>
15186f8572SMark Yao #include <edid.h>
16690e9ed1SSandy Huang #endif
17690e9ed1SSandy Huang #include <drm_modes.h>
18e2bce6e4SKever Yang #include <dm/ofnode.h>
1912ee5af0SDamon Ding #include <drm/drm_dsc.h>
200686a6a6SZhang Yubing #include <reset.h>
21690e9ed1SSandy Huang #include <spl_display.h>
220675a2a4SDamon Ding #include <clk.h>
23df0a5c43SDamon Ding #include <drm/drm_color_mgmt.h>
24186f8572SMark Yao 
25ecc31b6eSAndy Yan /*
26452afb13SDamon Ding  * major: IP major version, used for IP structure
27ecc31b6eSAndy Yan  * minor: big feature change under same structure
28452afb13SDamon Ding  * build: RTL current SVN number
29ecc31b6eSAndy Yan  */
30ecc31b6eSAndy Yan #define VOP_VERSION(major, minor)		((major) << 8 | (minor))
31ecc31b6eSAndy Yan #define VOP_MAJOR(version)			((version) >> 8)
32ecc31b6eSAndy Yan #define VOP_MINOR(version)			((version) & 0xff)
33ecc31b6eSAndy Yan 
34452afb13SDamon Ding #define VOP2_VERSION(major, minor, build)	((major) << 24 | (minor) << 16 | (build))
35452afb13SDamon Ding #define VOP2_MAJOR(version)			(((version) >> 24) & 0xff)
36452afb13SDamon Ding #define VOP2_MINOR(version)			(((version) >> 16) & 0xff)
37452afb13SDamon Ding #define VOP2_BUILD(version)			((version) & 0xffff)
38452afb13SDamon Ding 
39de3f896fSChaoyi Chen #define VOP_VERSION_RK3066			VOP_VERSION(2, 1)
40de3f896fSChaoyi Chen #define VOP_VERSION_RK3036			VOP_VERSION(2, 2)
41de3f896fSChaoyi Chen #define VOP_VERSION_RK3126			VOP_VERSION(2, 4)
42de3f896fSChaoyi Chen #define VOP_VERSION_PX30_LITE			VOP_VERSION(2, 5)
43de3f896fSChaoyi Chen #define VOP_VERSION_PX30_BIG			VOP_VERSION(2, 6)
44de3f896fSChaoyi Chen #define VOP_VERSION_RK3308			VOP_VERSION(2, 7)
45de3f896fSChaoyi Chen #define VOP_VERSION_RV1126			VOP_VERSION(2, 0xb)
46de3f896fSChaoyi Chen #define VOP_VERSION_RV1106			VOP_VERSION(2, 0xc)
47de3f896fSChaoyi Chen #define VOP_VERSION_RK3576_LITE			VOP_VERSION(2, 0xd)
48de3f896fSChaoyi Chen #define VOP_VERSION_RK3506			VOP_VERSION(2, 0xe)
49de3f896fSChaoyi Chen #define VOP_VERSION_RV1126B			VOP_VERSION(2, 0xf)
50de3f896fSChaoyi Chen #define VOP_VERSION_RK3288			VOP_VERSION(3, 0)
51de3f896fSChaoyi Chen #define VOP_VERSION_RK3288W			VOP_VERSION(3, 1)
52de3f896fSChaoyi Chen #define VOP_VERSION_RK3368			VOP_VERSION(3, 2)
53de3f896fSChaoyi Chen #define VOP_VERSION_RK3366			VOP_VERSION(3, 4)
54de3f896fSChaoyi Chen #define VOP_VERSION_RK3399_BIG			VOP_VERSION(3, 5)
55de3f896fSChaoyi Chen #define VOP_VERSION_RK3399_LITE			VOP_VERSION(3, 6)
56de3f896fSChaoyi Chen #define VOP_VERSION_RK3228			VOP_VERSION(3, 7)
57de3f896fSChaoyi Chen #define VOP_VERSION_RK3328			VOP_VERSION(3, 8)
58de3f896fSChaoyi Chen 
59452afb13SDamon Ding #define VOP_VERSION_RK3528			VOP2_VERSION(0x50, 0x17, 0x1263)
60452afb13SDamon Ding #define VOP_VERSION_RK3562			VOP2_VERSION(0x50, 0x17, 0x4350)
61452afb13SDamon Ding #define VOP_VERSION_RK3568			VOP2_VERSION(0x40, 0x15, 0x8023)
62a552a69cSDamon Ding #define VOP_VERSION_RK3576			VOP2_VERSION(0x50, 0x19, 0x9765)
63452afb13SDamon Ding #define VOP_VERSION_RK3588			VOP2_VERSION(0x40, 0x17, 0x6786)
64ecc31b6eSAndy Yan 
65d0408543SAndy Yan #define ROCKCHIP_OUTPUT_DUAL_CHANNEL_LEFT_RIGHT_MODE	BIT(0)
66d0408543SAndy Yan #define ROCKCHIP_OUTPUT_DUAL_CHANNEL_ODD_EVEN_MODE	BIT(1)
67d0408543SAndy Yan #define ROCKCHIP_OUTPUT_DATA_SWAP			BIT(2)
683df6e59eSDamon Ding #define ROCKCHIP_OUTPUT_MIPI_DS_MODE			BIT(3)
69d0408543SAndy Yan 
70ecc31b6eSAndy Yan #define ROCKCHIP_DSC_PPS_SIZE_BYTE			88
71ecc31b6eSAndy Yan 
7260e6e79dSSandy Huang #define ROCKCHIP_VOP2_SHARE_MODE_PRIMARY		1
7360e6e79dSSandy Huang #define ROCKCHIP_VOP2_SHARE_MODE_SECONDARY		2
7460e6e79dSSandy Huang 
75186f8572SMark Yao enum data_format {
76186f8572SMark Yao 	ROCKCHIP_FMT_ARGB8888 = 0,
77186f8572SMark Yao 	ROCKCHIP_FMT_RGB888,
78186f8572SMark Yao 	ROCKCHIP_FMT_RGB565,
79186f8572SMark Yao 	ROCKCHIP_FMT_YUV420SP = 4,
80186f8572SMark Yao 	ROCKCHIP_FMT_YUV422SP,
81186f8572SMark Yao 	ROCKCHIP_FMT_YUV444SP,
82186f8572SMark Yao };
83186f8572SMark Yao 
84186f8572SMark Yao enum display_mode {
85186f8572SMark Yao 	ROCKCHIP_DISPLAY_FULLSCREEN,
86186f8572SMark Yao 	ROCKCHIP_DISPLAY_CENTER,
87186f8572SMark Yao };
88186f8572SMark Yao 
8945fa51f3SSandy Huang enum rockchip_cmd_type {
9045fa51f3SSandy Huang 	CMD_TYPE_DEFAULT,
9145fa51f3SSandy Huang 	CMD_TYPE_SPI,
9245fa51f3SSandy Huang 	CMD_TYPE_MCU
9345fa51f3SSandy Huang };
9445fa51f3SSandy Huang 
9567b9012cSSandy Huang enum rockchip_mcu_cmd {
9667b9012cSSandy Huang 	MCU_WRCMD = 0,
9767b9012cSSandy Huang 	MCU_WRDATA,
9867b9012cSSandy Huang 	MCU_SETBYPASS,
9967b9012cSSandy Huang };
10067b9012cSSandy Huang 
101186f8572SMark Yao /*
102186f8572SMark Yao  * display output interface supported by rockchip lcdc
103186f8572SMark Yao  */
104186f8572SMark Yao #define ROCKCHIP_OUT_MODE_P888		0
105c55d261eSSandy Huang #define ROCKCHIP_OUT_MODE_BT1120	0
106186f8572SMark Yao #define ROCKCHIP_OUT_MODE_P666		1
107186f8572SMark Yao #define ROCKCHIP_OUT_MODE_P565		2
108bf7c1abfSDamon Ding #define RK3588_EDP_OUTPUT_MODE_YUV422	3
109c55d261eSSandy Huang #define ROCKCHIP_OUT_MODE_BT656		5
11040608a7cSDamon Ding #define ROCKCHIP_OUT_MODE_S666		9
11179feefb1SSandy Huang #define ROCKCHIP_OUT_MODE_S888		8
112bc291652SAlgea Cao #define ROCKCHIP_OUT_MODE_YUV422	9
11340608a7cSDamon Ding #define ROCKCHIP_OUT_MODE_S565		10
11479feefb1SSandy Huang #define ROCKCHIP_OUT_MODE_S888_DUMMY	12
115bf7c1abfSDamon Ding #define RK3588_DP_OUT_MODE_YUV422	12
116bf7c1abfSDamon Ding #define RK3576_EDP_OUT_MODE_YUV422	12
117bf7c1abfSDamon Ding #define RK3588_DP_OUT_MODE_YUV420	13
118bf7c1abfSDamon Ding #define RK3576_HDMI_OUT_MODE_YUV422	13
11979feefb1SSandy Huang #define ROCKCHIP_OUT_MODE_YUV420	14
120186f8572SMark Yao /* for use special outface */
121186f8572SMark Yao #define ROCKCHIP_OUT_MODE_AAAA		15
122186f8572SMark Yao 
123d0408543SAndy Yan #define VOP_OUTPUT_IF_RGB	BIT(0)
124d0408543SAndy Yan #define VOP_OUTPUT_IF_BT1120	BIT(1)
125d0408543SAndy Yan #define VOP_OUTPUT_IF_BT656	BIT(2)
126d0408543SAndy Yan #define VOP_OUTPUT_IF_LVDS0	BIT(3)
127d0408543SAndy Yan #define VOP_OUTPUT_IF_LVDS1	BIT(4)
128d0408543SAndy Yan #define VOP_OUTPUT_IF_MIPI0	BIT(5)
129d0408543SAndy Yan #define VOP_OUTPUT_IF_MIPI1	BIT(6)
130d0408543SAndy Yan #define VOP_OUTPUT_IF_eDP0	BIT(7)
131d0408543SAndy Yan #define VOP_OUTPUT_IF_eDP1	BIT(8)
132d0408543SAndy Yan #define VOP_OUTPUT_IF_DP0	BIT(9)
133d0408543SAndy Yan #define VOP_OUTPUT_IF_DP1	BIT(10)
134d0408543SAndy Yan #define VOP_OUTPUT_IF_HDMI0	BIT(11)
135d0408543SAndy Yan #define VOP_OUTPUT_IF_HDMI1	BIT(12)
136a552a69cSDamon Ding #define VOP_OUTPUT_IF_DP2	BIT(13)
137d0408543SAndy Yan 
13867b9012cSSandy Huang struct rockchip_mcu_timing {
13967b9012cSSandy Huang 	int mcu_pix_total;
14067b9012cSSandy Huang 	int mcu_cs_pst;
14167b9012cSSandy Huang 	int mcu_cs_pend;
14267b9012cSSandy Huang 	int mcu_rw_pst;
14367b9012cSSandy Huang 	int mcu_rw_pend;
14467b9012cSSandy Huang 	int mcu_hold_mode;
14567b9012cSSandy Huang };
14667b9012cSSandy Huang 
147cf53642aSSandy Huang struct vop_rect {
148cf53642aSSandy Huang 	int width;
149cf53642aSSandy Huang 	int height;
150cf53642aSSandy Huang };
151cf53642aSSandy Huang 
15244b1b62cSDamon Ding struct vop_urgency {
15344b1b62cSDamon Ding 	u8 urgen_thl;
15444b1b62cSDamon Ding 	u8 urgen_thh;
15544b1b62cSDamon Ding };
15644b1b62cSDamon Ding 
157ecc31b6eSAndy Yan struct rockchip_dsc_sink_cap {
158ecc31b6eSAndy Yan 	/**
159ecc31b6eSAndy Yan 	 * @slice_width: the number of pixel columns that comprise the slice width
160ecc31b6eSAndy Yan 	 * @slice_height: the number of pixel rows that comprise the slice height
161ecc31b6eSAndy Yan 	 * @block_pred: Does block prediction
162ecc31b6eSAndy Yan 	 * @native_420: Does sink support DSC with 4:2:0 compression
163ecc31b6eSAndy Yan 	 * @bpc_supported: compressed bpc supported by sink : 10, 12 or 16 bpc
164ecc31b6eSAndy Yan 	 * @version_major: DSC major version
165ecc31b6eSAndy Yan 	 * @version_minor: DSC minor version
166ecc31b6eSAndy Yan 	 * @target_bits_per_pixel_x16: bits num after compress and multiply 16
167ecc31b6eSAndy Yan 	 */
168ecc31b6eSAndy Yan 	u16 slice_width;
169ecc31b6eSAndy Yan 	u16 slice_height;
170ecc31b6eSAndy Yan 	bool block_pred;
171ecc31b6eSAndy Yan 	bool native_420;
172ecc31b6eSAndy Yan 	u8 bpc_supported;
173ecc31b6eSAndy Yan 	u8 version_major;
174ecc31b6eSAndy Yan 	u8 version_minor;
175ecc31b6eSAndy Yan 	u16 target_bits_per_pixel_x16;
176ecc31b6eSAndy Yan };
177ecc31b6eSAndy Yan 
178ee01dbb2SDamon Ding struct display_rect {
179ee01dbb2SDamon Ding 	int x;
180ee01dbb2SDamon Ding 	int y;
181ee01dbb2SDamon Ding 	int w;
182ee01dbb2SDamon Ding 	int h;
183ee01dbb2SDamon Ding };
184ee01dbb2SDamon Ding 
185ee01dbb2SDamon Ding struct bcsh_state {
186ee01dbb2SDamon Ding 	int brightness;
187ee01dbb2SDamon Ding 	int contrast;
188ee01dbb2SDamon Ding 	int saturation;
189ee01dbb2SDamon Ding 	int sin_hue;
190ee01dbb2SDamon Ding 	int cos_hue;
191ee01dbb2SDamon Ding };
192ee01dbb2SDamon Ding 
193186f8572SMark Yao struct crtc_state {
194186f8572SMark Yao 	struct udevice *dev;
1952a48727aSAlgea Cao 	struct rockchip_crtc *crtc;
196186f8572SMark Yao 	void *private;
197e2bce6e4SKever Yang 	ofnode node;
1986eff7620SSandy Huang 	struct device_node *ports_node; /* if (ports_node) it's vop2; */
1990669ab1fSDamon Ding 	struct device_node *port_node;
2000686a6a6SZhang Yubing 	struct reset_ctl dclk_rst;
2010675a2a4SDamon Ding 	struct clk dclk;
202186f8572SMark Yao 	int crtc_id;
203186f8572SMark Yao 
204186f8572SMark Yao 	int format;
205186f8572SMark Yao 	u32 dma_addr;
206186f8572SMark Yao 	int ymirror;
207186f8572SMark Yao 	int rb_swap;
208186f8572SMark Yao 	int xvir;
209ee01dbb2SDamon Ding 	int post_csc_mode;
210b61227a3SDamon Ding 	int dclk_core_div;
211b61227a3SDamon Ding 	int dclk_out_div;
212ee01dbb2SDamon Ding 	struct display_rect src_rect;
213ee01dbb2SDamon Ding 	struct display_rect crtc_rect;
214ee01dbb2SDamon Ding 	struct display_rect right_src_rect;
215ee01dbb2SDamon Ding 	struct display_rect right_crtc_rect;
216b7618fd3SSandy Huang 	bool yuv_overlay;
217ee01dbb2SDamon Ding 	bool post_r2y_en;
218ee01dbb2SDamon Ding 	bool post_y2r_en;
219ee01dbb2SDamon Ding 	bool bcsh_en;
220ee01dbb2SDamon Ding 	bool splice_mode;
2218e7ef808SDamon Ding 	bool soft_te;
222668e6278SDamon Ding 	bool overscan_by_win_scale;
223ee01dbb2SDamon Ding 	u8 splice_crtc_id;
22412ee5af0SDamon Ding 	u8 dsc_id;
22512ee5af0SDamon Ding 	u8 dsc_enable;
22612ee5af0SDamon Ding 	u8 dsc_slice_num;
22712ee5af0SDamon Ding 	u8 dsc_pixel_num;
22867b9012cSSandy Huang 	struct rockchip_mcu_timing mcu_timing;
229289af5f4SSandy Huang 	u32 dual_channel_swap;
23063cb669fSSandy Huang 	u32 feature;
231cf53642aSSandy Huang 	struct vop_rect max_output;
23212ee5af0SDamon Ding 
23312ee5af0SDamon Ding 	u64 dsc_txp_clk_rate;
23412ee5af0SDamon Ding 	u64 dsc_pxl_clk_rate;
23512ee5af0SDamon Ding 	u64 dsc_cds_clk_rate;
23612ee5af0SDamon Ding 	struct drm_dsc_picture_parameter_set pps;
23712ee5af0SDamon Ding 	struct rockchip_dsc_sink_cap dsc_sink_cap;
2380669ab1fSDamon Ding 
2390669ab1fSDamon Ding 	u32 *lut_val;
240186f8572SMark Yao };
241186f8572SMark Yao 
242186f8572SMark Yao struct panel_state {
2431a8d717cSWyon Bi 	struct rockchip_panel *panel;
244186f8572SMark Yao 
2451a8d717cSWyon Bi 	ofnode dsp_lut_node;
246186f8572SMark Yao };
247186f8572SMark Yao 
248b014f335SSandy Huang struct overscan {
249b014f335SSandy Huang 	int left_margin;
250b014f335SSandy Huang 	int right_margin;
251b014f335SSandy Huang 	int top_margin;
252b014f335SSandy Huang 	int bottom_margin;
253b014f335SSandy Huang };
254b014f335SSandy Huang 
255186f8572SMark Yao struct connector_state {
2560594ce39SZhang Yubing 	struct rockchip_connector *connector;
2570594ce39SZhang Yubing 	struct rockchip_connector *secondary;
258186f8572SMark Yao 
259186f8572SMark Yao 	struct drm_display_mode mode;
260b014f335SSandy Huang 	struct overscan overscan;
2619c170041SAlgea Cao 	u8 *edid;
262186f8572SMark Yao 	int bus_format;
26313f658dcSDamon Ding 	u32 bus_flags;
264186f8572SMark Yao 	int output_mode;
265186f8572SMark Yao 	int type;
266d0408543SAndy Yan 	int output_if;
267d0408543SAndy Yan 	int output_flags;
268df0a5c43SDamon Ding 	enum drm_color_encoding color_encoding;
269df0a5c43SDamon Ding 	enum drm_color_range color_range;
2702a74799bSJianqun Xu 	unsigned int bpc;
271186f8572SMark Yao 
27241874944SGuochun Huang 	/**
27341874944SGuochun Huang 	 * @hold_mode: enabled when it's:
27441874944SGuochun Huang 	 * (1) mcu hold mode
27541874944SGuochun Huang 	 * (2) mipi dsi cmd mode
27641874944SGuochun Huang 	 * (3) edp psr mode
27741874944SGuochun Huang 	 */
27841874944SGuochun Huang 	bool hold_mode;
27941874944SGuochun Huang 
28050a9508eSSandy Huang 	struct base2_disp_info *disp_info; /* disp_info from baseparameter 2.0 */
28150a9508eSSandy Huang 
282ecc31b6eSAndy Yan 	u8 dsc_id;
283ecc31b6eSAndy Yan 	u8 dsc_slice_num;
284ecc31b6eSAndy Yan 	u8 dsc_pixel_num;
285ecc31b6eSAndy Yan 	u64 dsc_txp_clk;
286ecc31b6eSAndy Yan 	u64 dsc_pxl_clk;
287ecc31b6eSAndy Yan 	u64 dsc_cds_clk;
288ecc31b6eSAndy Yan 	struct rockchip_dsc_sink_cap dsc_sink_cap;
28912ee5af0SDamon Ding 	struct drm_dsc_picture_parameter_set pps;
290ecc31b6eSAndy Yan 
2918e7ef808SDamon Ding 	struct gpio_desc *te_gpio;
2928e7ef808SDamon Ding 
293186f8572SMark Yao 	struct {
294186f8572SMark Yao 		u32 *lut;
295186f8572SMark Yao 		int size;
296186f8572SMark Yao 	} gamma;
297186f8572SMark Yao };
298186f8572SMark Yao 
299186f8572SMark Yao struct logo_info {
300186f8572SMark Yao 	int mode;
3010fda4887SDamon Ding 	int rotate;
302186f8572SMark Yao 	char *mem;
303186f8572SMark Yao 	bool ymirror;
304186f8572SMark Yao 	u32 offset;
305186f8572SMark Yao 	u32 width;
3067e72214dSShixiang Zheng 	int height;
307186f8572SMark Yao 	u32 bpp;
308186f8572SMark Yao };
309186f8572SMark Yao 
310186f8572SMark Yao struct rockchip_logo_cache {
311186f8572SMark Yao 	struct list_head head;
312186f8572SMark Yao 	char name[20];
313186f8572SMark Yao 	struct logo_info logo;
3140fda4887SDamon Ding 	int logo_rotate;
315186f8572SMark Yao };
316186f8572SMark Yao 
317186f8572SMark Yao struct display_state {
318186f8572SMark Yao 	struct list_head head;
3194b8c2ef1SMark Yao 
320186f8572SMark Yao 	const void *blob;
321e2bce6e4SKever Yang 	ofnode node;
3224b8c2ef1SMark Yao 
323186f8572SMark Yao 	struct crtc_state crtc_state;
324186f8572SMark Yao 	struct connector_state conn_state;
325186f8572SMark Yao 	struct panel_state panel_state;
3264b8c2ef1SMark Yao 
32754fc9addSSandy Huang 	char ulogo_name[30];
32854fc9addSSandy Huang 	char klogo_name[30];
3294b8c2ef1SMark Yao 
3304b8c2ef1SMark Yao 	struct logo_info logo;
3314b8c2ef1SMark Yao 	int logo_mode;
3324b8c2ef1SMark Yao 	int charge_logo_mode;
3330fda4887SDamon Ding 	int logo_rotate;
3344b8c2ef1SMark Yao 	void *mem_base;
3354b8c2ef1SMark Yao 	int mem_size;
3364b8c2ef1SMark Yao 
337186f8572SMark Yao 	int enable;
338186f8572SMark Yao 	int is_init;
339186f8572SMark Yao 	int is_enable;
3409764efebSDamon Ding 	bool is_klogo_valid;
3412bfb6166SSandy Huang 	bool force_output;
342690e9ed1SSandy Huang 	bool enabled_at_spl;
3432bfb6166SSandy Huang 	struct drm_display_mode force_mode;
3442bfb6166SSandy Huang 	u32 force_bus_format;
345d00abaefSWenping Zhang 
346d00abaefSWenping Zhang 	ulong vidcon_fb_addr;
347186f8572SMark Yao };
348186f8572SMark Yao 
349186f8572SMark Yao int drm_mode_vrefresh(const struct drm_display_mode *mode);
35067b9012cSSandy Huang int display_send_mcu_cmd(struct display_state *state, u32 type, u32 val);
351038b8732SAlgea Cao bool drm_mode_is_420_only(const struct drm_display_info *display,
352038b8732SAlgea Cao 			  struct drm_display_mode *mode);
353038b8732SAlgea Cao bool drm_mode_is_420_also(const struct drm_display_info *display,
354038b8732SAlgea Cao 			  struct drm_display_mode *mode);
3558e2bab3fSAlgea Cao bool drm_mode_is_420(const struct drm_display_info *display,
3568e2bab3fSAlgea Cao 		     struct drm_display_mode *mode);
357*80cb0596SZhang Yubing bool drm_mode_is_420_only(const struct drm_display_info *display,
358*80cb0596SZhang Yubing 		     struct drm_display_mode *mode);
35950a9508eSSandy Huang struct base2_disp_info *rockchip_get_disp_info(int type, int id);
360186f8572SMark Yao 
361cf53642aSSandy Huang void drm_mode_max_resolution_filter(struct hdmi_edid_data *edid_data,
362cf53642aSSandy Huang 				    struct vop_rect *max_output);
3636414e3bcSSandy Huang unsigned long get_cubic_lut_buffer(int crtc_id);
36413f658dcSDamon Ding int rockchip_ofnode_get_display_mode(ofnode node, struct drm_display_mode *mode,
36513f658dcSDamon Ding 				     u32 *bus_flags);
366690e9ed1SSandy Huang void rockchip_display_make_crc32_table(void);
367690e9ed1SSandy Huang uint32_t rockchip_display_crc32c_cal(unsigned char *data, int length);
368690e9ed1SSandy Huang void drm_mode_set_crtcinfo(struct drm_display_mode *p, int adjust_flags);
3692b992d78SDamon Ding void drm_mode_convert_to_origin_mode(struct drm_display_mode *mode);
3702b992d78SDamon Ding void drm_mode_convert_to_split_mode(struct drm_display_mode *mode);
371cf53642aSSandy Huang 
3724c765862SDamon Ding int display_rect_calc_hscale(struct display_rect *src, struct display_rect *dst,
3734c765862SDamon Ding 			     int min_hscale, int max_hscale);
3744c765862SDamon Ding int display_rect_calc_vscale(struct display_rect *src, struct display_rect *dst,
3754c765862SDamon Ding 			     int min_vscale, int max_vscale);
376cce9b06aSWyon Bi const struct device_node *
377cce9b06aSWyon Bi rockchip_of_graph_get_endpoint_by_regs(ofnode node, int port, int endpoint);
37817e6e1a5SChaoyi Chen const struct device_node *
37917e6e1a5SChaoyi Chen rockchip_of_graph_get_port_by_id(ofnode node, int id);
3804d64cedbSDamon Ding uint32_t rockchip_drm_get_cycles_per_pixel(uint32_t bus_format);
3812264c88bSDamon Ding char* rockchip_get_output_if_name(u32 output_if, char *name);
3824c765862SDamon Ding 
383690e9ed1SSandy Huang #ifdef CONFIG_SPL_BUILD
384690e9ed1SSandy Huang int rockchip_spl_vop_probe(struct crtc_state *crtc_state);
385690e9ed1SSandy Huang int rockchip_spl_dw_hdmi_probe(struct connector_state *conn_state);
386690e9ed1SSandy Huang int inno_spl_hdmi_phy_probe(struct display_state *state);
387690e9ed1SSandy Huang #endif
388186f8572SMark Yao #endif
389