hdmi.h 9.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339
  1. /*
  2. * Copyright (C) 2012 Avionic Design GmbH
  3. *
  4. * Permission is hereby granted, free of charge, to any person obtaining a
  5. * copy of this software and associated documentation files (the "Software"),
  6. * to deal in the Software without restriction, including without limitation
  7. * the rights to use, copy, modify, merge, publish, distribute, sub license,
  8. * and/or sell copies of the Software, and to permit persons to whom the
  9. * Software is furnished to do so, subject to the following conditions:
  10. *
  11. * The above copyright notice and this permission notice (including the
  12. * next paragraph) shall be included in all copies or substantial portions
  13. * of the Software.
  14. *
  15. * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
  16. * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
  17. * FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT. IN NO EVENT SHALL
  18. * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
  19. * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
  20. * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
  21. * DEALINGS IN THE SOFTWARE.
  22. */
  23. #ifndef __LINUX_HDMI_H_
  24. #define __LINUX_HDMI_H_
  25. #include <linux/types.h>
  26. #include <linux/device.h>
  27. enum hdmi_infoframe_type {
  28. HDMI_INFOFRAME_TYPE_VENDOR = 0x81,
  29. HDMI_INFOFRAME_TYPE_AVI = 0x82,
  30. HDMI_INFOFRAME_TYPE_SPD = 0x83,
  31. HDMI_INFOFRAME_TYPE_AUDIO = 0x84,
  32. };
  33. #define HDMI_IEEE_OUI 0x000c03
  34. #define HDMI_FORUM_IEEE_OUI 0xc45dd8
  35. #define HDMI_INFOFRAME_HEADER_SIZE 4
  36. #define HDMI_AVI_INFOFRAME_SIZE 13
  37. #define HDMI_SPD_INFOFRAME_SIZE 25
  38. #define HDMI_AUDIO_INFOFRAME_SIZE 10
  39. #define HDMI_INFOFRAME_SIZE(type) \
  40. (HDMI_INFOFRAME_HEADER_SIZE + HDMI_ ## type ## _INFOFRAME_SIZE)
  41. struct hdmi_any_infoframe {
  42. enum hdmi_infoframe_type type;
  43. unsigned char version;
  44. unsigned char length;
  45. };
  46. enum hdmi_colorspace {
  47. HDMI_COLORSPACE_RGB,
  48. HDMI_COLORSPACE_YUV422,
  49. HDMI_COLORSPACE_YUV444,
  50. HDMI_COLORSPACE_YUV420,
  51. HDMI_COLORSPACE_RESERVED4,
  52. HDMI_COLORSPACE_RESERVED5,
  53. HDMI_COLORSPACE_RESERVED6,
  54. HDMI_COLORSPACE_IDO_DEFINED,
  55. };
  56. enum hdmi_scan_mode {
  57. HDMI_SCAN_MODE_NONE,
  58. HDMI_SCAN_MODE_OVERSCAN,
  59. HDMI_SCAN_MODE_UNDERSCAN,
  60. HDMI_SCAN_MODE_RESERVED,
  61. };
  62. enum hdmi_colorimetry {
  63. HDMI_COLORIMETRY_NONE,
  64. HDMI_COLORIMETRY_ITU_601,
  65. HDMI_COLORIMETRY_ITU_709,
  66. HDMI_COLORIMETRY_EXTENDED,
  67. };
  68. enum hdmi_picture_aspect {
  69. HDMI_PICTURE_ASPECT_NONE,
  70. HDMI_PICTURE_ASPECT_4_3,
  71. HDMI_PICTURE_ASPECT_16_9,
  72. HDMI_PICTURE_ASPECT_64_27,
  73. HDMI_PICTURE_ASPECT_256_135,
  74. HDMI_PICTURE_ASPECT_RESERVED,
  75. };
  76. enum hdmi_active_aspect {
  77. HDMI_ACTIVE_ASPECT_16_9_TOP = 2,
  78. HDMI_ACTIVE_ASPECT_14_9_TOP = 3,
  79. HDMI_ACTIVE_ASPECT_16_9_CENTER = 4,
  80. HDMI_ACTIVE_ASPECT_PICTURE = 8,
  81. HDMI_ACTIVE_ASPECT_4_3 = 9,
  82. HDMI_ACTIVE_ASPECT_16_9 = 10,
  83. HDMI_ACTIVE_ASPECT_14_9 = 11,
  84. HDMI_ACTIVE_ASPECT_4_3_SP_14_9 = 13,
  85. HDMI_ACTIVE_ASPECT_16_9_SP_14_9 = 14,
  86. HDMI_ACTIVE_ASPECT_16_9_SP_4_3 = 15,
  87. };
  88. enum hdmi_extended_colorimetry {
  89. HDMI_EXTENDED_COLORIMETRY_XV_YCC_601,
  90. HDMI_EXTENDED_COLORIMETRY_XV_YCC_709,
  91. HDMI_EXTENDED_COLORIMETRY_S_YCC_601,
  92. HDMI_EXTENDED_COLORIMETRY_OPYCC_601,
  93. HDMI_EXTENDED_COLORIMETRY_OPRGB,
  94. /* The following EC values are only defined in CEA-861-F. */
  95. HDMI_EXTENDED_COLORIMETRY_BT2020_CONST_LUM,
  96. HDMI_EXTENDED_COLORIMETRY_BT2020,
  97. HDMI_EXTENDED_COLORIMETRY_RESERVED,
  98. };
  99. enum hdmi_quantization_range {
  100. HDMI_QUANTIZATION_RANGE_DEFAULT,
  101. HDMI_QUANTIZATION_RANGE_LIMITED,
  102. HDMI_QUANTIZATION_RANGE_FULL,
  103. HDMI_QUANTIZATION_RANGE_RESERVED,
  104. };
  105. /* non-uniform picture scaling */
  106. enum hdmi_nups {
  107. HDMI_NUPS_UNKNOWN,
  108. HDMI_NUPS_HORIZONTAL,
  109. HDMI_NUPS_VERTICAL,
  110. HDMI_NUPS_BOTH,
  111. };
  112. enum hdmi_ycc_quantization_range {
  113. HDMI_YCC_QUANTIZATION_RANGE_LIMITED,
  114. HDMI_YCC_QUANTIZATION_RANGE_FULL,
  115. };
  116. enum hdmi_content_type {
  117. HDMI_CONTENT_TYPE_GRAPHICS,
  118. HDMI_CONTENT_TYPE_PHOTO,
  119. HDMI_CONTENT_TYPE_CINEMA,
  120. HDMI_CONTENT_TYPE_GAME,
  121. };
  122. struct hdmi_avi_infoframe {
  123. enum hdmi_infoframe_type type;
  124. unsigned char version;
  125. unsigned char length;
  126. enum hdmi_colorspace colorspace;
  127. enum hdmi_scan_mode scan_mode;
  128. enum hdmi_colorimetry colorimetry;
  129. enum hdmi_picture_aspect picture_aspect;
  130. enum hdmi_active_aspect active_aspect;
  131. bool itc;
  132. enum hdmi_extended_colorimetry extended_colorimetry;
  133. enum hdmi_quantization_range quantization_range;
  134. enum hdmi_nups nups;
  135. unsigned char video_code;
  136. enum hdmi_ycc_quantization_range ycc_quantization_range;
  137. enum hdmi_content_type content_type;
  138. unsigned char pixel_repeat;
  139. unsigned short top_bar;
  140. unsigned short bottom_bar;
  141. unsigned short left_bar;
  142. unsigned short right_bar;
  143. };
  144. int hdmi_avi_infoframe_init(struct hdmi_avi_infoframe *frame);
  145. ssize_t hdmi_avi_infoframe_pack(struct hdmi_avi_infoframe *frame, void *buffer,
  146. size_t size);
  147. enum hdmi_spd_sdi {
  148. HDMI_SPD_SDI_UNKNOWN,
  149. HDMI_SPD_SDI_DSTB,
  150. HDMI_SPD_SDI_DVDP,
  151. HDMI_SPD_SDI_DVHS,
  152. HDMI_SPD_SDI_HDDVR,
  153. HDMI_SPD_SDI_DVC,
  154. HDMI_SPD_SDI_DSC,
  155. HDMI_SPD_SDI_VCD,
  156. HDMI_SPD_SDI_GAME,
  157. HDMI_SPD_SDI_PC,
  158. HDMI_SPD_SDI_BD,
  159. HDMI_SPD_SDI_SACD,
  160. HDMI_SPD_SDI_HDDVD,
  161. HDMI_SPD_SDI_PMP,
  162. };
  163. struct hdmi_spd_infoframe {
  164. enum hdmi_infoframe_type type;
  165. unsigned char version;
  166. unsigned char length;
  167. char vendor[8];
  168. char product[16];
  169. enum hdmi_spd_sdi sdi;
  170. };
  171. int hdmi_spd_infoframe_init(struct hdmi_spd_infoframe *frame,
  172. const char *vendor, const char *product);
  173. ssize_t hdmi_spd_infoframe_pack(struct hdmi_spd_infoframe *frame, void *buffer,
  174. size_t size);
  175. enum hdmi_audio_coding_type {
  176. HDMI_AUDIO_CODING_TYPE_STREAM,
  177. HDMI_AUDIO_CODING_TYPE_PCM,
  178. HDMI_AUDIO_CODING_TYPE_AC3,
  179. HDMI_AUDIO_CODING_TYPE_MPEG1,
  180. HDMI_AUDIO_CODING_TYPE_MP3,
  181. HDMI_AUDIO_CODING_TYPE_MPEG2,
  182. HDMI_AUDIO_CODING_TYPE_AAC_LC,
  183. HDMI_AUDIO_CODING_TYPE_DTS,
  184. HDMI_AUDIO_CODING_TYPE_ATRAC,
  185. HDMI_AUDIO_CODING_TYPE_DSD,
  186. HDMI_AUDIO_CODING_TYPE_EAC3,
  187. HDMI_AUDIO_CODING_TYPE_DTS_HD,
  188. HDMI_AUDIO_CODING_TYPE_MLP,
  189. HDMI_AUDIO_CODING_TYPE_DST,
  190. HDMI_AUDIO_CODING_TYPE_WMA_PRO,
  191. HDMI_AUDIO_CODING_TYPE_CXT,
  192. };
  193. enum hdmi_audio_sample_size {
  194. HDMI_AUDIO_SAMPLE_SIZE_STREAM,
  195. HDMI_AUDIO_SAMPLE_SIZE_16,
  196. HDMI_AUDIO_SAMPLE_SIZE_20,
  197. HDMI_AUDIO_SAMPLE_SIZE_24,
  198. };
  199. enum hdmi_audio_sample_frequency {
  200. HDMI_AUDIO_SAMPLE_FREQUENCY_STREAM,
  201. HDMI_AUDIO_SAMPLE_FREQUENCY_32000,
  202. HDMI_AUDIO_SAMPLE_FREQUENCY_44100,
  203. HDMI_AUDIO_SAMPLE_FREQUENCY_48000,
  204. HDMI_AUDIO_SAMPLE_FREQUENCY_88200,
  205. HDMI_AUDIO_SAMPLE_FREQUENCY_96000,
  206. HDMI_AUDIO_SAMPLE_FREQUENCY_176400,
  207. HDMI_AUDIO_SAMPLE_FREQUENCY_192000,
  208. };
  209. enum hdmi_audio_coding_type_ext {
  210. /* Refer to Audio Coding Type (CT) field in Data Byte 1 */
  211. HDMI_AUDIO_CODING_TYPE_EXT_CT,
  212. /*
  213. * The next three CXT values are defined in CEA-861-E only.
  214. * They do not exist in older versions, and in CEA-861-F they are
  215. * defined as 'Not in use'.
  216. */
  217. HDMI_AUDIO_CODING_TYPE_EXT_HE_AAC,
  218. HDMI_AUDIO_CODING_TYPE_EXT_HE_AAC_V2,
  219. HDMI_AUDIO_CODING_TYPE_EXT_MPEG_SURROUND,
  220. /* The following CXT values are only defined in CEA-861-F. */
  221. HDMI_AUDIO_CODING_TYPE_EXT_MPEG4_HE_AAC,
  222. HDMI_AUDIO_CODING_TYPE_EXT_MPEG4_HE_AAC_V2,
  223. HDMI_AUDIO_CODING_TYPE_EXT_MPEG4_AAC_LC,
  224. HDMI_AUDIO_CODING_TYPE_EXT_DRA,
  225. HDMI_AUDIO_CODING_TYPE_EXT_MPEG4_HE_AAC_SURROUND,
  226. HDMI_AUDIO_CODING_TYPE_EXT_MPEG4_AAC_LC_SURROUND = 10,
  227. };
  228. struct hdmi_audio_infoframe {
  229. enum hdmi_infoframe_type type;
  230. unsigned char version;
  231. unsigned char length;
  232. unsigned char channels;
  233. enum hdmi_audio_coding_type coding_type;
  234. enum hdmi_audio_sample_size sample_size;
  235. enum hdmi_audio_sample_frequency sample_frequency;
  236. enum hdmi_audio_coding_type_ext coding_type_ext;
  237. unsigned char channel_allocation;
  238. unsigned char level_shift_value;
  239. bool downmix_inhibit;
  240. };
  241. int hdmi_audio_infoframe_init(struct hdmi_audio_infoframe *frame);
  242. ssize_t hdmi_audio_infoframe_pack(struct hdmi_audio_infoframe *frame,
  243. void *buffer, size_t size);
  244. enum hdmi_3d_structure {
  245. HDMI_3D_STRUCTURE_INVALID = -1,
  246. HDMI_3D_STRUCTURE_FRAME_PACKING = 0,
  247. HDMI_3D_STRUCTURE_FIELD_ALTERNATIVE,
  248. HDMI_3D_STRUCTURE_LINE_ALTERNATIVE,
  249. HDMI_3D_STRUCTURE_SIDE_BY_SIDE_FULL,
  250. HDMI_3D_STRUCTURE_L_DEPTH,
  251. HDMI_3D_STRUCTURE_L_DEPTH_GFX_GFX_DEPTH,
  252. HDMI_3D_STRUCTURE_TOP_AND_BOTTOM,
  253. HDMI_3D_STRUCTURE_SIDE_BY_SIDE_HALF = 8,
  254. };
  255. struct hdmi_vendor_infoframe {
  256. enum hdmi_infoframe_type type;
  257. unsigned char version;
  258. unsigned char length;
  259. unsigned int oui;
  260. u8 vic;
  261. enum hdmi_3d_structure s3d_struct;
  262. unsigned int s3d_ext_data;
  263. };
  264. int hdmi_vendor_infoframe_init(struct hdmi_vendor_infoframe *frame);
  265. ssize_t hdmi_vendor_infoframe_pack(struct hdmi_vendor_infoframe *frame,
  266. void *buffer, size_t size);
  267. union hdmi_vendor_any_infoframe {
  268. struct {
  269. enum hdmi_infoframe_type type;
  270. unsigned char version;
  271. unsigned char length;
  272. unsigned int oui;
  273. } any;
  274. struct hdmi_vendor_infoframe hdmi;
  275. };
  276. /**
  277. * union hdmi_infoframe - overall union of all abstract infoframe representations
  278. * @any: generic infoframe
  279. * @avi: avi infoframe
  280. * @spd: spd infoframe
  281. * @vendor: union of all vendor infoframes
  282. * @audio: audio infoframe
  283. *
  284. * This is used by the generic pack function. This works since all infoframes
  285. * have the same header which also indicates which type of infoframe should be
  286. * packed.
  287. */
  288. union hdmi_infoframe {
  289. struct hdmi_any_infoframe any;
  290. struct hdmi_avi_infoframe avi;
  291. struct hdmi_spd_infoframe spd;
  292. union hdmi_vendor_any_infoframe vendor;
  293. struct hdmi_audio_infoframe audio;
  294. };
  295. ssize_t
  296. hdmi_infoframe_pack(union hdmi_infoframe *frame, void *buffer, size_t size);
  297. int hdmi_infoframe_unpack(union hdmi_infoframe *frame, void *buffer);
  298. void hdmi_infoframe_log(const char *level, struct device *dev,
  299. union hdmi_infoframe *frame);
  300. #endif /* _DRM_HDMI_H */