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