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