xref: /rk3399_rockchip-uboot/drivers/video/drm/rockchip_display.h (revision 4d64cedbbfac20f820d5efaad7b8b5cafd1bca05)
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>
20690e9ed1SSandy Huang #include <spl_display.h>
210675a2a4SDamon Ding #include <clk.h>
22186f8572SMark Yao 
23ecc31b6eSAndy Yan /*
24452afb13SDamon Ding  * major: IP major version, used for IP structure
25ecc31b6eSAndy Yan  * minor: big feature change under same structure
26452afb13SDamon Ding  * build: RTL current SVN number
27ecc31b6eSAndy Yan  */
28ecc31b6eSAndy Yan #define VOP_VERSION(major, minor)		((major) << 8 | (minor))
29ecc31b6eSAndy Yan #define VOP_MAJOR(version)			((version) >> 8)
30ecc31b6eSAndy Yan #define VOP_MINOR(version)			((version) & 0xff)
31ecc31b6eSAndy Yan 
32452afb13SDamon Ding #define VOP2_VERSION(major, minor, build)	((major) << 24 | (minor) << 16 | (build))
33452afb13SDamon Ding #define VOP2_MAJOR(version)			(((version) >> 24) & 0xff)
34452afb13SDamon Ding #define VOP2_MINOR(version)			(((version) >> 16) & 0xff)
35452afb13SDamon Ding #define VOP2_BUILD(version)			((version) & 0xffff)
36452afb13SDamon Ding 
37452afb13SDamon Ding #define VOP_VERSION_RK3528			VOP2_VERSION(0x50, 0x17, 0x1263)
38452afb13SDamon Ding #define VOP_VERSION_RK3562			VOP2_VERSION(0x50, 0x17, 0x4350)
39452afb13SDamon Ding #define VOP_VERSION_RK3568			VOP2_VERSION(0x40, 0x15, 0x8023)
40452afb13SDamon Ding #define VOP_VERSION_RK3588			VOP2_VERSION(0x40, 0x17, 0x6786)
41ecc31b6eSAndy Yan 
42d0408543SAndy Yan #define ROCKCHIP_OUTPUT_DUAL_CHANNEL_LEFT_RIGHT_MODE	BIT(0)
43d0408543SAndy Yan #define ROCKCHIP_OUTPUT_DUAL_CHANNEL_ODD_EVEN_MODE	BIT(1)
44d0408543SAndy Yan #define ROCKCHIP_OUTPUT_DATA_SWAP			BIT(2)
453df6e59eSDamon Ding #define ROCKCHIP_OUTPUT_MIPI_DS_MODE			BIT(3)
46d0408543SAndy Yan 
47ecc31b6eSAndy Yan #define ROCKCHIP_DSC_PPS_SIZE_BYTE			88
48ecc31b6eSAndy Yan 
49186f8572SMark Yao enum data_format {
50186f8572SMark Yao 	ROCKCHIP_FMT_ARGB8888 = 0,
51186f8572SMark Yao 	ROCKCHIP_FMT_RGB888,
52186f8572SMark Yao 	ROCKCHIP_FMT_RGB565,
53186f8572SMark Yao 	ROCKCHIP_FMT_YUV420SP = 4,
54186f8572SMark Yao 	ROCKCHIP_FMT_YUV422SP,
55186f8572SMark Yao 	ROCKCHIP_FMT_YUV444SP,
56186f8572SMark Yao };
57186f8572SMark Yao 
58186f8572SMark Yao enum display_mode {
59186f8572SMark Yao 	ROCKCHIP_DISPLAY_FULLSCREEN,
60186f8572SMark Yao 	ROCKCHIP_DISPLAY_CENTER,
61186f8572SMark Yao };
62186f8572SMark Yao 
6345fa51f3SSandy Huang enum rockchip_cmd_type {
6445fa51f3SSandy Huang 	CMD_TYPE_DEFAULT,
6545fa51f3SSandy Huang 	CMD_TYPE_SPI,
6645fa51f3SSandy Huang 	CMD_TYPE_MCU
6745fa51f3SSandy Huang };
6845fa51f3SSandy Huang 
6967b9012cSSandy Huang enum rockchip_mcu_cmd {
7067b9012cSSandy Huang 	MCU_WRCMD = 0,
7167b9012cSSandy Huang 	MCU_WRDATA,
7267b9012cSSandy Huang 	MCU_SETBYPASS,
7367b9012cSSandy Huang };
7467b9012cSSandy Huang 
75186f8572SMark Yao /*
76186f8572SMark Yao  * display output interface supported by rockchip lcdc
77186f8572SMark Yao  */
78186f8572SMark Yao #define ROCKCHIP_OUT_MODE_P888		0
79c55d261eSSandy Huang #define ROCKCHIP_OUT_MODE_BT1120	0
80186f8572SMark Yao #define ROCKCHIP_OUT_MODE_P666		1
81186f8572SMark Yao #define ROCKCHIP_OUT_MODE_P565		2
82c55d261eSSandy Huang #define ROCKCHIP_OUT_MODE_BT656		5
8379feefb1SSandy Huang #define ROCKCHIP_OUT_MODE_S888		8
84bc291652SAlgea Cao #define ROCKCHIP_OUT_MODE_YUV422	9
8579feefb1SSandy Huang #define ROCKCHIP_OUT_MODE_S888_DUMMY	12
8679feefb1SSandy Huang #define ROCKCHIP_OUT_MODE_YUV420	14
87186f8572SMark Yao /* for use special outface */
88186f8572SMark Yao #define ROCKCHIP_OUT_MODE_AAAA		15
89186f8572SMark Yao 
90d0408543SAndy Yan #define VOP_OUTPUT_IF_RGB	BIT(0)
91d0408543SAndy Yan #define VOP_OUTPUT_IF_BT1120	BIT(1)
92d0408543SAndy Yan #define VOP_OUTPUT_IF_BT656	BIT(2)
93d0408543SAndy Yan #define VOP_OUTPUT_IF_LVDS0	BIT(3)
94d0408543SAndy Yan #define VOP_OUTPUT_IF_LVDS1	BIT(4)
95d0408543SAndy Yan #define VOP_OUTPUT_IF_MIPI0	BIT(5)
96d0408543SAndy Yan #define VOP_OUTPUT_IF_MIPI1	BIT(6)
97d0408543SAndy Yan #define VOP_OUTPUT_IF_eDP0	BIT(7)
98d0408543SAndy Yan #define VOP_OUTPUT_IF_eDP1	BIT(8)
99d0408543SAndy Yan #define VOP_OUTPUT_IF_DP0	BIT(9)
100d0408543SAndy Yan #define VOP_OUTPUT_IF_DP1	BIT(10)
101d0408543SAndy Yan #define VOP_OUTPUT_IF_HDMI0	BIT(11)
102d0408543SAndy Yan #define VOP_OUTPUT_IF_HDMI1	BIT(12)
103d0408543SAndy Yan 
10467b9012cSSandy Huang struct rockchip_mcu_timing {
10567b9012cSSandy Huang 	int mcu_pix_total;
10667b9012cSSandy Huang 	int mcu_cs_pst;
10767b9012cSSandy Huang 	int mcu_cs_pend;
10867b9012cSSandy Huang 	int mcu_rw_pst;
10967b9012cSSandy Huang 	int mcu_rw_pend;
11067b9012cSSandy Huang 	int mcu_hold_mode;
11167b9012cSSandy Huang };
11267b9012cSSandy Huang 
113cf53642aSSandy Huang struct vop_rect {
114cf53642aSSandy Huang 	int width;
115cf53642aSSandy Huang 	int height;
116cf53642aSSandy Huang };
117cf53642aSSandy Huang 
118ecc31b6eSAndy Yan struct rockchip_dsc_sink_cap {
119ecc31b6eSAndy Yan 	/**
120ecc31b6eSAndy Yan 	 * @slice_width: the number of pixel columns that comprise the slice width
121ecc31b6eSAndy Yan 	 * @slice_height: the number of pixel rows that comprise the slice height
122ecc31b6eSAndy Yan 	 * @block_pred: Does block prediction
123ecc31b6eSAndy Yan 	 * @native_420: Does sink support DSC with 4:2:0 compression
124ecc31b6eSAndy Yan 	 * @bpc_supported: compressed bpc supported by sink : 10, 12 or 16 bpc
125ecc31b6eSAndy Yan 	 * @version_major: DSC major version
126ecc31b6eSAndy Yan 	 * @version_minor: DSC minor version
127ecc31b6eSAndy Yan 	 * @target_bits_per_pixel_x16: bits num after compress and multiply 16
128ecc31b6eSAndy Yan 	 */
129ecc31b6eSAndy Yan 	u16 slice_width;
130ecc31b6eSAndy Yan 	u16 slice_height;
131ecc31b6eSAndy Yan 	bool block_pred;
132ecc31b6eSAndy Yan 	bool native_420;
133ecc31b6eSAndy Yan 	u8 bpc_supported;
134ecc31b6eSAndy Yan 	u8 version_major;
135ecc31b6eSAndy Yan 	u8 version_minor;
136ecc31b6eSAndy Yan 	u16 target_bits_per_pixel_x16;
137ecc31b6eSAndy Yan };
138ecc31b6eSAndy Yan 
139ee01dbb2SDamon Ding struct display_rect {
140ee01dbb2SDamon Ding 	int x;
141ee01dbb2SDamon Ding 	int y;
142ee01dbb2SDamon Ding 	int w;
143ee01dbb2SDamon Ding 	int h;
144ee01dbb2SDamon Ding };
145ee01dbb2SDamon Ding 
146ee01dbb2SDamon Ding struct bcsh_state {
147ee01dbb2SDamon Ding 	int brightness;
148ee01dbb2SDamon Ding 	int contrast;
149ee01dbb2SDamon Ding 	int saturation;
150ee01dbb2SDamon Ding 	int sin_hue;
151ee01dbb2SDamon Ding 	int cos_hue;
152ee01dbb2SDamon Ding };
153ee01dbb2SDamon Ding 
154186f8572SMark Yao struct crtc_state {
155186f8572SMark Yao 	struct udevice *dev;
1562a48727aSAlgea Cao 	struct rockchip_crtc *crtc;
157186f8572SMark Yao 	void *private;
158e2bce6e4SKever Yang 	ofnode node;
1596eff7620SSandy Huang 	struct device_node *ports_node; /* if (ports_node) it's vop2; */
1600675a2a4SDamon Ding 	struct clk dclk;
161186f8572SMark Yao 	int crtc_id;
162186f8572SMark Yao 
163186f8572SMark Yao 	int format;
164186f8572SMark Yao 	u32 dma_addr;
165186f8572SMark Yao 	int ymirror;
166186f8572SMark Yao 	int rb_swap;
167186f8572SMark Yao 	int xvir;
168ee01dbb2SDamon Ding 	int post_csc_mode;
169b61227a3SDamon Ding 	int dclk_core_div;
170b61227a3SDamon Ding 	int dclk_out_div;
171ee01dbb2SDamon Ding 	struct display_rect src_rect;
172ee01dbb2SDamon Ding 	struct display_rect crtc_rect;
173ee01dbb2SDamon Ding 	struct display_rect right_src_rect;
174ee01dbb2SDamon Ding 	struct display_rect right_crtc_rect;
175b7618fd3SSandy Huang 	bool yuv_overlay;
176ee01dbb2SDamon Ding 	bool post_r2y_en;
177ee01dbb2SDamon Ding 	bool post_y2r_en;
178ee01dbb2SDamon Ding 	bool bcsh_en;
179ee01dbb2SDamon Ding 	bool splice_mode;
1808e7ef808SDamon Ding 	bool soft_te;
181ee01dbb2SDamon Ding 	u8 splice_crtc_id;
18212ee5af0SDamon Ding 	u8 dsc_id;
18312ee5af0SDamon Ding 	u8 dsc_enable;
18412ee5af0SDamon Ding 	u8 dsc_slice_num;
18512ee5af0SDamon Ding 	u8 dsc_pixel_num;
18667b9012cSSandy Huang 	struct rockchip_mcu_timing mcu_timing;
187289af5f4SSandy Huang 	u32 dual_channel_swap;
18863cb669fSSandy Huang 	u32 feature;
189cf53642aSSandy Huang 	struct vop_rect max_output;
19012ee5af0SDamon Ding 
19112ee5af0SDamon Ding 	u64 dsc_txp_clk_rate;
19212ee5af0SDamon Ding 	u64 dsc_pxl_clk_rate;
19312ee5af0SDamon Ding 	u64 dsc_cds_clk_rate;
19412ee5af0SDamon Ding 	struct drm_dsc_picture_parameter_set pps;
19512ee5af0SDamon Ding 	struct rockchip_dsc_sink_cap dsc_sink_cap;
196186f8572SMark Yao };
197186f8572SMark Yao 
198186f8572SMark Yao struct panel_state {
1991a8d717cSWyon Bi 	struct rockchip_panel *panel;
200186f8572SMark Yao 
2011a8d717cSWyon Bi 	ofnode dsp_lut_node;
202186f8572SMark Yao };
203186f8572SMark Yao 
204b014f335SSandy Huang struct overscan {
205b014f335SSandy Huang 	int left_margin;
206b014f335SSandy Huang 	int right_margin;
207b014f335SSandy Huang 	int top_margin;
208b014f335SSandy Huang 	int bottom_margin;
209b014f335SSandy Huang };
210b014f335SSandy Huang 
211186f8572SMark Yao struct connector_state {
2120594ce39SZhang Yubing 	struct rockchip_connector *connector;
2130594ce39SZhang Yubing 	struct rockchip_connector *secondary;
214186f8572SMark Yao 
215186f8572SMark Yao 	struct drm_display_mode mode;
216b014f335SSandy Huang 	struct overscan overscan;
217186f8572SMark Yao 	u8 edid[EDID_SIZE * 4];
218186f8572SMark Yao 	int bus_format;
21913f658dcSDamon Ding 	u32 bus_flags;
220186f8572SMark Yao 	int output_mode;
221186f8572SMark Yao 	int type;
222d0408543SAndy Yan 	int output_if;
223d0408543SAndy Yan 	int output_flags;
22479feefb1SSandy Huang 	int color_space;
2252a74799bSJianqun Xu 	unsigned int bpc;
226186f8572SMark Yao 
22741874944SGuochun Huang 	/**
22841874944SGuochun Huang 	 * @hold_mode: enabled when it's:
22941874944SGuochun Huang 	 * (1) mcu hold mode
23041874944SGuochun Huang 	 * (2) mipi dsi cmd mode
23141874944SGuochun Huang 	 * (3) edp psr mode
23241874944SGuochun Huang 	 */
23341874944SGuochun Huang 	bool hold_mode;
23441874944SGuochun Huang 
23550a9508eSSandy Huang 	struct base2_disp_info *disp_info; /* disp_info from baseparameter 2.0 */
23650a9508eSSandy Huang 
237ecc31b6eSAndy Yan 	u8 dsc_id;
238ecc31b6eSAndy Yan 	u8 dsc_slice_num;
239ecc31b6eSAndy Yan 	u8 dsc_pixel_num;
240ecc31b6eSAndy Yan 	u64 dsc_txp_clk;
241ecc31b6eSAndy Yan 	u64 dsc_pxl_clk;
242ecc31b6eSAndy Yan 	u64 dsc_cds_clk;
243ecc31b6eSAndy Yan 	struct rockchip_dsc_sink_cap dsc_sink_cap;
24412ee5af0SDamon Ding 	struct drm_dsc_picture_parameter_set pps;
245ecc31b6eSAndy Yan 
2468e7ef808SDamon Ding 	struct gpio_desc *te_gpio;
2478e7ef808SDamon Ding 
248186f8572SMark Yao 	struct {
249186f8572SMark Yao 		u32 *lut;
250186f8572SMark Yao 		int size;
251186f8572SMark Yao 	} gamma;
252186f8572SMark Yao };
253186f8572SMark Yao 
254186f8572SMark Yao struct logo_info {
255186f8572SMark Yao 	int mode;
256186f8572SMark Yao 	char *mem;
257186f8572SMark Yao 	bool ymirror;
258186f8572SMark Yao 	u32 offset;
259186f8572SMark Yao 	u32 width;
2607e72214dSShixiang Zheng 	int height;
261186f8572SMark Yao 	u32 bpp;
262186f8572SMark Yao };
263186f8572SMark Yao 
264186f8572SMark Yao struct rockchip_logo_cache {
265186f8572SMark Yao 	struct list_head head;
266186f8572SMark Yao 	char name[20];
267186f8572SMark Yao 	struct logo_info logo;
268186f8572SMark Yao };
269186f8572SMark Yao 
270186f8572SMark Yao struct display_state {
271186f8572SMark Yao 	struct list_head head;
2724b8c2ef1SMark Yao 
273186f8572SMark Yao 	const void *blob;
274e2bce6e4SKever Yang 	ofnode node;
2754b8c2ef1SMark Yao 
276186f8572SMark Yao 	struct crtc_state crtc_state;
277186f8572SMark Yao 	struct connector_state conn_state;
278186f8572SMark Yao 	struct panel_state panel_state;
2794b8c2ef1SMark Yao 
28054fc9addSSandy Huang 	char ulogo_name[30];
28154fc9addSSandy Huang 	char klogo_name[30];
2824b8c2ef1SMark Yao 
2834b8c2ef1SMark Yao 	struct logo_info logo;
2844b8c2ef1SMark Yao 	int logo_mode;
2854b8c2ef1SMark Yao 	int charge_logo_mode;
2864b8c2ef1SMark Yao 	void *mem_base;
2874b8c2ef1SMark Yao 	int mem_size;
2884b8c2ef1SMark Yao 
289186f8572SMark Yao 	int enable;
290186f8572SMark Yao 	int is_init;
291186f8572SMark Yao 	int is_enable;
2929764efebSDamon Ding 	bool is_klogo_valid;
2932bfb6166SSandy Huang 	bool force_output;
294690e9ed1SSandy Huang 	bool enabled_at_spl;
2952bfb6166SSandy Huang 	struct drm_display_mode force_mode;
2962bfb6166SSandy Huang 	u32 force_bus_format;
297186f8572SMark Yao };
298186f8572SMark Yao 
299186f8572SMark Yao int drm_mode_vrefresh(const struct drm_display_mode *mode);
30067b9012cSSandy Huang int display_send_mcu_cmd(struct display_state *state, u32 type, u32 val);
3018e2bab3fSAlgea Cao bool drm_mode_is_420(const struct drm_display_info *display,
3028e2bab3fSAlgea Cao 		     struct drm_display_mode *mode);
30350a9508eSSandy Huang struct base2_disp_info *rockchip_get_disp_info(int type, int id);
304186f8572SMark Yao 
305cf53642aSSandy Huang void drm_mode_max_resolution_filter(struct hdmi_edid_data *edid_data,
306cf53642aSSandy Huang 				    struct vop_rect *max_output);
3076414e3bcSSandy Huang unsigned long get_cubic_lut_buffer(int crtc_id);
30813f658dcSDamon Ding int rockchip_ofnode_get_display_mode(ofnode node, struct drm_display_mode *mode,
30913f658dcSDamon Ding 				     u32 *bus_flags);
310690e9ed1SSandy Huang void rockchip_display_make_crc32_table(void);
311690e9ed1SSandy Huang uint32_t rockchip_display_crc32c_cal(unsigned char *data, int length);
312690e9ed1SSandy Huang void drm_mode_set_crtcinfo(struct drm_display_mode *p, int adjust_flags);
313cf53642aSSandy Huang 
3144c765862SDamon Ding int display_rect_calc_hscale(struct display_rect *src, struct display_rect *dst,
3154c765862SDamon Ding 			     int min_hscale, int max_hscale);
3164c765862SDamon Ding int display_rect_calc_vscale(struct display_rect *src, struct display_rect *dst,
3174c765862SDamon Ding 			     int min_vscale, int max_vscale);
318cce9b06aSWyon Bi const struct device_node *
319cce9b06aSWyon Bi rockchip_of_graph_get_endpoint_by_regs(ofnode node, int port, int endpoint);
320*4d64cedbSDamon Ding uint32_t rockchip_drm_get_cycles_per_pixel(uint32_t bus_format);
3214c765862SDamon Ding 
322690e9ed1SSandy Huang #ifdef CONFIG_SPL_BUILD
323690e9ed1SSandy Huang int rockchip_spl_vop_probe(struct crtc_state *crtc_state);
324690e9ed1SSandy Huang int rockchip_spl_dw_hdmi_probe(struct connector_state *conn_state);
325690e9ed1SSandy Huang int inno_spl_hdmi_phy_probe(struct display_state *state);
326690e9ed1SSandy Huang #endif
327186f8572SMark Yao #endif
328