xref: /rk3399_rockchip-uboot/drivers/video/drm/rockchip_display.h (revision ee01dbb2a8880c0135bfcf1c843d27e5b08bae78)
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 
10186f8572SMark Yao #include <bmp_layout.h>
11186f8572SMark Yao #include <drm_modes.h>
12186f8572SMark Yao #include <edid.h>
13e2bce6e4SKever Yang #include <dm/ofnode.h>
14186f8572SMark Yao 
15ecc31b6eSAndy Yan /*
16ecc31b6eSAndy Yan  * major: IP major vertion, used for IP structure
17ecc31b6eSAndy Yan  * minor: big feature change under same structure
18ecc31b6eSAndy Yan  */
19ecc31b6eSAndy Yan #define VOP_VERSION(major, minor)	((major) << 8 | (minor))
20ecc31b6eSAndy Yan #define VOP_MAJOR(version)		((version) >> 8)
21ecc31b6eSAndy Yan #define VOP_MINOR(version)		((version) & 0xff)
22ecc31b6eSAndy Yan 
23ecc31b6eSAndy Yan #define VOP_VERSION_RK3568		VOP_VERSION(0x40, 0x15)
24ecc31b6eSAndy Yan #define VOP_VERSION_RK3588		VOP_VERSION(0x40, 0x17)
25ecc31b6eSAndy Yan 
26d0408543SAndy Yan #define ROCKCHIP_OUTPUT_DUAL_CHANNEL_LEFT_RIGHT_MODE	BIT(0)
27d0408543SAndy Yan #define ROCKCHIP_OUTPUT_DUAL_CHANNEL_ODD_EVEN_MODE	BIT(1)
28d0408543SAndy Yan #define ROCKCHIP_OUTPUT_DATA_SWAP			BIT(2)
293df6e59eSDamon Ding #define ROCKCHIP_OUTPUT_MIPI_DS_MODE			BIT(3)
30d0408543SAndy Yan 
31ecc31b6eSAndy Yan #define ROCKCHIP_DSC_PPS_SIZE_BYTE			88
32ecc31b6eSAndy Yan 
33186f8572SMark Yao enum data_format {
34186f8572SMark Yao 	ROCKCHIP_FMT_ARGB8888 = 0,
35186f8572SMark Yao 	ROCKCHIP_FMT_RGB888,
36186f8572SMark Yao 	ROCKCHIP_FMT_RGB565,
37186f8572SMark Yao 	ROCKCHIP_FMT_YUV420SP = 4,
38186f8572SMark Yao 	ROCKCHIP_FMT_YUV422SP,
39186f8572SMark Yao 	ROCKCHIP_FMT_YUV444SP,
40186f8572SMark Yao };
41186f8572SMark Yao 
42186f8572SMark Yao enum display_mode {
43186f8572SMark Yao 	ROCKCHIP_DISPLAY_FULLSCREEN,
44186f8572SMark Yao 	ROCKCHIP_DISPLAY_CENTER,
45186f8572SMark Yao };
46186f8572SMark Yao 
4745fa51f3SSandy Huang enum rockchip_cmd_type {
4845fa51f3SSandy Huang 	CMD_TYPE_DEFAULT,
4945fa51f3SSandy Huang 	CMD_TYPE_SPI,
5045fa51f3SSandy Huang 	CMD_TYPE_MCU
5145fa51f3SSandy Huang };
5245fa51f3SSandy Huang 
5367b9012cSSandy Huang enum rockchip_mcu_cmd {
5467b9012cSSandy Huang 	MCU_WRCMD = 0,
5567b9012cSSandy Huang 	MCU_WRDATA,
5667b9012cSSandy Huang 	MCU_SETBYPASS,
5767b9012cSSandy Huang };
5867b9012cSSandy Huang 
59186f8572SMark Yao /*
60186f8572SMark Yao  * display output interface supported by rockchip lcdc
61186f8572SMark Yao  */
62186f8572SMark Yao #define ROCKCHIP_OUT_MODE_P888		0
63c55d261eSSandy Huang #define ROCKCHIP_OUT_MODE_BT1120	0
64186f8572SMark Yao #define ROCKCHIP_OUT_MODE_P666		1
65186f8572SMark Yao #define ROCKCHIP_OUT_MODE_P565		2
66c55d261eSSandy Huang #define ROCKCHIP_OUT_MODE_BT656		5
6779feefb1SSandy Huang #define ROCKCHIP_OUT_MODE_S888		8
6879feefb1SSandy Huang #define ROCKCHIP_OUT_MODE_S888_DUMMY	12
6979feefb1SSandy Huang #define ROCKCHIP_OUT_MODE_YUV420	14
70186f8572SMark Yao /* for use special outface */
71186f8572SMark Yao #define ROCKCHIP_OUT_MODE_AAAA		15
72186f8572SMark Yao 
73d0408543SAndy Yan #define VOP_OUTPUT_IF_RGB	BIT(0)
74d0408543SAndy Yan #define VOP_OUTPUT_IF_BT1120	BIT(1)
75d0408543SAndy Yan #define VOP_OUTPUT_IF_BT656	BIT(2)
76d0408543SAndy Yan #define VOP_OUTPUT_IF_LVDS0	BIT(3)
77d0408543SAndy Yan #define VOP_OUTPUT_IF_LVDS1	BIT(4)
78d0408543SAndy Yan #define VOP_OUTPUT_IF_MIPI0	BIT(5)
79d0408543SAndy Yan #define VOP_OUTPUT_IF_MIPI1	BIT(6)
80d0408543SAndy Yan #define VOP_OUTPUT_IF_eDP0	BIT(7)
81d0408543SAndy Yan #define VOP_OUTPUT_IF_eDP1	BIT(8)
82d0408543SAndy Yan #define VOP_OUTPUT_IF_DP0	BIT(9)
83d0408543SAndy Yan #define VOP_OUTPUT_IF_DP1	BIT(10)
84d0408543SAndy Yan #define VOP_OUTPUT_IF_HDMI0	BIT(11)
85d0408543SAndy Yan #define VOP_OUTPUT_IF_HDMI1	BIT(12)
86d0408543SAndy Yan 
8767b9012cSSandy Huang struct rockchip_mcu_timing {
8867b9012cSSandy Huang 	int mcu_pix_total;
8967b9012cSSandy Huang 	int mcu_cs_pst;
9067b9012cSSandy Huang 	int mcu_cs_pend;
9167b9012cSSandy Huang 	int mcu_rw_pst;
9267b9012cSSandy Huang 	int mcu_rw_pend;
9367b9012cSSandy Huang 	int mcu_hold_mode;
9467b9012cSSandy Huang };
9567b9012cSSandy Huang 
96cf53642aSSandy Huang struct vop_rect {
97cf53642aSSandy Huang 	int width;
98cf53642aSSandy Huang 	int height;
99cf53642aSSandy Huang };
100cf53642aSSandy Huang 
101ecc31b6eSAndy Yan struct rockchip_dsc_sink_cap {
102ecc31b6eSAndy Yan 	/**
103ecc31b6eSAndy Yan 	 * @slice_width: the number of pixel columns that comprise the slice width
104ecc31b6eSAndy Yan 	 * @slice_height: the number of pixel rows that comprise the slice height
105ecc31b6eSAndy Yan 	 * @block_pred: Does block prediction
106ecc31b6eSAndy Yan 	 * @native_420: Does sink support DSC with 4:2:0 compression
107ecc31b6eSAndy Yan 	 * @bpc_supported: compressed bpc supported by sink : 10, 12 or 16 bpc
108ecc31b6eSAndy Yan 	 * @version_major: DSC major version
109ecc31b6eSAndy Yan 	 * @version_minor: DSC minor version
110ecc31b6eSAndy Yan 	 * @target_bits_per_pixel_x16: bits num after compress and multiply 16
111ecc31b6eSAndy Yan 	 */
112ecc31b6eSAndy Yan 	u16 slice_width;
113ecc31b6eSAndy Yan 	u16 slice_height;
114ecc31b6eSAndy Yan 	bool block_pred;
115ecc31b6eSAndy Yan 	bool native_420;
116ecc31b6eSAndy Yan 	u8 bpc_supported;
117ecc31b6eSAndy Yan 	u8 version_major;
118ecc31b6eSAndy Yan 	u8 version_minor;
119ecc31b6eSAndy Yan 	u16 target_bits_per_pixel_x16;
120ecc31b6eSAndy Yan };
121ecc31b6eSAndy Yan 
122*ee01dbb2SDamon Ding struct display_rect {
123*ee01dbb2SDamon Ding 	int x;
124*ee01dbb2SDamon Ding 	int y;
125*ee01dbb2SDamon Ding 	int w;
126*ee01dbb2SDamon Ding 	int h;
127*ee01dbb2SDamon Ding };
128*ee01dbb2SDamon Ding 
129*ee01dbb2SDamon Ding struct bcsh_state {
130*ee01dbb2SDamon Ding 	int brightness;
131*ee01dbb2SDamon Ding 	int contrast;
132*ee01dbb2SDamon Ding 	int saturation;
133*ee01dbb2SDamon Ding 	int sin_hue;
134*ee01dbb2SDamon Ding 	int cos_hue;
135*ee01dbb2SDamon Ding };
136*ee01dbb2SDamon Ding 
137186f8572SMark Yao struct crtc_state {
138186f8572SMark Yao 	struct udevice *dev;
1392a48727aSAlgea Cao 	struct rockchip_crtc *crtc;
140186f8572SMark Yao 	void *private;
141e2bce6e4SKever Yang 	ofnode node;
1426eff7620SSandy Huang 	struct device_node *ports_node; /* if (ports_node) it's vop2; */
143186f8572SMark Yao 	int crtc_id;
144186f8572SMark Yao 
145186f8572SMark Yao 	int format;
146186f8572SMark Yao 	u32 dma_addr;
147186f8572SMark Yao 	int ymirror;
148186f8572SMark Yao 	int rb_swap;
149186f8572SMark Yao 	int xvir;
150*ee01dbb2SDamon Ding 	int post_csc_mode;
151*ee01dbb2SDamon Ding 	struct display_rect src_rect;
152*ee01dbb2SDamon Ding 	struct display_rect crtc_rect;
153*ee01dbb2SDamon Ding 	struct display_rect right_src_rect;
154*ee01dbb2SDamon Ding 	struct display_rect right_crtc_rect;
155b7618fd3SSandy Huang 	bool yuv_overlay;
156*ee01dbb2SDamon Ding 	bool post_r2y_en;
157*ee01dbb2SDamon Ding 	bool post_y2r_en;
158*ee01dbb2SDamon Ding 	bool bcsh_en;
159*ee01dbb2SDamon Ding 	bool splice_mode;
160*ee01dbb2SDamon Ding 	u8 splice_crtc_id;
16167b9012cSSandy Huang 	struct rockchip_mcu_timing mcu_timing;
162289af5f4SSandy Huang 	u32 dual_channel_swap;
16363cb669fSSandy Huang 	u32 feature;
164cf53642aSSandy Huang 	struct vop_rect max_output;
165186f8572SMark Yao };
166186f8572SMark Yao 
167186f8572SMark Yao struct panel_state {
1681a8d717cSWyon Bi 	struct rockchip_panel *panel;
169186f8572SMark Yao 
1701a8d717cSWyon Bi 	ofnode dsp_lut_node;
171186f8572SMark Yao };
172186f8572SMark Yao 
173b014f335SSandy Huang struct overscan {
174b014f335SSandy Huang 	int left_margin;
175b014f335SSandy Huang 	int right_margin;
176b014f335SSandy Huang 	int top_margin;
177b014f335SSandy Huang 	int bottom_margin;
178b014f335SSandy Huang };
179b014f335SSandy Huang 
180186f8572SMark Yao struct connector_state {
181186f8572SMark Yao 	struct udevice *dev;
182186f8572SMark Yao 	const struct rockchip_connector *connector;
1831a8d717cSWyon Bi 	struct rockchip_bridge *bridge;
18415081c50SWyon Bi 	struct rockchip_phy *phy;
185e2bce6e4SKever Yang 	ofnode node;
186186f8572SMark Yao 
187186f8572SMark Yao 	void *private;
188186f8572SMark Yao 
189186f8572SMark Yao 	struct drm_display_mode mode;
190b014f335SSandy Huang 	struct overscan overscan;
191186f8572SMark Yao 	u8 edid[EDID_SIZE * 4];
192186f8572SMark Yao 	int bus_format;
193186f8572SMark Yao 	int output_mode;
194186f8572SMark Yao 	int type;
195d0408543SAndy Yan 	int output_if;
196d0408543SAndy Yan 	int output_flags;
19779feefb1SSandy Huang 	int color_space;
198ecc31b6eSAndy Yan 	int dsc_enable;
1992a74799bSJianqun Xu 	unsigned int bpc;
200186f8572SMark Yao 
20141874944SGuochun Huang 	/**
20241874944SGuochun Huang 	 * @hold_mode: enabled when it's:
20341874944SGuochun Huang 	 * (1) mcu hold mode
20441874944SGuochun Huang 	 * (2) mipi dsi cmd mode
20541874944SGuochun Huang 	 * (3) edp psr mode
20641874944SGuochun Huang 	 */
20741874944SGuochun Huang 	bool hold_mode;
20841874944SGuochun Huang 
20950a9508eSSandy Huang 	struct base2_disp_info *disp_info; /* disp_info from baseparameter 2.0 */
21050a9508eSSandy Huang 
211ecc31b6eSAndy Yan 	u8 dsc_id;
212ecc31b6eSAndy Yan 	u8 dsc_slice_num;
213ecc31b6eSAndy Yan 	u8 dsc_pixel_num;
214ecc31b6eSAndy Yan 	u64 dsc_txp_clk;
215ecc31b6eSAndy Yan 	u64 dsc_pxl_clk;
216ecc31b6eSAndy Yan 	u64 dsc_cds_clk;
217ecc31b6eSAndy Yan 	struct rockchip_dsc_sink_cap dsc_sink_cap;
218ecc31b6eSAndy Yan 
219186f8572SMark Yao 	struct {
220186f8572SMark Yao 		u32 *lut;
221186f8572SMark Yao 		int size;
222186f8572SMark Yao 	} gamma;
223186f8572SMark Yao };
224186f8572SMark Yao 
225186f8572SMark Yao struct logo_info {
226186f8572SMark Yao 	int mode;
227186f8572SMark Yao 	char *mem;
228186f8572SMark Yao 	bool ymirror;
229186f8572SMark Yao 	u32 offset;
230186f8572SMark Yao 	u32 width;
2317e72214dSShixiang Zheng 	int height;
232186f8572SMark Yao 	u32 bpp;
233186f8572SMark Yao };
234186f8572SMark Yao 
235186f8572SMark Yao struct rockchip_logo_cache {
236186f8572SMark Yao 	struct list_head head;
237186f8572SMark Yao 	char name[20];
238186f8572SMark Yao 	struct logo_info logo;
239186f8572SMark Yao };
240186f8572SMark Yao 
241186f8572SMark Yao struct display_state {
242186f8572SMark Yao 	struct list_head head;
2434b8c2ef1SMark Yao 
244186f8572SMark Yao 	const void *blob;
245e2bce6e4SKever Yang 	ofnode node;
2464b8c2ef1SMark Yao 
247186f8572SMark Yao 	struct crtc_state crtc_state;
248186f8572SMark Yao 	struct connector_state conn_state;
249186f8572SMark Yao 	struct panel_state panel_state;
2504b8c2ef1SMark Yao 
25154fc9addSSandy Huang 	char ulogo_name[30];
25254fc9addSSandy Huang 	char klogo_name[30];
2534b8c2ef1SMark Yao 
2544b8c2ef1SMark Yao 	struct logo_info logo;
2554b8c2ef1SMark Yao 	int logo_mode;
2564b8c2ef1SMark Yao 	int charge_logo_mode;
2574b8c2ef1SMark Yao 	void *mem_base;
2584b8c2ef1SMark Yao 	int mem_size;
2594b8c2ef1SMark Yao 
260186f8572SMark Yao 	int enable;
261186f8572SMark Yao 	int is_init;
262186f8572SMark Yao 	int is_enable;
2632bfb6166SSandy Huang 	bool force_output;
2642bfb6166SSandy Huang 	struct drm_display_mode force_mode;
2652bfb6166SSandy Huang 	u32 force_bus_format;
266186f8572SMark Yao };
267186f8572SMark Yao 
2681a8d717cSWyon Bi static inline struct rockchip_panel *state_get_panel(struct display_state *s)
2691a8d717cSWyon Bi {
2701a8d717cSWyon Bi 	struct panel_state *panel_state = &s->panel_state;
2711a8d717cSWyon Bi 
2721a8d717cSWyon Bi 	return panel_state->panel;
2731a8d717cSWyon Bi }
2741a8d717cSWyon Bi 
275186f8572SMark Yao int drm_mode_vrefresh(const struct drm_display_mode *mode);
27667b9012cSSandy Huang int display_send_mcu_cmd(struct display_state *state, u32 type, u32 val);
2778e2bab3fSAlgea Cao bool drm_mode_is_420(const struct drm_display_info *display,
2788e2bab3fSAlgea Cao 		     struct drm_display_mode *mode);
27950a9508eSSandy Huang struct base2_disp_info *rockchip_get_disp_info(int type, int id);
280186f8572SMark Yao 
281cf53642aSSandy Huang void drm_mode_max_resolution_filter(struct hdmi_edid_data *edid_data,
282cf53642aSSandy Huang 				    struct vop_rect *max_output);
2836414e3bcSSandy Huang unsigned long get_cubic_lut_buffer(int crtc_id);
284cf53642aSSandy Huang 
285186f8572SMark Yao #endif
286