drv_hdmi_external.h 8.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372
  1. #ifndef _DRV_HDMI_EXTERNAL_H
  2. #define _DRV_HDMI_EXTERNAL_H
  3. #include "drv_types.h"
  4. #include "plf_timing_id.h"
  5. #include "gpio_pin_define.h"
  6. #if (CONFIG_CHIPID==0x531)
  7. #include "../hdmi/531/mhl/cbus_mid.h"
  8. #elif (CONFIG_CHIPID==0x331)
  9. #include "../hdmi/331/mhl/cbus_mid.h"
  10. #elif (CONFIG_CHIPID==0x533)
  11. #include "../hdmi/533/mhl/cbus_mid.h"
  12. #elif (CONFIG_CHIPID==0x131)
  13. #include "../hdmi/131/mhl/cbus_mid.h"
  14. #elif (CONFIG_CHIPID==0x6710)
  15. #include "../hdmi/6710/mhl/cbus_mid.h"
  16. #elif (CONFIG_CHIPID==0x8506)
  17. #include "../hdmi/8506/mhl/cbus_mid.h"
  18. #endif
  19. typedef enum
  20. {
  21. HDMI_1 = 0,
  22. HDMI_2,
  23. HDMI_3,
  24. HDMI_4,
  25. HDMI_5,
  26. HDMI_6,
  27. HDMI_7,
  28. HDMI_8,
  29. HDMI_NUM,
  30. HDMI_NULL = -1
  31. } HDMI_NUM_T ;
  32. typedef enum
  33. {
  34. HDMI_PORT_A = 0,
  35. HDMI_PORT_B,
  36. HDMI_PORT_C,
  37. HDMI_PORT_D,
  38. HDMI_PORT_NUM,
  39. HDMI_PORT_NULL = -1
  40. } HDMI_PORT_T ;
  41. /* HDMI Timing struct */
  42. typedef struct _HDMI_Timing_Param_t{
  43. PLF_VideoID_t eVideoID;
  44. UINT16 wHActive;
  45. UINT16 wVActive; //one field
  46. UINT8 wVFreq;
  47. BOOL fInterlace;
  48. }HDMI_TIMING_PARAM_t;
  49. typedef struct {
  50. INT8 eBootSrc;
  51. UINT8 dSupportMaxHz;
  52. #if (CONFIG_CHIPID!=0x330)
  53. GPIOPin_t eARC_5V_GPIO;
  54. HDMI_PORT_T eARC_Port;
  55. #endif
  56. }HDMI_Customize_st;
  57. //HDMI EQ mode
  58. typedef enum
  59. {
  60. HDMI_EQ_INDEX_DEFAULT = 0,
  61. HDMI_EQ_INDEX_1,
  62. HDMI_EQ_INDEX_2 ,
  63. HDMI_EQ_INDEX_3 ,
  64. HDMI_EQ_INDEX_4,
  65. HDMI_EQ_INDEX_5,
  66. HDMI_EQ_INDEX_6,
  67. HDMI_EQ_INDEX_7,
  68. HDMI_EQ_INDEX_8,
  69. HDMI_EQ_INDEX_9,
  70. HDMI_EQ_INDEX_10
  71. } HDMI_EQ_INDEX_e;
  72. //start of hdmi infoframe typedfine
  73. enum hdmi_infoframe_type {
  74. HDMI_INFOFRAME_TYPE_VENDOR = 0x81,
  75. HDMI_INFOFRAME_TYPE_AVI = 0x82,
  76. HDMI_INFOFRAME_TYPE_SPD = 0x83,
  77. HDMI_INFOFRAME_TYPE_AUDIO = 0x84,
  78. HDMI_INFOFRAME_TYPE_MPEG = 0x85,
  79. HDMI_INFOFRAME_TYPE_NTSC_VBI = 0x86,
  80. };
  81. #define HDMI_IEEE_OUI 0x000c03
  82. #define HDMI_FORUM_IEEE_OUI 0xc45dd8
  83. #define HDMI_INFOFRAME_HEADER_SIZE 4
  84. #define HDMI_AVI_INFOFRAME_SIZE 13
  85. #define HDMI_SPD_INFOFRAME_SIZE 25
  86. #define HDMI_AUDIO_INFOFRAME_SIZE 10
  87. #define HDMI_INFOFRAME_SIZE(type) \
  88. (HDMI_INFOFRAME_HEADER_SIZE + HDMI_ ## type ## _INFOFRAME_SIZE)
  89. struct hdmi_any_infoframe {
  90. enum hdmi_infoframe_type type;
  91. unsigned char version;
  92. unsigned char length;
  93. };
  94. enum hdmi_colorspace {
  95. HDMI_COLORSPACE_RGB,
  96. HDMI_COLORSPACE_YUV422,
  97. HDMI_COLORSPACE_YUV444,
  98. HDMI_COLORSPACE_YUV420,
  99. HDMI_COLORSPACE_RESERVED4,
  100. HDMI_COLORSPACE_RESERVED5,
  101. HDMI_COLORSPACE_RESERVED6,
  102. HDMI_COLORSPACE_IDO_DEFINED,
  103. };
  104. enum hdmi_scan_mode {
  105. HDMI_SCAN_MODE_NONE,
  106. HDMI_SCAN_MODE_OVERSCAN,
  107. HDMI_SCAN_MODE_UNDERSCAN,
  108. HDMI_SCAN_MODE_RESERVED,
  109. };
  110. enum hdmi_colorimetry {
  111. HDMI_COLORIMETRY_NONE,
  112. HDMI_COLORIMETRY_ITU_601,
  113. HDMI_COLORIMETRY_ITU_709,
  114. HDMI_COLORIMETRY_EXTENDED,
  115. };
  116. enum hdmi_picture_aspect {
  117. HDMI_PICTURE_ASPECT_NONE,
  118. HDMI_PICTURE_ASPECT_4_3,
  119. HDMI_PICTURE_ASPECT_16_9,
  120. HDMI_PICTURE_ASPECT_64_27,
  121. HDMI_PICTURE_ASPECT_256_135,
  122. HDMI_PICTURE_ASPECT_RESERVED,
  123. };
  124. enum hdmi_active_aspect {
  125. HDMI_ACTIVE_ASPECT_16_9_TOP = 2,
  126. HDMI_ACTIVE_ASPECT_14_9_TOP = 3,
  127. HDMI_ACTIVE_ASPECT_16_9_CENTER = 4,
  128. HDMI_ACTIVE_ASPECT_PICTURE = 8,
  129. HDMI_ACTIVE_ASPECT_4_3 = 9,
  130. HDMI_ACTIVE_ASPECT_16_9 = 10,
  131. HDMI_ACTIVE_ASPECT_14_9 = 11,
  132. HDMI_ACTIVE_ASPECT_4_3_SP_14_9 = 13,
  133. HDMI_ACTIVE_ASPECT_16_9_SP_14_9 = 14,
  134. HDMI_ACTIVE_ASPECT_16_9_SP_4_3 = 15,
  135. };
  136. enum hdmi_extended_colorimetry {
  137. HDMI_EXTENDED_COLORIMETRY_XV_YCC_601,
  138. HDMI_EXTENDED_COLORIMETRY_XV_YCC_709,
  139. HDMI_EXTENDED_COLORIMETRY_S_YCC_601,
  140. HDMI_EXTENDED_COLORIMETRY_ADOBE_YCC_601,
  141. HDMI_EXTENDED_COLORIMETRY_ADOBE_RGB,
  142. /* The following EC values are only defined in CEA-861-F. */
  143. HDMI_EXTENDED_COLORIMETRY_BT2020_CONST_LUM,
  144. HDMI_EXTENDED_COLORIMETRY_BT2020,
  145. HDMI_EXTENDED_COLORIMETRY_RESERVED,
  146. };
  147. enum hdmi_quantization_range {
  148. HDMI_QUANTIZATION_RANGE_DEFAULT,
  149. HDMI_QUANTIZATION_RANGE_LIMITED,
  150. HDMI_QUANTIZATION_RANGE_FULL,
  151. HDMI_QUANTIZATION_RANGE_RESERVED,
  152. };
  153. /* non-uniform picture scaling */
  154. enum hdmi_nups {
  155. HDMI_NUPS_UNKNOWN,
  156. HDMI_NUPS_HORIZONTAL,
  157. HDMI_NUPS_VERTICAL,
  158. HDMI_NUPS_BOTH,
  159. };
  160. enum hdmi_ycc_quantization_range {
  161. HDMI_YCC_QUANTIZATION_RANGE_LIMITED,
  162. HDMI_YCC_QUANTIZATION_RANGE_FULL,
  163. };
  164. enum hdmi_content_type {
  165. HDMI_CONTENT_TYPE_GRAPHICS,
  166. HDMI_CONTENT_TYPE_PHOTO,
  167. HDMI_CONTENT_TYPE_CINEMA,
  168. HDMI_CONTENT_TYPE_GAME,
  169. };
  170. struct hdmi_avi_infoframe {
  171. enum hdmi_infoframe_type type;
  172. unsigned char version;
  173. unsigned char length;
  174. enum hdmi_colorspace colorspace;
  175. enum hdmi_scan_mode scan_mode;
  176. enum hdmi_colorimetry colorimetry;
  177. enum hdmi_picture_aspect picture_aspect;
  178. enum hdmi_active_aspect active_aspect;
  179. BOOL itc;
  180. enum hdmi_extended_colorimetry extended_colorimetry;
  181. enum hdmi_quantization_range quantization_range;
  182. enum hdmi_nups nups;
  183. unsigned char video_code;
  184. enum hdmi_ycc_quantization_range ycc_quantization_range;
  185. enum hdmi_content_type content_type;
  186. unsigned char pixel_repeat;
  187. unsigned short top_bar;
  188. unsigned short bottom_bar;
  189. unsigned short left_bar;
  190. unsigned short right_bar;
  191. };
  192. enum hdmi_spd_sdi {
  193. HDMI_SPD_SDI_UNKNOWN,
  194. HDMI_SPD_SDI_DSTB,
  195. HDMI_SPD_SDI_DVDP,
  196. HDMI_SPD_SDI_DVHS,
  197. HDMI_SPD_SDI_HDDVR,
  198. HDMI_SPD_SDI_DVC,
  199. HDMI_SPD_SDI_DSC,
  200. HDMI_SPD_SDI_VCD,
  201. HDMI_SPD_SDI_GAME,
  202. HDMI_SPD_SDI_PC,
  203. HDMI_SPD_SDI_BD,
  204. HDMI_SPD_SDI_SACD,
  205. HDMI_SPD_SDI_HDDVD,
  206. HDMI_SPD_SDI_PMP,
  207. };
  208. struct hdmi_spd_infoframe {
  209. enum hdmi_infoframe_type type;
  210. unsigned char version;
  211. unsigned char length;
  212. char vendor[8];
  213. char product[16];
  214. enum hdmi_spd_sdi sdi;
  215. };
  216. enum hdmi_audio_coding_type {
  217. HDMI_AUDIO_CODING_TYPE_STREAM, HDMI_AUDIO_CODING_TYPE_PCM,
  218. HDMI_AUDIO_CODING_TYPE_AC3,
  219. HDMI_AUDIO_CODING_TYPE_MPEG1,
  220. HDMI_AUDIO_CODING_TYPE_MP3,
  221. HDMI_AUDIO_CODING_TYPE_MPEG2,
  222. HDMI_AUDIO_CODING_TYPE_AAC_LC,
  223. HDMI_AUDIO_CODING_TYPE_DTS,
  224. HDMI_AUDIO_CODING_TYPE_ATRAC,
  225. HDMI_AUDIO_CODING_TYPE_DSD,
  226. HDMI_AUDIO_CODING_TYPE_EAC3,
  227. HDMI_AUDIO_CODING_TYPE_DTS_HD,
  228. HDMI_AUDIO_CODING_TYPE_MLP,
  229. HDMI_AUDIO_CODING_TYPE_DST,
  230. HDMI_AUDIO_CODING_TYPE_WMA_PRO,
  231. HDMI_AUDIO_CODING_TYPE_CXT,
  232. };
  233. enum hdmi_audio_sample_size {
  234. HDMI_AUDIO_SAMPLE_SIZE_STREAM,
  235. HDMI_AUDIO_SAMPLE_SIZE_16,
  236. HDMI_AUDIO_SAMPLE_SIZE_20,
  237. HDMI_AUDIO_SAMPLE_SIZE_24,
  238. };
  239. enum hdmi_audio_sample_frequency {
  240. HDMI_AUDIO_SAMPLE_FREQUENCY_STREAM,
  241. HDMI_AUDIO_SAMPLE_FREQUENCY_32000,
  242. HDMI_AUDIO_SAMPLE_FREQUENCY_44100,
  243. HDMI_AUDIO_SAMPLE_FREQUENCY_48000,
  244. HDMI_AUDIO_SAMPLE_FREQUENCY_88200,
  245. HDMI_AUDIO_SAMPLE_FREQUENCY_96000,
  246. HDMI_AUDIO_SAMPLE_FREQUENCY_176400,
  247. HDMI_AUDIO_SAMPLE_FREQUENCY_192000,
  248. };
  249. enum hdmi_audio_coding_type_ext {
  250. /* Refer to Audio Coding Type (CT) field in Data Byte 1 */
  251. HDMI_AUDIO_CODING_TYPE_EXT_CT,
  252. /*
  253. * The next three CXT values are defined in CEA-861-E only.
  254. * They do not exist in older versions, and in CEA-861-F they are
  255. * defined as 'Not in use'.
  256. */
  257. HDMI_AUDIO_CODING_TYPE_EXT_HE_AAC,
  258. HDMI_AUDIO_CODING_TYPE_EXT_HE_AAC_V2,
  259. HDMI_AUDIO_CODING_TYPE_EXT_MPEG_SURROUND,
  260. /* The following CXT values are only defined in CEA-861-F. */
  261. HDMI_AUDIO_CODING_TYPE_EXT_MPEG4_HE_AAC,
  262. HDMI_AUDIO_CODING_TYPE_EXT_MPEG4_HE_AAC_V2,
  263. HDMI_AUDIO_CODING_TYPE_EXT_MPEG4_AAC_LC,
  264. HDMI_AUDIO_CODING_TYPE_EXT_DRA,
  265. HDMI_AUDIO_CODING_TYPE_EXT_MPEG4_HE_AAC_SURROUND,
  266. HDMI_AUDIO_CODING_TYPE_EXT_MPEG4_AAC_LC_SURROUND = 10,
  267. };
  268. struct hdmi_audio_infoframe {
  269. enum hdmi_infoframe_type type;
  270. unsigned char version;
  271. unsigned char length;
  272. unsigned char channels;
  273. enum hdmi_audio_coding_type coding_type;
  274. enum hdmi_audio_sample_size sample_size;
  275. enum hdmi_audio_sample_frequency sample_frequency;
  276. enum hdmi_audio_coding_type_ext coding_type_ext;
  277. unsigned char channel_allocation;
  278. unsigned char level_shift_value;
  279. BOOL downmix_inhibit;
  280. };
  281. enum hdmi_3d_structure {
  282. HDMI_3D_STRUCTURE_INVALID = -1,
  283. HDMI_3D_STRUCTURE_FRAME_PACKING = 0,
  284. HDMI_3D_STRUCTURE_FIELD_ALTERNATIVE,
  285. HDMI_3D_STRUCTURE_LINE_ALTERNATIVE,
  286. HDMI_3D_STRUCTURE_SIDE_BY_SIDE_FULL,
  287. HDMI_3D_STRUCTURE_L_DEPTH,
  288. HDMI_3D_STRUCTURE_L_DEPTH_GFX_GFX_DEPTH,
  289. HDMI_3D_STRUCTURE_TOP_AND_BOTTOM,
  290. HDMI_3D_STRUCTURE_SIDE_BY_SIDE_HALF = 8,
  291. };
  292. struct hdmi_vendor_infoframe {
  293. enum hdmi_infoframe_type type;
  294. unsigned char version;
  295. unsigned char length;
  296. unsigned int oui;
  297. UINT8 vic;
  298. enum hdmi_3d_structure s3d_struct;
  299. unsigned int s3d_ext_data;
  300. };
  301. union hdmi_vendor_any_infoframe {
  302. struct {
  303. enum hdmi_infoframe_type type;
  304. unsigned char version;
  305. unsigned char length;
  306. unsigned int oui;
  307. } any;
  308. struct hdmi_vendor_infoframe hdmi;
  309. };
  310. /**
  311. * union hdmi_infoframe - overall union of all abstract infoframe representations
  312. * @any: generic infoframe
  313. * @avi: avi infoframe
  314. * @spd: spd infoframe
  315. * @vendor: union of all vendor infoframes
  316. * @audio: audio infoframe
  317. *
  318. * This is used by the generic pack function. This works since all infoframes
  319. * have the same header which also indicates which type of infoframe should be
  320. * packed.
  321. */
  322. union hdmi_infoframe {
  323. struct hdmi_any_infoframe any;
  324. struct hdmi_avi_infoframe avi;
  325. struct hdmi_spd_infoframe spd;
  326. union hdmi_vendor_any_infoframe vendor;
  327. struct hdmi_audio_infoframe audio;
  328. };
  329. //end of inforframe typedefine
  330. #endif /* __DRV_HDMI_H__ */