123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372 |
- #ifndef _DRV_HDMI_EXTERNAL_H
- #define _DRV_HDMI_EXTERNAL_H
- #include "drv_types.h"
- #include "plf_timing_id.h"
- #include "gpio_pin_define.h"
- #if (CONFIG_CHIPID==0x531)
- #include "../hdmi/531/mhl/cbus_mid.h"
- #elif (CONFIG_CHIPID==0x331)
- #include "../hdmi/331/mhl/cbus_mid.h"
- #elif (CONFIG_CHIPID==0x533)
- #include "../hdmi/533/mhl/cbus_mid.h"
- #elif (CONFIG_CHIPID==0x131)
- #include "../hdmi/131/mhl/cbus_mid.h"
- #elif (CONFIG_CHIPID==0x6710)
- #include "../hdmi/6710/mhl/cbus_mid.h"
- #elif (CONFIG_CHIPID==0x8506)
- #include "../hdmi/8506/mhl/cbus_mid.h"
- #endif
- typedef enum
- {
- HDMI_1 = 0,
- HDMI_2,
- HDMI_3,
- HDMI_4,
- HDMI_5,
- HDMI_6,
- HDMI_7,
- HDMI_8,
- HDMI_NUM,
- HDMI_NULL = -1
- } HDMI_NUM_T ;
- typedef enum
- {
- HDMI_PORT_A = 0,
- HDMI_PORT_B,
- HDMI_PORT_C,
- HDMI_PORT_D,
- HDMI_PORT_NUM,
- HDMI_PORT_NULL = -1
- } HDMI_PORT_T ;
- /* HDMI Timing struct */
- typedef struct _HDMI_Timing_Param_t{
- PLF_VideoID_t eVideoID;
- UINT16 wHActive;
- UINT16 wVActive; //one field
- UINT8 wVFreq;
- BOOL fInterlace;
- }HDMI_TIMING_PARAM_t;
- typedef struct {
- INT8 eBootSrc;
- UINT8 dSupportMaxHz;
- #if (CONFIG_CHIPID!=0x330)
- GPIOPin_t eARC_5V_GPIO;
- HDMI_PORT_T eARC_Port;
- #endif
- }HDMI_Customize_st;
- //HDMI EQ mode
- typedef enum
- {
- HDMI_EQ_INDEX_DEFAULT = 0,
- HDMI_EQ_INDEX_1,
- HDMI_EQ_INDEX_2 ,
- HDMI_EQ_INDEX_3 ,
- HDMI_EQ_INDEX_4,
- HDMI_EQ_INDEX_5,
- HDMI_EQ_INDEX_6,
- HDMI_EQ_INDEX_7,
- HDMI_EQ_INDEX_8,
- HDMI_EQ_INDEX_9,
- HDMI_EQ_INDEX_10
- } HDMI_EQ_INDEX_e;
- //start of hdmi infoframe typedfine
- enum hdmi_infoframe_type {
- HDMI_INFOFRAME_TYPE_VENDOR = 0x81,
- HDMI_INFOFRAME_TYPE_AVI = 0x82,
- HDMI_INFOFRAME_TYPE_SPD = 0x83,
- HDMI_INFOFRAME_TYPE_AUDIO = 0x84,
- HDMI_INFOFRAME_TYPE_MPEG = 0x85,
- HDMI_INFOFRAME_TYPE_NTSC_VBI = 0x86,
- };
- #define HDMI_IEEE_OUI 0x000c03
- #define HDMI_FORUM_IEEE_OUI 0xc45dd8
- #define HDMI_INFOFRAME_HEADER_SIZE 4
- #define HDMI_AVI_INFOFRAME_SIZE 13
- #define HDMI_SPD_INFOFRAME_SIZE 25
- #define HDMI_AUDIO_INFOFRAME_SIZE 10
- #define HDMI_INFOFRAME_SIZE(type) \
- (HDMI_INFOFRAME_HEADER_SIZE + HDMI_ ## type ## _INFOFRAME_SIZE)
- struct hdmi_any_infoframe {
- enum hdmi_infoframe_type type;
- unsigned char version;
- unsigned char length;
- };
- enum hdmi_colorspace {
- HDMI_COLORSPACE_RGB,
- HDMI_COLORSPACE_YUV422,
- HDMI_COLORSPACE_YUV444,
- HDMI_COLORSPACE_YUV420,
- HDMI_COLORSPACE_RESERVED4,
- HDMI_COLORSPACE_RESERVED5,
- HDMI_COLORSPACE_RESERVED6,
- HDMI_COLORSPACE_IDO_DEFINED,
- };
- enum hdmi_scan_mode {
- HDMI_SCAN_MODE_NONE,
- HDMI_SCAN_MODE_OVERSCAN,
- HDMI_SCAN_MODE_UNDERSCAN,
- HDMI_SCAN_MODE_RESERVED,
- };
- enum hdmi_colorimetry {
- HDMI_COLORIMETRY_NONE,
- HDMI_COLORIMETRY_ITU_601,
- HDMI_COLORIMETRY_ITU_709,
- HDMI_COLORIMETRY_EXTENDED,
- };
- enum hdmi_picture_aspect {
- HDMI_PICTURE_ASPECT_NONE,
- HDMI_PICTURE_ASPECT_4_3,
- HDMI_PICTURE_ASPECT_16_9,
- HDMI_PICTURE_ASPECT_64_27,
- HDMI_PICTURE_ASPECT_256_135,
- HDMI_PICTURE_ASPECT_RESERVED,
- };
- enum hdmi_active_aspect {
- HDMI_ACTIVE_ASPECT_16_9_TOP = 2,
- HDMI_ACTIVE_ASPECT_14_9_TOP = 3,
- HDMI_ACTIVE_ASPECT_16_9_CENTER = 4,
- HDMI_ACTIVE_ASPECT_PICTURE = 8,
- HDMI_ACTIVE_ASPECT_4_3 = 9,
- HDMI_ACTIVE_ASPECT_16_9 = 10,
- HDMI_ACTIVE_ASPECT_14_9 = 11,
- HDMI_ACTIVE_ASPECT_4_3_SP_14_9 = 13,
- HDMI_ACTIVE_ASPECT_16_9_SP_14_9 = 14,
- HDMI_ACTIVE_ASPECT_16_9_SP_4_3 = 15,
- };
- enum hdmi_extended_colorimetry {
- HDMI_EXTENDED_COLORIMETRY_XV_YCC_601,
- HDMI_EXTENDED_COLORIMETRY_XV_YCC_709,
- HDMI_EXTENDED_COLORIMETRY_S_YCC_601,
- HDMI_EXTENDED_COLORIMETRY_ADOBE_YCC_601,
- HDMI_EXTENDED_COLORIMETRY_ADOBE_RGB,
- /* The following EC values are only defined in CEA-861-F. */
- HDMI_EXTENDED_COLORIMETRY_BT2020_CONST_LUM,
- HDMI_EXTENDED_COLORIMETRY_BT2020,
- HDMI_EXTENDED_COLORIMETRY_RESERVED,
- };
- enum hdmi_quantization_range {
- HDMI_QUANTIZATION_RANGE_DEFAULT,
- HDMI_QUANTIZATION_RANGE_LIMITED,
- HDMI_QUANTIZATION_RANGE_FULL,
- HDMI_QUANTIZATION_RANGE_RESERVED,
- };
- /* non-uniform picture scaling */
- enum hdmi_nups {
- HDMI_NUPS_UNKNOWN,
- HDMI_NUPS_HORIZONTAL,
- HDMI_NUPS_VERTICAL,
- HDMI_NUPS_BOTH,
- };
- enum hdmi_ycc_quantization_range {
- HDMI_YCC_QUANTIZATION_RANGE_LIMITED,
- HDMI_YCC_QUANTIZATION_RANGE_FULL,
- };
- enum hdmi_content_type {
- HDMI_CONTENT_TYPE_GRAPHICS,
- HDMI_CONTENT_TYPE_PHOTO,
- HDMI_CONTENT_TYPE_CINEMA,
- HDMI_CONTENT_TYPE_GAME,
- };
- struct hdmi_avi_infoframe {
- enum hdmi_infoframe_type type;
- unsigned char version;
- unsigned char length;
- enum hdmi_colorspace colorspace;
- enum hdmi_scan_mode scan_mode;
- enum hdmi_colorimetry colorimetry;
- enum hdmi_picture_aspect picture_aspect;
- enum hdmi_active_aspect active_aspect;
- BOOL itc;
- enum hdmi_extended_colorimetry extended_colorimetry;
- enum hdmi_quantization_range quantization_range;
- enum hdmi_nups nups;
- unsigned char video_code;
- enum hdmi_ycc_quantization_range ycc_quantization_range;
- enum hdmi_content_type content_type;
- unsigned char pixel_repeat;
- unsigned short top_bar;
- unsigned short bottom_bar;
- unsigned short left_bar;
- unsigned short right_bar;
- };
- enum hdmi_spd_sdi {
- HDMI_SPD_SDI_UNKNOWN,
- HDMI_SPD_SDI_DSTB,
- HDMI_SPD_SDI_DVDP,
- HDMI_SPD_SDI_DVHS,
- HDMI_SPD_SDI_HDDVR,
- HDMI_SPD_SDI_DVC,
- HDMI_SPD_SDI_DSC,
- HDMI_SPD_SDI_VCD,
- HDMI_SPD_SDI_GAME,
- HDMI_SPD_SDI_PC,
- HDMI_SPD_SDI_BD,
- HDMI_SPD_SDI_SACD,
- HDMI_SPD_SDI_HDDVD,
- HDMI_SPD_SDI_PMP,
- };
- struct hdmi_spd_infoframe {
- enum hdmi_infoframe_type type;
- unsigned char version;
- unsigned char length;
- char vendor[8];
- char product[16];
- enum hdmi_spd_sdi sdi;
- };
- enum hdmi_audio_coding_type {
- HDMI_AUDIO_CODING_TYPE_STREAM, HDMI_AUDIO_CODING_TYPE_PCM,
- HDMI_AUDIO_CODING_TYPE_AC3,
- HDMI_AUDIO_CODING_TYPE_MPEG1,
- HDMI_AUDIO_CODING_TYPE_MP3,
- HDMI_AUDIO_CODING_TYPE_MPEG2,
- HDMI_AUDIO_CODING_TYPE_AAC_LC,
- HDMI_AUDIO_CODING_TYPE_DTS,
- HDMI_AUDIO_CODING_TYPE_ATRAC,
- HDMI_AUDIO_CODING_TYPE_DSD,
- HDMI_AUDIO_CODING_TYPE_EAC3,
- HDMI_AUDIO_CODING_TYPE_DTS_HD,
- HDMI_AUDIO_CODING_TYPE_MLP,
- HDMI_AUDIO_CODING_TYPE_DST,
- HDMI_AUDIO_CODING_TYPE_WMA_PRO,
- HDMI_AUDIO_CODING_TYPE_CXT,
- };
- enum hdmi_audio_sample_size {
- HDMI_AUDIO_SAMPLE_SIZE_STREAM,
- HDMI_AUDIO_SAMPLE_SIZE_16,
- HDMI_AUDIO_SAMPLE_SIZE_20,
- HDMI_AUDIO_SAMPLE_SIZE_24,
- };
- enum hdmi_audio_sample_frequency {
- HDMI_AUDIO_SAMPLE_FREQUENCY_STREAM,
- HDMI_AUDIO_SAMPLE_FREQUENCY_32000,
- HDMI_AUDIO_SAMPLE_FREQUENCY_44100,
- HDMI_AUDIO_SAMPLE_FREQUENCY_48000,
- HDMI_AUDIO_SAMPLE_FREQUENCY_88200,
- HDMI_AUDIO_SAMPLE_FREQUENCY_96000,
- HDMI_AUDIO_SAMPLE_FREQUENCY_176400,
- HDMI_AUDIO_SAMPLE_FREQUENCY_192000,
- };
- enum hdmi_audio_coding_type_ext {
- /* Refer to Audio Coding Type (CT) field in Data Byte 1 */
- HDMI_AUDIO_CODING_TYPE_EXT_CT,
- /*
- * The next three CXT values are defined in CEA-861-E only.
- * They do not exist in older versions, and in CEA-861-F they are
- * defined as 'Not in use'.
- */
- HDMI_AUDIO_CODING_TYPE_EXT_HE_AAC,
- HDMI_AUDIO_CODING_TYPE_EXT_HE_AAC_V2,
- HDMI_AUDIO_CODING_TYPE_EXT_MPEG_SURROUND,
- /* The following CXT values are only defined in CEA-861-F. */
- HDMI_AUDIO_CODING_TYPE_EXT_MPEG4_HE_AAC,
- HDMI_AUDIO_CODING_TYPE_EXT_MPEG4_HE_AAC_V2,
- HDMI_AUDIO_CODING_TYPE_EXT_MPEG4_AAC_LC,
- HDMI_AUDIO_CODING_TYPE_EXT_DRA,
- HDMI_AUDIO_CODING_TYPE_EXT_MPEG4_HE_AAC_SURROUND,
- HDMI_AUDIO_CODING_TYPE_EXT_MPEG4_AAC_LC_SURROUND = 10,
- };
- struct hdmi_audio_infoframe {
- enum hdmi_infoframe_type type;
- unsigned char version;
- unsigned char length;
- unsigned char channels;
- enum hdmi_audio_coding_type coding_type;
- enum hdmi_audio_sample_size sample_size;
- enum hdmi_audio_sample_frequency sample_frequency;
- enum hdmi_audio_coding_type_ext coding_type_ext;
- unsigned char channel_allocation;
- unsigned char level_shift_value;
- BOOL downmix_inhibit;
- };
- enum hdmi_3d_structure {
- HDMI_3D_STRUCTURE_INVALID = -1,
- HDMI_3D_STRUCTURE_FRAME_PACKING = 0,
- HDMI_3D_STRUCTURE_FIELD_ALTERNATIVE,
- HDMI_3D_STRUCTURE_LINE_ALTERNATIVE,
- HDMI_3D_STRUCTURE_SIDE_BY_SIDE_FULL,
- HDMI_3D_STRUCTURE_L_DEPTH,
- HDMI_3D_STRUCTURE_L_DEPTH_GFX_GFX_DEPTH,
- HDMI_3D_STRUCTURE_TOP_AND_BOTTOM,
- HDMI_3D_STRUCTURE_SIDE_BY_SIDE_HALF = 8,
- };
- struct hdmi_vendor_infoframe {
- enum hdmi_infoframe_type type;
- unsigned char version;
- unsigned char length;
- unsigned int oui;
- UINT8 vic;
- enum hdmi_3d_structure s3d_struct;
- unsigned int s3d_ext_data;
- };
- union hdmi_vendor_any_infoframe {
- struct {
- enum hdmi_infoframe_type type;
- unsigned char version;
- unsigned char length;
- unsigned int oui;
- } any;
- struct hdmi_vendor_infoframe hdmi;
- };
- /**
- * union hdmi_infoframe - overall union of all abstract infoframe representations
- * @any: generic infoframe
- * @avi: avi infoframe
- * @spd: spd infoframe
- * @vendor: union of all vendor infoframes
- * @audio: audio infoframe
- *
- * This is used by the generic pack function. This works since all infoframes
- * have the same header which also indicates which type of infoframe should be
- * packed.
- */
- union hdmi_infoframe {
- struct hdmi_any_infoframe any;
- struct hdmi_avi_infoframe avi;
- struct hdmi_spd_infoframe spd;
- union hdmi_vendor_any_infoframe vendor;
- struct hdmi_audio_infoframe audio;
- };
- //end of inforframe typedefine
- #endif /* __DRV_HDMI_H__ */
|