pineapple.c 46 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780
  1. // SPDX-License-Identifier: GPL-2.0-only
  2. /*
  3. * Copyright (c) 2022-2023 Qualcomm Innovation Center, Inc. All rights reserved.
  4. */
  5. #include <soc/qcom/of_common.h>
  6. #include "msm_vidc_control.h"
  7. #include "msm_vidc_pineapple.h"
  8. #include "msm_vidc_platform.h"
  9. #include "msm_vidc_debug.h"
  10. #include "msm_vidc_iris33.h"
  11. #include "hfi_property.h"
  12. #include "hfi_command.h"
  13. #include "venus_hfi.h"
  14. #define DEFAULT_VIDEO_CONCEAL_COLOR_BLACK 0x8020010
  15. #define MAX_BASE_LAYER_PRIORITY_ID 63
  16. #define MAX_OP_POINT 31
  17. #define MAX_BITRATE 245000000
  18. #define DEFAULT_BITRATE 20000000
  19. #define MINIMUM_FPS 1
  20. #define MAXIMUM_FPS 480
  21. #define MAX_QP 51
  22. #define DEFAULT_QP 20
  23. #define MAX_CONSTANT_QUALITY 100
  24. #define MIN_SLICE_BYTE_SIZE 512
  25. #define MAX_SLICE_BYTE_SIZE \
  26. ((MAX_BITRATE) >> 3)
  27. #define MAX_SLICE_MB_SIZE \
  28. (((4096 + 15) >> 4) * ((2304 + 15) >> 4))
  29. #define ENC MSM_VIDC_ENCODER
  30. #define DEC MSM_VIDC_DECODER
  31. #define H264 MSM_VIDC_H264
  32. #define HEVC MSM_VIDC_HEVC
  33. #define VP9 MSM_VIDC_VP9
  34. #define CODECS_ALL (H264 | HEVC | VP9)
  35. #define MAXIMUM_OVERRIDE_VP9_FPS 180
  36. #ifndef V4L2_PIX_FMT_QC08C
  37. #define V4L2_PIX_FMT_QC08C v4l2_fourcc('Q', '0', '8', 'C')
  38. #endif
  39. #ifndef V4L2_PIX_FMT_QC10C
  40. #define V4L2_PIX_FMT_QC10C v4l2_fourcc('Q', '1', '0', 'C')
  41. #endif
  42. static struct codec_info codec_data_pineapple[] = {
  43. {
  44. .v4l2_codec = V4L2_PIX_FMT_H264,
  45. .vidc_codec = MSM_VIDC_H264,
  46. .pixfmt_name = "AVC",
  47. },
  48. {
  49. .v4l2_codec = V4L2_PIX_FMT_HEVC,
  50. .vidc_codec = MSM_VIDC_HEVC,
  51. .pixfmt_name = "HEVC",
  52. },
  53. {
  54. .v4l2_codec = V4L2_PIX_FMT_VP9,
  55. .vidc_codec = MSM_VIDC_VP9,
  56. .pixfmt_name = "VP9",
  57. },
  58. };
  59. static struct color_format_info color_format_data_pineapple[] = {
  60. {
  61. .v4l2_color_format = V4L2_PIX_FMT_NV12,
  62. .vidc_color_format = MSM_VIDC_FMT_NV12,
  63. .pixfmt_name = "NV12",
  64. },
  65. {
  66. .v4l2_color_format = V4L2_PIX_FMT_NV21,
  67. .vidc_color_format = MSM_VIDC_FMT_NV21,
  68. .pixfmt_name = "NV21",
  69. },
  70. {
  71. .v4l2_color_format = V4L2_PIX_FMT_QC08C,
  72. .vidc_color_format = MSM_VIDC_FMT_NV12C,
  73. .pixfmt_name = "NV12C",
  74. },
  75. {
  76. .v4l2_color_format = V4L2_PIX_FMT_QC10C,
  77. .vidc_color_format = MSM_VIDC_FMT_TP10C,
  78. .pixfmt_name = "TP10C",
  79. },
  80. {
  81. .v4l2_color_format = V4L2_PIX_FMT_RGBA32,
  82. .vidc_color_format = MSM_VIDC_FMT_RGBA8888,
  83. .pixfmt_name = "RGBA",
  84. },
  85. };
  86. static struct color_primaries_info color_primaries_data_pineapple[] = {
  87. {
  88. .v4l2_color_primaries = V4L2_COLORSPACE_DEFAULT,
  89. .vidc_color_primaries = MSM_VIDC_PRIMARIES_RESERVED,
  90. },
  91. {
  92. .v4l2_color_primaries = V4L2_COLORSPACE_REC709,
  93. .vidc_color_primaries = MSM_VIDC_PRIMARIES_BT709,
  94. },
  95. {
  96. .v4l2_color_primaries = V4L2_COLORSPACE_470_SYSTEM_M,
  97. .vidc_color_primaries = MSM_VIDC_PRIMARIES_BT470_SYSTEM_M,
  98. },
  99. {
  100. .v4l2_color_primaries = V4L2_COLORSPACE_470_SYSTEM_BG,
  101. .vidc_color_primaries = MSM_VIDC_PRIMARIES_BT470_SYSTEM_BG,
  102. },
  103. {
  104. .v4l2_color_primaries = V4L2_COLORSPACE_SMPTE170M,
  105. .vidc_color_primaries = MSM_VIDC_PRIMARIES_BT601_525,
  106. },
  107. {
  108. .v4l2_color_primaries = V4L2_COLORSPACE_SMPTE240M,
  109. .vidc_color_primaries = MSM_VIDC_PRIMARIES_SMPTE_ST240M,
  110. },
  111. {
  112. .v4l2_color_primaries = V4L2_COLORSPACE_BT2020,
  113. .vidc_color_primaries = MSM_VIDC_PRIMARIES_BT2020,
  114. },
  115. {
  116. .v4l2_color_primaries = V4L2_COLORSPACE_DCI_P3,
  117. .vidc_color_primaries = MSM_VIDC_PRIMARIES_SMPTE_RP431_2,
  118. },
  119. };
  120. static struct transfer_char_info transfer_char_data_pineapple[] = {
  121. {
  122. .v4l2_transfer_char = V4L2_XFER_FUNC_DEFAULT,
  123. .vidc_transfer_char = MSM_VIDC_TRANSFER_RESERVED,
  124. },
  125. {
  126. .v4l2_transfer_char = V4L2_XFER_FUNC_709,
  127. .vidc_transfer_char = MSM_VIDC_TRANSFER_BT709,
  128. },
  129. {
  130. .v4l2_transfer_char = V4L2_XFER_FUNC_SMPTE240M,
  131. .vidc_transfer_char = MSM_VIDC_TRANSFER_SMPTE_ST240M,
  132. },
  133. {
  134. .v4l2_transfer_char = V4L2_XFER_FUNC_SRGB,
  135. .vidc_transfer_char = MSM_VIDC_TRANSFER_SRGB_SYCC,
  136. },
  137. {
  138. .v4l2_transfer_char = V4L2_XFER_FUNC_SMPTE2084,
  139. .vidc_transfer_char = MSM_VIDC_TRANSFER_SMPTE_ST2084_PQ,
  140. },
  141. };
  142. static struct matrix_coeff_info matrix_coeff_data_pineapple[] = {
  143. {
  144. .v4l2_matrix_coeff = V4L2_YCBCR_ENC_DEFAULT,
  145. .vidc_matrix_coeff = MSM_VIDC_MATRIX_COEFF_RESERVED,
  146. },
  147. {
  148. .v4l2_matrix_coeff = V4L2_YCBCR_ENC_709,
  149. .vidc_matrix_coeff = MSM_VIDC_MATRIX_COEFF_BT709,
  150. },
  151. {
  152. .v4l2_matrix_coeff = V4L2_YCBCR_ENC_XV709,
  153. .vidc_matrix_coeff = MSM_VIDC_MATRIX_COEFF_BT709,
  154. },
  155. {
  156. .v4l2_matrix_coeff = V4L2_YCBCR_ENC_XV601,
  157. .vidc_matrix_coeff = MSM_VIDC_MATRIX_COEFF_BT470_SYS_BG_OR_BT601_625,
  158. },
  159. {
  160. .v4l2_matrix_coeff = V4L2_YCBCR_ENC_601,
  161. .vidc_matrix_coeff = MSM_VIDC_MATRIX_COEFF_BT601_525_BT1358_525_OR_625,
  162. },
  163. {
  164. .v4l2_matrix_coeff = V4L2_YCBCR_ENC_SMPTE240M,
  165. .vidc_matrix_coeff = MSM_VIDC_MATRIX_COEFF_SMPTE_ST240,
  166. },
  167. {
  168. .v4l2_matrix_coeff = V4L2_YCBCR_ENC_BT2020,
  169. .vidc_matrix_coeff = MSM_VIDC_MATRIX_COEFF_BT2020_NON_CONSTANT,
  170. },
  171. {
  172. .v4l2_matrix_coeff = V4L2_YCBCR_ENC_BT2020_CONST_LUM,
  173. .vidc_matrix_coeff = MSM_VIDC_MATRIX_COEFF_BT2020_CONSTANT,
  174. },
  175. };
  176. static struct msm_platform_core_capability core_data_pineapple[] = {
  177. /* {type, value} */
  178. {ENC_CODECS, H264|HEVC},
  179. {DEC_CODECS, H264|HEVC|VP9},
  180. {MAX_SESSION_COUNT, 16},
  181. {MAX_NUM_720P_SESSIONS, 16},
  182. {MAX_NUM_1080P_SESSIONS, 16},
  183. {MAX_NUM_4K_SESSIONS, 8},
  184. {MAX_NUM_8K_SESSIONS, 2},
  185. {MAX_RT_MBPF, 174080}, /* (8192x4352)/256 + (4096x2176)/256*/
  186. {MAX_MBPF, 278528}, /* ((8192x4352)/256) * 2 */
  187. {MAX_MBPS, 7833600}, /* max_load
  188. * 7680x4320@60fps or 3840x2176@240fps
  189. * which is greater than 4096x2176@120fps,
  190. * 8192x4320@48fps
  191. */
  192. {MAX_MBPF_HQ, 8160}, /* ((1920x1088)/256) */
  193. {MAX_MBPS_HQ, 489600}, /* ((1920x1088)/256)@60fps */
  194. {MAX_MBPF_B_FRAME, 32640}, /* 3840x2176/256 */
  195. {MAX_MBPS_B_FRAME, 1958400}, /* 3840x2176/256 MBs@60fps */
  196. {MAX_MBPS_ALL_INTRA, 1044480}, /* 4096x2176/256 MBs@30fps */
  197. {MAX_ENH_LAYER_COUNT, 5},
  198. {NUM_VPP_PIPE, 4},
  199. {SW_PC, 1},
  200. {FW_UNLOAD, 0},
  201. {HW_RESPONSE_TIMEOUT, HW_RESPONSE_TIMEOUT_VALUE}, /* 1000 ms */
  202. {SW_PC_DELAY, SW_PC_DELAY_VALUE }, /* 1500 ms (>HW_RESPONSE_TIMEOUT)*/
  203. {FW_UNLOAD_DELAY, FW_UNLOAD_DELAY_VALUE }, /* 3000 ms (>SW_PC_DELAY)*/
  204. {DCVS, 1},
  205. {DECODE_BATCH, 1},
  206. {DECODE_BATCH_TIMEOUT, 200},
  207. {STATS_TIMEOUT_MS, 2000},
  208. {NON_FATAL_FAULTS, 1},
  209. {ENC_AUTO_FRAMERATE, 1},
  210. {DEVICE_CAPS, V4L2_CAP_VIDEO_M2M_MPLANE | V4L2_CAP_STREAMING},
  211. {SUPPORTS_SYNX_FENCE, 0},
  212. {SUPPORTS_REQUESTS, 0},
  213. };
  214. static int msm_vidc_set_ring_buffer_count_pineapple(void *instance,
  215. enum msm_vidc_inst_capability_type cap_id)
  216. {
  217. int rc = 0;
  218. struct msm_vidc_inst *inst = (struct msm_vidc_inst *) instance;
  219. struct v4l2_format *output_fmt, *input_fmt;
  220. struct msm_vidc_core* core;
  221. u32 count = 0, data_size = 0, pixel_count = 0, fps = 0;
  222. u32 frame_rate = 0, operating_rate = 0;
  223. if (!inst) {
  224. d_vpr_e("%s: invalid params\n", __func__);
  225. return -EINVAL;
  226. }
  227. core = inst->core;
  228. output_fmt = &inst->fmts[OUTPUT_PORT];
  229. input_fmt = &inst->fmts[INPUT_PORT];
  230. frame_rate = inst->capabilities[FRAME_RATE].value >> 16;
  231. operating_rate = inst->capabilities[OPERATING_RATE].value >> 16;
  232. fps = max(frame_rate, operating_rate);
  233. pixel_count = output_fmt->fmt.pix_mp.width *
  234. output_fmt->fmt.pix_mp.height;
  235. /*
  236. * try to enable ring buffer feature if
  237.  * resolution >= 8k and fps >= 30fps and
  238.  * resolution >= 4k and fps >= 120fps and
  239.  * resolution >= 1080p and fps >= 480fps and
  240.  * resolution >= 720p and fps >= 960fps
  241. */
  242. if ((pixel_count >= 7680 * 4320 && fps >= 30) &&
  243. (pixel_count >= 3840 * 2160 && fps >= 120) &&
  244. (pixel_count >= 1920 * 1080 && fps >= 480) &&
  245. (pixel_count >= 1280 * 720 && fps >= 960)) {
  246. data_size = input_fmt->fmt.pix_mp.plane_fmt[0].sizeimage;
  247. i_vpr_h(inst, "%s: calculate ring buffer count\n", __func__);
  248. rc = call_session_op(core, ring_buf_count, inst, data_size);
  249. if (rc) {
  250. i_vpr_e(inst, "%s: failed to calculate ring buf count\n",
  251. __func__);
  252. /* ignore error */
  253. rc = 0;
  254. inst->capabilities[cap_id].value = 0;
  255. }
  256. } else {
  257. i_vpr_h(inst,
  258. "%s: session %ux%u@%u fps does not support ring buffer\n",
  259. __func__, output_fmt->fmt.pix_mp.width,
  260. output_fmt->fmt.pix_mp.height, fps);
  261. inst->capabilities[cap_id].value = 0;
  262. }
  263. count = inst->capabilities[cap_id].value;
  264. i_vpr_h(inst, "%s: ring buffer count: %u\n", __func__, count);
  265. rc = venus_hfi_session_property(inst,
  266. HFI_PROP_ENC_RING_BIN_BUF,
  267. HFI_HOST_FLAGS_NONE,
  268. HFI_PORT_BITSTREAM,
  269. HFI_PAYLOAD_U32,
  270. &count,
  271. sizeof(u32));
  272. if (rc)
  273. return rc;
  274. return rc;
  275. }
  276. static struct msm_platform_inst_capability instance_cap_data_pineapple[] = {
  277. /* {cap, domain, codec,
  278. * min, max, step_or_mask, value,
  279. * v4l2_id,
  280. * hfi_id,
  281. * flags}
  282. */
  283. {FRAME_WIDTH, DEC, CODECS_ALL, 96, 8192, 1, 1920},
  284. {FRAME_WIDTH, DEC, VP9, 96, 4096, 1, 1920},
  285. {FRAME_WIDTH, ENC, CODECS_ALL, 128, 8192, 1, 1920},
  286. {FRAME_WIDTH, ENC, HEVC, 96, 8192, 1, 1920},
  287. {LOSSLESS_FRAME_WIDTH, ENC, CODECS_ALL, 128, 4096, 1, 1920},
  288. {LOSSLESS_FRAME_WIDTH, ENC, HEVC, 96, 4096, 1, 1920},
  289. {FRAME_HEIGHT, DEC, CODECS_ALL, 96, 8192, 1, 1080},
  290. {FRAME_HEIGHT, DEC, VP9, 96, 4096, 1, 1080},
  291. {FRAME_HEIGHT, ENC, CODECS_ALL, 128, 8192, 1, 1080},
  292. {FRAME_HEIGHT, ENC, HEVC, 96, 8192, 1, 1080},
  293. {LOSSLESS_FRAME_HEIGHT, ENC, CODECS_ALL, 128, 4096, 1, 1080},
  294. {LOSSLESS_FRAME_HEIGHT, ENC, HEVC, 96, 4096, 1, 1080},
  295. {PIX_FMTS, ENC|DEC, H264,
  296. MSM_VIDC_FMT_NV12,
  297. MSM_VIDC_FMT_NV12C,
  298. MSM_VIDC_FMT_NV12 | MSM_VIDC_FMT_NV21 | MSM_VIDC_FMT_NV12C,
  299. MSM_VIDC_FMT_NV12C},
  300. {PIX_FMTS, ENC|DEC, HEVC|VP9,
  301. MSM_VIDC_FMT_NV12,
  302. MSM_VIDC_FMT_TP10C,
  303. MSM_VIDC_FMT_NV12 | MSM_VIDC_FMT_NV21 | MSM_VIDC_FMT_NV12C |
  304. MSM_VIDC_FMT_TP10C,
  305. MSM_VIDC_FMT_NV12C},
  306. {MIN_BUFFERS_INPUT, ENC|DEC, CODECS_ALL, 0, 64, 1, 4,
  307. V4L2_CID_MIN_BUFFERS_FOR_OUTPUT,
  308. 0,
  309. CAP_FLAG_VOLATILE},
  310. {MIN_BUFFERS_OUTPUT, ENC|DEC, CODECS_ALL,
  311. 0, 64, 1, 4,
  312. V4L2_CID_MIN_BUFFERS_FOR_CAPTURE,
  313. HFI_PROP_BUFFER_FW_MIN_OUTPUT_COUNT,
  314. CAP_FLAG_OUTPUT_PORT | CAP_FLAG_VOLATILE},
  315. /* (8192 * 4320) / 256 */
  316. {MBPF, ENC, CODECS_ALL, 64, 138240, 1, 138240},
  317. {MBPF, ENC, HEVC, 36, 138240, 1, 138240},
  318. {MBPF, DEC, CODECS_ALL, 36, 138240, 1, 138240},
  319. /* (4096 * 2304) / 256 */
  320. {MBPF, DEC, VP9, 36, 36864, 1, 36864},
  321. /* (4096 * 2304) / 256 */
  322. {LOSSLESS_MBPF, ENC, H264|HEVC, 64, 36864, 1, 36864},
  323. /* Batch Mode Decode */
  324. /* TODO: update with new values based on updated voltage corner */
  325. {BATCH_MBPF, DEC, H264|HEVC|VP9, 64, 34816, 1, 34816},
  326. /* (4096 * 2304) / 256 */
  327. {BATCH_FPS, DEC, H264|HEVC|VP9, 1, 120, 1, 120},
  328. {FRAME_RATE, ENC, CODECS_ALL,
  329. (MINIMUM_FPS << 16), (MAXIMUM_FPS << 16),
  330. 1, (DEFAULT_FPS << 16),
  331. 0,
  332. HFI_PROP_FRAME_RATE,
  333. CAP_FLAG_OUTPUT_PORT},
  334. {OPERATING_RATE, ENC, CODECS_ALL,
  335. (MINIMUM_FPS << 16), (MAXIMUM_FPS << 16),
  336. 1, (DEFAULT_FPS << 16)},
  337. {INPUT_RATE, ENC|DEC, CODECS_ALL,
  338. (MINIMUM_FPS << 16), INT_MAX,
  339. 1, (DEFAULT_FPS << 16)},
  340. {TIMESTAMP_RATE, ENC|DEC, CODECS_ALL,
  341. (MINIMUM_FPS << 16), INT_MAX,
  342. 1, (DEFAULT_FPS << 16)},
  343. {SCALE_FACTOR, ENC, H264|HEVC, 1, 8, 1, 8},
  344. {MB_CYCLES_VSP, ENC, CODECS_ALL, 25, 25, 1, 25},
  345. {MB_CYCLES_VSP, DEC, CODECS_ALL, 25, 25, 1, 25},
  346. {MB_CYCLES_VSP, DEC, VP9, 60, 60, 1, 60},
  347. {MB_CYCLES_VPP, ENC, CODECS_ALL, 675, 675, 1, 675},
  348. {MB_CYCLES_VPP, DEC, CODECS_ALL, 200, 200, 1, 200},
  349. {MB_CYCLES_LP, ENC, CODECS_ALL, 320, 320, 1, 320},
  350. {MB_CYCLES_LP, DEC, CODECS_ALL, 200, 200, 1, 200},
  351. {MB_CYCLES_FW, ENC|DEC, CODECS_ALL, 489583, 489583, 1, 489583},
  352. {MB_CYCLES_FW_VPP, ENC, CODECS_ALL, 48405, 48405, 1, 48405},
  353. {MB_CYCLES_FW_VPP, DEC, CODECS_ALL, 66234, 66234, 1, 66234},
  354. {ENC_RING_BUFFER_COUNT, ENC, CODECS_ALL,
  355. 0, MAX_ENC_RING_BUF_COUNT, 1, 0},
  356. {CLIENT_ID, ENC|DEC, CODECS_ALL,
  357. INVALID_CLIENT_ID, INT_MAX, 1, INVALID_CLIENT_ID,
  358. 0},
  359. {HFLIP, ENC, CODECS_ALL,
  360. 0, 1, 1, 0,
  361. V4L2_CID_HFLIP,
  362. HFI_PROP_FLIP,
  363. CAP_FLAG_OUTPUT_PORT |
  364. CAP_FLAG_INPUT_PORT | CAP_FLAG_DYNAMIC_ALLOWED},
  365. {VFLIP, ENC, CODECS_ALL,
  366. 0, 1, 1, 0,
  367. V4L2_CID_VFLIP,
  368. HFI_PROP_FLIP,
  369. CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT |
  370. CAP_FLAG_DYNAMIC_ALLOWED},
  371. {ROTATION, ENC, CODECS_ALL,
  372. 0, 270, 90, 0,
  373. V4L2_CID_ROTATE,
  374. HFI_PROP_ROTATION,
  375. CAP_FLAG_OUTPUT_PORT},
  376. {SUPER_FRAME, ENC, H264|HEVC,
  377. 0, 32, 1, 0,
  378. 0, 0,
  379. CAP_FLAG_NONE},
  380. {SLICE_DECODE, DEC, CODECS_ALL,
  381. 0, 0, 0, 0,
  382. V4L2_CID_MPEG_VIDEO_DECODER_SLICE_INTERFACE,
  383. 0},
  384. {HEADER_MODE, ENC, CODECS_ALL,
  385. V4L2_MPEG_VIDEO_HEADER_MODE_SEPARATE,
  386. V4L2_MPEG_VIDEO_HEADER_MODE_JOINED_WITH_1ST_FRAME,
  387. BIT(V4L2_MPEG_VIDEO_HEADER_MODE_SEPARATE) |
  388. BIT(V4L2_MPEG_VIDEO_HEADER_MODE_JOINED_WITH_1ST_FRAME),
  389. V4L2_MPEG_VIDEO_HEADER_MODE_SEPARATE,
  390. V4L2_CID_MPEG_VIDEO_HEADER_MODE,
  391. HFI_PROP_SEQ_HEADER_MODE,
  392. CAP_FLAG_OUTPUT_PORT | CAP_FLAG_MENU},
  393. {PREPEND_SPSPPS_TO_IDR, ENC, CODECS_ALL,
  394. 0, 1, 1, 0,
  395. V4L2_CID_MPEG_VIDEO_PREPEND_SPSPPS_TO_IDR},
  396. {WITHOUT_STARTCODE, ENC, CODECS_ALL,
  397. 0, 1, 1, 0,
  398. V4L2_CID_MPEG_VIDEO_HEVC_WITHOUT_STARTCODE,
  399. HFI_PROP_NAL_LENGTH_FIELD,
  400. CAP_FLAG_OUTPUT_PORT},
  401. {NAL_LENGTH_FIELD, ENC, CODECS_ALL,
  402. V4L2_MPEG_VIDEO_HEVC_SIZE_0,
  403. V4L2_MPEG_VIDEO_HEVC_SIZE_4,
  404. BIT(V4L2_MPEG_VIDEO_HEVC_SIZE_0) |
  405. BIT(V4L2_MPEG_VIDEO_HEVC_SIZE_4),
  406. V4L2_MPEG_VIDEO_HEVC_SIZE_0,
  407. V4L2_CID_MPEG_VIDEO_HEVC_SIZE_OF_LENGTH_FIELD,
  408. HFI_PROP_NAL_LENGTH_FIELD,
  409. CAP_FLAG_MENU | CAP_FLAG_OUTPUT_PORT},
  410. /* TODO: Firmware introduced enumeration type for this
  411. * with and without seq header.
  412. */
  413. {REQUEST_I_FRAME, ENC, H264|HEVC,
  414. 0, 0, 0, 0,
  415. V4L2_CID_MPEG_VIDEO_FORCE_KEY_FRAME,
  416. HFI_PROP_REQUEST_SYNC_FRAME,
  417. CAP_FLAG_INPUT_PORT | CAP_FLAG_DYNAMIC_ALLOWED},
  418. /* Enc: Keeping CABAC and CAVLC as same bitrate.
  419. * Dec: there's no use of Bitrate cap
  420. */
  421. {BIT_RATE, ENC, H264|HEVC,
  422. 1, MAX_BITRATE, 1, DEFAULT_BITRATE,
  423. V4L2_CID_MPEG_VIDEO_BITRATE,
  424. HFI_PROP_TOTAL_BITRATE,
  425. CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT |
  426. CAP_FLAG_DYNAMIC_ALLOWED},
  427. {BITRATE_MODE, ENC, H264,
  428. V4L2_MPEG_VIDEO_BITRATE_MODE_VBR,
  429. V4L2_MPEG_VIDEO_BITRATE_MODE_CBR,
  430. BIT(V4L2_MPEG_VIDEO_BITRATE_MODE_VBR) |
  431. BIT(V4L2_MPEG_VIDEO_BITRATE_MODE_CBR),
  432. V4L2_MPEG_VIDEO_BITRATE_MODE_VBR,
  433. V4L2_CID_MPEG_VIDEO_BITRATE_MODE,
  434. HFI_PROP_RATE_CONTROL,
  435. CAP_FLAG_OUTPUT_PORT | CAP_FLAG_MENU},
  436. {BITRATE_MODE, ENC, HEVC,
  437. V4L2_MPEG_VIDEO_BITRATE_MODE_VBR,
  438. V4L2_MPEG_VIDEO_BITRATE_MODE_CQ,
  439. BIT(V4L2_MPEG_VIDEO_BITRATE_MODE_VBR) |
  440. BIT(V4L2_MPEG_VIDEO_BITRATE_MODE_CBR) |
  441. BIT(V4L2_MPEG_VIDEO_BITRATE_MODE_CQ),
  442. V4L2_MPEG_VIDEO_BITRATE_MODE_VBR,
  443. V4L2_CID_MPEG_VIDEO_BITRATE_MODE,
  444. HFI_PROP_RATE_CONTROL,
  445. CAP_FLAG_OUTPUT_PORT | CAP_FLAG_MENU},
  446. {CABAC_MAX_BITRATE, ENC, H264|HEVC, 0,
  447. 160000000, 1, 160000000},
  448. {CAVLC_MAX_BITRATE, ENC, H264, 0,
  449. 220000000, 1, 220000000},
  450. {ALLINTRA_MAX_BITRATE, ENC, H264|HEVC, 0,
  451. 245000000, 1, 245000000},
  452. {LOWLATENCY_MAX_BITRATE, ENC, H264|HEVC, 0,
  453. 70000000, 1, 70000000},
  454. {LOSSLESS, ENC, HEVC,
  455. 0, 1, 1, 0,
  456. V4L2_CID_MPEG_VIDEO_HEVC_LOSSLESS_CU},
  457. {FRAME_SKIP_MODE, ENC, H264|HEVC,
  458. V4L2_MPEG_VIDEO_FRAME_SKIP_MODE_DISABLED,
  459. V4L2_MPEG_VIDEO_FRAME_SKIP_MODE_BUF_LIMIT,
  460. BIT(V4L2_MPEG_VIDEO_FRAME_SKIP_MODE_DISABLED) |
  461. BIT(V4L2_MPEG_VIDEO_FRAME_SKIP_MODE_LEVEL_LIMIT) |
  462. BIT(V4L2_MPEG_VIDEO_FRAME_SKIP_MODE_BUF_LIMIT),
  463. V4L2_MPEG_VIDEO_FRAME_SKIP_MODE_DISABLED,
  464. V4L2_CID_MPEG_VIDEO_FRAME_SKIP_MODE,
  465. 0,
  466. CAP_FLAG_OUTPUT_PORT | CAP_FLAG_MENU},
  467. {FRAME_RC_ENABLE, ENC, H264|HEVC,
  468. 0, 1, 1, 1,
  469. V4L2_CID_MPEG_VIDEO_FRAME_RC_ENABLE},
  470. {CONSTANT_QUALITY, ENC, HEVC,
  471. 1, MAX_CONSTANT_QUALITY, 1, 90,
  472. V4L2_CID_MPEG_VIDEO_CONSTANT_QUALITY,
  473. HFI_PROP_CONSTANT_QUALITY,
  474. CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT |
  475. CAP_FLAG_DYNAMIC_ALLOWED},
  476. {GOP_SIZE, ENC, CODECS_ALL,
  477. 0, INT_MAX, 1, 2 * DEFAULT_FPS - 1,
  478. V4L2_CID_MPEG_VIDEO_GOP_SIZE,
  479. HFI_PROP_MAX_GOP_FRAMES,
  480. CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT |
  481. CAP_FLAG_DYNAMIC_ALLOWED},
  482. {GOP_CLOSURE, ENC, H264|HEVC,
  483. 0, 1, 1, 1,
  484. V4L2_CID_MPEG_VIDEO_GOP_CLOSURE,
  485. 0},
  486. {B_FRAME, ENC, H264|HEVC,
  487. 0, 7, 1, 0,
  488. V4L2_CID_MPEG_VIDEO_B_FRAMES,
  489. HFI_PROP_MAX_B_FRAMES,
  490. CAP_FLAG_OUTPUT_PORT},
  491. {BLUR_TYPES, ENC, H264|HEVC,
  492. MSM_VIDC_BLUR_NONE, MSM_VIDC_BLUR_EXTERNAL,
  493. BIT(MSM_VIDC_BLUR_NONE) | BIT(MSM_VIDC_BLUR_EXTERNAL),
  494. MSM_VIDC_BLUR_NONE,
  495. 0,
  496. HFI_PROP_BLUR_TYPES,
  497. CAP_FLAG_OUTPUT_PORT | CAP_FLAG_MENU},
  498. {CSC, ENC, CODECS_ALL,
  499. 0, 1, 1, 0,
  500. 0,
  501. HFI_PROP_CSC},
  502. {LOWLATENCY_MODE, ENC, H264|HEVC,
  503. 0, 1, 1, 0,
  504. 0,
  505. 0,
  506. CAP_FLAG_NONE},
  507. {LOWLATENCY_MODE, DEC, H264|HEVC|VP9,
  508. 0, 1, 1, 0,
  509. 0,
  510. HFI_PROP_SEQ_CHANGE_AT_SYNC_FRAME,
  511. CAP_FLAG_INPUT_PORT | CAP_FLAG_DYNAMIC_ALLOWED},
  512. {LTR_COUNT, ENC, H264|HEVC,
  513. 0, MAX_LTR_FRAME_COUNT_5, 1, 0,
  514. V4L2_CID_MPEG_VIDEO_LTR_COUNT,
  515. HFI_PROP_LTR_COUNT,
  516. CAP_FLAG_OUTPUT_PORT},
  517. {USE_LTR, ENC, H264|HEVC,
  518. 0,
  519. ((1 << MAX_LTR_FRAME_COUNT_5) - 1),
  520. 0, 0,
  521. V4L2_CID_MPEG_VIDEO_USE_LTR_FRAMES,
  522. HFI_PROP_LTR_USE,
  523. CAP_FLAG_INPUT_PORT | CAP_FLAG_DYNAMIC_ALLOWED},
  524. {MARK_LTR, ENC, H264|HEVC,
  525. INVALID_DEFAULT_MARK_OR_USE_LTR,
  526. (MAX_LTR_FRAME_COUNT_5 - 1),
  527. 1, INVALID_DEFAULT_MARK_OR_USE_LTR,
  528. V4L2_CID_MPEG_VIDEO_FRAME_LTR_INDEX,
  529. HFI_PROP_LTR_MARK,
  530. CAP_FLAG_INPUT_PORT | CAP_FLAG_DYNAMIC_ALLOWED},
  531. {BASELAYER_PRIORITY, ENC, H264,
  532. 0, MAX_BASE_LAYER_PRIORITY_ID, 1, 0,
  533. V4L2_CID_MPEG_VIDEO_BASELAYER_PRIORITY_ID,
  534. HFI_PROP_BASELAYER_PRIORITYID,
  535. CAP_FLAG_OUTPUT_PORT | CAP_FLAG_DYNAMIC_ALLOWED},
  536. {AU_DELIMITER, ENC, H264|HEVC,
  537. 0, 1, 1, 0,
  538. V4L2_CID_MPEG_VIDEO_AU_DELIMITER,
  539. HFI_PROP_AUD,
  540. CAP_FLAG_OUTPUT_PORT},
  541. {CONTENT_ADAPTIVE_CODING, ENC, H264|HEVC,
  542. 0, 1, 1, 1,
  543. 0,
  544. HFI_PROP_CONTENT_ADAPTIVE_CODING,
  545. CAP_FLAG_OUTPUT_PORT},
  546. {REQUEST_PREPROCESS, ENC, H264|HEVC,
  547. MSM_VIDC_PREPROCESS_NONE,
  548. MSM_VIDC_PREPROCESS_TYPE0,
  549. BIT(MSM_VIDC_PREPROCESS_NONE) |
  550. BIT(MSM_VIDC_PREPROCESS_TYPE0),
  551. MSM_VIDC_PREPROCESS_NONE,
  552. 0, HFI_PROP_REQUEST_PREPROCESS,
  553. CAP_FLAG_OUTPUT_PORT | CAP_FLAG_MENU},
  554. {MIN_QUALITY, ENC, H264|HEVC,
  555. 0, MAX_SUPPORTED_MIN_QUALITY, 70, MAX_SUPPORTED_MIN_QUALITY,
  556. 0,
  557. HFI_PROP_MAINTAIN_MIN_QUALITY,
  558. CAP_FLAG_OUTPUT_PORT},
  559. {VBV_DELAY, ENC, H264|HEVC,
  560. 200, 300, 100, 300,
  561. V4L2_CID_MPEG_VIDEO_VBV_DELAY,
  562. HFI_PROP_VBV_DELAY,
  563. CAP_FLAG_OUTPUT_PORT},
  564. {PEAK_BITRATE, ENC, H264|HEVC,
  565. /* default peak bitrate is 10% larger than avg bitrate */
  566. 1, MAX_BITRATE, 1, DEFAULT_BITRATE,
  567. V4L2_CID_MPEG_VIDEO_BITRATE_PEAK,
  568. HFI_PROP_TOTAL_PEAK_BITRATE,
  569. CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT |
  570. CAP_FLAG_DYNAMIC_ALLOWED},
  571. {MIN_FRAME_QP, ENC, H264,
  572. MIN_QP_8BIT, MAX_QP, 1, MIN_QP_8BIT,
  573. V4L2_CID_MPEG_VIDEO_H264_MIN_QP,
  574. HFI_PROP_MIN_QP_PACKED,
  575. CAP_FLAG_OUTPUT_PORT},
  576. {MIN_FRAME_QP, ENC, HEVC,
  577. MIN_QP_10BIT, MAX_QP, 1, MIN_QP_10BIT,
  578. V4L2_CID_MPEG_VIDEO_HEVC_MIN_QP,
  579. HFI_PROP_MIN_QP_PACKED,
  580. CAP_FLAG_OUTPUT_PORT},
  581. {I_FRAME_MIN_QP, ENC, H264,
  582. MIN_QP_8BIT, MAX_QP, 1, MIN_QP_8BIT,
  583. V4L2_CID_MPEG_VIDEO_H264_I_FRAME_MIN_QP},
  584. {I_FRAME_MIN_QP, ENC, HEVC,
  585. MIN_QP_10BIT, MAX_QP, 1, MIN_QP_10BIT,
  586. V4L2_CID_MPEG_VIDEO_HEVC_I_FRAME_MIN_QP},
  587. {P_FRAME_MIN_QP, ENC, H264,
  588. MIN_QP_8BIT, MAX_QP, 1, MIN_QP_8BIT,
  589. V4L2_CID_MPEG_VIDEO_H264_P_FRAME_MIN_QP},
  590. {P_FRAME_MIN_QP, ENC, HEVC,
  591. MIN_QP_10BIT, MAX_QP, 1, MIN_QP_10BIT,
  592. V4L2_CID_MPEG_VIDEO_HEVC_P_FRAME_MIN_QP},
  593. {B_FRAME_MIN_QP, ENC, H264,
  594. MIN_QP_8BIT, MAX_QP, 1, MIN_QP_8BIT,
  595. V4L2_CID_MPEG_VIDEO_H264_B_FRAME_MIN_QP},
  596. {B_FRAME_MIN_QP, ENC, HEVC,
  597. MIN_QP_10BIT, MAX_QP, 1, MIN_QP_10BIT,
  598. V4L2_CID_MPEG_VIDEO_HEVC_B_FRAME_MIN_QP},
  599. {MAX_FRAME_QP, ENC, H264,
  600. MIN_QP_8BIT, MAX_QP, 1, MAX_QP,
  601. V4L2_CID_MPEG_VIDEO_H264_MAX_QP,
  602. HFI_PROP_MAX_QP_PACKED,
  603. CAP_FLAG_OUTPUT_PORT},
  604. {MAX_FRAME_QP, ENC, HEVC,
  605. MIN_QP_10BIT, MAX_QP, 1, MAX_QP,
  606. V4L2_CID_MPEG_VIDEO_HEVC_MAX_QP,
  607. HFI_PROP_MAX_QP_PACKED,
  608. CAP_FLAG_OUTPUT_PORT},
  609. {I_FRAME_MAX_QP, ENC, H264,
  610. MIN_QP_8BIT, MAX_QP, 1, MAX_QP,
  611. V4L2_CID_MPEG_VIDEO_H264_I_FRAME_MAX_QP},
  612. {I_FRAME_MAX_QP, ENC, HEVC,
  613. MIN_QP_10BIT, MAX_QP, 1, MAX_QP,
  614. V4L2_CID_MPEG_VIDEO_HEVC_I_FRAME_MAX_QP},
  615. {P_FRAME_MAX_QP, ENC, H264,
  616. MIN_QP_8BIT, MAX_QP, 1, MAX_QP,
  617. V4L2_CID_MPEG_VIDEO_H264_P_FRAME_MAX_QP},
  618. {P_FRAME_MAX_QP, ENC, HEVC,
  619. MIN_QP_10BIT, MAX_QP, 1, MAX_QP,
  620. V4L2_CID_MPEG_VIDEO_HEVC_P_FRAME_MAX_QP},
  621. {B_FRAME_MAX_QP, ENC, H264,
  622. MIN_QP_8BIT, MAX_QP, 1, MAX_QP,
  623. V4L2_CID_MPEG_VIDEO_H264_B_FRAME_MAX_QP},
  624. {B_FRAME_MAX_QP, ENC, HEVC,
  625. MIN_QP_10BIT, MAX_QP, 1, MAX_QP,
  626. V4L2_CID_MPEG_VIDEO_HEVC_B_FRAME_MAX_QP},
  627. {I_FRAME_QP, ENC, HEVC,
  628. MIN_QP_10BIT, MAX_QP, 1, DEFAULT_QP,
  629. V4L2_CID_MPEG_VIDEO_HEVC_I_FRAME_QP,
  630. HFI_PROP_QP_PACKED,
  631. CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT |
  632. CAP_FLAG_DYNAMIC_ALLOWED},
  633. {I_FRAME_QP, ENC, H264,
  634. MIN_QP_8BIT, MAX_QP, 1, DEFAULT_QP,
  635. V4L2_CID_MPEG_VIDEO_H264_I_FRAME_QP,
  636. HFI_PROP_QP_PACKED,
  637. CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT |
  638. CAP_FLAG_DYNAMIC_ALLOWED},
  639. {P_FRAME_QP, ENC, HEVC,
  640. MIN_QP_10BIT, MAX_QP, 1, DEFAULT_QP,
  641. V4L2_CID_MPEG_VIDEO_HEVC_P_FRAME_QP,
  642. HFI_PROP_QP_PACKED,
  643. CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT |
  644. CAP_FLAG_DYNAMIC_ALLOWED},
  645. {P_FRAME_QP, ENC, H264,
  646. MIN_QP_8BIT, MAX_QP, 1, DEFAULT_QP,
  647. V4L2_CID_MPEG_VIDEO_H264_P_FRAME_QP,
  648. HFI_PROP_QP_PACKED,
  649. CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT |
  650. CAP_FLAG_DYNAMIC_ALLOWED},
  651. {B_FRAME_QP, ENC, HEVC,
  652. MIN_QP_10BIT, MAX_QP, 1, DEFAULT_QP,
  653. V4L2_CID_MPEG_VIDEO_HEVC_B_FRAME_QP,
  654. HFI_PROP_QP_PACKED,
  655. CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT |
  656. CAP_FLAG_DYNAMIC_ALLOWED},
  657. {B_FRAME_QP, ENC, H264,
  658. MIN_QP_8BIT, MAX_QP, 1, DEFAULT_QP,
  659. V4L2_CID_MPEG_VIDEO_H264_B_FRAME_QP,
  660. HFI_PROP_QP_PACKED,
  661. CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT |
  662. CAP_FLAG_DYNAMIC_ALLOWED},
  663. {LAYER_TYPE, ENC, HEVC,
  664. V4L2_MPEG_VIDEO_HEVC_HIERARCHICAL_CODING_B,
  665. V4L2_MPEG_VIDEO_HEVC_HIERARCHICAL_CODING_P,
  666. BIT(V4L2_MPEG_VIDEO_HEVC_HIERARCHICAL_CODING_B) |
  667. BIT(V4L2_MPEG_VIDEO_HEVC_HIERARCHICAL_CODING_P),
  668. V4L2_MPEG_VIDEO_HEVC_HIERARCHICAL_CODING_P,
  669. V4L2_CID_MPEG_VIDEO_HEVC_HIER_CODING_TYPE,
  670. HFI_PROP_LAYER_ENCODING_TYPE,
  671. CAP_FLAG_OUTPUT_PORT | CAP_FLAG_MENU},
  672. {LAYER_TYPE, ENC, H264,
  673. V4L2_MPEG_VIDEO_H264_HIERARCHICAL_CODING_B,
  674. V4L2_MPEG_VIDEO_H264_HIERARCHICAL_CODING_P,
  675. BIT(V4L2_MPEG_VIDEO_H264_HIERARCHICAL_CODING_B) |
  676. BIT(V4L2_MPEG_VIDEO_H264_HIERARCHICAL_CODING_P),
  677. V4L2_MPEG_VIDEO_H264_HIERARCHICAL_CODING_P,
  678. V4L2_CID_MPEG_VIDEO_H264_HIERARCHICAL_CODING_TYPE,
  679. HFI_PROP_LAYER_ENCODING_TYPE,
  680. CAP_FLAG_OUTPUT_PORT | CAP_FLAG_MENU},
  681. {LAYER_ENABLE, ENC, H264,
  682. 0, 1, 1, 0,
  683. V4L2_CID_MPEG_VIDEO_H264_HIERARCHICAL_CODING,
  684. HFI_PROP_LAYER_ENCODING_TYPE,
  685. CAP_FLAG_OUTPUT_PORT},
  686. {LAYER_ENABLE, ENC, HEVC,
  687. 0, 1, 1, 0,
  688. 0,
  689. 0,
  690. CAP_FLAG_OUTPUT_PORT},
  691. {ENH_LAYER_COUNT, ENC, HEVC,
  692. 0, 5, 1, 0,
  693. V4L2_CID_MPEG_VIDEO_HEVC_HIER_CODING_LAYER,
  694. HFI_PROP_LAYER_COUNT,
  695. CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT |
  696. CAP_FLAG_DYNAMIC_ALLOWED},
  697. {ENH_LAYER_COUNT, ENC, H264,
  698. 0, 5, 1, 0,
  699. V4L2_CID_MPEG_VIDEO_H264_HIERARCHICAL_CODING_LAYER,
  700. HFI_PROP_LAYER_COUNT,
  701. CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT |
  702. CAP_FLAG_DYNAMIC_ALLOWED},
  703. {L0_BR, ENC, H264,
  704. 1, MAX_BITRATE, 1, DEFAULT_BITRATE,
  705. V4L2_CID_MPEG_VIDEO_H264_HIER_CODING_L0_BR,
  706. HFI_PROP_BITRATE_LAYER1,
  707. CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT |
  708. CAP_FLAG_DYNAMIC_ALLOWED},
  709. {L0_BR, ENC, HEVC,
  710. 1, MAX_BITRATE, 1, DEFAULT_BITRATE,
  711. V4L2_CID_MPEG_VIDEO_HEVC_HIER_CODING_L0_BR,
  712. HFI_PROP_BITRATE_LAYER1,
  713. CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT |
  714. CAP_FLAG_DYNAMIC_ALLOWED},
  715. {L1_BR, ENC, H264,
  716. 1, MAX_BITRATE, 1, DEFAULT_BITRATE,
  717. V4L2_CID_MPEG_VIDEO_H264_HIER_CODING_L1_BR,
  718. HFI_PROP_BITRATE_LAYER2,
  719. CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT |
  720. CAP_FLAG_DYNAMIC_ALLOWED},
  721. {L1_BR, ENC, HEVC,
  722. 1, MAX_BITRATE, 1, DEFAULT_BITRATE,
  723. V4L2_CID_MPEG_VIDEO_HEVC_HIER_CODING_L1_BR,
  724. HFI_PROP_BITRATE_LAYER2,
  725. CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT |
  726. CAP_FLAG_DYNAMIC_ALLOWED},
  727. {L2_BR, ENC, H264,
  728. 1, MAX_BITRATE, 1, DEFAULT_BITRATE,
  729. V4L2_CID_MPEG_VIDEO_H264_HIER_CODING_L2_BR,
  730. HFI_PROP_BITRATE_LAYER3,
  731. CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT |
  732. CAP_FLAG_DYNAMIC_ALLOWED},
  733. {L2_BR, ENC, HEVC,
  734. 1, MAX_BITRATE, 1, DEFAULT_BITRATE,
  735. V4L2_CID_MPEG_VIDEO_HEVC_HIER_CODING_L2_BR,
  736. HFI_PROP_BITRATE_LAYER3,
  737. CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT |
  738. CAP_FLAG_DYNAMIC_ALLOWED},
  739. {L3_BR, ENC, H264,
  740. 1, MAX_BITRATE, 1, DEFAULT_BITRATE,
  741. V4L2_CID_MPEG_VIDEO_H264_HIER_CODING_L3_BR,
  742. HFI_PROP_BITRATE_LAYER4,
  743. CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT |
  744. CAP_FLAG_DYNAMIC_ALLOWED},
  745. {L3_BR, ENC, HEVC,
  746. 1, MAX_BITRATE, 1, DEFAULT_BITRATE,
  747. V4L2_CID_MPEG_VIDEO_HEVC_HIER_CODING_L3_BR,
  748. HFI_PROP_BITRATE_LAYER4,
  749. CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT |
  750. CAP_FLAG_DYNAMIC_ALLOWED},
  751. {L4_BR, ENC, H264,
  752. 1, MAX_BITRATE, 1, DEFAULT_BITRATE,
  753. V4L2_CID_MPEG_VIDEO_H264_HIER_CODING_L4_BR,
  754. HFI_PROP_BITRATE_LAYER5,
  755. CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT |
  756. CAP_FLAG_DYNAMIC_ALLOWED},
  757. {L4_BR, ENC, HEVC,
  758. 1, MAX_BITRATE, 1, DEFAULT_BITRATE,
  759. V4L2_CID_MPEG_VIDEO_HEVC_HIER_CODING_L4_BR,
  760. HFI_PROP_BITRATE_LAYER5,
  761. CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT |
  762. CAP_FLAG_DYNAMIC_ALLOWED},
  763. {L5_BR, ENC, H264,
  764. 1, MAX_BITRATE, 1, DEFAULT_BITRATE,
  765. V4L2_CID_MPEG_VIDEO_H264_HIER_CODING_L5_BR,
  766. HFI_PROP_BITRATE_LAYER6,
  767. CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT |
  768. CAP_FLAG_DYNAMIC_ALLOWED},
  769. {L5_BR, ENC, HEVC,
  770. 1, MAX_BITRATE, 1, DEFAULT_BITRATE,
  771. V4L2_CID_MPEG_VIDEO_HEVC_HIER_CODING_L5_BR,
  772. HFI_PROP_BITRATE_LAYER6,
  773. CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT |
  774. CAP_FLAG_DYNAMIC_ALLOWED},
  775. {ENTROPY_MODE, ENC, H264,
  776. V4L2_MPEG_VIDEO_H264_ENTROPY_MODE_CAVLC,
  777. V4L2_MPEG_VIDEO_H264_ENTROPY_MODE_CABAC,
  778. BIT(V4L2_MPEG_VIDEO_H264_ENTROPY_MODE_CAVLC) |
  779. BIT(V4L2_MPEG_VIDEO_H264_ENTROPY_MODE_CABAC),
  780. V4L2_MPEG_VIDEO_H264_ENTROPY_MODE_CABAC,
  781. V4L2_CID_MPEG_VIDEO_H264_ENTROPY_MODE,
  782. HFI_PROP_CABAC_SESSION,
  783. CAP_FLAG_OUTPUT_PORT | CAP_FLAG_MENU},
  784. {ENTROPY_MODE, DEC, H264|HEVC|VP9,
  785. V4L2_MPEG_VIDEO_H264_ENTROPY_MODE_CAVLC,
  786. V4L2_MPEG_VIDEO_H264_ENTROPY_MODE_CABAC,
  787. BIT(V4L2_MPEG_VIDEO_H264_ENTROPY_MODE_CAVLC) |
  788. BIT(V4L2_MPEG_VIDEO_H264_ENTROPY_MODE_CABAC),
  789. V4L2_MPEG_VIDEO_H264_ENTROPY_MODE_CABAC,
  790. 0,
  791. HFI_PROP_CABAC_SESSION},
  792. {PROFILE, ENC|DEC, H264,
  793. V4L2_MPEG_VIDEO_H264_PROFILE_BASELINE,
  794. V4L2_MPEG_VIDEO_H264_PROFILE_CONSTRAINED_HIGH,
  795. BIT(V4L2_MPEG_VIDEO_H264_PROFILE_BASELINE) |
  796. BIT(V4L2_MPEG_VIDEO_H264_PROFILE_CONSTRAINED_HIGH) |
  797. BIT(V4L2_MPEG_VIDEO_H264_PROFILE_CONSTRAINED_BASELINE) |
  798. BIT(V4L2_MPEG_VIDEO_H264_PROFILE_MAIN) |
  799. BIT(V4L2_MPEG_VIDEO_H264_PROFILE_HIGH),
  800. V4L2_MPEG_VIDEO_H264_PROFILE_HIGH,
  801. V4L2_CID_MPEG_VIDEO_H264_PROFILE,
  802. HFI_PROP_PROFILE,
  803. CAP_FLAG_OUTPUT_PORT | CAP_FLAG_MENU},
  804. {PROFILE, ENC|DEC, HEVC,
  805. V4L2_MPEG_VIDEO_HEVC_PROFILE_MAIN,
  806. V4L2_MPEG_VIDEO_HEVC_PROFILE_MAIN_10_STILL_PICTURE,
  807. BIT(V4L2_MPEG_VIDEO_HEVC_PROFILE_MAIN) |
  808. BIT(V4L2_MPEG_VIDEO_HEVC_PROFILE_MAIN_STILL_PICTURE) |
  809. BIT(V4L2_MPEG_VIDEO_HEVC_PROFILE_MAIN_10) |
  810. BIT(V4L2_MPEG_VIDEO_HEVC_PROFILE_MAIN_10_STILL_PICTURE),
  811. V4L2_MPEG_VIDEO_HEVC_PROFILE_MAIN,
  812. V4L2_CID_MPEG_VIDEO_HEVC_PROFILE,
  813. HFI_PROP_PROFILE,
  814. CAP_FLAG_OUTPUT_PORT | CAP_FLAG_MENU},
  815. {PROFILE, DEC, VP9,
  816. V4L2_MPEG_VIDEO_VP9_PROFILE_0,
  817. V4L2_MPEG_VIDEO_VP9_PROFILE_2,
  818. BIT(V4L2_MPEG_VIDEO_VP9_PROFILE_0) |
  819. BIT(V4L2_MPEG_VIDEO_VP9_PROFILE_2),
  820. V4L2_MPEG_VIDEO_VP9_PROFILE_0,
  821. V4L2_CID_MPEG_VIDEO_VP9_PROFILE,
  822. HFI_PROP_PROFILE,
  823. CAP_FLAG_OUTPUT_PORT | CAP_FLAG_MENU},
  824. {LEVEL, ENC, H264,
  825. V4L2_MPEG_VIDEO_H264_LEVEL_1_0,
  826. V4L2_MPEG_VIDEO_H264_LEVEL_6_0,
  827. BIT(V4L2_MPEG_VIDEO_H264_LEVEL_1_0) |
  828. BIT(V4L2_MPEG_VIDEO_H264_LEVEL_1B) |
  829. BIT(V4L2_MPEG_VIDEO_H264_LEVEL_1_1) |
  830. BIT(V4L2_MPEG_VIDEO_H264_LEVEL_1_2) |
  831. BIT(V4L2_MPEG_VIDEO_H264_LEVEL_1_3) |
  832. BIT(V4L2_MPEG_VIDEO_H264_LEVEL_2_0) |
  833. BIT(V4L2_MPEG_VIDEO_H264_LEVEL_2_1) |
  834. BIT(V4L2_MPEG_VIDEO_H264_LEVEL_2_2) |
  835. BIT(V4L2_MPEG_VIDEO_H264_LEVEL_3_0) |
  836. BIT(V4L2_MPEG_VIDEO_H264_LEVEL_3_1) |
  837. BIT(V4L2_MPEG_VIDEO_H264_LEVEL_3_2) |
  838. BIT(V4L2_MPEG_VIDEO_H264_LEVEL_4_0) |
  839. BIT(V4L2_MPEG_VIDEO_H264_LEVEL_4_1) |
  840. BIT(V4L2_MPEG_VIDEO_H264_LEVEL_4_2) |
  841. BIT(V4L2_MPEG_VIDEO_H264_LEVEL_5_0) |
  842. BIT(V4L2_MPEG_VIDEO_H264_LEVEL_5_1) |
  843. BIT(V4L2_MPEG_VIDEO_H264_LEVEL_5_2) |
  844. BIT(V4L2_MPEG_VIDEO_H264_LEVEL_6_0),
  845. V4L2_MPEG_VIDEO_H264_LEVEL_5_0,
  846. V4L2_CID_MPEG_VIDEO_H264_LEVEL,
  847. HFI_PROP_LEVEL,
  848. CAP_FLAG_OUTPUT_PORT | CAP_FLAG_MENU},
  849. {LEVEL, ENC, HEVC,
  850. V4L2_MPEG_VIDEO_HEVC_LEVEL_1,
  851. V4L2_MPEG_VIDEO_HEVC_LEVEL_6,
  852. BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_1) |
  853. BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_2) |
  854. BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_2_1) |
  855. BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_3) |
  856. BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_3_1) |
  857. BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_4) |
  858. BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_4_1) |
  859. BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_5) |
  860. BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_5_1) |
  861. BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_5_2) |
  862. BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_6),
  863. V4L2_MPEG_VIDEO_HEVC_LEVEL_5,
  864. V4L2_CID_MPEG_VIDEO_HEVC_LEVEL,
  865. HFI_PROP_LEVEL,
  866. CAP_FLAG_OUTPUT_PORT | CAP_FLAG_MENU},
  867. {LEVEL, DEC, H264,
  868. V4L2_MPEG_VIDEO_H264_LEVEL_1_0,
  869. V4L2_MPEG_VIDEO_H264_LEVEL_6_2,
  870. BIT(V4L2_MPEG_VIDEO_H264_LEVEL_1_0) |
  871. BIT(V4L2_MPEG_VIDEO_H264_LEVEL_1B) |
  872. BIT(V4L2_MPEG_VIDEO_H264_LEVEL_1_1) |
  873. BIT(V4L2_MPEG_VIDEO_H264_LEVEL_1_2) |
  874. BIT(V4L2_MPEG_VIDEO_H264_LEVEL_1_3) |
  875. BIT(V4L2_MPEG_VIDEO_H264_LEVEL_2_0) |
  876. BIT(V4L2_MPEG_VIDEO_H264_LEVEL_2_1) |
  877. BIT(V4L2_MPEG_VIDEO_H264_LEVEL_2_2) |
  878. BIT(V4L2_MPEG_VIDEO_H264_LEVEL_3_0) |
  879. BIT(V4L2_MPEG_VIDEO_H264_LEVEL_3_1) |
  880. BIT(V4L2_MPEG_VIDEO_H264_LEVEL_3_2) |
  881. BIT(V4L2_MPEG_VIDEO_H264_LEVEL_4_0) |
  882. BIT(V4L2_MPEG_VIDEO_H264_LEVEL_4_1) |
  883. BIT(V4L2_MPEG_VIDEO_H264_LEVEL_4_2) |
  884. BIT(V4L2_MPEG_VIDEO_H264_LEVEL_5_0) |
  885. BIT(V4L2_MPEG_VIDEO_H264_LEVEL_5_1) |
  886. BIT(V4L2_MPEG_VIDEO_H264_LEVEL_5_2) |
  887. BIT(V4L2_MPEG_VIDEO_H264_LEVEL_6_0) |
  888. BIT(V4L2_MPEG_VIDEO_H264_LEVEL_6_1) |
  889. BIT(V4L2_MPEG_VIDEO_H264_LEVEL_6_2),
  890. V4L2_MPEG_VIDEO_H264_LEVEL_6_1,
  891. V4L2_CID_MPEG_VIDEO_H264_LEVEL,
  892. HFI_PROP_LEVEL,
  893. CAP_FLAG_OUTPUT_PORT | CAP_FLAG_MENU},
  894. {LEVEL, DEC, HEVC,
  895. V4L2_MPEG_VIDEO_HEVC_LEVEL_1,
  896. V4L2_MPEG_VIDEO_HEVC_LEVEL_6_2,
  897. BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_1) |
  898. BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_2) |
  899. BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_2_1) |
  900. BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_3) |
  901. BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_3_1) |
  902. BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_4) |
  903. BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_4_1) |
  904. BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_5) |
  905. BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_5_1) |
  906. BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_5_2) |
  907. BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_6) |
  908. BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_6_1)|
  909. BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_6_2),
  910. V4L2_MPEG_VIDEO_HEVC_LEVEL_6_1,
  911. V4L2_CID_MPEG_VIDEO_HEVC_LEVEL,
  912. HFI_PROP_LEVEL,
  913. CAP_FLAG_OUTPUT_PORT | CAP_FLAG_MENU},
  914. {LEVEL, DEC, VP9,
  915. V4L2_MPEG_VIDEO_VP9_LEVEL_1_0,
  916. V4L2_MPEG_VIDEO_VP9_LEVEL_6_0,
  917. BIT(V4L2_MPEG_VIDEO_VP9_LEVEL_1_0) |
  918. BIT(V4L2_MPEG_VIDEO_VP9_LEVEL_1_1) |
  919. BIT(V4L2_MPEG_VIDEO_VP9_LEVEL_2_0) |
  920. BIT(V4L2_MPEG_VIDEO_VP9_LEVEL_2_1) |
  921. BIT(V4L2_MPEG_VIDEO_VP9_LEVEL_3_0) |
  922. BIT(V4L2_MPEG_VIDEO_VP9_LEVEL_3_1) |
  923. BIT(V4L2_MPEG_VIDEO_VP9_LEVEL_4_0) |
  924. BIT(V4L2_MPEG_VIDEO_VP9_LEVEL_4_1) |
  925. BIT(V4L2_MPEG_VIDEO_VP9_LEVEL_5_0) |
  926. BIT(V4L2_MPEG_VIDEO_VP9_LEVEL_5_1) |
  927. BIT(V4L2_MPEG_VIDEO_VP9_LEVEL_5_2) |
  928. BIT(V4L2_MPEG_VIDEO_VP9_LEVEL_6_0),
  929. V4L2_MPEG_VIDEO_VP9_LEVEL_6_0,
  930. V4L2_CID_MPEG_VIDEO_VP9_LEVEL,
  931. HFI_PROP_LEVEL,
  932. CAP_FLAG_OUTPUT_PORT | CAP_FLAG_MENU},
  933. {HEVC_TIER, ENC|DEC, HEVC,
  934. V4L2_MPEG_VIDEO_HEVC_TIER_MAIN,
  935. V4L2_MPEG_VIDEO_HEVC_TIER_HIGH,
  936. BIT(V4L2_MPEG_VIDEO_HEVC_TIER_MAIN) |
  937. BIT(V4L2_MPEG_VIDEO_HEVC_TIER_HIGH),
  938. V4L2_MPEG_VIDEO_HEVC_TIER_HIGH,
  939. V4L2_CID_MPEG_VIDEO_HEVC_TIER,
  940. HFI_PROP_TIER,
  941. CAP_FLAG_OUTPUT_PORT | CAP_FLAG_MENU},
  942. {LF_MODE, ENC, H264,
  943. V4L2_MPEG_VIDEO_H264_LOOP_FILTER_MODE_ENABLED,
  944. DB_H264_DISABLE_SLICE_BOUNDARY,
  945. BIT(V4L2_MPEG_VIDEO_H264_LOOP_FILTER_MODE_ENABLED) |
  946. BIT(V4L2_MPEG_VIDEO_H264_LOOP_FILTER_MODE_DISABLED) |
  947. BIT(DB_H264_DISABLE_SLICE_BOUNDARY),
  948. V4L2_MPEG_VIDEO_H264_LOOP_FILTER_MODE_ENABLED,
  949. V4L2_CID_MPEG_VIDEO_H264_LOOP_FILTER_MODE,
  950. HFI_PROP_DEBLOCKING_MODE,
  951. CAP_FLAG_OUTPUT_PORT | CAP_FLAG_MENU},
  952. {LF_MODE, ENC, HEVC,
  953. V4L2_MPEG_VIDEO_HEVC_LOOP_FILTER_MODE_DISABLED,
  954. DB_HEVC_DISABLE_SLICE_BOUNDARY,
  955. BIT(V4L2_MPEG_VIDEO_HEVC_LOOP_FILTER_MODE_DISABLED) |
  956. BIT(V4L2_MPEG_VIDEO_HEVC_LOOP_FILTER_MODE_ENABLED) |
  957. BIT(DB_HEVC_DISABLE_SLICE_BOUNDARY),
  958. V4L2_MPEG_VIDEO_HEVC_LOOP_FILTER_MODE_ENABLED,
  959. V4L2_CID_MPEG_VIDEO_HEVC_LOOP_FILTER_MODE,
  960. HFI_PROP_DEBLOCKING_MODE,
  961. CAP_FLAG_OUTPUT_PORT | CAP_FLAG_MENU},
  962. {LF_ALPHA, ENC, H264,
  963. -6, 6, 1, 0,
  964. V4L2_CID_MPEG_VIDEO_H264_LOOP_FILTER_ALPHA},
  965. {LF_ALPHA, ENC, HEVC,
  966. -6, 6, 1, 0,
  967. V4L2_CID_MPEG_VIDEO_HEVC_LF_TC_OFFSET_DIV2},
  968. {LF_BETA, ENC, H264,
  969. -6, 6, 1, 0,
  970. V4L2_CID_MPEG_VIDEO_H264_LOOP_FILTER_BETA},
  971. {LF_BETA, ENC, HEVC,
  972. -6, 6, 1, 0,
  973. V4L2_CID_MPEG_VIDEO_HEVC_LF_BETA_OFFSET_DIV2},
  974. {SLICE_MODE, ENC, H264|HEVC,
  975. V4L2_MPEG_VIDEO_MULTI_SLICE_MODE_SINGLE,
  976. V4L2_MPEG_VIDEO_MULTI_SLICE_MODE_MAX_BYTES,
  977. BIT(V4L2_MPEG_VIDEO_MULTI_SLICE_MODE_SINGLE) |
  978. BIT(V4L2_MPEG_VIDEO_MULTI_SLICE_MODE_MAX_MB) |
  979. BIT(V4L2_MPEG_VIDEO_MULTI_SLICE_MODE_MAX_BYTES),
  980. V4L2_MPEG_VIDEO_MULTI_SLICE_MODE_SINGLE,
  981. V4L2_CID_MPEG_VIDEO_MULTI_SLICE_MODE,
  982. 0,
  983. CAP_FLAG_OUTPUT_PORT | CAP_FLAG_MENU},
  984. {SLICE_MAX_BYTES, ENC, H264|HEVC,
  985. MIN_SLICE_BYTE_SIZE, MAX_SLICE_BYTE_SIZE,
  986. 1, MIN_SLICE_BYTE_SIZE,
  987. V4L2_CID_MPEG_VIDEO_MULTI_SLICE_MAX_BYTES,
  988. HFI_PROP_MULTI_SLICE_BYTES_COUNT,
  989. CAP_FLAG_OUTPUT_PORT},
  990. {SLICE_MAX_MB, ENC, H264|HEVC,
  991. 1, MAX_SLICE_MB_SIZE, 1, 1,
  992. V4L2_CID_MPEG_VIDEO_MULTI_SLICE_MAX_MB,
  993. HFI_PROP_MULTI_SLICE_MB_COUNT,
  994. CAP_FLAG_OUTPUT_PORT},
  995. {MB_RC, ENC, H264|HEVC,
  996. 0, 1, 1, 1,
  997. V4L2_CID_MPEG_VIDEO_MB_RC_ENABLE,
  998. 0,
  999. CAP_FLAG_OUTPUT_PORT},
  1000. {TRANSFORM_8X8, ENC, H264,
  1001. 0, 1, 1, 1,
  1002. V4L2_CID_MPEG_VIDEO_H264_8X8_TRANSFORM,
  1003. HFI_PROP_8X8_TRANSFORM,
  1004. CAP_FLAG_OUTPUT_PORT},
  1005. {CHROMA_QP_INDEX_OFFSET, ENC, HEVC,
  1006. MIN_CHROMA_QP_OFFSET, MAX_CHROMA_QP_OFFSET,
  1007. 1, MAX_CHROMA_QP_OFFSET,
  1008. V4L2_CID_MPEG_VIDEO_H264_CHROMA_QP_INDEX_OFFSET,
  1009. HFI_PROP_CHROMA_QP_OFFSET,
  1010. CAP_FLAG_OUTPUT_PORT},
  1011. {DISPLAY_DELAY_ENABLE, DEC, H264|HEVC|VP9,
  1012. 0, 1, 1, 0,
  1013. V4L2_CID_MPEG_VIDEO_DEC_DISPLAY_DELAY_ENABLE,
  1014. HFI_PROP_DECODE_ORDER_OUTPUT,
  1015. CAP_FLAG_INPUT_PORT},
  1016. {DISPLAY_DELAY, DEC, H264|HEVC|VP9,
  1017. 0, 1, 1, 0,
  1018. V4L2_CID_MPEG_VIDEO_DEC_DISPLAY_DELAY,
  1019. HFI_PROP_DECODE_ORDER_OUTPUT,
  1020. CAP_FLAG_INPUT_PORT},
  1021. {OUTPUT_ORDER, DEC, H264|HEVC|VP9,
  1022. 0, 1, 1, 0,
  1023. 0,
  1024. HFI_PROP_DECODE_ORDER_OUTPUT,
  1025. CAP_FLAG_INPUT_PORT},
  1026. {INPUT_BUF_HOST_MAX_COUNT, ENC|DEC, CODECS_ALL,
  1027. DEFAULT_MAX_HOST_BUF_COUNT, DEFAULT_MAX_HOST_BURST_BUF_COUNT,
  1028. 1, DEFAULT_MAX_HOST_BUF_COUNT,
  1029. 0,
  1030. HFI_PROP_BUFFER_HOST_MAX_COUNT,
  1031. CAP_FLAG_INPUT_PORT},
  1032. {OUTPUT_BUF_HOST_MAX_COUNT, ENC|DEC, CODECS_ALL,
  1033. DEFAULT_MAX_HOST_BUF_COUNT, DEFAULT_MAX_HOST_BURST_BUF_COUNT,
  1034. 1, DEFAULT_MAX_HOST_BUF_COUNT,
  1035. 0,
  1036. HFI_PROP_BUFFER_HOST_MAX_COUNT,
  1037. CAP_FLAG_OUTPUT_PORT},
  1038. {CONCEAL_COLOR_8BIT, DEC, CODECS_ALL, 0x0, 0xff3fcff, 1,
  1039. DEFAULT_VIDEO_CONCEAL_COLOR_BLACK,
  1040. V4L2_CID_MPEG_VIDEO_MUTE_YUV,
  1041. HFI_PROP_CONCEAL_COLOR_8BIT,
  1042. CAP_FLAG_INPUT_PORT},
  1043. {CONCEAL_COLOR_10BIT, DEC, CODECS_ALL, 0x0, 0x3fffffff, 1,
  1044. DEFAULT_VIDEO_CONCEAL_COLOR_BLACK,
  1045. V4L2_CID_MPEG_VIDEO_MUTE_YUV,
  1046. HFI_PROP_CONCEAL_COLOR_10BIT,
  1047. CAP_FLAG_INPUT_PORT},
  1048. {STAGE, DEC|ENC, CODECS_ALL,
  1049. MSM_VIDC_STAGE_1,
  1050. MSM_VIDC_STAGE_2, 1,
  1051. MSM_VIDC_STAGE_2,
  1052. 0,
  1053. HFI_PROP_STAGE},
  1054. {PIPE, DEC|ENC, CODECS_ALL,
  1055. MSM_VIDC_PIPE_1,
  1056. MSM_VIDC_PIPE_4, 1,
  1057. MSM_VIDC_PIPE_4,
  1058. 0,
  1059. HFI_PROP_PIPE},
  1060. {POC, DEC, H264, 0, 2, 1, 1,
  1061. 0,
  1062. HFI_PROP_PIC_ORDER_CNT_TYPE},
  1063. {QUALITY_MODE, ENC, CODECS_ALL,
  1064. MSM_VIDC_MAX_QUALITY_MODE,
  1065. MSM_VIDC_POWER_SAVE_MODE, 1,
  1066. MSM_VIDC_POWER_SAVE_MODE},
  1067. {CODED_FRAMES, DEC, H264|HEVC,
  1068. CODED_FRAMES_PROGRESSIVE, CODED_FRAMES_INTERLACE,
  1069. 1, CODED_FRAMES_PROGRESSIVE,
  1070. 0,
  1071. HFI_PROP_CODED_FRAMES},
  1072. {BIT_DEPTH, DEC, CODECS_ALL, BIT_DEPTH_8, BIT_DEPTH_10, 1, BIT_DEPTH_8,
  1073. 0,
  1074. HFI_PROP_LUMA_CHROMA_BIT_DEPTH},
  1075. {CODEC_CONFIG, DEC, H264|HEVC, 0, 1, 1, 0,
  1076. 0, 0,
  1077. CAP_FLAG_DYNAMIC_ALLOWED},
  1078. {BITSTREAM_SIZE_OVERWRITE, DEC, CODECS_ALL, 0, INT_MAX, 1, 0,
  1079. 0},
  1080. {THUMBNAIL_MODE, DEC, CODECS_ALL,
  1081. 0, 1, 1, 0,
  1082. 0,
  1083. HFI_PROP_THUMBNAIL_MODE,
  1084. CAP_FLAG_INPUT_PORT},
  1085. {DEFAULT_HEADER, DEC, CODECS_ALL,
  1086. 0, 1, 1, 0,
  1087. 0,
  1088. HFI_PROP_DEC_DEFAULT_HEADER},
  1089. {RAP_FRAME, DEC, CODECS_ALL,
  1090. 0, 1, 1, 1,
  1091. 0,
  1092. HFI_PROP_DEC_START_FROM_RAP_FRAME,
  1093. CAP_FLAG_INPUT_PORT},
  1094. {SEQ_CHANGE_AT_SYNC_FRAME, DEC, CODECS_ALL,
  1095. 0, 1, 1, 1,
  1096. 0,
  1097. HFI_PROP_SEQ_CHANGE_AT_SYNC_FRAME,
  1098. CAP_FLAG_INPUT_PORT | CAP_FLAG_DYNAMIC_ALLOWED},
  1099. {FIRMWARE_PRIORITY_OFFSET, DEC | ENC, CODECS_ALL,
  1100. 1, 1, 1, 1},
  1101. {ALL_INTRA, ENC, H264|HEVC,
  1102. 0, 1, 1, 0,
  1103. 0,
  1104. 0,
  1105. CAP_FLAG_OUTPUT_PORT},
  1106. {COMPLEXITY, ENC, H264|HEVC,
  1107. 0, 100,
  1108. 1, DEFAULT_COMPLEXITY,
  1109. 0},
  1110. };
  1111. static struct msm_platform_inst_cap_dependency instance_cap_dependency_data_pineapple[] = {
  1112. /* {cap, domain, codec,
  1113. * parents,
  1114. * children,
  1115. * adjust, set}
  1116. */
  1117. {PIX_FMTS, ENC, HEVC,
  1118. {PROFILE, MIN_FRAME_QP, MAX_FRAME_QP, I_FRAME_QP, P_FRAME_QP,
  1119. B_FRAME_QP, MIN_QUALITY, BLUR_TYPES, LTR_COUNT}},
  1120. {PIX_FMTS, DEC, HEVC,
  1121. {PROFILE}},
  1122. {FRAME_RATE, ENC, CODECS_ALL,
  1123. {0},
  1124. NULL,
  1125. msm_vidc_set_q16},
  1126. {ENC_RING_BUFFER_COUNT, ENC, CODECS_ALL,
  1127. {0},
  1128. NULL,
  1129. msm_vidc_set_ring_buffer_count_pineapple},
  1130. {HFLIP, ENC, CODECS_ALL,
  1131. {0},
  1132. NULL,
  1133. msm_vidc_set_flip},
  1134. {VFLIP, ENC, CODECS_ALL,
  1135. {0},
  1136. NULL,
  1137. msm_vidc_set_flip},
  1138. {ROTATION, ENC, CODECS_ALL,
  1139. {0},
  1140. NULL,
  1141. msm_vidc_set_rotation},
  1142. {SUPER_FRAME, ENC, H264|HEVC,
  1143. {INPUT_BUF_HOST_MAX_COUNT, OUTPUT_BUF_HOST_MAX_COUNT},
  1144. NULL,
  1145. NULL},
  1146. {HEADER_MODE, ENC, CODECS_ALL,
  1147. {0},
  1148. NULL,
  1149. msm_vidc_set_header_mode},
  1150. {WITHOUT_STARTCODE, ENC, CODECS_ALL,
  1151. {0},
  1152. NULL,
  1153. msm_vidc_set_nal_length},
  1154. {REQUEST_I_FRAME, ENC, H264|HEVC,
  1155. {0},
  1156. NULL,
  1157. msm_vidc_set_req_sync_frame},
  1158. {BIT_RATE, ENC, H264,
  1159. {PEAK_BITRATE, L0_BR},
  1160. msm_vidc_adjust_bitrate,
  1161. msm_vidc_set_bitrate},
  1162. {BIT_RATE, ENC, HEVC,
  1163. {PEAK_BITRATE, L0_BR},
  1164. msm_vidc_adjust_bitrate,
  1165. msm_vidc_set_bitrate},
  1166. {BITRATE_MODE, ENC, H264,
  1167. {LTR_COUNT, I_FRAME_QP, P_FRAME_QP,
  1168. B_FRAME_QP, ENH_LAYER_COUNT, BIT_RATE,
  1169. MIN_QUALITY, VBV_DELAY,
  1170. PEAK_BITRATE, SLICE_MODE, CONTENT_ADAPTIVE_CODING,
  1171. BLUR_TYPES, LOWLATENCY_MODE},
  1172. msm_vidc_adjust_bitrate_mode,
  1173. msm_vidc_set_u32_enum},
  1174. {BITRATE_MODE, ENC, HEVC,
  1175. {LTR_COUNT, I_FRAME_QP, P_FRAME_QP,
  1176. B_FRAME_QP, CONSTANT_QUALITY, ENH_LAYER_COUNT,
  1177. BIT_RATE, MIN_QUALITY, VBV_DELAY,
  1178. PEAK_BITRATE, SLICE_MODE, CONTENT_ADAPTIVE_CODING,
  1179. BLUR_TYPES, LOWLATENCY_MODE},
  1180. msm_vidc_adjust_bitrate_mode,
  1181. msm_vidc_set_u32_enum},
  1182. {CONSTANT_QUALITY, ENC, HEVC,
  1183. {0},
  1184. NULL,
  1185. msm_vidc_set_constant_quality},
  1186. {GOP_SIZE, ENC, CODECS_ALL,
  1187. {ALL_INTRA},
  1188. msm_vidc_adjust_gop_size,
  1189. msm_vidc_set_gop_size},
  1190. {B_FRAME, ENC, H264|HEVC,
  1191. {ALL_INTRA},
  1192. msm_vidc_adjust_b_frame,
  1193. msm_vidc_set_u32},
  1194. {BLUR_TYPES, ENC, H264|HEVC,
  1195. {0},
  1196. msm_vidc_adjust_blur_type,
  1197. msm_vidc_set_u32_enum},
  1198. {LOWLATENCY_MODE, ENC, H264 | HEVC,
  1199. {STAGE, BIT_RATE},
  1200. msm_vidc_adjust_enc_lowlatency_mode,
  1201. NULL},
  1202. {LOWLATENCY_MODE, DEC, H264|HEVC|VP9,
  1203. {STAGE},
  1204. msm_vidc_adjust_dec_lowlatency_mode,
  1205. NULL},
  1206. {LTR_COUNT, ENC, H264|HEVC,
  1207. {0},
  1208. msm_vidc_adjust_ltr_count,
  1209. msm_vidc_set_u32},
  1210. {USE_LTR, ENC, H264|HEVC,
  1211. {0},
  1212. msm_vidc_adjust_use_ltr,
  1213. msm_vidc_set_use_and_mark_ltr},
  1214. {MARK_LTR, ENC, H264|HEVC,
  1215. {0},
  1216. msm_vidc_adjust_mark_ltr,
  1217. msm_vidc_set_use_and_mark_ltr},
  1218. {AU_DELIMITER, ENC, H264|HEVC,
  1219. {0},
  1220. NULL,
  1221. msm_vidc_set_u32},
  1222. {CONTENT_ADAPTIVE_CODING, ENC, H264|HEVC,
  1223. {REQUEST_PREPROCESS},
  1224. msm_vidc_adjust_brs,
  1225. msm_vidc_set_vbr_related_properties},
  1226. {REQUEST_PREPROCESS, ENC, H264|HEVC,
  1227. {0},
  1228. msm_vidc_adjust_preprocess,
  1229. msm_vidc_set_preprocess},
  1230. {MIN_QUALITY, ENC, H264,
  1231. {BLUR_TYPES},
  1232. msm_vidc_adjust_min_quality,
  1233. msm_vidc_set_u32},
  1234. {MIN_QUALITY, ENC, HEVC,
  1235. {BLUR_TYPES},
  1236. msm_vidc_adjust_min_quality,
  1237. msm_vidc_set_u32},
  1238. {VBV_DELAY, ENC, H264|HEVC,
  1239. {0},
  1240. NULL,
  1241. msm_vidc_set_cbr_related_properties},
  1242. {PEAK_BITRATE, ENC, H264|HEVC,
  1243. {0},
  1244. msm_vidc_adjust_peak_bitrate,
  1245. msm_vidc_set_cbr_related_properties},
  1246. {MIN_FRAME_QP, ENC, H264,
  1247. {0},
  1248. NULL,
  1249. msm_vidc_set_min_qp},
  1250. {MIN_FRAME_QP, ENC, HEVC,
  1251. {0},
  1252. msm_vidc_adjust_hevc_min_qp,
  1253. msm_vidc_set_min_qp},
  1254. {MAX_FRAME_QP, ENC, H264,
  1255. {0},
  1256. NULL,
  1257. msm_vidc_set_max_qp},
  1258. {MAX_FRAME_QP, ENC, HEVC,
  1259. {0},
  1260. msm_vidc_adjust_hevc_max_qp,
  1261. msm_vidc_set_max_qp},
  1262. {I_FRAME_QP, ENC, HEVC,
  1263. {0},
  1264. msm_vidc_adjust_hevc_i_frame_qp,
  1265. msm_vidc_set_frame_qp},
  1266. {I_FRAME_QP, ENC, H264,
  1267. {0},
  1268. NULL,
  1269. msm_vidc_set_frame_qp},
  1270. {P_FRAME_QP, ENC, HEVC,
  1271. {0},
  1272. msm_vidc_adjust_hevc_p_frame_qp,
  1273. msm_vidc_set_frame_qp},
  1274. {P_FRAME_QP, ENC, H264,
  1275. {0},
  1276. NULL,
  1277. msm_vidc_set_frame_qp},
  1278. {B_FRAME_QP, ENC, HEVC,
  1279. {0},
  1280. msm_vidc_adjust_hevc_b_frame_qp,
  1281. msm_vidc_set_frame_qp},
  1282. {B_FRAME_QP, ENC, H264,
  1283. {0},
  1284. NULL,
  1285. msm_vidc_set_frame_qp},
  1286. {LAYER_TYPE, ENC, H264|HEVC,
  1287. {CONTENT_ADAPTIVE_CODING, LTR_COUNT}},
  1288. {LAYER_ENABLE, ENC, H264|HEVC,
  1289. {CONTENT_ADAPTIVE_CODING}},
  1290. {ENH_LAYER_COUNT, ENC, H264|HEVC,
  1291. {GOP_SIZE, B_FRAME, BIT_RATE, MIN_QUALITY, LTR_COUNT},
  1292. msm_vidc_adjust_layer_count,
  1293. msm_vidc_set_layer_count_and_type},
  1294. {L0_BR, ENC, H264|HEVC,
  1295. {L1_BR},
  1296. msm_vidc_adjust_layer_bitrate,
  1297. msm_vidc_set_layer_bitrate},
  1298. {L1_BR, ENC, H264|HEVC,
  1299. {L2_BR},
  1300. msm_vidc_adjust_layer_bitrate,
  1301. msm_vidc_set_layer_bitrate},
  1302. {L2_BR, ENC, H264|HEVC,
  1303. {L3_BR},
  1304. msm_vidc_adjust_layer_bitrate,
  1305. msm_vidc_set_layer_bitrate},
  1306. {L3_BR, ENC, H264|HEVC,
  1307. {L4_BR},
  1308. msm_vidc_adjust_layer_bitrate,
  1309. msm_vidc_set_layer_bitrate},
  1310. {L4_BR, ENC, H264|HEVC,
  1311. {L5_BR},
  1312. msm_vidc_adjust_layer_bitrate,
  1313. msm_vidc_set_layer_bitrate},
  1314. {L5_BR, ENC, H264|HEVC,
  1315. {0},
  1316. msm_vidc_adjust_layer_bitrate,
  1317. msm_vidc_set_layer_bitrate},
  1318. {ENTROPY_MODE, ENC, H264,
  1319. {BIT_RATE},
  1320. msm_vidc_adjust_entropy_mode,
  1321. msm_vidc_set_u32},
  1322. {PROFILE, ENC, H264,
  1323. {ENTROPY_MODE, TRANSFORM_8X8},
  1324. NULL,
  1325. msm_vidc_set_u32_enum},
  1326. {PROFILE, DEC, H264,
  1327. {ENTROPY_MODE},
  1328. NULL,
  1329. msm_vidc_set_u32_enum},
  1330. {PROFILE, ENC|DEC, HEVC,
  1331. {0},
  1332. msm_vidc_adjust_profile,
  1333. msm_vidc_set_u32_enum},
  1334. {PROFILE, DEC, VP9,
  1335. {0},
  1336. NULL,
  1337. msm_vidc_set_u32_enum},
  1338. {LEVEL, DEC, CODECS_ALL,
  1339. {0},
  1340. NULL,
  1341. msm_vidc_set_u32_enum},
  1342. {LEVEL, ENC, CODECS_ALL,
  1343. {0},
  1344. NULL,
  1345. msm_vidc_set_level},
  1346. {HEVC_TIER, ENC|DEC, HEVC,
  1347. {0},
  1348. NULL,
  1349. msm_vidc_set_u32_enum},
  1350. {LF_MODE, ENC, CODECS_ALL,
  1351. {0},
  1352. NULL,
  1353. msm_vidc_set_deblock_mode},
  1354. {SLICE_MODE, ENC, H264|HEVC,
  1355. {STAGE, DELIVERY_MODE},
  1356. msm_vidc_adjust_slice_count,
  1357. msm_vidc_set_slice_count},
  1358. {TRANSFORM_8X8, ENC, H264,
  1359. {0},
  1360. msm_vidc_adjust_transform_8x8,
  1361. msm_vidc_set_u32},
  1362. {CHROMA_QP_INDEX_OFFSET, ENC, HEVC,
  1363. {0},
  1364. msm_vidc_adjust_chroma_qp_index_offset,
  1365. msm_vidc_set_chroma_qp_index_offset},
  1366. {DISPLAY_DELAY_ENABLE, DEC, H264|HEVC|VP9,
  1367. {OUTPUT_ORDER},
  1368. NULL,
  1369. NULL},
  1370. {DISPLAY_DELAY, DEC, H264|HEVC|VP9,
  1371. {OUTPUT_ORDER},
  1372. NULL,
  1373. NULL},
  1374. {OUTPUT_ORDER, DEC, H264|HEVC|VP9,
  1375. {0},
  1376. msm_vidc_adjust_output_order,
  1377. msm_vidc_set_u32},
  1378. {INPUT_BUF_HOST_MAX_COUNT, ENC|DEC, CODECS_ALL,
  1379. {0},
  1380. msm_vidc_adjust_input_buf_host_max_count,
  1381. msm_vidc_set_u32},
  1382. {INPUT_BUF_HOST_MAX_COUNT, ENC, H264|HEVC,
  1383. {0},
  1384. msm_vidc_adjust_input_buf_host_max_count,
  1385. msm_vidc_set_u32},
  1386. {OUTPUT_BUF_HOST_MAX_COUNT, ENC|DEC, CODECS_ALL,
  1387. {0},
  1388. msm_vidc_adjust_output_buf_host_max_count,
  1389. msm_vidc_set_u32},
  1390. {OUTPUT_BUF_HOST_MAX_COUNT, ENC, H264|HEVC,
  1391. {0},
  1392. msm_vidc_adjust_output_buf_host_max_count,
  1393. msm_vidc_set_u32},
  1394. {CONCEAL_COLOR_8BIT, DEC, CODECS_ALL,
  1395. {0},
  1396. NULL,
  1397. msm_vidc_set_u32_packed},
  1398. {CONCEAL_COLOR_10BIT, DEC, CODECS_ALL,
  1399. {0},
  1400. NULL,
  1401. msm_vidc_set_u32_packed},
  1402. {STAGE, ENC | DEC, CODECS_ALL,
  1403. {0},
  1404. NULL,
  1405. msm_vidc_set_stage},
  1406. {STAGE, ENC, H264|HEVC,
  1407. {0},
  1408. NULL,
  1409. msm_vidc_set_stage},
  1410. {STAGE, DEC, H264|HEVC|VP9,
  1411. {0},
  1412. NULL,
  1413. msm_vidc_set_stage},
  1414. {PIPE, DEC|ENC, CODECS_ALL,
  1415. {0},
  1416. NULL,
  1417. msm_vidc_set_pipe},
  1418. {THUMBNAIL_MODE, DEC, CODECS_ALL,
  1419. {OUTPUT_ORDER},
  1420. NULL,
  1421. msm_vidc_set_u32},
  1422. {RAP_FRAME, DEC, CODECS_ALL,
  1423. {0},
  1424. NULL,
  1425. msm_vidc_set_u32},
  1426. {FIRMWARE_PRIORITY_OFFSET, DEC | ENC, CODECS_ALL,
  1427. {0},
  1428. NULL,
  1429. NULL},
  1430. {ALL_INTRA, ENC, H264|HEVC,
  1431. {LTR_COUNT, SLICE_MODE, BIT_RATE},
  1432. msm_vidc_adjust_all_intra,
  1433. NULL},
  1434. };
  1435. /* Default UBWC config for LPDDR5 */
  1436. static struct msm_vidc_ubwc_config_data ubwc_config_pineapple[] = {
  1437. UBWC_CONFIG(8, 32, 16, 0, 1, 1, 1),
  1438. };
  1439. static struct msm_vidc_format_capability format_data_pineapple = {
  1440. .codec_info = codec_data_pineapple,
  1441. .codec_info_size = ARRAY_SIZE(codec_data_pineapple),
  1442. .color_format_info = color_format_data_pineapple,
  1443. .color_format_info_size = ARRAY_SIZE(color_format_data_pineapple),
  1444. .color_prim_info = color_primaries_data_pineapple,
  1445. .color_prim_info_size = ARRAY_SIZE(color_primaries_data_pineapple),
  1446. .transfer_char_info = transfer_char_data_pineapple,
  1447. .transfer_char_info_size = ARRAY_SIZE(transfer_char_data_pineapple),
  1448. .matrix_coeff_info = matrix_coeff_data_pineapple,
  1449. .matrix_coeff_info_size = ARRAY_SIZE(matrix_coeff_data_pineapple),
  1450. };
  1451. static const struct msm_vidc_platform_data pineapple_data = {
  1452. .core_data = core_data_pineapple,
  1453. .core_data_size = ARRAY_SIZE(core_data_pineapple),
  1454. .inst_cap_data = instance_cap_data_pineapple,
  1455. .inst_cap_data_size = ARRAY_SIZE(instance_cap_data_pineapple),
  1456. .inst_cap_dependency_data = instance_cap_dependency_data_pineapple,
  1457. .inst_cap_dependency_data_size = ARRAY_SIZE(instance_cap_dependency_data_pineapple),
  1458. .csc_data.vpe_csc_custom_bias_coeff = vpe_csc_custom_bias_coeff,
  1459. .csc_data.vpe_csc_custom_matrix_coeff = vpe_csc_custom_matrix_coeff,
  1460. .csc_data.vpe_csc_custom_limit_coeff = vpe_csc_custom_limit_coeff,
  1461. .ubwc_config = ubwc_config_pineapple,
  1462. .format_data = &format_data_pineapple,
  1463. };
  1464. int msm_vidc_pineapple_check_ddr_type(void)
  1465. {
  1466. u32 ddr_type;
  1467. ddr_type = of_fdt_get_ddrtype();
  1468. if (ddr_type != DDR_TYPE_LPDDR5 &&
  1469. ddr_type != DDR_TYPE_LPDDR5X) {
  1470. d_vpr_e("%s: wrong ddr type %d\n", __func__, ddr_type);
  1471. return -EINVAL;
  1472. } else {
  1473. d_vpr_h("%s: ddr type %d\n", __func__, ddr_type);
  1474. }
  1475. return 0;
  1476. }
  1477. static int msm_vidc_init_data(struct msm_vidc_core *core)
  1478. {
  1479. int rc = 0;
  1480. if (!core || !core->platform) {
  1481. d_vpr_e("%s: invalid params\n", __func__);
  1482. return -EINVAL;
  1483. }
  1484. d_vpr_h("%s: initialize pineapple data\n", __func__);
  1485. core->platform->data = pineapple_data;
  1486. rc = msm_vidc_pineapple_check_ddr_type();
  1487. if (rc)
  1488. return rc;
  1489. return rc;
  1490. }
  1491. int msm_vidc_init_platform_pineapple(struct msm_vidc_core *core)
  1492. {
  1493. int rc = 0;
  1494. rc = msm_vidc_init_data(core);
  1495. if (rc)
  1496. return rc;
  1497. return 0;
  1498. }
  1499. int msm_vidc_deinit_platform_pineapple(struct msm_vidc_core *core)
  1500. {
  1501. /* do nothing */
  1502. return 0;
  1503. }