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