|  | /* | 
|  | * Copyright (C) 2017 Amlogic, Inc. All rights reserved. | 
|  | * * | 
|  | This program is free software; you can redistribute it and/or modify | 
|  | * it under the terms of the GNU General Public License as published by | 
|  | * the Free Software Foundation; either version 2 of the License, or | 
|  | * (at your option) any later version. | 
|  | * * | 
|  | This program is distributed in the hope that it will be useful, but WITHOUT | 
|  | * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or | 
|  | * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for | 
|  | * more details. | 
|  | * * | 
|  | You should have received a copy of the GNU General Public License along | 
|  | * with this program; if not, write to the Free Software Foundation, Inc., | 
|  | * 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. | 
|  | * * | 
|  | Description: | 
|  | */ | 
|  |  | 
|  | #ifndef __HDMI_H__ | 
|  | #define __HDMI_H__ | 
|  |  | 
|  | /* Little-Endian format */ | 
|  | enum scdc_addr { | 
|  | SINK_VER = 0x01, | 
|  | SOURCE_VER, /* RW */ | 
|  | UPDATE_0 = 0x10, /* RW */ | 
|  | UPDATE_1, /* RW */ | 
|  | TMDS_CFG = 0x20, /* RW */ | 
|  | SCRAMBLER_ST, | 
|  | CONFIG_0 = 0x30, /* RW */ | 
|  | STATUS_FLAGS_0 = 0x40, | 
|  | STATUS_FLAGS_1, | 
|  | ERR_DET_0_L = 0x50, | 
|  | ERR_DET_0_H, | 
|  | ERR_DET_1_L, | 
|  | ERR_DET_1_H, | 
|  | ERR_DET_2_L, | 
|  | ERR_DET_2_H, | 
|  | ERR_DET_CHKSUM, | 
|  | TEST_CONFIG_0 = 0xC0, /* RW */ | 
|  | MANUFACT_IEEE_OUI_2 = 0xD0, | 
|  | MANUFACT_IEEE_OUI_1, | 
|  | MANUFACT_IEEE_OUI_0, | 
|  | DEVICE_ID = 0xD3, /* 0xD3 ~ 0xDD */ | 
|  | /* RW   0xDE ~ 0xFF */ | 
|  | MANUFACT_SPECIFIC = 0xDE, | 
|  | }; | 
|  |  | 
|  | #define HDMITX_VIC420_OFFSET	0x100 | 
|  | #define HDMITX_VESA_OFFSET	0x301 | 
|  |  | 
|  | /* HDMI VIC definitions */ | 
|  | enum hdmi_vic { | 
|  | /* Refer to CEA 861-D */ | 
|  | HDMI_unkown = 0, | 
|  | HDMI_640x480p60_4x3 = 1, | 
|  | HDMI_720x480p60_4x3 = 2, | 
|  | HDMI_720x480p60_16x9 = 3, | 
|  | HDMI_1280x720p60_16x9 = 4, | 
|  | HDMI_1920x1080i60_16x9 = 5, | 
|  | HDMI_720x480i60_4x3 = 6, | 
|  | HDMI_720x480i60_16x9 = 7, | 
|  | HDMI_720x240p60_4x3 = 8, | 
|  | HDMI_720x240p60_16x9 = 9, | 
|  | HDMI_2880x480i60_4x3 = 10, | 
|  | HDMI_2880x480i60_16x9 = 11, | 
|  | HDMI_2880x240p60_4x3 = 12, | 
|  | HDMI_2880x240p60_16x9 = 13, | 
|  | HDMI_1440x480p60_4x3 = 14, | 
|  | HDMI_1440x480p60_16x9 = 15, | 
|  | HDMI_1920x1080p60_16x9 = 16, | 
|  | HDMI_720x576p50_4x3 = 17, | 
|  | HDMI_720x576p50_16x9 = 18, | 
|  | HDMI_1280x720p50_16x9 = 19, | 
|  | HDMI_1920x1080i50_16x9 = 20, | 
|  | HDMI_720x576i50_4x3 = 21, | 
|  | HDMI_720x576i50_16x9 = 22, | 
|  | HDMI_720x288p_4x3 = 23, | 
|  | HDMI_720x288p_16x9 = 24, | 
|  | HDMI_2880x576i50_4x3 = 25, | 
|  | HDMI_2880x576i50_16x9 = 26, | 
|  | HDMI_2880x288p50_4x3 = 27, | 
|  | HDMI_2880x288p50_16x9 = 28, | 
|  | HDMI_1440x576p_4x3 = 29, | 
|  | HDMI_1440x576p_16x9 = 30, | 
|  | HDMI_1920x1080p50_16x9 = 31, | 
|  | HDMI_1920x1080p24_16x9 = 32, | 
|  | HDMI_1920x1080p25_16x9 = 33, | 
|  | HDMI_1920x1080p30_16x9 = 34, | 
|  | HDMI_2880x480p60_4x3 = 35, | 
|  | HDMI_2880x480p60_16x9 = 36, | 
|  | HDMI_2880x576p50_4x3 = 37, | 
|  | HDMI_2880x576p50_16x9 = 38, | 
|  | HDMI_1920x1080i_t1250_50_16x9 = 39, | 
|  | HDMI_1920x1080i100_16x9 = 40, | 
|  | HDMI_1280x720p100_16x9 = 41, | 
|  | HDMI_720x576p100_4x3 = 42, | 
|  | HDMI_720x576p100_16x9 = 43, | 
|  | HDMI_720x576i100_4x3 = 44, | 
|  | HDMI_720x576i100_16x9 = 45, | 
|  | HDMI_1920x1080i120_16x9 = 46, | 
|  | HDMI_1280x720p120_16x9 = 47, | 
|  | HDMI_720x480p120_4x3 = 48, | 
|  | HDMI_720x480p120_16x9 = 49, | 
|  | HDMI_720x480i120_4x3 = 50, | 
|  | HDMI_720x480i120_16x9 = 51, | 
|  | HDMI_720x576p200_4x3 = 52, | 
|  | HDMI_720x576p200_16x9 = 53, | 
|  | HDMI_720x576i200_4x3 = 54, | 
|  | HDMI_720x576i200_16x9 = 55, | 
|  | HDMI_720x480p240_4x3 = 56, | 
|  | HDMI_720x480p240_16x9 = 57, | 
|  | HDMI_720x480i240_4x3 = 58, | 
|  | HDMI_720x480i240_16x9 = 59, | 
|  | /* Refet to CEA 861-F */ | 
|  | HDMI_1280x720p24_16x9 = 60, | 
|  | HDMI_1280x720p25_16x9 = 61, | 
|  | HDMI_1280x720p30_16x9 = 62, | 
|  | HDMI_1920x1080p120_16x9 = 63, | 
|  | HDMI_1920x1080p100_16x9 = 64, | 
|  | HDMI_1280x720p24_64x27 = 65, | 
|  | HDMI_1280x720p25_64x27 = 66, | 
|  | HDMI_1280x720p30_64x27 = 67, | 
|  | HDMI_1280x720p50_64x27 = 68, | 
|  | HDMI_1280x720p60_64x27 = 69, | 
|  | HDMI_1280x720p100_64x27 = 70, | 
|  | HDMI_1280x720p120_64x27 = 71, | 
|  | HDMI_1920x1080p24_64x27 = 72, | 
|  | HDMI_1920x1080p25_64x27 = 73, | 
|  | HDMI_1920x1080p30_64x27 = 74, | 
|  | HDMI_1920x1080p50_64x27 = 75, | 
|  | HDMI_1920x1080p60_64x27 = 76, | 
|  | HDMI_1920x1080p100_64x27 = 77, | 
|  | HDMI_1920x1080p120_64x27 = 78, | 
|  | HDMI_1680x720p24_64x27 = 79, | 
|  | HDMI_1680x720p25_64x27 = 80, | 
|  | HDMI_1680x720p30_64x27 = 81, | 
|  | HDMI_1680x720p50_64x27 = 82, | 
|  | HDMI_1680x720p60_64x27 = 83, | 
|  | HDMI_1680x720p100_64x27 = 84, | 
|  | HDMI_1680x720p120_64x27 = 85, | 
|  | HDMI_2560x1080p24_64x27 = 86, | 
|  | HDMI_2560x1080p25_64x27 = 87, | 
|  | HDMI_2560x1080p30_64x27 = 88, | 
|  | HDMI_2560x1080p50_64x27 = 89, | 
|  | HDMI_2560x1080p60_64x27 = 90, | 
|  | HDMI_2560x1080p100_64x27 = 91, | 
|  | HDMI_2560x1080p120_64x27 = 92, | 
|  | HDMI_3840x2160p24_16x9 = 93, | 
|  | HDMI_3840x2160p25_16x9 = 94, | 
|  | HDMI_3840x2160p30_16x9 = 95, | 
|  | HDMI_3840x2160p50_16x9 = 96, | 
|  | HDMI_3840x2160p60_16x9 = 97, | 
|  | HDMI_4096x2160p24_256x135 = 98, | 
|  | HDMI_4096x2160p25_256x135 = 99, | 
|  | HDMI_4096x2160p30_256x135 = 100, | 
|  | HDMI_4096x2160p50_256x135 = 101, | 
|  | HDMI_4096x2160p60_256x135 = 102, | 
|  | HDMI_3840x2160p24_64x27 = 103, | 
|  | HDMI_3840x2160p25_64x27 = 104, | 
|  | HDMI_3840x2160p30_64x27 = 105, | 
|  | HDMI_3840x2160p50_64x27 = 106, | 
|  | HDMI_3840x2160p60_64x27 = 107, | 
|  | HDMI_RESERVED = 108, | 
|  | /* | 
|  | the following vic is for those y420 mode | 
|  | they are all beyond OFFSET_HDMITX_VIC420(0x1000) | 
|  | and they has same vic with normal vic in the lower bytes. | 
|  | */ | 
|  | HDMI_VIC_Y420 =	HDMITX_VIC420_OFFSET, | 
|  | HDMI_3840x2160p50_16x9_Y420 = | 
|  | HDMITX_VIC420_OFFSET + HDMI_3840x2160p50_16x9, | 
|  | HDMI_3840x2160p60_16x9_Y420 = | 
|  | HDMITX_VIC420_OFFSET + HDMI_3840x2160p60_16x9, | 
|  | HDMI_4096x2160p50_256x135_Y420 = | 
|  | HDMITX_VIC420_OFFSET + HDMI_4096x2160p50_256x135, | 
|  | HDMI_4096x2160p60_256x135_Y420 = | 
|  | HDMITX_VIC420_OFFSET + HDMI_4096x2160p60_256x135, | 
|  | HDMI_3840x2160p50_64x27_Y420 = | 
|  | HDMITX_VIC420_OFFSET + HDMI_3840x2160p50_64x27, | 
|  | HDMI_3840x2160p60_64x27_Y420 = | 
|  | HDMITX_VIC420_OFFSET + HDMI_3840x2160p60_64x27, | 
|  | HDMIV_640x480p60hz = HDMITX_VESA_OFFSET, | 
|  | HDMIV_800x480p60hz, | 
|  | HDMIV_1280x480p60hz, | 
|  | HDMIV_800x600p60hz, | 
|  | HDMIV_852x480p60hz, | 
|  | HDMIV_854x480p60hz, | 
|  | HDMIV_1024x600p60hz, | 
|  | HDMIV_1024x768p60hz, | 
|  | HDMIV_1152x864p75hz, | 
|  | HDMIV_1280x600p60hz, | 
|  | HDMIV_1280x768p60hz, | 
|  | HDMIV_1280x800p60hz, | 
|  | HDMIV_1280x960p60hz, | 
|  | HDMIV_1280x1024p60hz, | 
|  | HDMIV_1360x768p60hz, | 
|  | HDMIV_1366x768p60hz, | 
|  | HDMIV_1400x1050p60hz, | 
|  | HDMIV_1440x900p60hz, | 
|  | HDMIV_1440x2560p60hz, | 
|  | HDMIV_1440x2560p70hz, | 
|  | HDMIV_1600x900p60hz, | 
|  | HDMIV_1600x1200p60hz, | 
|  | HDMIV_1680x1050p60hz, | 
|  | HDMIV_1920x1200p60hz, | 
|  | HDMIV_2160x1200p90hz, | 
|  | HDMIV_2560x1080p60hz, | 
|  | HDMIV_2560x1440p60hz, | 
|  | HDMIV_2560x1600p60hz, | 
|  | HDMIV_3440x1440p60hz, | 
|  | HDMIV_480x320p60hz, | 
|  | }; | 
|  |  | 
|  | /* CEA TIMING STRUCT DEFINITION */ | 
|  | struct hdmi_cea_timing { | 
|  | unsigned int pixel_freq; /* Unit: 1000 */ | 
|  | unsigned int h_freq; /* Unit: Hz */ | 
|  | unsigned int v_freq; /* Unit: 0.001 Hz */ | 
|  | unsigned int vsync_polarity:1; /* 1: positive  0: negative */ | 
|  | unsigned int hsync_polarity:1; | 
|  | unsigned short h_active; | 
|  | unsigned short h_total; | 
|  | unsigned short h_blank; | 
|  | unsigned short h_front; | 
|  | unsigned short h_sync; | 
|  | unsigned short h_back; | 
|  | unsigned short v_active; | 
|  | unsigned short v_total; | 
|  | unsigned short v_blank; | 
|  | unsigned short v_front; | 
|  | unsigned short v_sync; | 
|  | unsigned short v_back; | 
|  | unsigned short v_sync_ln; | 
|  | }; | 
|  |  | 
|  | /* Refer CEA861-D Page 116 Table 55 */ | 
|  | struct dtd { | 
|  | unsigned short pixel_clock; | 
|  | unsigned short h_active; | 
|  | unsigned short h_blank; | 
|  | unsigned short v_active; | 
|  | unsigned short v_blank; | 
|  | unsigned short h_sync_offset; | 
|  | unsigned short h_sync; | 
|  | unsigned short v_sync_offset; | 
|  | unsigned short v_sync; | 
|  | unsigned char h_image_size; | 
|  | unsigned char v_image_size; | 
|  | unsigned char h_border; | 
|  | unsigned char v_border; | 
|  | unsigned char flags; | 
|  | enum hdmi_vic vic; | 
|  | }; | 
|  |  | 
|  | /* Dolby Version support information from EDID*/ | 
|  | /* Refer to DV Spec version2.9 page26 to page39*/ | 
|  | enum block_type { | 
|  | ERROR_NULL = 0, | 
|  | ERROR_LENGTH, | 
|  | ERROR_OUI, | 
|  | CORRECT, | 
|  | }; | 
|  |  | 
|  |  | 
|  |  | 
|  | #define DV_IEEE_OUI             0x00D046 | 
|  | #define HDR10_PLUS_IEEE_OUI	0x90848B | 
|  |  | 
|  | #define HDMI_PACKET_VEND        1 | 
|  | #define HDMI_PACKET_DRM		0x86 | 
|  |  | 
|  | #define CMD_CONF_OFFSET         (0x14 << 24) | 
|  | #define CONF_AVI_BT2020         (CMD_CONF_OFFSET + 0X2000 + 0x00) | 
|  | #define CLR_AVI_BT2020          0x0 | 
|  | #define SET_AVI_BT2020          0x1 | 
|  | /* set value as COLORSPACE_RGB444, YUV422, YUV444, YUV420 */ | 
|  | #define CONF_AVI_RGBYCC_INDIC   (CMD_CONF_OFFSET + 0X2000 + 0x01) | 
|  | #define CONF_AVI_Q01            (CMD_CONF_OFFSET + 0X2000 + 0x02) | 
|  | #define RGB_RANGE_DEFAULT       0 | 
|  | #define RGB_RANGE_LIM           1 | 
|  | #define RGB_RANGE_FUL           2 | 
|  | #define RGB_RANGE_RSVD          3 | 
|  | #define CONF_AVI_YQ01           (CMD_CONF_OFFSET + 0X2000 + 0x03) | 
|  | #define YCC_RANGE_LIM           0 | 
|  | #define YCC_RANGE_FUL           1 | 
|  | #define YCC_RANGE_RSVD          2 | 
|  |  | 
|  | struct hdr_info { | 
|  | unsigned int hdr_sup_eotf_sdr:1; | 
|  | unsigned int hdr_sup_eotf_hdr:1; | 
|  | unsigned int hdr_sup_eotf_smpte_st_2084:1; | 
|  | unsigned int hdr_sup_eotf_hlg:1; | 
|  | unsigned int hdr_sup_SMD_type1:1; | 
|  | unsigned char hdr_lum_max; | 
|  | unsigned char hdr_lum_avg; | 
|  | unsigned char hdr_lum_min; | 
|  | unsigned char rawdata[7]; | 
|  | }; | 
|  |  | 
|  | struct hdr10_plus_info { | 
|  | uint32_t ieeeoui; | 
|  | uint8_t length; | 
|  | uint8_t application_version; | 
|  | }; | 
|  |  | 
|  | enum hdmi_hdr_transfer { | 
|  | T_UNKNOWN = 0, | 
|  | T_BT709, | 
|  | T_UNDEF, | 
|  | T_BT601, | 
|  | T_BT470M, | 
|  | T_BT470BG, | 
|  | T_SMPTE170M, | 
|  | T_SMPTE240M, | 
|  | T_LINEAR, | 
|  | T_LOG100, | 
|  | T_LOG316, | 
|  | T_IEC61966_2_4, | 
|  | T_BT1361E, | 
|  | T_IEC61966_2_1, | 
|  | T_BT2020_10, | 
|  | T_BT2020_12, | 
|  | T_SMPTE_ST_2084, | 
|  | T_SMPTE_ST_28, | 
|  | T_HLG, | 
|  | }; | 
|  |  | 
|  | enum hdmi_hdr_color { | 
|  | C_UNKNOWN = 0, | 
|  | C_BT709, | 
|  | C_UNDEF, | 
|  | C_BT601, | 
|  | C_BT470M, | 
|  | C_BT470BG, | 
|  | C_SMPTE170M, | 
|  | C_SMPTE240M, | 
|  | C_FILM, | 
|  | C_BT2020, | 
|  | }; | 
|  |  | 
|  | /* master_display_info for display device */ | 
|  | struct master_display_info_s { | 
|  | u32 present_flag; | 
|  | u32 features;			/* feature bits bt2020/2084 */ | 
|  | u32 primaries[3][2];		/* normalized 50000 in G,B,R order */ | 
|  | u32 white_point[2]; 	/* normalized 50000 */ | 
|  | u32 luminance[2];		/* max/min lumin, normalized 10000 */ | 
|  | u32 max_content;		/* Maximum Content Light Level */ | 
|  | u32 max_frame_average;	/* Maximum Frame-average Light Level */ | 
|  | }; | 
|  |  | 
|  | struct hdr10plus_para { | 
|  | uint8_t application_version; | 
|  | uint8_t targeted_max_lum; | 
|  | uint8_t average_maxrgb; | 
|  | uint8_t distribution_values[9]; | 
|  | uint8_t num_bezier_curve_anchors; | 
|  | uint32_t knee_point_x; | 
|  | uint32_t knee_point_y; | 
|  | uint8_t bezier_curve_anchors[9]; | 
|  | uint8_t graphics_overlay_flag; | 
|  | uint8_t no_delay_flag; | 
|  | }; | 
|  |  | 
|  | struct dv_info { | 
|  | unsigned char rawdata[27]; | 
|  | enum block_type block_flag; | 
|  | uint32_t ieeeoui; | 
|  | uint8_t ver; /* 0 or 1 or 2*/ | 
|  | uint8_t length;/*ver1: 15 or 12*/ | 
|  |  | 
|  | uint8_t sup_yuv422_12bit:1; | 
|  | /* if as 0, then support RGB tunnel mode */ | 
|  | uint8_t sup_2160p60hz:1; | 
|  | /* if as 0, then support 2160p30hz */ | 
|  | uint8_t sup_global_dimming:1; | 
|  | uint16_t Rx; | 
|  | uint16_t Ry; | 
|  | uint16_t Gx; | 
|  | uint16_t Gy; | 
|  | uint16_t Bx; | 
|  | uint16_t By; | 
|  | uint16_t Wx; | 
|  | uint16_t Wy; | 
|  | uint16_t tminPQ; | 
|  | uint16_t tmaxPQ; | 
|  | uint8_t dm_major_ver; | 
|  | uint8_t dm_minor_ver; | 
|  | uint8_t dm_version; | 
|  | uint8_t tmaxLUM; | 
|  | uint8_t colorimetry:1;/* ver1*/ | 
|  | uint8_t tminLUM; | 
|  | uint8_t low_latency;/* ver1_12 and 2*/ | 
|  | uint8_t sup_backlight_control:1;/*only ver2*/ | 
|  | uint8_t backlt_min_luma;/*only ver2*/ | 
|  | uint8_t Interface;/*only ver2*/ | 
|  | uint8_t sup_10b_12b_444;/*only ver2*/ | 
|  | }; | 
|  |  | 
|  | enum eotf_type { | 
|  | EOTF_T_NULL = 0, | 
|  | EOTF_T_DOLBYVISION, | 
|  | EOTF_T_HDR10, | 
|  | EOTF_T_SDR, | 
|  | EOTF_T_LL_MODE, | 
|  | EOTF_T_MAX, | 
|  | }; | 
|  |  | 
|  | enum mode_type { | 
|  | YUV422_BIT12 = 0, | 
|  | RGB_8BIT, | 
|  | RGB_10_12BIT, | 
|  | YUV444_10_12BIT, | 
|  | }; | 
|  |  | 
|  | /* Dolby Version VSIF  parameter*/ | 
|  | struct dv_vsif_para { | 
|  | uint8_t ver; /* 0 or 1 or 2*/ | 
|  | uint8_t length;/*ver1: 15 or 12*/ | 
|  | union { | 
|  | struct { | 
|  | uint8_t low_latency:1; | 
|  | uint8_t dobly_vision_signal:1; | 
|  | uint8_t backlt_ctrl_MD_present:1; | 
|  | uint8_t auxiliary_MD_present:1; | 
|  | uint8_t eff_tmax_PQ_hi; | 
|  | uint8_t eff_tmax_PQ_low; | 
|  | uint8_t auxiliary_runmode; | 
|  | uint8_t auxiliary_runversion; | 
|  | uint8_t auxiliary_debug0; | 
|  | } ver2; | 
|  | } vers; | 
|  | }; | 
|  |  | 
|  | #define Y420CMDB_MAX 32 | 
|  | #define VIC_MAX_NUM  256 | 
|  | struct rx_cap { | 
|  | unsigned int native_Mode; | 
|  | /*video*/ | 
|  | unsigned int VIC[VIC_MAX_NUM]; | 
|  | unsigned int VIC_count; | 
|  | unsigned int native_VIC; | 
|  | /*vendor*/ | 
|  | unsigned int IEEEOUI; | 
|  | unsigned int Max_TMDS_Clock1; /* HDMI1.4b TMDS_CLK */ | 
|  | unsigned int HF_IEEEOUI;	/* For HDMI Forum */ | 
|  | unsigned int Max_TMDS_Clock2; /* HDMI2.0 TMDS_CLK */ | 
|  | /* CEA861-F, Table 56, Colorimetry Data Block */ | 
|  | unsigned int colorimetry_data; | 
|  | unsigned int scdc_present:1; | 
|  | unsigned int scdc_rr_capable:1; /* SCDC read request */ | 
|  | unsigned int lte_340mcsc_scramble:1; | 
|  | unsigned support_ycbcr444_flag:1; | 
|  | unsigned support_ycbcr422_flag:1; | 
|  | unsigned int dc_y444:1; | 
|  | unsigned int dc_30bit:1; | 
|  | unsigned int dc_36bit:1; | 
|  | unsigned int dc_48bit:1; | 
|  | unsigned int dc_y420:1; | 
|  | unsigned int dc_30bit_420:1; | 
|  | unsigned int dc_36bit_420:1; | 
|  | unsigned int dc_48bit_420:1; | 
|  | unsigned char edid_version; | 
|  | unsigned char edid_revision; | 
|  | unsigned int ColorDeepSupport; | 
|  | unsigned int Video_Latency; | 
|  | unsigned int Audio_Latency; | 
|  | unsigned int Interlaced_Video_Latency; | 
|  | unsigned int Interlaced_Audio_Latency; | 
|  | unsigned int threeD_present; | 
|  | unsigned int threeD_Multi_present; | 
|  | unsigned int hdmi_vic_LEN; | 
|  | enum hdmi_vic preferred_mode; | 
|  | struct dtd dtd[16]; | 
|  | unsigned char dtd_idx; | 
|  | unsigned char flag_vfpdb; | 
|  | unsigned char number_of_dtd; | 
|  | unsigned char pref_colorspace; | 
|  | struct hdr_info hdr_info; | 
|  | struct dv_info dv_info; | 
|  | struct hdr10_plus_info hdr10plus_info; | 
|  | /*blk0 check sum*/ | 
|  | unsigned char chksum; | 
|  | /*blk0-3 check sum*/ | 
|  | unsigned char checksum[10]; | 
|  | unsigned char edid_changed; | 
|  | /* for total = 32*8 = 256 VICs */ | 
|  | /* for Y420CMDB bitmap */ | 
|  | unsigned char bitmap_valid; | 
|  | unsigned char bitmap_length; | 
|  | unsigned char y420_all_vic; | 
|  | unsigned char y420cmdb_bitmap[Y420CMDB_MAX]; | 
|  | }; | 
|  |  | 
|  | enum color_attr_type { | 
|  | COLOR_ATTR_YCBCR444_12BIT = 0, | 
|  | COLOR_ATTR_YCBCR422_12BIT, | 
|  | COLOR_ATTR_YCBCR420_12BIT, | 
|  | COLOR_ATTR_RGB_12BIT, | 
|  | COLOR_ATTR_YCBCR444_10BIT, | 
|  | COLOR_ATTR_YCBCR422_10BIT, | 
|  | COLOR_ATTR_YCBCR420_10BIT, | 
|  | COLOR_ATTR_RGB_10BIT, | 
|  | COLOR_ATTR_YCBCR444_8BIT, | 
|  | COLOR_ATTR_YCBCR422_8BIT, | 
|  | COLOR_ATTR_YCBCR420_8BIT, | 
|  | COLOR_ATTR_RGB_8BIT, | 
|  | COLOR_ATTR_RESERVED, | 
|  | }; | 
|  |  | 
|  | struct color_attr_to_string { | 
|  | enum color_attr_type color_attr; | 
|  | const char *color_attr_string; | 
|  | }; | 
|  |  | 
|  | enum hdmi_color_depth { | 
|  | HDMI_COLOR_DEPTH_24B = 4, | 
|  | HDMI_COLOR_DEPTH_30B = 5, | 
|  | HDMI_COLOR_DEPTH_36B = 6, | 
|  | HDMI_COLOR_DEPTH_48B = 7, | 
|  | }; | 
|  |  | 
|  | enum hdmi_color_format { | 
|  | HDMI_COLOR_FORMAT_RGB, | 
|  | HDMI_COLOR_FORMAT_422, | 
|  | HDMI_COLOR_FORMAT_444, | 
|  | HDMI_COLOR_FORMAT_420, | 
|  | }; | 
|  |  | 
|  | enum hdmi_color_range { | 
|  | HDMI_COLOR_RANGE_LIM, | 
|  | HDMI_COLOR_RANGE_FUL, | 
|  | }; | 
|  |  | 
|  | enum hdmi_audio_packet { | 
|  | HDMI_AUDIO_PACKET_SMP = 0x02, | 
|  | HDMI_AUDIO_PACKET_1BT = 0x07, | 
|  | HDMI_AUDIO_PACKET_DST = 0x08, | 
|  | HDMI_AUDIO_PACKET_HBR = 0x09, | 
|  | }; | 
|  |  | 
|  | /* get hdmi cea timing | 
|  | * t: struct hdmi_cea_timing * | 
|  | */ | 
|  | #define GET_TIMING(name) (t->name) | 
|  |  | 
|  | struct parse_cd { | 
|  | enum hdmi_color_depth cd; | 
|  | const char *name; | 
|  | }; | 
|  |  | 
|  | struct parse_cs { | 
|  | enum hdmi_color_format cs; | 
|  | const char *name; | 
|  | }; | 
|  |  | 
|  | struct parse_cr { | 
|  | enum hdmi_color_format cr; | 
|  | const char *name; | 
|  | }; | 
|  |  | 
|  | #define EDID_BLK_NO	4 | 
|  | #define EDID_BLK_SIZE	128 | 
|  | struct hdmi_format_para { | 
|  | enum hdmi_vic vic; | 
|  | char *name; /* full name, 1280x720p60hz */ | 
|  | char *sname; /* short name, 1280x720p60hz -> 720p60hz */ | 
|  | char ext_name[32]; | 
|  | enum hdmi_color_depth cd; /* cd8, cd10 or cd12 */ | 
|  | enum hdmi_color_format cs; /* rgb, y444, y422, y420 */ | 
|  | enum hdmi_color_range cr; /* limit, full */ | 
|  | unsigned int pixel_repetition_factor; | 
|  | unsigned int progress_mode:1; /* 0: Interlace  1: Progressive */ | 
|  | unsigned int scrambler_en:1; | 
|  | unsigned int tmds_clk_div40:1; | 
|  | unsigned int tmds_clk; /* Unit: 1000 */ | 
|  | struct hdmi_cea_timing timing; | 
|  | }; | 
|  |  | 
|  | struct hdmi_support_mode { | 
|  | enum hdmi_vic vic; | 
|  | char *sname; | 
|  | char y420; | 
|  | }; | 
|  |  | 
|  | struct hdmitx_dev { | 
|  | unsigned char rx_edid[512]; /* some RX may exceeds 256Bytes */ | 
|  | struct { | 
|  | int (*get_hpd_state)(void); | 
|  | int (*read_edid)(unsigned char *buf, unsigned char addr, | 
|  | unsigned char blk_no); | 
|  | void (*turn_off)(void); | 
|  | void (*list_support_modes)(void); | 
|  | void (*dump_regs)(void); | 
|  | void (*test_bist)(unsigned int mode); | 
|  | void (*output_blank)(unsigned int blank); | 
|  | } HWOp; | 
|  | unsigned char rawedid[EDID_BLK_SIZE * EDID_BLK_NO]; | 
|  | struct rx_cap RXCap; | 
|  | struct hdmi_format_para *para; | 
|  | enum hdmi_vic vic; | 
|  | unsigned int frac_rate_policy; | 
|  | unsigned int mode420; | 
|  | unsigned int dc30; | 
|  | enum eotf_type hdmi_current_eotf_type; | 
|  | enum mode_type hdmi_current_tunnel_mode; | 
|  | /* Add dongle_mode, clock, phy may be different from mbox */ | 
|  | unsigned int dongle_mode; | 
|  | }; | 
|  |  | 
|  | struct hdmi_format_para *hdmi_get_fmt_paras(enum hdmi_vic vic); | 
|  | enum hdmi_vic hdmi_get_fmt_vic(char const *name); | 
|  | void hdmi_parse_attr(struct hdmi_format_para *para, char const *name); | 
|  | void hdmi_tx_set(struct hdmitx_dev *hdev); | 
|  | int hdmi_outputmode_check(char *mode); | 
|  | /* Parsing RAW EDID data from edid to pRXCap */ | 
|  | unsigned int hdmi_edid_parsing(unsigned char *edid, struct rx_cap *pRXCap); | 
|  | struct hdmi_format_para *hdmi_match_dtd_paras(struct dtd *t); | 
|  |  | 
|  | extern void hdmitx_set_drm_pkt(struct master_display_info_s *data); | 
|  | #ifndef CONFIG_AML_HDMITX20 | 
|  | void __attribute__((weak))hdmitx_set_drm_pkt(struct master_display_info_s *data) | 
|  | { | 
|  | } | 
|  | #endif | 
|  |  | 
|  | void hdmitx_set_vsif_pkt(enum eotf_type type, enum mode_type tunnel_mode, | 
|  | struct dv_vsif_para *data); | 
|  | void hdmitx_set_hdr10plus_pkt(unsigned int flag, | 
|  | struct hdr10plus_para *data); | 
|  |  | 
|  | /* | 
|  | * Must be called at uboot | 
|  | */ | 
|  | void hdmi_tx_init(void); | 
|  |  | 
|  | extern struct hdmitx_dev hdmitx_device; | 
|  |  | 
|  | #ifndef printk | 
|  | #define printk printf | 
|  | #endif | 
|  | #ifndef pr_info | 
|  | #define pr_info printf | 
|  | #endif | 
|  |  | 
|  | #define hdmitx_debug() /* printf("hd: %s[%d]\n", __func__, __LINE__) */ | 
|  |  | 
|  | extern struct hdr_info *hdmitx_get_rx_hdr_info(void); | 
|  | #ifndef CONFIG_AML_HDMITX20 | 
|  | struct hdr_info * __attribute__((weak))hdmitx_get_rx_hdr_info(void) | 
|  | { | 
|  | return NULL; | 
|  | } | 
|  | #endif | 
|  |  | 
|  | #endif |