Message ID | 1690550624-14642-27-git-send-email-quic_vgarodia@quicinc.com (mailing list archive) |
---|---|
State | New, archived |
Headers | show |
Series | Qualcomm video decoder/encoder driver | expand |
On 28/07/2023 16:23, Vikash Garodia wrote: > From: Dikshita Agarwal <quic_dikshita@quicinc.com> > > This implements all the capabilities supported by sm8550. > > Signed-off-by: Dikshita Agarwal <quic_dikshita@quicinc.com> > Signed-off-by: Vikash Garodia <quic_vgarodia@quicinc.com> > --- > .../iris/platform/sm8550/inc/msm_vidc_sm8550.h | 14 + > .../iris/platform/sm8550/src/msm_vidc_sm8550.c | 1727 ++++++++++++++++++++ > 2 files changed, 1741 insertions(+) > create mode 100644 drivers/media/platform/qcom/iris/platform/sm8550/inc/msm_vidc_sm8550.h > create mode 100644 drivers/media/platform/qcom/iris/platform/sm8550/src/msm_vidc_sm8550.c > > diff --git a/drivers/media/platform/qcom/iris/platform/sm8550/inc/msm_vidc_sm8550.h b/drivers/media/platform/qcom/iris/platform/sm8550/inc/msm_vidc_sm8550.h > new file mode 100644 > index 0000000..0a2f172 > --- /dev/null > +++ b/drivers/media/platform/qcom/iris/platform/sm8550/inc/msm_vidc_sm8550.h > @@ -0,0 +1,14 @@ > +/* SPDX-License-Identifier: GPL-2.0-only */ > +/* > + * Copyright (c) 2020-2021, The Linux Foundation. All rights reserved. > + * Copyright (c) 2021-2023 Qualcomm Innovation Center, Inc. All rights reserved. > + */ > + > +#ifndef _MSM_VIDC_SM8550_H_ > +#define _MSM_VIDC_SM8550_H_ > + > +#include "msm_vidc_core.h" > + > +int msm_vidc_init_platform_sm8550(struct msm_vidc_core *core); > + > +#endif // _MSM_VIDC_SM8550_H_ > diff --git a/drivers/media/platform/qcom/iris/platform/sm8550/src/msm_vidc_sm8550.c b/drivers/media/platform/qcom/iris/platform/sm8550/src/msm_vidc_sm8550.c > new file mode 100644 > index 0000000..2408556 > --- /dev/null > +++ b/drivers/media/platform/qcom/iris/platform/sm8550/src/msm_vidc_sm8550.c > @@ -0,0 +1,1727 @@ > +// SPDX-License-Identifier: GPL-2.0-only > +/* > + * Copyright (c) 2020-2021, The Linux Foundation. All rights reserved. > + * Copyright (c) 2021-2023 Qualcomm Innovation Center, Inc. All rights reserved. > + */ > + > +#include <dt-bindings/clock/qcom,sm8550-gcc.h> > +#include <dt-bindings/clock/qcom,sm8450-videocc.h> > + > +#include "hfi_command.h" > +#include "hfi_property.h" > +#include "msm_vidc_control.h" > +#include "msm_vidc_debug.h" > +#include "msm_vidc_iris3.h" > +#include "msm_vidc_sm8550.h" > +#include "msm_vidc_platform.h" > + > +/* version: major[24:31], minor[16:23], revision[0:15] */ > +#define DRIVER_VERSION 0x04000000 > +#define DEFAULT_VIDEO_CONCEAL_COLOR_BLACK 0x8020010 > +#define MAX_BASE_LAYER_PRIORITY_ID 63 > +#define MAX_OP_POINT 31 > +#define MAX_BITRATE 245000000 > +#define DEFAULT_BITRATE 20000000 > +#define MINIMUM_FPS 1 > +#define MAXIMUM_FPS 480 > +#define MAXIMUM_DEC_FPS 960 > +#define MAX_QP 51 > +#define DEFAULT_QP 20 > +#define MAX_CONSTANT_QUALITY 100 > +#define MIN_SLICE_BYTE_SIZE 512 > +#define MAX_SLICE_BYTE_SIZE \ > + ((MAX_BITRATE) >> 3) > +#define MAX_SLICE_MB_SIZE \ > + (((4096 + 15) >> 4) * ((2304 + 15) >> 4)) > + > +#define ENC MSM_VIDC_ENCODER > +#define DEC MSM_VIDC_DECODER > +#define H264 MSM_VIDC_H264 > +#define HEVC MSM_VIDC_HEVC > +#define VP9 MSM_VIDC_VP9 Another redefinition. Inline it. > +#define CODECS_ALL (H264 | HEVC | VP9) > +#define MAXIMUM_OVERRIDE_VP9_FPS 200 > + > +static struct codec_info codec_data_sm8550[] = { > + { > + .v4l2_codec = V4L2_PIX_FMT_H264, > + .vidc_codec = MSM_VIDC_H264, > + .pixfmt_name = "AVC", Have you considered using existing code which enumerates formats? For example, it is much better to refactor v4l_fill_fmtdesc() to allow getting the description instead of adding your own names here. Not to mention that printk supports %p4cc for printing fourcc values. I hope you knew that. > + }, > + { > + .v4l2_codec = V4L2_PIX_FMT_HEVC, > + .vidc_codec = MSM_VIDC_HEVC, > + .pixfmt_name = "HEVC", > + }, > + { > + .v4l2_codec = V4L2_PIX_FMT_VP9, > + .vidc_codec = MSM_VIDC_VP9, > + .pixfmt_name = "VP9", > + }, > +}; > + > +static struct color_format_info color_format_data_sm8550[] = { > + { > + .v4l2_color_format = V4L2_PIX_FMT_NV12, > + .vidc_color_format = MSM_VIDC_FMT_NV12, > + .pixfmt_name = "NV12", > + }, > + { > + .v4l2_color_format = V4L2_PIX_FMT_NV21, > + .vidc_color_format = MSM_VIDC_FMT_NV21, > + .pixfmt_name = "NV21", > + }, > + { > + .v4l2_color_format = V4L2_PIX_FMT_QC08C, > + .vidc_color_format = MSM_VIDC_FMT_NV12C, > + .pixfmt_name = "NV12C", > + }, > + { > + .v4l2_color_format = V4L2_PIX_FMT_QC10C, > + .vidc_color_format = MSM_VIDC_FMT_TP10C, > + .pixfmt_name = "TP10C", > + }, > + { > + .v4l2_color_format = V4L2_PIX_FMT_RGBA32, > + .vidc_color_format = MSM_VIDC_FMT_RGBA8888, > + .pixfmt_name = "RGBA", > + }, > +}; > + > +static struct color_primaries_info color_primaries_data_sm8550[] = { > + { > + .v4l2_color_primaries = V4L2_COLORSPACE_DEFAULT, > + .vidc_color_primaries = MSM_VIDC_PRIMARIES_RESERVED, > + }, > + { > + .v4l2_color_primaries = V4L2_COLORSPACE_REC709, > + .vidc_color_primaries = MSM_VIDC_PRIMARIES_BT709, > + }, > + { > + .v4l2_color_primaries = V4L2_COLORSPACE_470_SYSTEM_M, > + .vidc_color_primaries = MSM_VIDC_PRIMARIES_BT470_SYSTEM_M, > + }, > + { > + .v4l2_color_primaries = V4L2_COLORSPACE_470_SYSTEM_BG, > + .vidc_color_primaries = MSM_VIDC_PRIMARIES_BT470_SYSTEM_BG, > + }, > + { > + .v4l2_color_primaries = V4L2_COLORSPACE_SMPTE170M, > + .vidc_color_primaries = MSM_VIDC_PRIMARIES_BT601_525, > + }, > + { > + .v4l2_color_primaries = V4L2_COLORSPACE_SMPTE240M, > + .vidc_color_primaries = MSM_VIDC_PRIMARIES_SMPTE_ST240M, > + }, > + { > + .v4l2_color_primaries = V4L2_COLORSPACE_BT2020, > + .vidc_color_primaries = MSM_VIDC_PRIMARIES_BT2020, > + }, > + { > + .v4l2_color_primaries = V4L2_COLORSPACE_DCI_P3, > + .vidc_color_primaries = MSM_VIDC_PRIMARIES_SMPTE_RP431_2, > + }, > +}; > + > +static struct transfer_char_info transfer_char_data_sm8550[] = { > + { > + .v4l2_transfer_char = V4L2_XFER_FUNC_DEFAULT, > + .vidc_transfer_char = MSM_VIDC_TRANSFER_RESERVED, > + }, > + { > + .v4l2_transfer_char = V4L2_XFER_FUNC_709, > + .vidc_transfer_char = MSM_VIDC_TRANSFER_BT709, > + }, > + { > + .v4l2_transfer_char = V4L2_XFER_FUNC_SMPTE240M, > + .vidc_transfer_char = MSM_VIDC_TRANSFER_SMPTE_ST240M, > + }, > + { > + .v4l2_transfer_char = V4L2_XFER_FUNC_SRGB, > + .vidc_transfer_char = MSM_VIDC_TRANSFER_SRGB_SYCC, > + }, > + { > + .v4l2_transfer_char = V4L2_XFER_FUNC_SMPTE2084, > + .vidc_transfer_char = MSM_VIDC_TRANSFER_SMPTE_ST2084_PQ, > + }, > +}; > + > +static struct matrix_coeff_info matrix_coeff_data_sm8550[] = { > + { > + .v4l2_matrix_coeff = V4L2_YCBCR_ENC_DEFAULT, > + .vidc_matrix_coeff = MSM_VIDC_MATRIX_COEFF_RESERVED, > + }, > + { > + .v4l2_matrix_coeff = V4L2_YCBCR_ENC_709, > + .vidc_matrix_coeff = MSM_VIDC_MATRIX_COEFF_BT709, > + }, > + { > + .v4l2_matrix_coeff = V4L2_YCBCR_ENC_XV709, > + .vidc_matrix_coeff = MSM_VIDC_MATRIX_COEFF_BT709, > + }, > + { > + .v4l2_matrix_coeff = V4L2_YCBCR_ENC_XV601, > + .vidc_matrix_coeff = MSM_VIDC_MATRIX_COEFF_BT470_SYS_BG_OR_BT601_625, > + }, > + { > + .v4l2_matrix_coeff = V4L2_YCBCR_ENC_601, > + .vidc_matrix_coeff = MSM_VIDC_MATRIX_COEFF_BT601_525_BT1358_525_OR_625, > + }, > + { > + .v4l2_matrix_coeff = V4L2_YCBCR_ENC_SMPTE240M, > + .vidc_matrix_coeff = MSM_VIDC_MATRIX_COEFF_SMPTE_ST240, > + }, > + { > + .v4l2_matrix_coeff = V4L2_YCBCR_ENC_BT2020, > + .vidc_matrix_coeff = MSM_VIDC_MATRIX_COEFF_BT2020_NON_CONSTANT, > + }, > + { > + .v4l2_matrix_coeff = V4L2_YCBCR_ENC_BT2020_CONST_LUM, > + .vidc_matrix_coeff = MSM_VIDC_MATRIX_COEFF_BT2020_CONSTANT, > + }, > +}; Are you going to say that these tables are platform-specific instead of being generic to the driver? > + > +static struct msm_platform_core_capability core_data_sm8550[] = { > + /* {type, value} */ > + {ENC_CODECS, H264 | HEVC}, > + {DEC_CODECS, H264 | HEVC | VP9}, > + {MAX_SESSION_COUNT, 16}, > + {MAX_NUM_720P_SESSIONS, 16}, > + {MAX_NUM_1080P_SESSIONS, 16}, > + {MAX_NUM_4K_SESSIONS, 8}, > + {MAX_NUM_8K_SESSIONS, 2}, > + {MAX_RT_MBPF, 174080}, /* (8192x4352)/256 + (4096x2176)/256*/ > + {MAX_MBPF, 278528}, /* ((8192x4352)/256) * 2 */ > + {MAX_MBPS, 7833600}, /* max_load > + * 7680x4320@60fps or 3840x2176@240fps > + * which is greater than 4096x2176@120fps, > + * 8192x4320@48fps > + */ > + {MAX_MBPF_HQ, 8160}, /* ((1920x1088)/256) */ > + {MAX_MBPS_HQ, 489600}, /* ((1920x1088)/256)@60fps */ > + {MAX_MBPF_B_FRAME, 32640}, /* 3840x2176/256 */ > + {MAX_MBPS_B_FRAME, 1958400}, /* 3840x2176/256 MBs@60fps */ > + {MAX_MBPS_ALL_INTRA, 1044480}, /* 4096x2176/256 MBs@30fps */ > + {MAX_ENH_LAYER_COUNT, 5}, > + {NUM_VPP_PIPE, 4}, > + {SW_PC, 1}, > + {FW_UNLOAD, 0}, > + {HW_RESPONSE_TIMEOUT, HW_RESPONSE_TIMEOUT_VALUE}, /* 1000 ms */ > + {SW_PC_DELAY, SW_PC_DELAY_VALUE }, /* 1500 ms (>HW_RESPONSE_TIMEOUT)*/ > + {FW_UNLOAD_DELAY, FW_UNLOAD_DELAY_VALUE }, /* 3000 ms (>SW_PC_DELAY)*/ > + {DCVS, 1}, > + {DECODE_BATCH, 1}, > + {DECODE_BATCH_TIMEOUT, 200}, > + {STATS_TIMEOUT_MS, 2000}, > + {NON_FATAL_FAULTS, 1}, > + {DEVICE_CAPS, V4L2_CAP_VIDEO_M2M_MPLANE | V4L2_CAP_STREAMING}, Unless there is a good reason, please change this to be a proper data structure instead of being a type-value array. With the T-V it is impossible to notice if the value is missing or duplicated. This comment also applies to the next 'capability' array. > +}; > + > +static struct msm_platform_inst_capability instance_cap_data_sm8550[] = { > + /* {cap, domain, codec, > + * min, max, step_or_mask, value, > + * v4l2_id, > + * hfi_id, > + * flags} > + */ > + {FRAME_WIDTH, DEC, CODECS_ALL, 96, 8192, 1, 1920}, > + > + {FRAME_WIDTH, DEC, VP9, 96, 4096, 1, 1920}, > + > + {FRAME_WIDTH, ENC, CODECS_ALL, 128, 8192, 1, 1920}, > + > + {FRAME_WIDTH, ENC, HEVC, 96, 8192, 1, 1920}, > + > + {LOSSLESS_FRAME_WIDTH, ENC, CODECS_ALL, 128, 4096, 1, 1920}, > + > + {LOSSLESS_FRAME_WIDTH, ENC, HEVC, 96, 4096, 1, 1920}, > + > + {FRAME_HEIGHT, DEC, CODECS_ALL, 96, 8192, 1, 1080}, > + > + {FRAME_HEIGHT, DEC, VP9, 96, 4096, 1, 1080}, > + > + {FRAME_HEIGHT, ENC, CODECS_ALL, 128, 8192, 1, 1080}, > + > + {FRAME_HEIGHT, ENC, HEVC, 96, 8192, 1, 1080}, > + > + {LOSSLESS_FRAME_HEIGHT, ENC, CODECS_ALL, 128, 4096, 1, 1080}, > + > + {LOSSLESS_FRAME_HEIGHT, ENC, HEVC, 96, 4096, 1, 1080}, > + > + {PIX_FMTS, ENC | DEC, H264, > + MSM_VIDC_FMT_NV12, > + MSM_VIDC_FMT_NV12C, > + MSM_VIDC_FMT_NV12 | MSM_VIDC_FMT_NV21 | MSM_VIDC_FMT_NV12C, > + MSM_VIDC_FMT_NV12C}, > + > + {PIX_FMTS, ENC | DEC, HEVC | VP9, > + MSM_VIDC_FMT_NV12, > + MSM_VIDC_FMT_TP10C, > + MSM_VIDC_FMT_NV12 | MSM_VIDC_FMT_NV21 | MSM_VIDC_FMT_NV12C | > + MSM_VIDC_FMT_TP10C, > + MSM_VIDC_FMT_NV12C}, > + > + {MIN_BUFFERS_INPUT, ENC | DEC, CODECS_ALL, 0, 64, 1, 4, > + V4L2_CID_MIN_BUFFERS_FOR_OUTPUT, > + 0, > + CAP_FLAG_VOLATILE}, > + > + {MIN_BUFFERS_OUTPUT, ENC | DEC, CODECS_ALL, > + 0, 64, 1, 4, > + V4L2_CID_MIN_BUFFERS_FOR_CAPTURE, > + HFI_PROP_BUFFER_FW_MIN_OUTPUT_COUNT, > + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_VOLATILE}, > + > + /* (8192 * 4320) / 256 */ > + {MBPF, ENC, CODECS_ALL, 64, 138240, 1, 138240}, > + > + {MBPF, ENC, HEVC, 36, 138240, 1, 138240}, > + > + {MBPF, DEC, CODECS_ALL, 36, 138240, 1, 138240}, > + > + /* (4096 * 2304) / 256 */ > + {MBPF, DEC, VP9, 36, 36864, 1, 36864}, > + > + /* (4096 * 2304) / 256 */ > + {LOSSLESS_MBPF, ENC, H264 | HEVC, 64, 36864, 1, 36864}, > + > + /* Batch Mode Decode */ > + /* TODO: update with new values based on updated voltage corner */ > + {BATCH_MBPF, DEC, H264 | HEVC | VP9, 64, 34816, 1, 34816}, > + > + /* (4096 * 2304) / 256 */ > + {BATCH_FPS, DEC, H264 | HEVC | VP9, 1, 120, 1, 120}, > + > + {FRAME_RATE, ENC | DEC, CODECS_ALL, > + (MINIMUM_FPS << 16), (MAXIMUM_FPS << 16), > + 1, (DEFAULT_FPS << 16), > + 0, > + HFI_PROP_FRAME_RATE, > + CAP_FLAG_OUTPUT_PORT}, > + > + {OPERATING_RATE, ENC | DEC, CODECS_ALL, > + (MINIMUM_FPS << 16), (MAXIMUM_FPS << 16), > + 1, (DEFAULT_FPS << 16)}, > + > + {INPUT_RATE, ENC | DEC, CODECS_ALL, > + (MINIMUM_FPS << 16), INT_MAX, > + 1, (DEFAULT_FPS << 16)}, > + > + {TIMESTAMP_RATE, ENC | DEC, CODECS_ALL, > + (MINIMUM_FPS << 16), INT_MAX, > + 1, (DEFAULT_FPS << 16)}, > + > + {SCALE_FACTOR, ENC, H264 | HEVC, 1, 8, 1, 8}, > + > + {MB_CYCLES_VSP, ENC, CODECS_ALL, 25, 25, 1, 25}, > + > + {MB_CYCLES_VSP, DEC, CODECS_ALL, 25, 25, 1, 25}, > + > + {MB_CYCLES_VSP, DEC, VP9, 60, 60, 1, 60}, > + > + {MB_CYCLES_VPP, ENC, CODECS_ALL, 675, 675, 1, 675}, > + > + {MB_CYCLES_VPP, DEC, CODECS_ALL, 200, 200, 1, 200}, > + > + {MB_CYCLES_LP, ENC, CODECS_ALL, 320, 320, 1, 320}, > + > + {MB_CYCLES_LP, DEC, CODECS_ALL, 200, 200, 1, 200}, > + > + {MB_CYCLES_FW, ENC | DEC, CODECS_ALL, 489583, 489583, 1, 489583}, > + > + {MB_CYCLES_FW_VPP, ENC, CODECS_ALL, 48405, 48405, 1, 48405}, > + > + {MB_CYCLES_FW_VPP, DEC, CODECS_ALL, 66234, 66234, 1, 66234}, > + > + {HFLIP, ENC, CODECS_ALL, > + 0, 1, 1, 0, > + V4L2_CID_HFLIP, > + HFI_PROP_FLIP, > + CAP_FLAG_OUTPUT_PORT | > + CAP_FLAG_INPUT_PORT | CAP_FLAG_DYNAMIC_ALLOWED}, > + > + {VFLIP, ENC, CODECS_ALL, > + 0, 1, 1, 0, > + V4L2_CID_VFLIP, > + HFI_PROP_FLIP, > + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT | > + CAP_FLAG_DYNAMIC_ALLOWED}, > + > + {ROTATION, ENC, CODECS_ALL, > + 0, 270, 90, 0, > + V4L2_CID_ROTATE, > + HFI_PROP_ROTATION, > + CAP_FLAG_OUTPUT_PORT}, > + > + {HEADER_MODE, ENC, CODECS_ALL, > + V4L2_MPEG_VIDEO_HEADER_MODE_SEPARATE, > + V4L2_MPEG_VIDEO_HEADER_MODE_JOINED_WITH_1ST_FRAME, > + BIT(V4L2_MPEG_VIDEO_HEADER_MODE_SEPARATE) | > + BIT(V4L2_MPEG_VIDEO_HEADER_MODE_JOINED_WITH_1ST_FRAME), > + V4L2_MPEG_VIDEO_HEADER_MODE_SEPARATE, > + V4L2_CID_MPEG_VIDEO_HEADER_MODE, > + HFI_PROP_SEQ_HEADER_MODE, > + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_MENU}, > + > + {PREPEND_SPSPPS_TO_IDR, ENC, CODECS_ALL, > + 0, 1, 1, 0, > + V4L2_CID_MPEG_VIDEO_PREPEND_SPSPPS_TO_IDR}, > + > + {WITHOUT_STARTCODE, ENC, CODECS_ALL, > + 0, 1, 1, 0, > + V4L2_CID_MPEG_VIDEO_HEVC_WITHOUT_STARTCODE, > + HFI_PROP_NAL_LENGTH_FIELD, > + CAP_FLAG_OUTPUT_PORT}, > + > + {NAL_LENGTH_FIELD, ENC, CODECS_ALL, > + V4L2_MPEG_VIDEO_HEVC_SIZE_0, > + V4L2_MPEG_VIDEO_HEVC_SIZE_4, > + BIT(V4L2_MPEG_VIDEO_HEVC_SIZE_0) | > + BIT(V4L2_MPEG_VIDEO_HEVC_SIZE_4), > + V4L2_MPEG_VIDEO_HEVC_SIZE_0, > + V4L2_CID_MPEG_VIDEO_HEVC_SIZE_OF_LENGTH_FIELD, > + HFI_PROP_NAL_LENGTH_FIELD, > + CAP_FLAG_MENU | CAP_FLAG_OUTPUT_PORT}, > + > + /* TODO: Firmware introduced enumeration type for this > + * with and without seq header. > + */ > + {REQUEST_I_FRAME, ENC, H264 | HEVC, > + 0, 0, 0, 0, > + V4L2_CID_MPEG_VIDEO_FORCE_KEY_FRAME, > + HFI_PROP_REQUEST_SYNC_FRAME, > + CAP_FLAG_INPUT_PORT | CAP_FLAG_DYNAMIC_ALLOWED}, > + > + /* Enc: Keeping CABAC and CAVLC as same bitrate. > + * Dec: there's no use of Bitrate cap > + */ > + {BIT_RATE, ENC, H264 | HEVC, > + 1, MAX_BITRATE, 1, DEFAULT_BITRATE, > + V4L2_CID_MPEG_VIDEO_BITRATE, > + HFI_PROP_TOTAL_BITRATE, > + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT | > + CAP_FLAG_DYNAMIC_ALLOWED}, > + > + {BITRATE_MODE, ENC, H264, > + V4L2_MPEG_VIDEO_BITRATE_MODE_VBR, > + V4L2_MPEG_VIDEO_BITRATE_MODE_CBR, > + BIT(V4L2_MPEG_VIDEO_BITRATE_MODE_VBR) | > + BIT(V4L2_MPEG_VIDEO_BITRATE_MODE_CBR), > + V4L2_MPEG_VIDEO_BITRATE_MODE_VBR, > + V4L2_CID_MPEG_VIDEO_BITRATE_MODE, > + HFI_PROP_RATE_CONTROL, > + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_MENU}, > + > + {BITRATE_MODE, ENC, HEVC, > + V4L2_MPEG_VIDEO_BITRATE_MODE_VBR, > + V4L2_MPEG_VIDEO_BITRATE_MODE_CQ, > + BIT(V4L2_MPEG_VIDEO_BITRATE_MODE_VBR) | > + BIT(V4L2_MPEG_VIDEO_BITRATE_MODE_CBR) | > + BIT(V4L2_MPEG_VIDEO_BITRATE_MODE_CQ), > + V4L2_MPEG_VIDEO_BITRATE_MODE_VBR, > + V4L2_CID_MPEG_VIDEO_BITRATE_MODE, > + HFI_PROP_RATE_CONTROL, > + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_MENU}, > + > + {CABAC_MAX_BITRATE, ENC, H264 | HEVC, 0, > + 160000000, 1, 160000000}, > + > + {CAVLC_MAX_BITRATE, ENC, H264, 0, > + 220000000, 1, 220000000}, > + > + {ALLINTRA_MAX_BITRATE, ENC, H264 | HEVC, 0, > + 245000000, 1, 245000000}, > + > + {NUM_COMV, DEC, CODECS_ALL, > + 0, INT_MAX, 1, 0}, > + > + {LOSSLESS, ENC, HEVC, > + 0, 1, 1, 0, > + V4L2_CID_MPEG_VIDEO_HEVC_LOSSLESS_CU}, > + > + {FRAME_SKIP_MODE, ENC, H264 | HEVC, > + V4L2_MPEG_VIDEO_FRAME_SKIP_MODE_DISABLED, > + V4L2_MPEG_VIDEO_FRAME_SKIP_MODE_BUF_LIMIT, > + BIT(V4L2_MPEG_VIDEO_FRAME_SKIP_MODE_DISABLED) | > + BIT(V4L2_MPEG_VIDEO_FRAME_SKIP_MODE_LEVEL_LIMIT) | > + BIT(V4L2_MPEG_VIDEO_FRAME_SKIP_MODE_BUF_LIMIT), > + V4L2_MPEG_VIDEO_FRAME_SKIP_MODE_DISABLED, > + V4L2_CID_MPEG_VIDEO_FRAME_SKIP_MODE, > + 0, > + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_MENU}, > + > + {FRAME_RC_ENABLE, ENC, H264 | HEVC, > + 0, 1, 1, 1, > + V4L2_CID_MPEG_VIDEO_FRAME_RC_ENABLE}, > + > + {CONSTANT_QUALITY, ENC, HEVC, > + 1, MAX_CONSTANT_QUALITY, 1, 90, > + V4L2_CID_MPEG_VIDEO_CONSTANT_QUALITY, > + HFI_PROP_CONSTANT_QUALITY, > + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT | > + CAP_FLAG_DYNAMIC_ALLOWED}, > + > + {GOP_SIZE, ENC, CODECS_ALL, > + 0, INT_MAX, 1, 2 * DEFAULT_FPS - 1, > + V4L2_CID_MPEG_VIDEO_GOP_SIZE, > + HFI_PROP_MAX_GOP_FRAMES, > + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT | > + CAP_FLAG_DYNAMIC_ALLOWED}, > + > + {GOP_CLOSURE, ENC, H264 | HEVC, > + 0, 1, 1, 1, > + V4L2_CID_MPEG_VIDEO_GOP_CLOSURE, > + 0}, > + > + {B_FRAME, ENC, H264 | HEVC, > + 0, 7, 1, 0, > + V4L2_CID_MPEG_VIDEO_B_FRAMES, > + HFI_PROP_MAX_B_FRAMES, > + CAP_FLAG_OUTPUT_PORT}, > + > + {LTR_COUNT, ENC, H264 | HEVC, > + 0, MAX_LTR_FRAME_COUNT_2, 1, 0, > + V4L2_CID_MPEG_VIDEO_LTR_COUNT, > + HFI_PROP_LTR_COUNT, > + CAP_FLAG_OUTPUT_PORT}, > + > + {USE_LTR, ENC, H264 | HEVC, > + 0, > + ((1 << MAX_LTR_FRAME_COUNT_2) - 1), > + 0, 0, > + V4L2_CID_MPEG_VIDEO_USE_LTR_FRAMES, > + HFI_PROP_LTR_USE, > + CAP_FLAG_INPUT_PORT | CAP_FLAG_DYNAMIC_ALLOWED}, > + > + {MARK_LTR, ENC, H264 | HEVC, > + INVALID_DEFAULT_MARK_OR_USE_LTR, > + (MAX_LTR_FRAME_COUNT_2 - 1), > + 1, INVALID_DEFAULT_MARK_OR_USE_LTR, > + V4L2_CID_MPEG_VIDEO_FRAME_LTR_INDEX, > + HFI_PROP_LTR_MARK, > + CAP_FLAG_INPUT_PORT | CAP_FLAG_DYNAMIC_ALLOWED}, > + > + {BASELAYER_PRIORITY, ENC, H264, > + 0, MAX_BASE_LAYER_PRIORITY_ID, 1, 0, > + V4L2_CID_MPEG_VIDEO_BASELAYER_PRIORITY_ID, > + HFI_PROP_BASELAYER_PRIORITYID, > + CAP_FLAG_OUTPUT_PORT}, > + > + {IR_TYPE, ENC, H264 | HEVC, > + V4L2_CID_MPEG_VIDEO_INTRA_REFRESH_PERIOD_TYPE_RANDOM, > + V4L2_CID_MPEG_VIDEO_INTRA_REFRESH_PERIOD_TYPE_CYCLIC, > + BIT(V4L2_CID_MPEG_VIDEO_INTRA_REFRESH_PERIOD_TYPE_RANDOM) | > + BIT(V4L2_CID_MPEG_VIDEO_INTRA_REFRESH_PERIOD_TYPE_CYCLIC), > + V4L2_CID_MPEG_VIDEO_INTRA_REFRESH_PERIOD_TYPE_RANDOM, > + V4L2_CID_MPEG_VIDEO_INTRA_REFRESH_PERIOD_TYPE, > + 0, > + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_MENU}, > + > + {IR_PERIOD, ENC, H264 | HEVC, > + 0, INT_MAX, 1, 0, > + V4L2_CID_MPEG_VIDEO_INTRA_REFRESH_PERIOD, > + 0, > + CAP_FLAG_INPUT_PORT | CAP_FLAG_OUTPUT_PORT | > + CAP_FLAG_DYNAMIC_ALLOWED}, > + > + {AU_DELIMITER, ENC, H264 | HEVC, > + 0, 1, 1, 0, > + V4L2_CID_MPEG_VIDEO_AU_DELIMITER, > + HFI_PROP_AUD, > + CAP_FLAG_OUTPUT_PORT}, > + > + {MIN_QUALITY, ENC, H264 | HEVC, > + 0, MAX_SUPPORTED_MIN_QUALITY, 70, MAX_SUPPORTED_MIN_QUALITY, > + 0, > + HFI_PROP_MAINTAIN_MIN_QUALITY, > + CAP_FLAG_OUTPUT_PORT}, > + > + {VBV_DELAY, ENC, H264 | HEVC, > + 200, 300, 100, 300, > + V4L2_CID_MPEG_VIDEO_VBV_DELAY, > + HFI_PROP_VBV_DELAY, > + CAP_FLAG_OUTPUT_PORT}, > + > + {PEAK_BITRATE, ENC, H264 | HEVC, > + /* default peak bitrate is 10% larger than avg bitrate */ > + 1, MAX_BITRATE, 1, DEFAULT_BITRATE, > + V4L2_CID_MPEG_VIDEO_BITRATE_PEAK, > + HFI_PROP_TOTAL_PEAK_BITRATE, > + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT | > + CAP_FLAG_DYNAMIC_ALLOWED}, > + > + {MIN_FRAME_QP, ENC, H264, > + MIN_QP_8BIT, MAX_QP, 1, MIN_QP_8BIT, > + V4L2_CID_MPEG_VIDEO_H264_MIN_QP, > + HFI_PROP_MIN_QP_PACKED, > + CAP_FLAG_OUTPUT_PORT}, > + > + {MIN_FRAME_QP, ENC, HEVC, > + MIN_QP_10BIT, MAX_QP, 1, MIN_QP_10BIT, > + V4L2_CID_MPEG_VIDEO_HEVC_MIN_QP, > + HFI_PROP_MIN_QP_PACKED, > + CAP_FLAG_OUTPUT_PORT}, > + > + {I_FRAME_MIN_QP, ENC, H264, > + MIN_QP_8BIT, MAX_QP, 1, MIN_QP_8BIT, > + V4L2_CID_MPEG_VIDEO_H264_I_FRAME_MIN_QP}, > + > + {I_FRAME_MIN_QP, ENC, HEVC, > + MIN_QP_10BIT, MAX_QP, 1, MIN_QP_10BIT, > + V4L2_CID_MPEG_VIDEO_HEVC_I_FRAME_MIN_QP}, > + > + {P_FRAME_MIN_QP, ENC, H264, > + MIN_QP_8BIT, MAX_QP, 1, MIN_QP_8BIT, > + V4L2_CID_MPEG_VIDEO_H264_P_FRAME_MIN_QP}, > + > + {P_FRAME_MIN_QP, ENC, HEVC, > + MIN_QP_10BIT, MAX_QP, 1, MIN_QP_10BIT, > + V4L2_CID_MPEG_VIDEO_HEVC_P_FRAME_MIN_QP}, > + > + {B_FRAME_MIN_QP, ENC, H264, > + MIN_QP_8BIT, MAX_QP, 1, MIN_QP_8BIT, > + V4L2_CID_MPEG_VIDEO_H264_B_FRAME_MIN_QP}, > + > + {B_FRAME_MIN_QP, ENC, HEVC, > + MIN_QP_10BIT, MAX_QP, 1, MIN_QP_10BIT, > + V4L2_CID_MPEG_VIDEO_HEVC_B_FRAME_MIN_QP}, > + > + {MAX_FRAME_QP, ENC, H264, > + MIN_QP_8BIT, MAX_QP, 1, MAX_QP, > + V4L2_CID_MPEG_VIDEO_H264_MAX_QP, > + HFI_PROP_MAX_QP_PACKED, > + CAP_FLAG_OUTPUT_PORT}, > + > + {MAX_FRAME_QP, ENC, HEVC, > + MIN_QP_10BIT, MAX_QP, 1, MAX_QP, > + V4L2_CID_MPEG_VIDEO_HEVC_MAX_QP, > + HFI_PROP_MAX_QP_PACKED, > + CAP_FLAG_OUTPUT_PORT}, > + > + {I_FRAME_MAX_QP, ENC, H264, > + MIN_QP_8BIT, MAX_QP, 1, MAX_QP, > + V4L2_CID_MPEG_VIDEO_H264_I_FRAME_MAX_QP}, > + > + {I_FRAME_MAX_QP, ENC, HEVC, > + MIN_QP_10BIT, MAX_QP, 1, MAX_QP, > + V4L2_CID_MPEG_VIDEO_HEVC_I_FRAME_MAX_QP}, > + > + {P_FRAME_MAX_QP, ENC, H264, > + MIN_QP_8BIT, MAX_QP, 1, MAX_QP, > + V4L2_CID_MPEG_VIDEO_H264_P_FRAME_MAX_QP}, > + > + {P_FRAME_MAX_QP, ENC, HEVC, > + MIN_QP_10BIT, MAX_QP, 1, MAX_QP, > + V4L2_CID_MPEG_VIDEO_HEVC_P_FRAME_MAX_QP}, > + > + {B_FRAME_MAX_QP, ENC, H264, > + MIN_QP_8BIT, MAX_QP, 1, MAX_QP, > + V4L2_CID_MPEG_VIDEO_H264_B_FRAME_MAX_QP}, > + > + {B_FRAME_MAX_QP, ENC, HEVC, > + MIN_QP_10BIT, MAX_QP, 1, MAX_QP, > + V4L2_CID_MPEG_VIDEO_HEVC_B_FRAME_MAX_QP}, > + > + {I_FRAME_QP, ENC, HEVC, > + MIN_QP_10BIT, MAX_QP, 1, DEFAULT_QP, > + V4L2_CID_MPEG_VIDEO_HEVC_I_FRAME_QP, > + HFI_PROP_QP_PACKED, > + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT | > + CAP_FLAG_DYNAMIC_ALLOWED}, > + > + {I_FRAME_QP, ENC, H264, > + MIN_QP_8BIT, MAX_QP, 1, DEFAULT_QP, > + V4L2_CID_MPEG_VIDEO_H264_I_FRAME_QP, > + HFI_PROP_QP_PACKED, > + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT | > + CAP_FLAG_DYNAMIC_ALLOWED}, > + > + {P_FRAME_QP, ENC, HEVC, > + MIN_QP_10BIT, MAX_QP, 1, DEFAULT_QP, > + V4L2_CID_MPEG_VIDEO_HEVC_P_FRAME_QP, > + HFI_PROP_QP_PACKED, > + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT | > + CAP_FLAG_DYNAMIC_ALLOWED}, > + > + {P_FRAME_QP, ENC, H264, > + MIN_QP_8BIT, MAX_QP, 1, DEFAULT_QP, > + V4L2_CID_MPEG_VIDEO_H264_P_FRAME_QP, > + HFI_PROP_QP_PACKED, > + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT | > + CAP_FLAG_DYNAMIC_ALLOWED}, > + > + {B_FRAME_QP, ENC, HEVC, > + MIN_QP_10BIT, MAX_QP, 1, DEFAULT_QP, > + V4L2_CID_MPEG_VIDEO_HEVC_B_FRAME_QP, > + HFI_PROP_QP_PACKED, > + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT | > + CAP_FLAG_DYNAMIC_ALLOWED}, > + > + {B_FRAME_QP, ENC, H264, > + MIN_QP_8BIT, MAX_QP, 1, DEFAULT_QP, > + V4L2_CID_MPEG_VIDEO_H264_B_FRAME_QP, > + HFI_PROP_QP_PACKED, > + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT | > + CAP_FLAG_DYNAMIC_ALLOWED}, > + > + {LAYER_TYPE, ENC, HEVC, > + V4L2_MPEG_VIDEO_HEVC_HIERARCHICAL_CODING_B, > + V4L2_MPEG_VIDEO_HEVC_HIERARCHICAL_CODING_P, > + BIT(V4L2_MPEG_VIDEO_HEVC_HIERARCHICAL_CODING_B) | > + BIT(V4L2_MPEG_VIDEO_HEVC_HIERARCHICAL_CODING_P), > + V4L2_MPEG_VIDEO_HEVC_HIERARCHICAL_CODING_P, > + V4L2_CID_MPEG_VIDEO_HEVC_HIER_CODING_TYPE, > + HFI_PROP_LAYER_ENCODING_TYPE, > + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_MENU}, > + > + {LAYER_TYPE, ENC, H264, > + V4L2_MPEG_VIDEO_H264_HIERARCHICAL_CODING_B, > + V4L2_MPEG_VIDEO_H264_HIERARCHICAL_CODING_P, > + BIT(V4L2_MPEG_VIDEO_H264_HIERARCHICAL_CODING_B) | > + BIT(V4L2_MPEG_VIDEO_H264_HIERARCHICAL_CODING_P), > + V4L2_MPEG_VIDEO_H264_HIERARCHICAL_CODING_P, > + V4L2_CID_MPEG_VIDEO_H264_HIERARCHICAL_CODING_TYPE, > + HFI_PROP_LAYER_ENCODING_TYPE, > + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_MENU}, > + > + {LAYER_ENABLE, ENC, H264, > + 0, 1, 1, 0, > + V4L2_CID_MPEG_VIDEO_H264_HIERARCHICAL_CODING, > + HFI_PROP_LAYER_ENCODING_TYPE, > + CAP_FLAG_OUTPUT_PORT}, > + > + {LAYER_ENABLE, ENC, HEVC, > + 0, 1, 1, 0, > + 0, > + 0, > + CAP_FLAG_OUTPUT_PORT}, > + > + {ENH_LAYER_COUNT, ENC, HEVC, > + 0, 5, 1, 0, > + V4L2_CID_MPEG_VIDEO_HEVC_HIER_CODING_LAYER, > + HFI_PROP_LAYER_COUNT, > + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT | > + CAP_FLAG_DYNAMIC_ALLOWED}, > + > + {ENH_LAYER_COUNT, ENC, H264, > + 0, 5, 1, 0, > + V4L2_CID_MPEG_VIDEO_H264_HIERARCHICAL_CODING_LAYER, > + HFI_PROP_LAYER_COUNT, > + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT | > + CAP_FLAG_DYNAMIC_ALLOWED}, > + > + {L0_BR, ENC, H264, > + 1, MAX_BITRATE, 1, DEFAULT_BITRATE, > + V4L2_CID_MPEG_VIDEO_H264_HIER_CODING_L0_BR, > + HFI_PROP_BITRATE_LAYER1, > + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT | > + CAP_FLAG_DYNAMIC_ALLOWED}, > + > + {L0_BR, ENC, HEVC, > + 1, MAX_BITRATE, 1, DEFAULT_BITRATE, > + V4L2_CID_MPEG_VIDEO_HEVC_HIER_CODING_L0_BR, > + HFI_PROP_BITRATE_LAYER1, > + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT | > + CAP_FLAG_DYNAMIC_ALLOWED}, > + > + {L1_BR, ENC, H264, > + 1, MAX_BITRATE, 1, DEFAULT_BITRATE, > + V4L2_CID_MPEG_VIDEO_H264_HIER_CODING_L1_BR, > + HFI_PROP_BITRATE_LAYER2, > + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT | > + CAP_FLAG_DYNAMIC_ALLOWED}, > + > + {L1_BR, ENC, HEVC, > + 1, MAX_BITRATE, 1, DEFAULT_BITRATE, > + V4L2_CID_MPEG_VIDEO_HEVC_HIER_CODING_L1_BR, > + HFI_PROP_BITRATE_LAYER2, > + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT | > + CAP_FLAG_DYNAMIC_ALLOWED}, > + > + {L2_BR, ENC, H264, > + 1, MAX_BITRATE, 1, DEFAULT_BITRATE, > + V4L2_CID_MPEG_VIDEO_H264_HIER_CODING_L2_BR, > + HFI_PROP_BITRATE_LAYER3, > + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT | > + CAP_FLAG_DYNAMIC_ALLOWED}, > + > + {L2_BR, ENC, HEVC, > + 1, MAX_BITRATE, 1, DEFAULT_BITRATE, > + V4L2_CID_MPEG_VIDEO_HEVC_HIER_CODING_L2_BR, > + HFI_PROP_BITRATE_LAYER3, > + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT | > + CAP_FLAG_DYNAMIC_ALLOWED}, > + > + {L3_BR, ENC, H264, > + 1, MAX_BITRATE, 1, DEFAULT_BITRATE, > + V4L2_CID_MPEG_VIDEO_H264_HIER_CODING_L3_BR, > + HFI_PROP_BITRATE_LAYER4, > + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT | > + CAP_FLAG_DYNAMIC_ALLOWED}, > + {L3_BR, ENC, HEVC, > + 1, MAX_BITRATE, 1, DEFAULT_BITRATE, > + V4L2_CID_MPEG_VIDEO_HEVC_HIER_CODING_L3_BR, > + HFI_PROP_BITRATE_LAYER4, > + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT | > + CAP_FLAG_DYNAMIC_ALLOWED}, > + > + {L4_BR, ENC, H264, > + 1, MAX_BITRATE, 1, DEFAULT_BITRATE, > + V4L2_CID_MPEG_VIDEO_H264_HIER_CODING_L4_BR, > + HFI_PROP_BITRATE_LAYER5, > + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT | > + CAP_FLAG_DYNAMIC_ALLOWED}, > + > + {L4_BR, ENC, HEVC, > + 1, MAX_BITRATE, 1, DEFAULT_BITRATE, > + V4L2_CID_MPEG_VIDEO_HEVC_HIER_CODING_L4_BR, > + HFI_PROP_BITRATE_LAYER5, > + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT | > + CAP_FLAG_DYNAMIC_ALLOWED}, > + > + {L5_BR, ENC, H264, > + 1, MAX_BITRATE, 1, DEFAULT_BITRATE, > + V4L2_CID_MPEG_VIDEO_H264_HIER_CODING_L5_BR, > + HFI_PROP_BITRATE_LAYER6, > + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT | > + CAP_FLAG_DYNAMIC_ALLOWED}, > + > + {L5_BR, ENC, HEVC, > + 1, MAX_BITRATE, 1, DEFAULT_BITRATE, > + V4L2_CID_MPEG_VIDEO_HEVC_HIER_CODING_L5_BR, > + HFI_PROP_BITRATE_LAYER6, > + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT | > + CAP_FLAG_DYNAMIC_ALLOWED}, > + > + {ENTROPY_MODE, ENC, H264, > + V4L2_MPEG_VIDEO_H264_ENTROPY_MODE_CAVLC, > + V4L2_MPEG_VIDEO_H264_ENTROPY_MODE_CABAC, > + BIT(V4L2_MPEG_VIDEO_H264_ENTROPY_MODE_CAVLC) | > + BIT(V4L2_MPEG_VIDEO_H264_ENTROPY_MODE_CABAC), > + V4L2_MPEG_VIDEO_H264_ENTROPY_MODE_CABAC, > + V4L2_CID_MPEG_VIDEO_H264_ENTROPY_MODE, > + HFI_PROP_CABAC_SESSION, > + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_MENU}, > + > + {ENTROPY_MODE, DEC, H264 | HEVC | VP9, > + V4L2_MPEG_VIDEO_H264_ENTROPY_MODE_CAVLC, > + V4L2_MPEG_VIDEO_H264_ENTROPY_MODE_CABAC, > + BIT(V4L2_MPEG_VIDEO_H264_ENTROPY_MODE_CAVLC) | > + BIT(V4L2_MPEG_VIDEO_H264_ENTROPY_MODE_CABAC), > + V4L2_MPEG_VIDEO_H264_ENTROPY_MODE_CABAC, > + 0, > + HFI_PROP_CABAC_SESSION}, > + > + {PROFILE, ENC | DEC, H264, > + V4L2_MPEG_VIDEO_H264_PROFILE_BASELINE, > + V4L2_MPEG_VIDEO_H264_PROFILE_CONSTRAINED_HIGH, > + BIT(V4L2_MPEG_VIDEO_H264_PROFILE_BASELINE) | > + BIT(V4L2_MPEG_VIDEO_H264_PROFILE_CONSTRAINED_HIGH) | > + BIT(V4L2_MPEG_VIDEO_H264_PROFILE_CONSTRAINED_BASELINE) | > + BIT(V4L2_MPEG_VIDEO_H264_PROFILE_MAIN) | > + BIT(V4L2_MPEG_VIDEO_H264_PROFILE_HIGH), > + V4L2_MPEG_VIDEO_H264_PROFILE_HIGH, > + V4L2_CID_MPEG_VIDEO_H264_PROFILE, > + HFI_PROP_PROFILE, > + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_MENU}, > + > + {PROFILE, ENC | DEC, HEVC, > + V4L2_MPEG_VIDEO_HEVC_PROFILE_MAIN, > + V4L2_MPEG_VIDEO_HEVC_PROFILE_MAIN_10, > + BIT(V4L2_MPEG_VIDEO_HEVC_PROFILE_MAIN) | > + BIT(V4L2_MPEG_VIDEO_HEVC_PROFILE_MAIN_STILL_PICTURE) | > + BIT(V4L2_MPEG_VIDEO_HEVC_PROFILE_MAIN_10), > + V4L2_MPEG_VIDEO_HEVC_PROFILE_MAIN, > + V4L2_CID_MPEG_VIDEO_HEVC_PROFILE, > + HFI_PROP_PROFILE, > + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_MENU}, > + > + {PROFILE, DEC, VP9, > + V4L2_MPEG_VIDEO_VP9_PROFILE_0, > + V4L2_MPEG_VIDEO_VP9_PROFILE_2, > + BIT(V4L2_MPEG_VIDEO_VP9_PROFILE_0) | > + BIT(V4L2_MPEG_VIDEO_VP9_PROFILE_2), > + V4L2_MPEG_VIDEO_VP9_PROFILE_0, > + V4L2_CID_MPEG_VIDEO_VP9_PROFILE, > + HFI_PROP_PROFILE, > + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_MENU}, > + > + {LEVEL, ENC, H264, > + V4L2_MPEG_VIDEO_H264_LEVEL_1_0, > + V4L2_MPEG_VIDEO_H264_LEVEL_6_0, > + BIT(V4L2_MPEG_VIDEO_H264_LEVEL_1_0) | > + BIT(V4L2_MPEG_VIDEO_H264_LEVEL_1B) | > + BIT(V4L2_MPEG_VIDEO_H264_LEVEL_1_1) | > + BIT(V4L2_MPEG_VIDEO_H264_LEVEL_1_2) | > + BIT(V4L2_MPEG_VIDEO_H264_LEVEL_1_3) | > + BIT(V4L2_MPEG_VIDEO_H264_LEVEL_2_0) | > + BIT(V4L2_MPEG_VIDEO_H264_LEVEL_2_1) | > + BIT(V4L2_MPEG_VIDEO_H264_LEVEL_2_2) | > + BIT(V4L2_MPEG_VIDEO_H264_LEVEL_3_0) | > + BIT(V4L2_MPEG_VIDEO_H264_LEVEL_3_1) | > + BIT(V4L2_MPEG_VIDEO_H264_LEVEL_3_2) | > + BIT(V4L2_MPEG_VIDEO_H264_LEVEL_4_0) | > + BIT(V4L2_MPEG_VIDEO_H264_LEVEL_4_1) | > + BIT(V4L2_MPEG_VIDEO_H264_LEVEL_4_2) | > + BIT(V4L2_MPEG_VIDEO_H264_LEVEL_5_0) | > + BIT(V4L2_MPEG_VIDEO_H264_LEVEL_5_1) | > + BIT(V4L2_MPEG_VIDEO_H264_LEVEL_5_2) | > + BIT(V4L2_MPEG_VIDEO_H264_LEVEL_6_0), > + V4L2_MPEG_VIDEO_H264_LEVEL_5_0, > + V4L2_CID_MPEG_VIDEO_H264_LEVEL, > + HFI_PROP_LEVEL, > + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_MENU}, > + > + {LEVEL, ENC, HEVC, > + V4L2_MPEG_VIDEO_HEVC_LEVEL_1, > + V4L2_MPEG_VIDEO_HEVC_LEVEL_6_2, > + BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_1) | > + BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_2) | > + BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_2_1) | > + BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_3) | > + BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_3_1) | > + BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_4) | > + BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_4_1) | > + BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_5) | > + BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_5_1) | > + BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_5_2) | > + BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_6) | > + BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_6_1) | > + BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_6_2), > + V4L2_MPEG_VIDEO_HEVC_LEVEL_5, > + V4L2_CID_MPEG_VIDEO_HEVC_LEVEL, > + HFI_PROP_LEVEL, > + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_MENU}, > + > + {LEVEL, DEC, H264, > + V4L2_MPEG_VIDEO_H264_LEVEL_1_0, > + V4L2_MPEG_VIDEO_H264_LEVEL_6_2, > + BIT(V4L2_MPEG_VIDEO_H264_LEVEL_1_0) | > + BIT(V4L2_MPEG_VIDEO_H264_LEVEL_1B) | > + BIT(V4L2_MPEG_VIDEO_H264_LEVEL_1_1) | > + BIT(V4L2_MPEG_VIDEO_H264_LEVEL_1_2) | > + BIT(V4L2_MPEG_VIDEO_H264_LEVEL_1_3) | > + BIT(V4L2_MPEG_VIDEO_H264_LEVEL_2_0) | > + BIT(V4L2_MPEG_VIDEO_H264_LEVEL_2_1) | > + BIT(V4L2_MPEG_VIDEO_H264_LEVEL_2_2) | > + BIT(V4L2_MPEG_VIDEO_H264_LEVEL_3_0) | > + BIT(V4L2_MPEG_VIDEO_H264_LEVEL_3_1) | > + BIT(V4L2_MPEG_VIDEO_H264_LEVEL_3_2) | > + BIT(V4L2_MPEG_VIDEO_H264_LEVEL_4_0) | > + BIT(V4L2_MPEG_VIDEO_H264_LEVEL_4_1) | > + BIT(V4L2_MPEG_VIDEO_H264_LEVEL_4_2) | > + BIT(V4L2_MPEG_VIDEO_H264_LEVEL_5_0) | > + BIT(V4L2_MPEG_VIDEO_H264_LEVEL_5_1) | > + BIT(V4L2_MPEG_VIDEO_H264_LEVEL_5_2) | > + BIT(V4L2_MPEG_VIDEO_H264_LEVEL_6_0) | > + BIT(V4L2_MPEG_VIDEO_H264_LEVEL_6_1) | > + BIT(V4L2_MPEG_VIDEO_H264_LEVEL_6_2), > + V4L2_MPEG_VIDEO_H264_LEVEL_6_1, > + V4L2_CID_MPEG_VIDEO_H264_LEVEL, > + HFI_PROP_LEVEL, > + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_MENU}, > + > + {LEVEL, DEC, HEVC, > + V4L2_MPEG_VIDEO_HEVC_LEVEL_1, > + V4L2_MPEG_VIDEO_HEVC_LEVEL_6_2, > + BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_1) | > + BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_2) | > + BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_2_1) | > + BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_3) | > + BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_3_1) | > + BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_4) | > + BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_4_1) | > + BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_5) | > + BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_5_1) | > + BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_5_2) | > + BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_6) | > + BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_6_1) | > + BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_6_2), > + V4L2_MPEG_VIDEO_HEVC_LEVEL_6_1, > + V4L2_CID_MPEG_VIDEO_HEVC_LEVEL, > + HFI_PROP_LEVEL, > + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_MENU}, > + > + {LEVEL, DEC, VP9, > + V4L2_MPEG_VIDEO_VP9_LEVEL_1_0, > + V4L2_MPEG_VIDEO_VP9_LEVEL_6_0, > + BIT(V4L2_MPEG_VIDEO_VP9_LEVEL_1_0) | > + BIT(V4L2_MPEG_VIDEO_VP9_LEVEL_1_1) | > + BIT(V4L2_MPEG_VIDEO_VP9_LEVEL_2_0) | > + BIT(V4L2_MPEG_VIDEO_VP9_LEVEL_2_1) | > + BIT(V4L2_MPEG_VIDEO_VP9_LEVEL_3_0) | > + BIT(V4L2_MPEG_VIDEO_VP9_LEVEL_3_1) | > + BIT(V4L2_MPEG_VIDEO_VP9_LEVEL_4_0) | > + BIT(V4L2_MPEG_VIDEO_VP9_LEVEL_4_1) | > + BIT(V4L2_MPEG_VIDEO_VP9_LEVEL_5_0) | > + BIT(V4L2_MPEG_VIDEO_VP9_LEVEL_5_1) | > + BIT(V4L2_MPEG_VIDEO_VP9_LEVEL_5_2) | > + BIT(V4L2_MPEG_VIDEO_VP9_LEVEL_6_0), > + V4L2_MPEG_VIDEO_VP9_LEVEL_6_0, > + V4L2_CID_MPEG_VIDEO_VP9_LEVEL, > + HFI_PROP_LEVEL, > + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_MENU}, > + > + {HEVC_TIER, ENC | DEC, HEVC, > + V4L2_MPEG_VIDEO_HEVC_TIER_MAIN, > + V4L2_MPEG_VIDEO_HEVC_TIER_HIGH, > + BIT(V4L2_MPEG_VIDEO_HEVC_TIER_MAIN) | > + BIT(V4L2_MPEG_VIDEO_HEVC_TIER_HIGH), > + V4L2_MPEG_VIDEO_HEVC_TIER_HIGH, > + V4L2_CID_MPEG_VIDEO_HEVC_TIER, > + HFI_PROP_TIER, > + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_MENU}, > + > + {LF_MODE, ENC, H264, > + V4L2_MPEG_VIDEO_H264_LOOP_FILTER_MODE_ENABLED, > + DB_H264_DISABLE_SLICE_BOUNDARY, > + BIT(V4L2_MPEG_VIDEO_H264_LOOP_FILTER_MODE_ENABLED) | > + BIT(V4L2_MPEG_VIDEO_H264_LOOP_FILTER_MODE_DISABLED) | > + BIT(DB_H264_DISABLE_SLICE_BOUNDARY), > + V4L2_MPEG_VIDEO_H264_LOOP_FILTER_MODE_ENABLED, > + V4L2_CID_MPEG_VIDEO_H264_LOOP_FILTER_MODE, > + HFI_PROP_DEBLOCKING_MODE, > + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_MENU}, > + > + {LF_MODE, ENC, HEVC, > + V4L2_MPEG_VIDEO_HEVC_LOOP_FILTER_MODE_DISABLED, > + DB_HEVC_DISABLE_SLICE_BOUNDARY, > + BIT(V4L2_MPEG_VIDEO_HEVC_LOOP_FILTER_MODE_DISABLED) | > + BIT(V4L2_MPEG_VIDEO_HEVC_LOOP_FILTER_MODE_ENABLED) | > + BIT(DB_HEVC_DISABLE_SLICE_BOUNDARY), > + V4L2_MPEG_VIDEO_HEVC_LOOP_FILTER_MODE_ENABLED, > + V4L2_CID_MPEG_VIDEO_HEVC_LOOP_FILTER_MODE, > + HFI_PROP_DEBLOCKING_MODE, > + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_MENU}, > + > + {LF_ALPHA, ENC, H264, > + -6, 6, 1, 0, > + V4L2_CID_MPEG_VIDEO_H264_LOOP_FILTER_ALPHA}, > + > + {LF_ALPHA, ENC, HEVC, > + -6, 6, 1, 0, > + V4L2_CID_MPEG_VIDEO_HEVC_LF_TC_OFFSET_DIV2}, > + > + {LF_BETA, ENC, H264, > + -6, 6, 1, 0, > + V4L2_CID_MPEG_VIDEO_H264_LOOP_FILTER_BETA}, > + > + {LF_BETA, ENC, HEVC, > + -6, 6, 1, 0, > + V4L2_CID_MPEG_VIDEO_HEVC_LF_BETA_OFFSET_DIV2}, > + > + {SLICE_MODE, ENC, H264 | HEVC, > + V4L2_MPEG_VIDEO_MULTI_SLICE_MODE_SINGLE, > + V4L2_MPEG_VIDEO_MULTI_SLICE_MODE_MAX_BYTES, > + BIT(V4L2_MPEG_VIDEO_MULTI_SLICE_MODE_SINGLE) | > + BIT(V4L2_MPEG_VIDEO_MULTI_SLICE_MODE_MAX_MB) | > + BIT(V4L2_MPEG_VIDEO_MULTI_SLICE_MODE_MAX_BYTES), > + V4L2_MPEG_VIDEO_MULTI_SLICE_MODE_SINGLE, > + V4L2_CID_MPEG_VIDEO_MULTI_SLICE_MODE, > + 0, > + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_MENU}, > + > + {SLICE_MAX_BYTES, ENC, H264 | HEVC, > + MIN_SLICE_BYTE_SIZE, MAX_SLICE_BYTE_SIZE, > + 1, MIN_SLICE_BYTE_SIZE, > + V4L2_CID_MPEG_VIDEO_MULTI_SLICE_MAX_BYTES, > + HFI_PROP_MULTI_SLICE_BYTES_COUNT, > + CAP_FLAG_OUTPUT_PORT}, > + > + {SLICE_MAX_MB, ENC, H264 | HEVC, > + 1, MAX_SLICE_MB_SIZE, 1, 1, > + V4L2_CID_MPEG_VIDEO_MULTI_SLICE_MAX_MB, > + HFI_PROP_MULTI_SLICE_MB_COUNT, > + CAP_FLAG_OUTPUT_PORT}, > + > + {MB_RC, ENC, H264 | HEVC, > + 0, 1, 1, 1, > + V4L2_CID_MPEG_VIDEO_MB_RC_ENABLE, > + 0, > + CAP_FLAG_OUTPUT_PORT}, > + > + {TRANSFORM_8X8, ENC, H264, > + 0, 1, 1, 1, > + V4L2_CID_MPEG_VIDEO_H264_8X8_TRANSFORM, > + HFI_PROP_8X8_TRANSFORM, > + CAP_FLAG_OUTPUT_PORT}, > + > + {CHROMA_QP_INDEX_OFFSET, ENC, HEVC, > + MIN_CHROMA_QP_OFFSET, MAX_CHROMA_QP_OFFSET, > + 1, MAX_CHROMA_QP_OFFSET, > + V4L2_CID_MPEG_VIDEO_H264_CHROMA_QP_INDEX_OFFSET, > + HFI_PROP_CHROMA_QP_OFFSET, > + CAP_FLAG_OUTPUT_PORT}, > + > + {DISPLAY_DELAY_ENABLE, DEC, H264 | HEVC | VP9, > + 0, 1, 1, 0, > + V4L2_CID_MPEG_VIDEO_DEC_DISPLAY_DELAY_ENABLE, > + HFI_PROP_DECODE_ORDER_OUTPUT, > + CAP_FLAG_INPUT_PORT}, > + > + {DISPLAY_DELAY, DEC, H264 | HEVC | VP9, > + 0, 1, 1, 0, > + V4L2_CID_MPEG_VIDEO_DEC_DISPLAY_DELAY, > + HFI_PROP_DECODE_ORDER_OUTPUT, > + CAP_FLAG_INPUT_PORT}, > + > + {OUTPUT_ORDER, DEC, H264 | HEVC | VP9, > + 0, 1, 1, 0, > + 0, > + HFI_PROP_DECODE_ORDER_OUTPUT, > + CAP_FLAG_INPUT_PORT}, > + > + {INPUT_BUF_HOST_MAX_COUNT, ENC | DEC, CODECS_ALL, > + DEFAULT_MAX_HOST_BUF_COUNT, DEFAULT_MAX_HOST_BURST_BUF_COUNT, > + 1, DEFAULT_MAX_HOST_BUF_COUNT, > + 0, > + HFI_PROP_BUFFER_HOST_MAX_COUNT, > + CAP_FLAG_INPUT_PORT}, > + > + {OUTPUT_BUF_HOST_MAX_COUNT, ENC | DEC, CODECS_ALL, > + DEFAULT_MAX_HOST_BUF_COUNT, DEFAULT_MAX_HOST_BURST_BUF_COUNT, > + 1, DEFAULT_MAX_HOST_BUF_COUNT, > + 0, > + HFI_PROP_BUFFER_HOST_MAX_COUNT, > + CAP_FLAG_OUTPUT_PORT}, > + > + {CONCEAL_COLOR_8BIT, DEC, CODECS_ALL, 0x0, 0xff3fcff, 1, > + DEFAULT_VIDEO_CONCEAL_COLOR_BLACK, > + V4L2_CID_MPEG_VIDEO_MUTE_YUV, > + HFI_PROP_CONCEAL_COLOR_8BIT, > + CAP_FLAG_INPUT_PORT}, > + > + {CONCEAL_COLOR_10BIT, DEC, CODECS_ALL, 0x0, 0x3fffffff, 1, > + DEFAULT_VIDEO_CONCEAL_COLOR_BLACK, > + V4L2_CID_MPEG_VIDEO_MUTE_YUV, > + HFI_PROP_CONCEAL_COLOR_10BIT, > + CAP_FLAG_INPUT_PORT}, > + > + {STAGE, DEC | ENC, CODECS_ALL, > + MSM_VIDC_STAGE_1, > + MSM_VIDC_STAGE_2, 1, > + MSM_VIDC_STAGE_2, > + 0, > + HFI_PROP_STAGE}, > + > + {PIPE, DEC | ENC, CODECS_ALL, > + MSM_VIDC_PIPE_1, > + MSM_VIDC_PIPE_4, 1, > + MSM_VIDC_PIPE_4, > + 0, > + HFI_PROP_PIPE}, > + > + {POC, DEC, H264, 0, 2, 1, 1, > + 0, > + HFI_PROP_PIC_ORDER_CNT_TYPE}, > + > + {QUALITY_MODE, ENC, CODECS_ALL, > + MSM_VIDC_MAX_QUALITY_MODE, > + MSM_VIDC_POWER_SAVE_MODE, 1, > + MSM_VIDC_POWER_SAVE_MODE}, > + > + {CODED_FRAMES, DEC, H264 | HEVC, > + CODED_FRAMES_PROGRESSIVE, CODED_FRAMES_INTERLACE, > + 1, CODED_FRAMES_PROGRESSIVE, > + 0, > + HFI_PROP_CODED_FRAMES}, > + > + {BIT_DEPTH, DEC, CODECS_ALL, BIT_DEPTH_8, BIT_DEPTH_10, 1, BIT_DEPTH_8, > + 0, > + HFI_PROP_LUMA_CHROMA_BIT_DEPTH}, > + > + {BITSTREAM_SIZE_OVERWRITE, DEC, CODECS_ALL, 0, INT_MAX, 1, 0, > + 0}, > + > + {DEFAULT_HEADER, DEC, CODECS_ALL, > + 0, 1, 1, 0, > + 0, > + HFI_PROP_DEC_DEFAULT_HEADER}, > + > + {RAP_FRAME, DEC, CODECS_ALL, > + 0, 1, 1, 1, > + 0, > + HFI_PROP_DEC_START_FROM_RAP_FRAME, > + CAP_FLAG_INPUT_PORT}, > + > + {SEQ_CHANGE_AT_SYNC_FRAME, DEC, CODECS_ALL, > + 0, 1, 1, 1, > + 0, > + HFI_PROP_SEQ_CHANGE_AT_SYNC_FRAME, > + CAP_FLAG_INPUT_PORT | CAP_FLAG_DYNAMIC_ALLOWED}, > + > + {ALL_INTRA, ENC, H264 | HEVC, > + 0, 1, 1, 0, > + 0, > + 0, > + CAP_FLAG_OUTPUT_PORT}, > +}; > + > +static struct msm_platform_inst_cap_dependency instance_cap_dependency_data_sm8550[] = { > + /* {cap, domain, codec, > + * children, > + * adjust, set} > + */ > + > + {PIX_FMTS, ENC, H264, > + {IR_PERIOD}}, > + > + {PIX_FMTS, ENC, HEVC, > + {PROFILE, MIN_FRAME_QP, MAX_FRAME_QP, I_FRAME_QP, P_FRAME_QP, > + B_FRAME_QP, MIN_QUALITY, IR_PERIOD, LTR_COUNT}}, > + > + {PIX_FMTS, DEC, HEVC, > + {PROFILE}}, > + > + {FRAME_RATE, ENC, CODECS_ALL, > + {0}, > + NULL, > + msm_vidc_set_q16}, > + > + {HFLIP, ENC, CODECS_ALL, > + {0}, > + NULL, > + msm_vidc_set_flip}, > + > + {VFLIP, ENC, CODECS_ALL, > + {0}, > + NULL, > + msm_vidc_set_flip}, > + > + {ROTATION, ENC, CODECS_ALL, > + {0}, > + NULL, > + msm_vidc_set_rotation}, > + > + {HEADER_MODE, ENC, CODECS_ALL, > + {0}, > + NULL, > + msm_vidc_set_header_mode}, > + > + {WITHOUT_STARTCODE, ENC, CODECS_ALL, > + {0}, > + NULL, > + msm_vidc_set_nal_length}, > + > + {REQUEST_I_FRAME, ENC, H264 | HEVC, > + {0}, > + NULL, > + msm_vidc_set_req_sync_frame}, > + > + {BIT_RATE, ENC, H264, > + {PEAK_BITRATE, L0_BR}, > + msm_vidc_adjust_bitrate, > + msm_vidc_set_bitrate}, > + > + {BIT_RATE, ENC, HEVC, > + {PEAK_BITRATE, L0_BR}, > + msm_vidc_adjust_bitrate, > + msm_vidc_set_bitrate}, > + > + {BITRATE_MODE, ENC, H264, > + {LTR_COUNT, IR_PERIOD, I_FRAME_QP, P_FRAME_QP, > + B_FRAME_QP, ENH_LAYER_COUNT, BIT_RATE, > + MIN_QUALITY, VBV_DELAY, > + PEAK_BITRATE, SLICE_MODE}, > + msm_vidc_adjust_bitrate_mode, > + msm_vidc_set_u32_enum}, > + > + {BITRATE_MODE, ENC, HEVC, > + {LTR_COUNT, IR_PERIOD, I_FRAME_QP, P_FRAME_QP, > + B_FRAME_QP, CONSTANT_QUALITY, ENH_LAYER_COUNT, > + BIT_RATE, MIN_QUALITY, VBV_DELAY, > + PEAK_BITRATE, SLICE_MODE}, > + msm_vidc_adjust_bitrate_mode, > + msm_vidc_set_u32_enum}, > + > + {CONSTANT_QUALITY, ENC, HEVC, > + {0}, > + NULL, > + msm_vidc_set_constant_quality}, > + > + {GOP_SIZE, ENC, CODECS_ALL, > + {ALL_INTRA}, > + msm_vidc_adjust_gop_size, > + msm_vidc_set_gop_size}, > + > + {B_FRAME, ENC, H264 | HEVC, > + {ALL_INTRA}, > + msm_vidc_adjust_b_frame, > + msm_vidc_set_u32}, > + > + {LTR_COUNT, ENC, H264 | HEVC, > + {0}, > + msm_vidc_adjust_ltr_count, > + msm_vidc_set_u32}, > + > + {USE_LTR, ENC, H264 | HEVC, > + {0}, > + msm_vidc_adjust_use_ltr, > + msm_vidc_set_use_and_mark_ltr}, > + > + {MARK_LTR, ENC, H264 | HEVC, > + {0}, > + msm_vidc_adjust_mark_ltr, > + msm_vidc_set_use_and_mark_ltr}, > + > + {IR_PERIOD, ENC, H264 | HEVC, > + {0}, > + msm_vidc_adjust_ir_period, > + msm_vidc_set_ir_period}, > + > + {AU_DELIMITER, ENC, H264 | HEVC, > + {0}, > + NULL, > + msm_vidc_set_u32}, > + > + {MIN_QUALITY, ENC, H264, > + {0}, > + msm_vidc_adjust_min_quality, > + msm_vidc_set_u32}, > + > + {MIN_QUALITY, ENC, HEVC, > + {0}, > + msm_vidc_adjust_min_quality, > + msm_vidc_set_u32}, > + > + {VBV_DELAY, ENC, H264 | HEVC, > + {0}, > + NULL, > + msm_vidc_set_cbr_related_properties}, > + > + {PEAK_BITRATE, ENC, H264 | HEVC, > + {0}, > + msm_vidc_adjust_peak_bitrate, > + msm_vidc_set_cbr_related_properties}, > + > + {MIN_FRAME_QP, ENC, H264, > + {0}, > + NULL, > + msm_vidc_set_min_qp}, > + > + {MIN_FRAME_QP, ENC, HEVC, > + {0}, > + msm_vidc_adjust_hevc_min_qp, > + msm_vidc_set_min_qp}, > + > + {MAX_FRAME_QP, ENC, H264, > + {0}, > + NULL, > + msm_vidc_set_max_qp}, > + > + {MAX_FRAME_QP, ENC, HEVC, > + {0}, > + msm_vidc_adjust_hevc_max_qp, > + msm_vidc_set_max_qp}, > + > + {I_FRAME_QP, ENC, HEVC, > + {0}, > + msm_vidc_adjust_hevc_i_frame_qp, > + msm_vidc_set_frame_qp}, > + > + {I_FRAME_QP, ENC, H264, > + {0}, > + NULL, > + msm_vidc_set_frame_qp}, > + > + {P_FRAME_QP, ENC, HEVC, > + {0}, > + msm_vidc_adjust_hevc_p_frame_qp, > + msm_vidc_set_frame_qp}, > + > + {P_FRAME_QP, ENC, H264, > + {0}, > + NULL, > + msm_vidc_set_frame_qp}, > + > + {B_FRAME_QP, ENC, HEVC, > + {0}, > + msm_vidc_adjust_hevc_b_frame_qp, > + msm_vidc_set_frame_qp}, > + > + {B_FRAME_QP, ENC, H264, > + {0}, > + NULL, > + msm_vidc_set_frame_qp}, > + > + {LAYER_TYPE, ENC, H264 | HEVC, > + {LTR_COUNT}}, > + > + {LAYER_ENABLE, ENC, H264 | HEVC, > + {0}}, > + > + {ENH_LAYER_COUNT, ENC, H264 | HEVC, > + {GOP_SIZE, B_FRAME, BIT_RATE, MIN_QUALITY, SLICE_MODE, > + LTR_COUNT}, > + msm_vidc_adjust_layer_count, > + msm_vidc_set_layer_count_and_type}, > + > + {L0_BR, ENC, H264 | HEVC, > + {L1_BR}, > + msm_vidc_adjust_layer_bitrate, > + msm_vidc_set_layer_bitrate}, > + > + {L1_BR, ENC, H264 | HEVC, > + {L2_BR}, > + msm_vidc_adjust_layer_bitrate, > + msm_vidc_set_layer_bitrate}, > + > + {L2_BR, ENC, H264 | HEVC, > + {L3_BR}, > + msm_vidc_adjust_layer_bitrate, > + msm_vidc_set_layer_bitrate}, > + > + {L3_BR, ENC, H264 | HEVC, > + {L4_BR}, > + msm_vidc_adjust_layer_bitrate, > + msm_vidc_set_layer_bitrate}, > + > + {L4_BR, ENC, H264 | HEVC, > + {L5_BR}, > + msm_vidc_adjust_layer_bitrate, > + msm_vidc_set_layer_bitrate}, > + > + {L5_BR, ENC, H264 | HEVC, > + {0}, > + msm_vidc_adjust_layer_bitrate, > + msm_vidc_set_layer_bitrate}, > + > + {ENTROPY_MODE, ENC, H264, > + {BIT_RATE}, > + msm_vidc_adjust_entropy_mode, > + msm_vidc_set_u32}, > + > + {PROFILE, ENC, H264, > + {ENTROPY_MODE, TRANSFORM_8X8}, > + NULL, > + msm_vidc_set_u32_enum}, > + > + {PROFILE, DEC, H264, > + {ENTROPY_MODE}, > + NULL, > + msm_vidc_set_u32_enum}, > + > + {PROFILE, ENC | DEC, HEVC, > + {0}, > + msm_vidc_adjust_profile, > + msm_vidc_set_u32_enum}, > + > + {PROFILE, DEC, VP9, > + {0}, > + NULL, > + msm_vidc_set_u32_enum}, > + > + {LEVEL, DEC, CODECS_ALL, > + {0}, > + NULL, > + msm_vidc_set_u32_enum}, > + > + {LEVEL, ENC, CODECS_ALL, > + {0}, > + NULL, > + msm_vidc_set_level}, > + > + {HEVC_TIER, ENC | DEC, HEVC, > + {0}, > + NULL, > + msm_vidc_set_u32_enum}, > + > + {LF_MODE, ENC, CODECS_ALL, > + {0}, > + NULL, > + msm_vidc_set_deblock_mode}, > + > + {SLICE_MODE, ENC, H264 | HEVC, > + {STAGE}, > + msm_vidc_adjust_slice_count, > + msm_vidc_set_slice_count}, > + > + {TRANSFORM_8X8, ENC, H264, > + {0}, > + msm_vidc_adjust_transform_8x8, > + msm_vidc_set_u32}, > + > + {CHROMA_QP_INDEX_OFFSET, ENC, HEVC, > + {0}, > + msm_vidc_adjust_chroma_qp_index_offset, > + msm_vidc_set_chroma_qp_index_offset}, > + > + {DISPLAY_DELAY_ENABLE, DEC, H264 | HEVC | VP9, > + {OUTPUT_ORDER}, > + NULL, > + NULL}, > + > + {DISPLAY_DELAY, DEC, H264 | HEVC | VP9, > + {OUTPUT_ORDER}, > + NULL, > + NULL}, > + > + {OUTPUT_ORDER, DEC, H264 | HEVC | VP9, > + {0}, > + msm_vidc_adjust_output_order, > + msm_vidc_set_u32}, > + > + {INPUT_BUF_HOST_MAX_COUNT, ENC | DEC, CODECS_ALL, > + {0}, > + msm_vidc_adjust_input_buf_host_max_count, > + msm_vidc_set_u32}, > + > + {INPUT_BUF_HOST_MAX_COUNT, ENC, H264 | HEVC, > + {0}, > + msm_vidc_adjust_input_buf_host_max_count, > + msm_vidc_set_u32}, > + > + {OUTPUT_BUF_HOST_MAX_COUNT, ENC | DEC, CODECS_ALL, > + {0}, > + msm_vidc_adjust_output_buf_host_max_count, > + msm_vidc_set_u32}, > + > + {OUTPUT_BUF_HOST_MAX_COUNT, ENC, H264 | HEVC, > + {0}, > + msm_vidc_adjust_output_buf_host_max_count, > + msm_vidc_set_u32}, > + > + {CONCEAL_COLOR_8BIT, DEC, CODECS_ALL, > + {0}, > + NULL, > + msm_vidc_set_u32_packed}, > + > + {CONCEAL_COLOR_10BIT, DEC, CODECS_ALL, > + {0}, > + NULL, > + msm_vidc_set_u32_packed}, > + > + {STAGE, ENC | DEC, CODECS_ALL, > + {0}, > + NULL, > + msm_vidc_set_stage}, > + > + {STAGE, ENC, H264 | HEVC, > + {0}, > + NULL, > + msm_vidc_set_stage}, > + > + {STAGE, DEC, H264 | HEVC | VP9, > + {0}, > + NULL, > + msm_vidc_set_stage}, > + > + {PIPE, DEC | ENC, CODECS_ALL, > + {0}, > + NULL, > + msm_vidc_set_pipe}, > + > + {RAP_FRAME, DEC, CODECS_ALL, > + {0}, > + NULL, > + msm_vidc_set_u32}, > + > + {ALL_INTRA, ENC, H264 | HEVC, > + {LTR_COUNT, IR_PERIOD, SLICE_MODE, BIT_RATE}, > + msm_vidc_adjust_all_intra, > + NULL}, > +}; > + > +/* Default UBWC config for LPDDR5 */ > +static struct msm_vidc_ubwc_config_data ubwc_config_sm8550[] = { > + UBWC_CONFIG(8, 32, 16, 0, 1, 1, 1), > +}; > + > +static struct msm_vidc_format_capability format_data_sm8550 = { > + .codec_info = codec_data_sm8550, > + .codec_info_size = ARRAY_SIZE(codec_data_sm8550), > + .color_format_info = color_format_data_sm8550, > + .color_format_info_size = ARRAY_SIZE(color_format_data_sm8550), > + .color_prim_info = color_primaries_data_sm8550, > + .color_prim_info_size = ARRAY_SIZE(color_primaries_data_sm8550), > + .transfer_char_info = transfer_char_data_sm8550, > + .transfer_char_info_size = ARRAY_SIZE(transfer_char_data_sm8550), > + .matrix_coeff_info = matrix_coeff_data_sm8550, > + .matrix_coeff_info_size = ARRAY_SIZE(matrix_coeff_data_sm8550), > +}; > + > +/* name, min_kbps, max_kbps */ > +static const struct bw_table sm8550_bw_table[] = { > + { "venus-cnoc", 1000, 1000 }, > + { "venus-ddr", 1000, 15000000 }, We have OPP tables for that. There is no need to limit the min/max, just put it to OPP. > +}; > + > +/* name */ > +static const struct pd_table sm8550_pd_table[] = { > + { "iris-ctl" }, > + { "vcodec" }, > +}; > + > +/* name */ > +static const char * const sm8550_opp_table[] = { "mx", "mmcx", NULL }; > + > +/* name, clock id, scaling */ > +static const struct clk_table sm8550_clk_table[] = { > + { "gcc_video_axi0", GCC_VIDEO_AXI0_CLK, 0 }, > + { "core_clk", VIDEO_CC_MVS0C_CLK, 0 }, > + { "vcodec_clk", VIDEO_CC_MVS0_CLK, 1 }, > +}; This strucuture looks like a perfect candidate to be replaced by devm_clk_bulk_get_all(). > + > +/* name, exclusive_release */ > +static const struct clk_rst_table sm8550_clk_reset_table[] = { > + { "video_axi_reset", 0 }, Can we assume that resets are generic at least? > +}; > + > +/* name, start, size, secure, dma_coherant, region, dma_mask */ > +const struct context_bank_table sm8550_context_bank_table[] = { > + {"qcom,vidc,cb-ns", 0x25800000, 0xba800000, 0, 1, MSM_VIDC_NON_SECURE, 0xe0000000 - 1}, > + {"qcom,vidc,cb-sec-non-pxl", 0x01000000, 0x24800000, 1, 0, MSM_VIDC_SECURE_NONPIXEL, 0 }, Aren't these a properties of subdevices? If so, why are you putting them here? > +}; > + > +/* freq */ > +static struct freq_table sm8550_freq_table[] = { > + {533333333}, {444000000}, {366000000}, {338000000}, {240000000} OPP table contents. > +}; > + > +/* register, value, mask */ > +static const struct reg_preset_table sm8550_reg_preset_table[] = { > + { 0xB0088, 0x0, 0x11 }, > +}; > + > +/* decoder properties */ > +static const u32 sm8550_vdec_psc_avc[] = { > + HFI_PROP_BITSTREAM_RESOLUTION, > + HFI_PROP_CROP_OFFSETS, > + HFI_PROP_CODED_FRAMES, > + HFI_PROP_BUFFER_FW_MIN_OUTPUT_COUNT, > + HFI_PROP_PIC_ORDER_CNT_TYPE, > + HFI_PROP_PROFILE, > + HFI_PROP_LEVEL, > + HFI_PROP_SIGNAL_COLOR_INFO, > +}; > + > +static const u32 sm8550_vdec_psc_hevc[] = { > + HFI_PROP_BITSTREAM_RESOLUTION, > + HFI_PROP_CROP_OFFSETS, > + HFI_PROP_LUMA_CHROMA_BIT_DEPTH, > + HFI_PROP_BUFFER_FW_MIN_OUTPUT_COUNT, > + HFI_PROP_PROFILE, > + HFI_PROP_LEVEL, > + HFI_PROP_TIER, > + HFI_PROP_SIGNAL_COLOR_INFO, > +}; > + > +static const u32 sm8550_vdec_psc_vp9[] = { > + HFI_PROP_BITSTREAM_RESOLUTION, > + HFI_PROP_CROP_OFFSETS, > + HFI_PROP_LUMA_CHROMA_BIT_DEPTH, > + HFI_PROP_BUFFER_FW_MIN_OUTPUT_COUNT, > + HFI_PROP_PROFILE, > + HFI_PROP_LEVEL, > +}; > + > +static const u32 sm8550_vdec_input_properties_avc[] = { > + HFI_PROP_NO_OUTPUT, > + HFI_PROP_SUBFRAME_INPUT, > +}; > + > +static const u32 sm8550_vdec_input_properties_hevc[] = { > + HFI_PROP_NO_OUTPUT, > + HFI_PROP_SUBFRAME_INPUT, > +}; > + > +static const u32 sm8550_vdec_input_properties_vp9[] = { > + HFI_PROP_NO_OUTPUT, > + HFI_PROP_SUBFRAME_INPUT, > +}; > + > +static const u32 sm8550_vdec_output_properties_avc[] = { > + HFI_PROP_WORST_COMPRESSION_RATIO, > + HFI_PROP_WORST_COMPLEXITY_FACTOR, > + HFI_PROP_PICTURE_TYPE, > + HFI_PROP_DPB_LIST, > + HFI_PROP_CABAC_SESSION, > +}; > + > +static const u32 sm8550_vdec_output_properties_hevc[] = { > + HFI_PROP_WORST_COMPRESSION_RATIO, > + HFI_PROP_WORST_COMPLEXITY_FACTOR, > + HFI_PROP_PICTURE_TYPE, > + HFI_PROP_DPB_LIST, > +}; > + > +static const u32 sm8550_vdec_output_properties_vp9[] = { > + HFI_PROP_WORST_COMPRESSION_RATIO, > + HFI_PROP_WORST_COMPLEXITY_FACTOR, > + HFI_PROP_PICTURE_TYPE, > + HFI_PROP_DPB_LIST, > +}; > + > +static const struct msm_vidc_platform_data sm8550_data = { > + /* resources dependent on other module */ > + .bw_tbl = sm8550_bw_table, > + .bw_tbl_size = ARRAY_SIZE(sm8550_bw_table), > + .clk_tbl = sm8550_clk_table, > + .clk_tbl_size = ARRAY_SIZE(sm8550_clk_table), > + .clk_rst_tbl = sm8550_clk_reset_table, > + .clk_rst_tbl_size = ARRAY_SIZE(sm8550_clk_reset_table), > + .subcache_tbl = NULL, > + .subcache_tbl_size = 0, > + > + /* populate context bank */ > + .context_bank_tbl = sm8550_context_bank_table, > + .context_bank_tbl_size = ARRAY_SIZE(sm8550_context_bank_table), > + > + /* populate power domain and opp table */ > + .pd_tbl = sm8550_pd_table, > + .pd_tbl_size = ARRAY_SIZE(sm8550_pd_table), > + .opp_tbl = sm8550_opp_table, > + .opp_tbl_size = ARRAY_SIZE(sm8550_opp_table), > + > + /* platform specific resources */ > + .freq_tbl = sm8550_freq_table, > + .freq_tbl_size = ARRAY_SIZE(sm8550_freq_table), > + .reg_prst_tbl = sm8550_reg_preset_table, > + .reg_prst_tbl_size = ARRAY_SIZE(sm8550_reg_preset_table), > + .fwname = "vpu30_4v", > + .pas_id = 9, > + > + /* caps related resorces */ > + .core_data = core_data_sm8550, > + .core_data_size = ARRAY_SIZE(core_data_sm8550), > + .inst_cap_data = instance_cap_data_sm8550, > + .inst_cap_data_size = ARRAY_SIZE(instance_cap_data_sm8550), > + .inst_cap_dependency_data = instance_cap_dependency_data_sm8550, > + .inst_cap_dependency_data_size = ARRAY_SIZE(instance_cap_dependency_data_sm8550), > + .ubwc_config = ubwc_config_sm8550, > + .format_data = &format_data_sm8550, > + > + /* decoder properties related*/ > + .psc_avc_tbl = sm8550_vdec_psc_avc, > + .psc_avc_tbl_size = ARRAY_SIZE(sm8550_vdec_psc_avc), > + .psc_hevc_tbl = sm8550_vdec_psc_hevc, > + .psc_hevc_tbl_size = ARRAY_SIZE(sm8550_vdec_psc_hevc), > + .psc_vp9_tbl = sm8550_vdec_psc_vp9, > + .psc_vp9_tbl_size = ARRAY_SIZE(sm8550_vdec_psc_vp9), > + .dec_input_prop_avc = sm8550_vdec_input_properties_avc, > + .dec_input_prop_hevc = sm8550_vdec_input_properties_hevc, > + .dec_input_prop_vp9 = sm8550_vdec_input_properties_vp9, > + .dec_input_prop_size_avc = ARRAY_SIZE(sm8550_vdec_input_properties_avc), > + .dec_input_prop_size_hevc = ARRAY_SIZE(sm8550_vdec_input_properties_hevc), > + .dec_input_prop_size_vp9 = ARRAY_SIZE(sm8550_vdec_input_properties_vp9), > + .dec_output_prop_avc = sm8550_vdec_output_properties_avc, > + .dec_output_prop_hevc = sm8550_vdec_output_properties_hevc, > + .dec_output_prop_vp9 = sm8550_vdec_output_properties_vp9, > + .dec_output_prop_size_avc = ARRAY_SIZE(sm8550_vdec_output_properties_avc), > + .dec_output_prop_size_hevc = ARRAY_SIZE(sm8550_vdec_output_properties_hevc), > + .dec_output_prop_size_vp9 = ARRAY_SIZE(sm8550_vdec_output_properties_vp9), Size should come next to the array reference. > +}; > + > +static int msm_vidc_init_data(struct msm_vidc_core *core) > +{ > + d_vpr_h("%s: initialize sm8550 data\n", __func__); > + > + core->platform->data = sm8550_data; > + Please use of_device_match_data() instead. > + return 0; > +} > + > +int msm_vidc_init_platform_sm8550(struct msm_vidc_core *core) > +{ > + return msm_vidc_init_data(core); > +}
On 7/28/2023 7:43 PM, Dmitry Baryshkov wrote: > On 28/07/2023 16:23, Vikash Garodia wrote: >> From: Dikshita Agarwal <quic_dikshita@quicinc.com> >> >> This implements all the capabilities supported by sm8550. >> >> Signed-off-by: Dikshita Agarwal <quic_dikshita@quicinc.com> >> Signed-off-by: Vikash Garodia <quic_vgarodia@quicinc.com> >> --- >>  .../iris/platform/sm8550/inc/msm_vidc_sm8550.h    |  14 + >>  .../iris/platform/sm8550/src/msm_vidc_sm8550.c    | 1727 >> ++++++++++++++++++++ >>  2 files changed, 1741 insertions(+) >>  create mode 100644 >> drivers/media/platform/qcom/iris/platform/sm8550/inc/msm_vidc_sm8550.h >>  create mode 100644 >> drivers/media/platform/qcom/iris/platform/sm8550/src/msm_vidc_sm8550.c >> >> diff --git >> a/drivers/media/platform/qcom/iris/platform/sm8550/inc/msm_vidc_sm8550.h >> b/drivers/media/platform/qcom/iris/platform/sm8550/inc/msm_vidc_sm8550.h >> new file mode 100644 >> index 0000000..0a2f172 >> --- /dev/null >> +++ b/drivers/media/platform/qcom/iris/platform/sm8550/inc/msm_vidc_sm8550.h >> @@ -0,0 +1,14 @@ >> +/* SPDX-License-Identifier: GPL-2.0-only */ >> +/* >> + * Copyright (c) 2020-2021, The Linux Foundation. All rights reserved. >> + * Copyright (c) 2021-2023 Qualcomm Innovation Center, Inc. All rights >> reserved. >> + */ >> + >> +#ifndef _MSM_VIDC_SM8550_H_ >> +#define _MSM_VIDC_SM8550_H_ >> + >> +#include "msm_vidc_core.h" >> + >> +int msm_vidc_init_platform_sm8550(struct msm_vidc_core *core); >> + >> +#endif // _MSM_VIDC_SM8550_H_ >> diff --git >> a/drivers/media/platform/qcom/iris/platform/sm8550/src/msm_vidc_sm8550.c >> b/drivers/media/platform/qcom/iris/platform/sm8550/src/msm_vidc_sm8550.c >> new file mode 100644 >> index 0000000..2408556 >> --- /dev/null >> +++ b/drivers/media/platform/qcom/iris/platform/sm8550/src/msm_vidc_sm8550.c >> @@ -0,0 +1,1727 @@ >> +// SPDX-License-Identifier: GPL-2.0-only >> +/* >> + * Copyright (c) 2020-2021, The Linux Foundation. All rights reserved. >> + * Copyright (c) 2021-2023 Qualcomm Innovation Center, Inc. All rights >> reserved. >> + */ >> + >> +#include <dt-bindings/clock/qcom,sm8550-gcc.h> >> +#include <dt-bindings/clock/qcom,sm8450-videocc.h> >> + >> +#include "hfi_command.h" >> +#include "hfi_property.h" >> +#include "msm_vidc_control.h" >> +#include "msm_vidc_debug.h" >> +#include "msm_vidc_iris3.h" >> +#include "msm_vidc_sm8550.h" >> +#include "msm_vidc_platform.h" >> + >> +/* version: major[24:31], minor[16:23], revision[0:15] */ >> +#define DRIVER_VERSION         0x04000000 >> +#define DEFAULT_VIDEO_CONCEAL_COLOR_BLACK 0x8020010 >> +#define MAX_BASE_LAYER_PRIORITY_ID 63 >> +#define MAX_OP_POINT           31 >> +#define MAX_BITRATE            245000000 >> +#define DEFAULT_BITRATE        20000000 >> +#define MINIMUM_FPS            1 >> +#define MAXIMUM_FPS            480 >> +#define MAXIMUM_DEC_FPS        960 >> +#define MAX_QP                 51 >> +#define DEFAULT_QP             20 >> +#define MAX_CONSTANT_QUALITY   100 >> +#define MIN_SLICE_BYTE_SIZE    512 >> +#define MAX_SLICE_BYTE_SIZE      \ >> +   ((MAX_BITRATE) >> 3) >> +#define MAX_SLICE_MB_SIZE        \ >> +   (((4096 + 15) >> 4) * ((2304 + 15) >> 4)) >> + >> +#define ENC    MSM_VIDC_ENCODER >> +#define DEC    MSM_VIDC_DECODER >> +#define H264   MSM_VIDC_H264 >> +#define HEVC   MSM_VIDC_HEVC >> +#define VP9    MSM_VIDC_VP9 > > Another redefinition. Inline it. > >> +#define CODECS_ALL    (H264 | HEVC | VP9) >> +#define MAXIMUM_OVERRIDE_VP9_FPS 200 >> + >> +static struct codec_info codec_data_sm8550[] = { >> +   { >> +       .v4l2_codec = V4L2_PIX_FMT_H264, >> +       .vidc_codec = MSM_VIDC_H264, >> +       .pixfmt_name = "AVC", > > Have you considered using existing code which enumerates formats? For > example, it is much better to refactor v4l_fill_fmtdesc() to allow getting > the description instead of adding your own names here. > Not to mention that printk supports %p4cc for printing fourcc values. I > hope you knew that. > Sure, will explore more on this. >> +   }, >> +   { >> +       .v4l2_codec = V4L2_PIX_FMT_HEVC, >> +       .vidc_codec = MSM_VIDC_HEVC, >> +       .pixfmt_name = "HEVC", >> +   }, >> +   { >> +       .v4l2_codec = V4L2_PIX_FMT_VP9, >> +       .vidc_codec = MSM_VIDC_VP9, >> +       .pixfmt_name = "VP9", >> +   }, >> +}; >> + >> +static struct color_format_info color_format_data_sm8550[] = { >> +   { >> +       .v4l2_color_format = V4L2_PIX_FMT_NV12, >> +       .vidc_color_format = MSM_VIDC_FMT_NV12, >> +       .pixfmt_name      = "NV12", >> +   }, >> +   { >> +       .v4l2_color_format = V4L2_PIX_FMT_NV21, >> +       .vidc_color_format = MSM_VIDC_FMT_NV21, >> +       .pixfmt_name      = "NV21", >> +   }, >> +   { >> +       .v4l2_color_format = V4L2_PIX_FMT_QC08C, >> +       .vidc_color_format = MSM_VIDC_FMT_NV12C, >> +       .pixfmt_name      = "NV12C", >> +   }, >> +   { >> +       .v4l2_color_format = V4L2_PIX_FMT_QC10C, >> +       .vidc_color_format = MSM_VIDC_FMT_TP10C, >> +       .pixfmt_name      = "TP10C", >> +   }, >> +   { >> +       .v4l2_color_format = V4L2_PIX_FMT_RGBA32, >> +       .vidc_color_format = MSM_VIDC_FMT_RGBA8888, >> +       .pixfmt_name      = "RGBA", >> +   }, >> +}; >> + >> +static struct color_primaries_info color_primaries_data_sm8550[] = { >> +   { >> +       .v4l2_color_primaries = V4L2_COLORSPACE_DEFAULT, >> +       .vidc_color_primaries = MSM_VIDC_PRIMARIES_RESERVED, >> +   }, >> +   { >> +       .v4l2_color_primaries = V4L2_COLORSPACE_REC709, >> +       .vidc_color_primaries = MSM_VIDC_PRIMARIES_BT709, >> +   }, >> +   { >> +       .v4l2_color_primaries = V4L2_COLORSPACE_470_SYSTEM_M, >> +       .vidc_color_primaries = MSM_VIDC_PRIMARIES_BT470_SYSTEM_M, >> +   }, >> +   { >> +       .v4l2_color_primaries = V4L2_COLORSPACE_470_SYSTEM_BG, >> +       .vidc_color_primaries = MSM_VIDC_PRIMARIES_BT470_SYSTEM_BG, >> +   }, >> +   { >> +       .v4l2_color_primaries = V4L2_COLORSPACE_SMPTE170M, >> +       .vidc_color_primaries = MSM_VIDC_PRIMARIES_BT601_525, >> +   }, >> +   { >> +       .v4l2_color_primaries = V4L2_COLORSPACE_SMPTE240M, >> +       .vidc_color_primaries = MSM_VIDC_PRIMARIES_SMPTE_ST240M, >> +   }, >> +   { >> +       .v4l2_color_primaries = V4L2_COLORSPACE_BT2020, >> +       .vidc_color_primaries = MSM_VIDC_PRIMARIES_BT2020, >> +   }, >> +   { >> +       .v4l2_color_primaries = V4L2_COLORSPACE_DCI_P3, >> +       .vidc_color_primaries = MSM_VIDC_PRIMARIES_SMPTE_RP431_2, >> +   }, >> +}; >> + >> +static struct transfer_char_info transfer_char_data_sm8550[] = { >> +   { >> +       .v4l2_transfer_char = V4L2_XFER_FUNC_DEFAULT, >> +       .vidc_transfer_char = MSM_VIDC_TRANSFER_RESERVED, >> +   }, >> +   { >> +       .v4l2_transfer_char = V4L2_XFER_FUNC_709, >> +       .vidc_transfer_char = MSM_VIDC_TRANSFER_BT709, >> +   }, >> +   { >> +       .v4l2_transfer_char = V4L2_XFER_FUNC_SMPTE240M, >> +       .vidc_transfer_char = MSM_VIDC_TRANSFER_SMPTE_ST240M, >> +   }, >> +   { >> +       .v4l2_transfer_char = V4L2_XFER_FUNC_SRGB, >> +       .vidc_transfer_char = MSM_VIDC_TRANSFER_SRGB_SYCC, >> +   }, >> +   { >> +       .v4l2_transfer_char = V4L2_XFER_FUNC_SMPTE2084, >> +       .vidc_transfer_char = MSM_VIDC_TRANSFER_SMPTE_ST2084_PQ, >> +   }, >> +}; >> + >> +static struct matrix_coeff_info matrix_coeff_data_sm8550[] = { >> +   { >> +       .v4l2_matrix_coeff = V4L2_YCBCR_ENC_DEFAULT, >> +       .vidc_matrix_coeff = MSM_VIDC_MATRIX_COEFF_RESERVED, >> +   }, >> +   { >> +       .v4l2_matrix_coeff = V4L2_YCBCR_ENC_709, >> +       .vidc_matrix_coeff = MSM_VIDC_MATRIX_COEFF_BT709, >> +   }, >> +   { >> +       .v4l2_matrix_coeff = V4L2_YCBCR_ENC_XV709, >> +       .vidc_matrix_coeff = MSM_VIDC_MATRIX_COEFF_BT709, >> +   }, >> +   { >> +       .v4l2_matrix_coeff = V4L2_YCBCR_ENC_XV601, >> +       .vidc_matrix_coeff = >> MSM_VIDC_MATRIX_COEFF_BT470_SYS_BG_OR_BT601_625, >> +   }, >> +   { >> +       .v4l2_matrix_coeff = V4L2_YCBCR_ENC_601, >> +       .vidc_matrix_coeff = >> MSM_VIDC_MATRIX_COEFF_BT601_525_BT1358_525_OR_625, >> +   }, >> +   { >> +       .v4l2_matrix_coeff = V4L2_YCBCR_ENC_SMPTE240M, >> +       .vidc_matrix_coeff = MSM_VIDC_MATRIX_COEFF_SMPTE_ST240, >> +   }, >> +   { >> +       .v4l2_matrix_coeff = V4L2_YCBCR_ENC_BT2020, >> +       .vidc_matrix_coeff = MSM_VIDC_MATRIX_COEFF_BT2020_NON_CONSTANT, >> +   }, >> +   { >> +       .v4l2_matrix_coeff = V4L2_YCBCR_ENC_BT2020_CONST_LUM, >> +       .vidc_matrix_coeff = MSM_VIDC_MATRIX_COEFF_BT2020_CONSTANT, >> +   }, >> +}; > > Are you going to say that these tables are platform-specific instead of > being generic to the driver? > future platform can support new codec and that will require new color primaries. So, yes these can differ for different platforms. >> + >> +static struct msm_platform_core_capability core_data_sm8550[] = { >> +   /* {type, value} */ >> +   {ENC_CODECS, H264 | HEVC}, >> +   {DEC_CODECS, H264 | HEVC | VP9}, >> +   {MAX_SESSION_COUNT, 16}, >> +   {MAX_NUM_720P_SESSIONS, 16}, >> +   {MAX_NUM_1080P_SESSIONS, 16}, >> +   {MAX_NUM_4K_SESSIONS, 8}, >> +   {MAX_NUM_8K_SESSIONS, 2}, >> +   {MAX_RT_MBPF, 174080},   /* (8192x4352)/256 + (4096x2176)/256*/ >> +   {MAX_MBPF, 278528}, /* ((8192x4352)/256) * 2 */ >> +   {MAX_MBPS, 7833600},   /* max_load >> +                * 7680x4320@60fps or 3840x2176@240fps >> +                * which is greater than 4096x2176@120fps, >> +                * 8192x4320@48fps >> +                */ >> +   {MAX_MBPF_HQ, 8160}, /* ((1920x1088)/256) */ >> +   {MAX_MBPS_HQ, 489600}, /* ((1920x1088)/256)@60fps */ >> +   {MAX_MBPF_B_FRAME, 32640}, /* 3840x2176/256 */ >> +   {MAX_MBPS_B_FRAME, 1958400}, /* 3840x2176/256 MBs@60fps */ >> +   {MAX_MBPS_ALL_INTRA, 1044480}, /* 4096x2176/256 MBs@30fps */ >> +   {MAX_ENH_LAYER_COUNT, 5}, >> +   {NUM_VPP_PIPE, 4}, >> +   {SW_PC, 1}, >> +   {FW_UNLOAD, 0}, >> +   {HW_RESPONSE_TIMEOUT, HW_RESPONSE_TIMEOUT_VALUE}, /* 1000 ms */ >> +   {SW_PC_DELAY,        SW_PC_DELAY_VALUE       }, /* 1500 ms >> (>HW_RESPONSE_TIMEOUT)*/ >> +   {FW_UNLOAD_DELAY,    FW_UNLOAD_DELAY_VALUE   }, /* 3000 ms >> (>SW_PC_DELAY)*/ >> +   {DCVS, 1}, >> +   {DECODE_BATCH, 1}, >> +   {DECODE_BATCH_TIMEOUT, 200}, >> +   {STATS_TIMEOUT_MS, 2000}, >> +   {NON_FATAL_FAULTS, 1}, >> +   {DEVICE_CAPS, V4L2_CAP_VIDEO_M2M_MPLANE | V4L2_CAP_STREAMING}, > > Unless there is a good reason, please change this to be a proper data > structure instead of being a type-value array. With the T-V it is > impossible to notice if the value is missing or duplicated. This comment > also applies to the next 'capability' array. > Core has set of caps. All caps might not be supported for all the hardware. So it's quite valid to miss a cap entry if its not applicable for that hardware. subsequently with caps as enum, it will become easy to copy these caps from platform to core. please check msm_vidc_init_core_caps API in [1] [1] https://patchwork.linuxtv.org/project/linux-media/patch/1690550624-14642-11-git-send-email-quic_vgarodia@quicinc.com/ >> +}; >> + >> +static struct msm_platform_inst_capability instance_cap_data_sm8550[] = { >> +   /* {cap, domain, codec, >> +    *     min, max, step_or_mask, value, >> +    *     v4l2_id, >> +    *     hfi_id, >> +    *     flags} >> +    */ >> +   {FRAME_WIDTH, DEC, CODECS_ALL, 96, 8192, 1, 1920}, >> + >> +   {FRAME_WIDTH, DEC, VP9, 96, 4096, 1, 1920}, >> + >> +   {FRAME_WIDTH, ENC, CODECS_ALL, 128, 8192, 1, 1920}, >> + >> +   {FRAME_WIDTH, ENC, HEVC, 96, 8192, 1, 1920}, >> + >> +   {LOSSLESS_FRAME_WIDTH, ENC, CODECS_ALL, 128, 4096, 1, 1920}, >> + >> +   {LOSSLESS_FRAME_WIDTH, ENC, HEVC, 96, 4096, 1, 1920}, >> + >> +   {FRAME_HEIGHT, DEC, CODECS_ALL, 96, 8192, 1, 1080}, >> + >> +   {FRAME_HEIGHT, DEC, VP9, 96, 4096, 1, 1080}, >> + >> +   {FRAME_HEIGHT, ENC, CODECS_ALL, 128, 8192, 1, 1080}, >> + >> +   {FRAME_HEIGHT, ENC, HEVC, 96, 8192, 1, 1080}, >> + >> +   {LOSSLESS_FRAME_HEIGHT, ENC, CODECS_ALL, 128, 4096, 1, 1080}, >> + >> +   {LOSSLESS_FRAME_HEIGHT, ENC, HEVC, 96, 4096, 1, 1080}, >> + >> +   {PIX_FMTS, ENC | DEC, H264, >> +       MSM_VIDC_FMT_NV12, >> +       MSM_VIDC_FMT_NV12C, >> +       MSM_VIDC_FMT_NV12 | MSM_VIDC_FMT_NV21 | MSM_VIDC_FMT_NV12C, >> +       MSM_VIDC_FMT_NV12C}, >> + >> +   {PIX_FMTS, ENC | DEC, HEVC | VP9, >> +       MSM_VIDC_FMT_NV12, >> +       MSM_VIDC_FMT_TP10C, >> +       MSM_VIDC_FMT_NV12 | MSM_VIDC_FMT_NV21 | MSM_VIDC_FMT_NV12C | >> +       MSM_VIDC_FMT_TP10C, >> +       MSM_VIDC_FMT_NV12C}, >> + >> +   {MIN_BUFFERS_INPUT, ENC | DEC, CODECS_ALL, 0, 64, 1, 4, >> +       V4L2_CID_MIN_BUFFERS_FOR_OUTPUT, >> +       0, >> +       CAP_FLAG_VOLATILE}, >> + >> +   {MIN_BUFFERS_OUTPUT, ENC | DEC, CODECS_ALL, >> +       0, 64, 1, 4, >> +       V4L2_CID_MIN_BUFFERS_FOR_CAPTURE, >> +       HFI_PROP_BUFFER_FW_MIN_OUTPUT_COUNT, >> +       CAP_FLAG_OUTPUT_PORT | CAP_FLAG_VOLATILE}, >> + >> +   /* (8192 * 4320) / 256 */ >> +   {MBPF, ENC, CODECS_ALL, 64, 138240, 1, 138240}, >> + >> +   {MBPF, ENC, HEVC, 36, 138240, 1, 138240}, >> + >> +   {MBPF, DEC, CODECS_ALL, 36, 138240, 1, 138240}, >> + >> +   /* (4096 * 2304) / 256 */ >> +   {MBPF, DEC, VP9, 36, 36864, 1, 36864}, >> + >> +   /* (4096 * 2304) / 256 */ >> +   {LOSSLESS_MBPF, ENC, H264 | HEVC, 64, 36864, 1, 36864}, >> + >> +   /* Batch Mode Decode */ >> +   /* TODO: update with new values based on updated voltage corner */ >> +   {BATCH_MBPF, DEC, H264 | HEVC | VP9, 64, 34816, 1, 34816}, >> + >> +   /* (4096 * 2304) / 256 */ >> +   {BATCH_FPS, DEC, H264 | HEVC | VP9, 1, 120, 1, 120}, >> + >> +   {FRAME_RATE, ENC | DEC, CODECS_ALL, >> +       (MINIMUM_FPS << 16), (MAXIMUM_FPS << 16), >> +       1, (DEFAULT_FPS << 16), >> +       0, >> +       HFI_PROP_FRAME_RATE, >> +       CAP_FLAG_OUTPUT_PORT}, >> + >> +   {OPERATING_RATE, ENC | DEC, CODECS_ALL, >> +       (MINIMUM_FPS << 16), (MAXIMUM_FPS << 16), >> +       1, (DEFAULT_FPS << 16)}, >> + >> +   {INPUT_RATE, ENC | DEC, CODECS_ALL, >> +       (MINIMUM_FPS << 16), INT_MAX, >> +       1, (DEFAULT_FPS << 16)}, >> + >> +   {TIMESTAMP_RATE, ENC | DEC, CODECS_ALL, >> +       (MINIMUM_FPS << 16), INT_MAX, >> +       1, (DEFAULT_FPS << 16)}, >> + >> +   {SCALE_FACTOR, ENC, H264 | HEVC, 1, 8, 1, 8}, >> + >> +   {MB_CYCLES_VSP, ENC, CODECS_ALL, 25, 25, 1, 25}, >> + >> +   {MB_CYCLES_VSP, DEC, CODECS_ALL, 25, 25, 1, 25}, >> + >> +   {MB_CYCLES_VSP, DEC, VP9, 60, 60, 1, 60}, >> + >> +   {MB_CYCLES_VPP, ENC, CODECS_ALL, 675, 675, 1, 675}, >> + >> +   {MB_CYCLES_VPP, DEC, CODECS_ALL, 200, 200, 1, 200}, >> + >> +   {MB_CYCLES_LP, ENC, CODECS_ALL, 320, 320, 1, 320}, >> + >> +   {MB_CYCLES_LP, DEC, CODECS_ALL, 200, 200, 1, 200}, >> + >> +   {MB_CYCLES_FW, ENC | DEC, CODECS_ALL, 489583, 489583, 1, 489583}, >> + >> +   {MB_CYCLES_FW_VPP, ENC, CODECS_ALL, 48405, 48405, 1, 48405}, >> + >> +   {MB_CYCLES_FW_VPP, DEC, CODECS_ALL, 66234, 66234, 1, 66234}, >> + >> +   {HFLIP, ENC, CODECS_ALL, >> +       0, 1, 1, 0, >> +       V4L2_CID_HFLIP, >> +       HFI_PROP_FLIP, >> +       CAP_FLAG_OUTPUT_PORT | >> +       CAP_FLAG_INPUT_PORT | CAP_FLAG_DYNAMIC_ALLOWED}, >> + >> +   {VFLIP, ENC, CODECS_ALL, >> +       0, 1, 1, 0, >> +       V4L2_CID_VFLIP, >> +       HFI_PROP_FLIP, >> +       CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT | >> +       CAP_FLAG_DYNAMIC_ALLOWED}, >> + >> +   {ROTATION, ENC, CODECS_ALL, >> +       0, 270, 90, 0, >> +       V4L2_CID_ROTATE, >> +       HFI_PROP_ROTATION, >> +       CAP_FLAG_OUTPUT_PORT}, >> + >> +   {HEADER_MODE, ENC, CODECS_ALL, >> +       V4L2_MPEG_VIDEO_HEADER_MODE_SEPARATE, >> +       V4L2_MPEG_VIDEO_HEADER_MODE_JOINED_WITH_1ST_FRAME, >> +       BIT(V4L2_MPEG_VIDEO_HEADER_MODE_SEPARATE) | >> +       BIT(V4L2_MPEG_VIDEO_HEADER_MODE_JOINED_WITH_1ST_FRAME), >> +       V4L2_MPEG_VIDEO_HEADER_MODE_SEPARATE, >> +       V4L2_CID_MPEG_VIDEO_HEADER_MODE, >> +       HFI_PROP_SEQ_HEADER_MODE, >> +       CAP_FLAG_OUTPUT_PORT | CAP_FLAG_MENU}, >> + >> +   {PREPEND_SPSPPS_TO_IDR, ENC, CODECS_ALL, >> +       0, 1, 1, 0, >> +       V4L2_CID_MPEG_VIDEO_PREPEND_SPSPPS_TO_IDR}, >> + >> +   {WITHOUT_STARTCODE, ENC, CODECS_ALL, >> +       0, 1, 1, 0, >> +       V4L2_CID_MPEG_VIDEO_HEVC_WITHOUT_STARTCODE, >> +       HFI_PROP_NAL_LENGTH_FIELD, >> +       CAP_FLAG_OUTPUT_PORT}, >> + >> +   {NAL_LENGTH_FIELD, ENC, CODECS_ALL, >> +       V4L2_MPEG_VIDEO_HEVC_SIZE_0, >> +       V4L2_MPEG_VIDEO_HEVC_SIZE_4, >> +       BIT(V4L2_MPEG_VIDEO_HEVC_SIZE_0) | >> +       BIT(V4L2_MPEG_VIDEO_HEVC_SIZE_4), >> +       V4L2_MPEG_VIDEO_HEVC_SIZE_0, >> +       V4L2_CID_MPEG_VIDEO_HEVC_SIZE_OF_LENGTH_FIELD, >> +       HFI_PROP_NAL_LENGTH_FIELD, >> +       CAP_FLAG_MENU | CAP_FLAG_OUTPUT_PORT}, >> + >> +   /* TODO: Firmware introduced enumeration type for this >> +    * with and without seq header. >> +    */ >> +   {REQUEST_I_FRAME, ENC, H264 | HEVC, >> +       0, 0, 0, 0, >> +       V4L2_CID_MPEG_VIDEO_FORCE_KEY_FRAME, >> +       HFI_PROP_REQUEST_SYNC_FRAME, >> +       CAP_FLAG_INPUT_PORT | CAP_FLAG_DYNAMIC_ALLOWED}, >> + >> +   /* Enc: Keeping CABAC and CAVLC as same bitrate. >> +    * Dec: there's no use of Bitrate cap >> +    */ >> +   {BIT_RATE, ENC, H264 | HEVC, >> +       1, MAX_BITRATE, 1, DEFAULT_BITRATE, >> +       V4L2_CID_MPEG_VIDEO_BITRATE, >> +       HFI_PROP_TOTAL_BITRATE, >> +       CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT | >> +       CAP_FLAG_DYNAMIC_ALLOWED}, >> + >> +   {BITRATE_MODE, ENC, H264, >> +       V4L2_MPEG_VIDEO_BITRATE_MODE_VBR, >> +       V4L2_MPEG_VIDEO_BITRATE_MODE_CBR, >> +       BIT(V4L2_MPEG_VIDEO_BITRATE_MODE_VBR) | >> +       BIT(V4L2_MPEG_VIDEO_BITRATE_MODE_CBR), >> +       V4L2_MPEG_VIDEO_BITRATE_MODE_VBR, >> +       V4L2_CID_MPEG_VIDEO_BITRATE_MODE, >> +       HFI_PROP_RATE_CONTROL, >> +       CAP_FLAG_OUTPUT_PORT | CAP_FLAG_MENU}, >> + >> +   {BITRATE_MODE, ENC, HEVC, >> +       V4L2_MPEG_VIDEO_BITRATE_MODE_VBR, >> +       V4L2_MPEG_VIDEO_BITRATE_MODE_CQ, >> +       BIT(V4L2_MPEG_VIDEO_BITRATE_MODE_VBR) | >> +       BIT(V4L2_MPEG_VIDEO_BITRATE_MODE_CBR) | >> +       BIT(V4L2_MPEG_VIDEO_BITRATE_MODE_CQ), >> +       V4L2_MPEG_VIDEO_BITRATE_MODE_VBR, >> +       V4L2_CID_MPEG_VIDEO_BITRATE_MODE, >> +       HFI_PROP_RATE_CONTROL, >> +       CAP_FLAG_OUTPUT_PORT | CAP_FLAG_MENU}, >> + >> +   {CABAC_MAX_BITRATE, ENC, H264 | HEVC, 0, >> +       160000000, 1, 160000000}, >> + >> +   {CAVLC_MAX_BITRATE, ENC, H264, 0, >> +       220000000, 1, 220000000}, >> + >> +   {ALLINTRA_MAX_BITRATE, ENC, H264 | HEVC, 0, >> +       245000000, 1, 245000000}, >> + >> +   {NUM_COMV, DEC, CODECS_ALL, >> +       0, INT_MAX, 1, 0}, >> + >> +   {LOSSLESS, ENC, HEVC, >> +       0, 1, 1, 0, >> +       V4L2_CID_MPEG_VIDEO_HEVC_LOSSLESS_CU}, >> + >> +   {FRAME_SKIP_MODE, ENC, H264 | HEVC, >> +       V4L2_MPEG_VIDEO_FRAME_SKIP_MODE_DISABLED, >> +       V4L2_MPEG_VIDEO_FRAME_SKIP_MODE_BUF_LIMIT, >> +       BIT(V4L2_MPEG_VIDEO_FRAME_SKIP_MODE_DISABLED) | >> +       BIT(V4L2_MPEG_VIDEO_FRAME_SKIP_MODE_LEVEL_LIMIT) | >> +       BIT(V4L2_MPEG_VIDEO_FRAME_SKIP_MODE_BUF_LIMIT), >> +       V4L2_MPEG_VIDEO_FRAME_SKIP_MODE_DISABLED, >> +       V4L2_CID_MPEG_VIDEO_FRAME_SKIP_MODE, >> +       0, >> +       CAP_FLAG_OUTPUT_PORT | CAP_FLAG_MENU}, >> + >> +   {FRAME_RC_ENABLE, ENC, H264 | HEVC, >> +       0, 1, 1, 1, >> +       V4L2_CID_MPEG_VIDEO_FRAME_RC_ENABLE}, >> + >> +   {CONSTANT_QUALITY, ENC, HEVC, >> +       1, MAX_CONSTANT_QUALITY, 1, 90, >> +       V4L2_CID_MPEG_VIDEO_CONSTANT_QUALITY, >> +       HFI_PROP_CONSTANT_QUALITY, >> +       CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT | >> +       CAP_FLAG_DYNAMIC_ALLOWED}, >> + >> +   {GOP_SIZE, ENC, CODECS_ALL, >> +       0, INT_MAX, 1, 2 * DEFAULT_FPS - 1, >> +       V4L2_CID_MPEG_VIDEO_GOP_SIZE, >> +       HFI_PROP_MAX_GOP_FRAMES, >> +       CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT | >> +       CAP_FLAG_DYNAMIC_ALLOWED}, >> + >> +   {GOP_CLOSURE, ENC, H264 | HEVC, >> +       0, 1, 1, 1, >> +       V4L2_CID_MPEG_VIDEO_GOP_CLOSURE, >> +       0}, >> + >> +   {B_FRAME, ENC, H264 | HEVC, >> +       0, 7, 1, 0, >> +       V4L2_CID_MPEG_VIDEO_B_FRAMES, >> +       HFI_PROP_MAX_B_FRAMES, >> +       CAP_FLAG_OUTPUT_PORT}, >> + >> +   {LTR_COUNT, ENC, H264 | HEVC, >> +       0, MAX_LTR_FRAME_COUNT_2, 1, 0, >> +       V4L2_CID_MPEG_VIDEO_LTR_COUNT, >> +       HFI_PROP_LTR_COUNT, >> +       CAP_FLAG_OUTPUT_PORT}, >> + >> +   {USE_LTR, ENC, H264 | HEVC, >> +       0, >> +       ((1 << MAX_LTR_FRAME_COUNT_2) - 1), >> +       0, 0, >> +       V4L2_CID_MPEG_VIDEO_USE_LTR_FRAMES, >> +       HFI_PROP_LTR_USE, >> +       CAP_FLAG_INPUT_PORT | CAP_FLAG_DYNAMIC_ALLOWED}, >> + >> +   {MARK_LTR, ENC, H264 | HEVC, >> +       INVALID_DEFAULT_MARK_OR_USE_LTR, >> +       (MAX_LTR_FRAME_COUNT_2 - 1), >> +       1, INVALID_DEFAULT_MARK_OR_USE_LTR, >> +       V4L2_CID_MPEG_VIDEO_FRAME_LTR_INDEX, >> +       HFI_PROP_LTR_MARK, >> +       CAP_FLAG_INPUT_PORT | CAP_FLAG_DYNAMIC_ALLOWED}, >> + >> +   {BASELAYER_PRIORITY, ENC, H264, >> +       0, MAX_BASE_LAYER_PRIORITY_ID, 1, 0, >> +       V4L2_CID_MPEG_VIDEO_BASELAYER_PRIORITY_ID, >> +       HFI_PROP_BASELAYER_PRIORITYID, >> +       CAP_FLAG_OUTPUT_PORT}, >> + >> +   {IR_TYPE, ENC, H264 | HEVC, >> +       V4L2_CID_MPEG_VIDEO_INTRA_REFRESH_PERIOD_TYPE_RANDOM, >> +       V4L2_CID_MPEG_VIDEO_INTRA_REFRESH_PERIOD_TYPE_CYCLIC, >> +       BIT(V4L2_CID_MPEG_VIDEO_INTRA_REFRESH_PERIOD_TYPE_RANDOM) | >> +       BIT(V4L2_CID_MPEG_VIDEO_INTRA_REFRESH_PERIOD_TYPE_CYCLIC), >> +       V4L2_CID_MPEG_VIDEO_INTRA_REFRESH_PERIOD_TYPE_RANDOM, >> +       V4L2_CID_MPEG_VIDEO_INTRA_REFRESH_PERIOD_TYPE, >> +       0, >> +       CAP_FLAG_OUTPUT_PORT | CAP_FLAG_MENU}, >> + >> +   {IR_PERIOD, ENC, H264 | HEVC, >> +       0, INT_MAX, 1, 0, >> +       V4L2_CID_MPEG_VIDEO_INTRA_REFRESH_PERIOD, >> +       0, >> +       CAP_FLAG_INPUT_PORT | CAP_FLAG_OUTPUT_PORT | >> +       CAP_FLAG_DYNAMIC_ALLOWED}, >> + >> +   {AU_DELIMITER, ENC, H264 | HEVC, >> +       0, 1, 1, 0, >> +       V4L2_CID_MPEG_VIDEO_AU_DELIMITER, >> +       HFI_PROP_AUD, >> +       CAP_FLAG_OUTPUT_PORT}, >> + >> +   {MIN_QUALITY, ENC, H264 | HEVC, >> +       0, MAX_SUPPORTED_MIN_QUALITY, 70, MAX_SUPPORTED_MIN_QUALITY, >> +       0, >> +       HFI_PROP_MAINTAIN_MIN_QUALITY, >> +       CAP_FLAG_OUTPUT_PORT}, >> + >> +   {VBV_DELAY, ENC, H264 | HEVC, >> +       200, 300, 100, 300, >> +       V4L2_CID_MPEG_VIDEO_VBV_DELAY, >> +       HFI_PROP_VBV_DELAY, >> +       CAP_FLAG_OUTPUT_PORT}, >> + >> +   {PEAK_BITRATE, ENC, H264 | HEVC, >> +       /* default peak bitrate is 10% larger than avg bitrate */ >> +       1, MAX_BITRATE, 1, DEFAULT_BITRATE, >> +       V4L2_CID_MPEG_VIDEO_BITRATE_PEAK, >> +       HFI_PROP_TOTAL_PEAK_BITRATE, >> +       CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT | >> +           CAP_FLAG_DYNAMIC_ALLOWED}, >> + >> +   {MIN_FRAME_QP, ENC, H264, >> +       MIN_QP_8BIT, MAX_QP, 1, MIN_QP_8BIT, >> +       V4L2_CID_MPEG_VIDEO_H264_MIN_QP, >> +       HFI_PROP_MIN_QP_PACKED, >> +       CAP_FLAG_OUTPUT_PORT}, >> + >> +   {MIN_FRAME_QP, ENC, HEVC, >> +       MIN_QP_10BIT, MAX_QP, 1, MIN_QP_10BIT, >> +       V4L2_CID_MPEG_VIDEO_HEVC_MIN_QP, >> +       HFI_PROP_MIN_QP_PACKED, >> +       CAP_FLAG_OUTPUT_PORT}, >> + >> +   {I_FRAME_MIN_QP, ENC, H264, >> +       MIN_QP_8BIT, MAX_QP, 1, MIN_QP_8BIT, >> +       V4L2_CID_MPEG_VIDEO_H264_I_FRAME_MIN_QP}, >> + >> +   {I_FRAME_MIN_QP, ENC, HEVC, >> +       MIN_QP_10BIT, MAX_QP, 1, MIN_QP_10BIT, >> +       V4L2_CID_MPEG_VIDEO_HEVC_I_FRAME_MIN_QP}, >> + >> +   {P_FRAME_MIN_QP, ENC, H264, >> +       MIN_QP_8BIT, MAX_QP, 1, MIN_QP_8BIT, >> +       V4L2_CID_MPEG_VIDEO_H264_P_FRAME_MIN_QP}, >> + >> +   {P_FRAME_MIN_QP, ENC, HEVC, >> +       MIN_QP_10BIT, MAX_QP, 1, MIN_QP_10BIT, >> +       V4L2_CID_MPEG_VIDEO_HEVC_P_FRAME_MIN_QP}, >> + >> +   {B_FRAME_MIN_QP, ENC, H264, >> +       MIN_QP_8BIT, MAX_QP, 1, MIN_QP_8BIT, >> +       V4L2_CID_MPEG_VIDEO_H264_B_FRAME_MIN_QP}, >> + >> +   {B_FRAME_MIN_QP, ENC, HEVC, >> +       MIN_QP_10BIT, MAX_QP, 1, MIN_QP_10BIT, >> +       V4L2_CID_MPEG_VIDEO_HEVC_B_FRAME_MIN_QP}, >> + >> +   {MAX_FRAME_QP, ENC, H264, >> +       MIN_QP_8BIT, MAX_QP, 1, MAX_QP, >> +       V4L2_CID_MPEG_VIDEO_H264_MAX_QP, >> +       HFI_PROP_MAX_QP_PACKED, >> +       CAP_FLAG_OUTPUT_PORT}, >> + >> +   {MAX_FRAME_QP, ENC, HEVC, >> +       MIN_QP_10BIT, MAX_QP, 1, MAX_QP, >> +       V4L2_CID_MPEG_VIDEO_HEVC_MAX_QP, >> +       HFI_PROP_MAX_QP_PACKED, >> +       CAP_FLAG_OUTPUT_PORT}, >> + >> +   {I_FRAME_MAX_QP, ENC, H264, >> +       MIN_QP_8BIT, MAX_QP, 1, MAX_QP, >> +       V4L2_CID_MPEG_VIDEO_H264_I_FRAME_MAX_QP}, >> + >> +   {I_FRAME_MAX_QP, ENC, HEVC, >> +       MIN_QP_10BIT, MAX_QP, 1, MAX_QP, >> +       V4L2_CID_MPEG_VIDEO_HEVC_I_FRAME_MAX_QP}, >> + >> +   {P_FRAME_MAX_QP, ENC, H264, >> +       MIN_QP_8BIT, MAX_QP, 1, MAX_QP, >> +       V4L2_CID_MPEG_VIDEO_H264_P_FRAME_MAX_QP}, >> + >> +   {P_FRAME_MAX_QP, ENC, HEVC, >> +       MIN_QP_10BIT, MAX_QP, 1, MAX_QP, >> +       V4L2_CID_MPEG_VIDEO_HEVC_P_FRAME_MAX_QP}, >> + >> +   {B_FRAME_MAX_QP, ENC, H264, >> +       MIN_QP_8BIT, MAX_QP, 1, MAX_QP, >> +       V4L2_CID_MPEG_VIDEO_H264_B_FRAME_MAX_QP}, >> + >> +   {B_FRAME_MAX_QP, ENC, HEVC, >> +       MIN_QP_10BIT, MAX_QP, 1, MAX_QP, >> +       V4L2_CID_MPEG_VIDEO_HEVC_B_FRAME_MAX_QP}, >> + >> +   {I_FRAME_QP, ENC, HEVC, >> +       MIN_QP_10BIT, MAX_QP, 1, DEFAULT_QP, >> +       V4L2_CID_MPEG_VIDEO_HEVC_I_FRAME_QP, >> +       HFI_PROP_QP_PACKED, >> +       CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT | >> +           CAP_FLAG_DYNAMIC_ALLOWED}, >> + >> +   {I_FRAME_QP, ENC, H264, >> +       MIN_QP_8BIT, MAX_QP, 1, DEFAULT_QP, >> +       V4L2_CID_MPEG_VIDEO_H264_I_FRAME_QP, >> +       HFI_PROP_QP_PACKED, >> +       CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT | >> +           CAP_FLAG_DYNAMIC_ALLOWED}, >> + >> +   {P_FRAME_QP, ENC, HEVC, >> +       MIN_QP_10BIT, MAX_QP, 1, DEFAULT_QP, >> +       V4L2_CID_MPEG_VIDEO_HEVC_P_FRAME_QP, >> +       HFI_PROP_QP_PACKED, >> +       CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT | >> +           CAP_FLAG_DYNAMIC_ALLOWED}, >> + >> +   {P_FRAME_QP, ENC, H264, >> +       MIN_QP_8BIT, MAX_QP, 1, DEFAULT_QP, >> +       V4L2_CID_MPEG_VIDEO_H264_P_FRAME_QP, >> +       HFI_PROP_QP_PACKED, >> +       CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT | >> +           CAP_FLAG_DYNAMIC_ALLOWED}, >> + >> +   {B_FRAME_QP, ENC, HEVC, >> +       MIN_QP_10BIT, MAX_QP, 1, DEFAULT_QP, >> +       V4L2_CID_MPEG_VIDEO_HEVC_B_FRAME_QP, >> +       HFI_PROP_QP_PACKED, >> +       CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT | >> +           CAP_FLAG_DYNAMIC_ALLOWED}, >> + >> +   {B_FRAME_QP, ENC, H264, >> +       MIN_QP_8BIT, MAX_QP, 1, DEFAULT_QP, >> +       V4L2_CID_MPEG_VIDEO_H264_B_FRAME_QP, >> +       HFI_PROP_QP_PACKED, >> +       CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT | >> +           CAP_FLAG_DYNAMIC_ALLOWED}, >> + >> +   {LAYER_TYPE, ENC, HEVC, >> +       V4L2_MPEG_VIDEO_HEVC_HIERARCHICAL_CODING_B, >> +       V4L2_MPEG_VIDEO_HEVC_HIERARCHICAL_CODING_P, >> +       BIT(V4L2_MPEG_VIDEO_HEVC_HIERARCHICAL_CODING_B) | >> +       BIT(V4L2_MPEG_VIDEO_HEVC_HIERARCHICAL_CODING_P), >> +       V4L2_MPEG_VIDEO_HEVC_HIERARCHICAL_CODING_P, >> +       V4L2_CID_MPEG_VIDEO_HEVC_HIER_CODING_TYPE, >> +       HFI_PROP_LAYER_ENCODING_TYPE, >> +       CAP_FLAG_OUTPUT_PORT | CAP_FLAG_MENU}, >> + >> +   {LAYER_TYPE, ENC, H264, >> +       V4L2_MPEG_VIDEO_H264_HIERARCHICAL_CODING_B, >> +       V4L2_MPEG_VIDEO_H264_HIERARCHICAL_CODING_P, >> +       BIT(V4L2_MPEG_VIDEO_H264_HIERARCHICAL_CODING_B) | >> +       BIT(V4L2_MPEG_VIDEO_H264_HIERARCHICAL_CODING_P), >> +       V4L2_MPEG_VIDEO_H264_HIERARCHICAL_CODING_P, >> +       V4L2_CID_MPEG_VIDEO_H264_HIERARCHICAL_CODING_TYPE, >> +       HFI_PROP_LAYER_ENCODING_TYPE, >> +       CAP_FLAG_OUTPUT_PORT | CAP_FLAG_MENU}, >> + >> +   {LAYER_ENABLE, ENC, H264, >> +       0, 1, 1, 0, >> +       V4L2_CID_MPEG_VIDEO_H264_HIERARCHICAL_CODING, >> +       HFI_PROP_LAYER_ENCODING_TYPE, >> +       CAP_FLAG_OUTPUT_PORT}, >> + >> +   {LAYER_ENABLE, ENC, HEVC, >> +       0, 1, 1, 0, >> +       0, >> +       0, >> +       CAP_FLAG_OUTPUT_PORT}, >> + >> +   {ENH_LAYER_COUNT, ENC, HEVC, >> +       0, 5, 1, 0, >> +       V4L2_CID_MPEG_VIDEO_HEVC_HIER_CODING_LAYER, >> +       HFI_PROP_LAYER_COUNT, >> +       CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT | >> +           CAP_FLAG_DYNAMIC_ALLOWED}, >> + >> +   {ENH_LAYER_COUNT, ENC, H264, >> +       0, 5, 1, 0, >> +       V4L2_CID_MPEG_VIDEO_H264_HIERARCHICAL_CODING_LAYER, >> +       HFI_PROP_LAYER_COUNT, >> +       CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT | >> +           CAP_FLAG_DYNAMIC_ALLOWED}, >> + >> +   {L0_BR, ENC, H264, >> +       1, MAX_BITRATE, 1, DEFAULT_BITRATE, >> +       V4L2_CID_MPEG_VIDEO_H264_HIER_CODING_L0_BR, >> +       HFI_PROP_BITRATE_LAYER1, >> +       CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT | >> +           CAP_FLAG_DYNAMIC_ALLOWED}, >> + >> +   {L0_BR, ENC, HEVC, >> +       1, MAX_BITRATE, 1, DEFAULT_BITRATE, >> +       V4L2_CID_MPEG_VIDEO_HEVC_HIER_CODING_L0_BR, >> +       HFI_PROP_BITRATE_LAYER1, >> +       CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT | >> +           CAP_FLAG_DYNAMIC_ALLOWED}, >> + >> +   {L1_BR, ENC, H264, >> +       1, MAX_BITRATE, 1, DEFAULT_BITRATE, >> +       V4L2_CID_MPEG_VIDEO_H264_HIER_CODING_L1_BR, >> +       HFI_PROP_BITRATE_LAYER2, >> +       CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT | >> +           CAP_FLAG_DYNAMIC_ALLOWED}, >> + >> +   {L1_BR, ENC, HEVC, >> +       1, MAX_BITRATE, 1, DEFAULT_BITRATE, >> +       V4L2_CID_MPEG_VIDEO_HEVC_HIER_CODING_L1_BR, >> +       HFI_PROP_BITRATE_LAYER2, >> +       CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT | >> +           CAP_FLAG_DYNAMIC_ALLOWED}, >> + >> +   {L2_BR, ENC, H264, >> +       1, MAX_BITRATE, 1, DEFAULT_BITRATE, >> +       V4L2_CID_MPEG_VIDEO_H264_HIER_CODING_L2_BR, >> +       HFI_PROP_BITRATE_LAYER3, >> +       CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT | >> +           CAP_FLAG_DYNAMIC_ALLOWED}, >> + >> +   {L2_BR, ENC, HEVC, >> +       1, MAX_BITRATE, 1, DEFAULT_BITRATE, >> +       V4L2_CID_MPEG_VIDEO_HEVC_HIER_CODING_L2_BR, >> +       HFI_PROP_BITRATE_LAYER3, >> +       CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT | >> +           CAP_FLAG_DYNAMIC_ALLOWED}, >> + >> +   {L3_BR, ENC, H264, >> +       1, MAX_BITRATE, 1, DEFAULT_BITRATE, >> +       V4L2_CID_MPEG_VIDEO_H264_HIER_CODING_L3_BR, >> +       HFI_PROP_BITRATE_LAYER4, >> +       CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT | >> +           CAP_FLAG_DYNAMIC_ALLOWED}, >> +   {L3_BR, ENC, HEVC, >> +       1, MAX_BITRATE, 1, DEFAULT_BITRATE, >> +       V4L2_CID_MPEG_VIDEO_HEVC_HIER_CODING_L3_BR, >> +       HFI_PROP_BITRATE_LAYER4, >> +       CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT | >> +           CAP_FLAG_DYNAMIC_ALLOWED}, >> + >> +   {L4_BR, ENC, H264, >> +       1, MAX_BITRATE, 1, DEFAULT_BITRATE, >> +       V4L2_CID_MPEG_VIDEO_H264_HIER_CODING_L4_BR, >> +       HFI_PROP_BITRATE_LAYER5, >> +       CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT | >> +           CAP_FLAG_DYNAMIC_ALLOWED}, >> + >> +   {L4_BR, ENC, HEVC, >> +       1, MAX_BITRATE, 1, DEFAULT_BITRATE, >> +       V4L2_CID_MPEG_VIDEO_HEVC_HIER_CODING_L4_BR, >> +       HFI_PROP_BITRATE_LAYER5, >> +       CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT | >> +           CAP_FLAG_DYNAMIC_ALLOWED}, >> + >> +   {L5_BR, ENC, H264, >> +       1, MAX_BITRATE, 1, DEFAULT_BITRATE, >> +       V4L2_CID_MPEG_VIDEO_H264_HIER_CODING_L5_BR, >> +       HFI_PROP_BITRATE_LAYER6, >> +       CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT | >> +           CAP_FLAG_DYNAMIC_ALLOWED}, >> + >> +   {L5_BR, ENC, HEVC, >> +       1, MAX_BITRATE, 1, DEFAULT_BITRATE, >> +       V4L2_CID_MPEG_VIDEO_HEVC_HIER_CODING_L5_BR, >> +       HFI_PROP_BITRATE_LAYER6, >> +       CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT | >> +           CAP_FLAG_DYNAMIC_ALLOWED}, >> + >> +   {ENTROPY_MODE, ENC, H264, >> +       V4L2_MPEG_VIDEO_H264_ENTROPY_MODE_CAVLC, >> +       V4L2_MPEG_VIDEO_H264_ENTROPY_MODE_CABAC, >> +       BIT(V4L2_MPEG_VIDEO_H264_ENTROPY_MODE_CAVLC) | >> +       BIT(V4L2_MPEG_VIDEO_H264_ENTROPY_MODE_CABAC), >> +       V4L2_MPEG_VIDEO_H264_ENTROPY_MODE_CABAC, >> +       V4L2_CID_MPEG_VIDEO_H264_ENTROPY_MODE, >> +       HFI_PROP_CABAC_SESSION, >> +       CAP_FLAG_OUTPUT_PORT | CAP_FLAG_MENU}, >> + >> +   {ENTROPY_MODE, DEC, H264 | HEVC | VP9, >> +       V4L2_MPEG_VIDEO_H264_ENTROPY_MODE_CAVLC, >> +       V4L2_MPEG_VIDEO_H264_ENTROPY_MODE_CABAC, >> +       BIT(V4L2_MPEG_VIDEO_H264_ENTROPY_MODE_CAVLC) | >> +       BIT(V4L2_MPEG_VIDEO_H264_ENTROPY_MODE_CABAC), >> +       V4L2_MPEG_VIDEO_H264_ENTROPY_MODE_CABAC, >> +       0, >> +       HFI_PROP_CABAC_SESSION}, >> + >> +   {PROFILE, ENC | DEC, H264, >> +       V4L2_MPEG_VIDEO_H264_PROFILE_BASELINE, >> +       V4L2_MPEG_VIDEO_H264_PROFILE_CONSTRAINED_HIGH, >> +       BIT(V4L2_MPEG_VIDEO_H264_PROFILE_BASELINE) | >> +       BIT(V4L2_MPEG_VIDEO_H264_PROFILE_CONSTRAINED_HIGH) | >> +       BIT(V4L2_MPEG_VIDEO_H264_PROFILE_CONSTRAINED_BASELINE) | >> +       BIT(V4L2_MPEG_VIDEO_H264_PROFILE_MAIN) | >> +       BIT(V4L2_MPEG_VIDEO_H264_PROFILE_HIGH), >> +       V4L2_MPEG_VIDEO_H264_PROFILE_HIGH, >> +       V4L2_CID_MPEG_VIDEO_H264_PROFILE, >> +       HFI_PROP_PROFILE, >> +       CAP_FLAG_OUTPUT_PORT | CAP_FLAG_MENU}, >> + >> +   {PROFILE, ENC | DEC, HEVC, >> +       V4L2_MPEG_VIDEO_HEVC_PROFILE_MAIN, >> +       V4L2_MPEG_VIDEO_HEVC_PROFILE_MAIN_10, >> +       BIT(V4L2_MPEG_VIDEO_HEVC_PROFILE_MAIN) | >> +       BIT(V4L2_MPEG_VIDEO_HEVC_PROFILE_MAIN_STILL_PICTURE) | >> +       BIT(V4L2_MPEG_VIDEO_HEVC_PROFILE_MAIN_10), >> +       V4L2_MPEG_VIDEO_HEVC_PROFILE_MAIN, >> +       V4L2_CID_MPEG_VIDEO_HEVC_PROFILE, >> +       HFI_PROP_PROFILE, >> +       CAP_FLAG_OUTPUT_PORT | CAP_FLAG_MENU}, >> + >> +   {PROFILE, DEC, VP9, >> +       V4L2_MPEG_VIDEO_VP9_PROFILE_0, >> +       V4L2_MPEG_VIDEO_VP9_PROFILE_2, >> +       BIT(V4L2_MPEG_VIDEO_VP9_PROFILE_0) | >> +       BIT(V4L2_MPEG_VIDEO_VP9_PROFILE_2), >> +       V4L2_MPEG_VIDEO_VP9_PROFILE_0, >> +       V4L2_CID_MPEG_VIDEO_VP9_PROFILE, >> +       HFI_PROP_PROFILE, >> +       CAP_FLAG_OUTPUT_PORT | CAP_FLAG_MENU}, >> + >> +   {LEVEL, ENC, H264, >> +       V4L2_MPEG_VIDEO_H264_LEVEL_1_0, >> +       V4L2_MPEG_VIDEO_H264_LEVEL_6_0, >> +       BIT(V4L2_MPEG_VIDEO_H264_LEVEL_1_0) | >> +       BIT(V4L2_MPEG_VIDEO_H264_LEVEL_1B) | >> +       BIT(V4L2_MPEG_VIDEO_H264_LEVEL_1_1) | >> +       BIT(V4L2_MPEG_VIDEO_H264_LEVEL_1_2) | >> +       BIT(V4L2_MPEG_VIDEO_H264_LEVEL_1_3) | >> +       BIT(V4L2_MPEG_VIDEO_H264_LEVEL_2_0) | >> +       BIT(V4L2_MPEG_VIDEO_H264_LEVEL_2_1) | >> +       BIT(V4L2_MPEG_VIDEO_H264_LEVEL_2_2) | >> +       BIT(V4L2_MPEG_VIDEO_H264_LEVEL_3_0) | >> +       BIT(V4L2_MPEG_VIDEO_H264_LEVEL_3_1) | >> +       BIT(V4L2_MPEG_VIDEO_H264_LEVEL_3_2) | >> +       BIT(V4L2_MPEG_VIDEO_H264_LEVEL_4_0) | >> +       BIT(V4L2_MPEG_VIDEO_H264_LEVEL_4_1) | >> +       BIT(V4L2_MPEG_VIDEO_H264_LEVEL_4_2) | >> +       BIT(V4L2_MPEG_VIDEO_H264_LEVEL_5_0) | >> +       BIT(V4L2_MPEG_VIDEO_H264_LEVEL_5_1) | >> +       BIT(V4L2_MPEG_VIDEO_H264_LEVEL_5_2) | >> +       BIT(V4L2_MPEG_VIDEO_H264_LEVEL_6_0), >> +       V4L2_MPEG_VIDEO_H264_LEVEL_5_0, >> +       V4L2_CID_MPEG_VIDEO_H264_LEVEL, >> +       HFI_PROP_LEVEL, >> +       CAP_FLAG_OUTPUT_PORT | CAP_FLAG_MENU}, >> + >> +   {LEVEL, ENC, HEVC, >> +       V4L2_MPEG_VIDEO_HEVC_LEVEL_1, >> +       V4L2_MPEG_VIDEO_HEVC_LEVEL_6_2, >> +       BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_1) | >> +       BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_2) | >> +       BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_2_1) | >> +       BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_3) | >> +       BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_3_1) | >> +       BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_4) | >> +       BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_4_1) | >> +       BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_5) | >> +       BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_5_1) | >> +       BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_5_2) | >> +       BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_6) | >> +       BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_6_1) | >> +       BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_6_2), >> +       V4L2_MPEG_VIDEO_HEVC_LEVEL_5, >> +       V4L2_CID_MPEG_VIDEO_HEVC_LEVEL, >> +       HFI_PROP_LEVEL, >> +       CAP_FLAG_OUTPUT_PORT | CAP_FLAG_MENU}, >> + >> +   {LEVEL, DEC, H264, >> +       V4L2_MPEG_VIDEO_H264_LEVEL_1_0, >> +       V4L2_MPEG_VIDEO_H264_LEVEL_6_2, >> +       BIT(V4L2_MPEG_VIDEO_H264_LEVEL_1_0) | >> +       BIT(V4L2_MPEG_VIDEO_H264_LEVEL_1B) | >> +       BIT(V4L2_MPEG_VIDEO_H264_LEVEL_1_1) | >> +       BIT(V4L2_MPEG_VIDEO_H264_LEVEL_1_2) | >> +       BIT(V4L2_MPEG_VIDEO_H264_LEVEL_1_3) | >> +       BIT(V4L2_MPEG_VIDEO_H264_LEVEL_2_0) | >> +       BIT(V4L2_MPEG_VIDEO_H264_LEVEL_2_1) | >> +       BIT(V4L2_MPEG_VIDEO_H264_LEVEL_2_2) | >> +       BIT(V4L2_MPEG_VIDEO_H264_LEVEL_3_0) | >> +       BIT(V4L2_MPEG_VIDEO_H264_LEVEL_3_1) | >> +       BIT(V4L2_MPEG_VIDEO_H264_LEVEL_3_2) | >> +       BIT(V4L2_MPEG_VIDEO_H264_LEVEL_4_0) | >> +       BIT(V4L2_MPEG_VIDEO_H264_LEVEL_4_1) | >> +       BIT(V4L2_MPEG_VIDEO_H264_LEVEL_4_2) | >> +       BIT(V4L2_MPEG_VIDEO_H264_LEVEL_5_0) | >> +       BIT(V4L2_MPEG_VIDEO_H264_LEVEL_5_1) | >> +       BIT(V4L2_MPEG_VIDEO_H264_LEVEL_5_2) | >> +       BIT(V4L2_MPEG_VIDEO_H264_LEVEL_6_0) | >> +       BIT(V4L2_MPEG_VIDEO_H264_LEVEL_6_1) | >> +       BIT(V4L2_MPEG_VIDEO_H264_LEVEL_6_2), >> +       V4L2_MPEG_VIDEO_H264_LEVEL_6_1, >> +       V4L2_CID_MPEG_VIDEO_H264_LEVEL, >> +       HFI_PROP_LEVEL, >> +       CAP_FLAG_OUTPUT_PORT | CAP_FLAG_MENU}, >> + >> +   {LEVEL, DEC, HEVC, >> +       V4L2_MPEG_VIDEO_HEVC_LEVEL_1, >> +       V4L2_MPEG_VIDEO_HEVC_LEVEL_6_2, >> +       BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_1) | >> +       BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_2) | >> +       BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_2_1) | >> +       BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_3) | >> +       BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_3_1) | >> +       BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_4) | >> +       BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_4_1) | >> +       BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_5) | >> +       BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_5_1) | >> +       BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_5_2) | >> +       BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_6) | >> +       BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_6_1) | >> +       BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_6_2), >> +       V4L2_MPEG_VIDEO_HEVC_LEVEL_6_1, >> +       V4L2_CID_MPEG_VIDEO_HEVC_LEVEL, >> +       HFI_PROP_LEVEL, >> +       CAP_FLAG_OUTPUT_PORT | CAP_FLAG_MENU}, >> + >> +   {LEVEL, DEC, VP9, >> +       V4L2_MPEG_VIDEO_VP9_LEVEL_1_0, >> +       V4L2_MPEG_VIDEO_VP9_LEVEL_6_0, >> +       BIT(V4L2_MPEG_VIDEO_VP9_LEVEL_1_0) | >> +       BIT(V4L2_MPEG_VIDEO_VP9_LEVEL_1_1) | >> +       BIT(V4L2_MPEG_VIDEO_VP9_LEVEL_2_0) | >> +       BIT(V4L2_MPEG_VIDEO_VP9_LEVEL_2_1) | >> +       BIT(V4L2_MPEG_VIDEO_VP9_LEVEL_3_0) | >> +       BIT(V4L2_MPEG_VIDEO_VP9_LEVEL_3_1) | >> +       BIT(V4L2_MPEG_VIDEO_VP9_LEVEL_4_0) | >> +       BIT(V4L2_MPEG_VIDEO_VP9_LEVEL_4_1) | >> +       BIT(V4L2_MPEG_VIDEO_VP9_LEVEL_5_0) | >> +       BIT(V4L2_MPEG_VIDEO_VP9_LEVEL_5_1) | >> +       BIT(V4L2_MPEG_VIDEO_VP9_LEVEL_5_2) | >> +       BIT(V4L2_MPEG_VIDEO_VP9_LEVEL_6_0), >> +       V4L2_MPEG_VIDEO_VP9_LEVEL_6_0, >> +       V4L2_CID_MPEG_VIDEO_VP9_LEVEL, >> +       HFI_PROP_LEVEL, >> +       CAP_FLAG_OUTPUT_PORT | CAP_FLAG_MENU}, >> + >> +   {HEVC_TIER, ENC | DEC, HEVC, >> +       V4L2_MPEG_VIDEO_HEVC_TIER_MAIN, >> +       V4L2_MPEG_VIDEO_HEVC_TIER_HIGH, >> +       BIT(V4L2_MPEG_VIDEO_HEVC_TIER_MAIN) | >> +       BIT(V4L2_MPEG_VIDEO_HEVC_TIER_HIGH), >> +       V4L2_MPEG_VIDEO_HEVC_TIER_HIGH, >> +       V4L2_CID_MPEG_VIDEO_HEVC_TIER, >> +       HFI_PROP_TIER, >> +       CAP_FLAG_OUTPUT_PORT | CAP_FLAG_MENU}, >> + >> +   {LF_MODE, ENC, H264, >> +       V4L2_MPEG_VIDEO_H264_LOOP_FILTER_MODE_ENABLED, >> +       DB_H264_DISABLE_SLICE_BOUNDARY, >> +       BIT(V4L2_MPEG_VIDEO_H264_LOOP_FILTER_MODE_ENABLED) | >> +       BIT(V4L2_MPEG_VIDEO_H264_LOOP_FILTER_MODE_DISABLED) | >> +       BIT(DB_H264_DISABLE_SLICE_BOUNDARY), >> +       V4L2_MPEG_VIDEO_H264_LOOP_FILTER_MODE_ENABLED, >> +       V4L2_CID_MPEG_VIDEO_H264_LOOP_FILTER_MODE, >> +       HFI_PROP_DEBLOCKING_MODE, >> +       CAP_FLAG_OUTPUT_PORT | CAP_FLAG_MENU}, >> + >> +   {LF_MODE, ENC, HEVC, >> +       V4L2_MPEG_VIDEO_HEVC_LOOP_FILTER_MODE_DISABLED, >> +       DB_HEVC_DISABLE_SLICE_BOUNDARY, >> +       BIT(V4L2_MPEG_VIDEO_HEVC_LOOP_FILTER_MODE_DISABLED) | >> +       BIT(V4L2_MPEG_VIDEO_HEVC_LOOP_FILTER_MODE_ENABLED) | >> +       BIT(DB_HEVC_DISABLE_SLICE_BOUNDARY), >> +       V4L2_MPEG_VIDEO_HEVC_LOOP_FILTER_MODE_ENABLED, >> +       V4L2_CID_MPEG_VIDEO_HEVC_LOOP_FILTER_MODE, >> +       HFI_PROP_DEBLOCKING_MODE, >> +       CAP_FLAG_OUTPUT_PORT | CAP_FLAG_MENU}, >> + >> +   {LF_ALPHA, ENC, H264, >> +       -6, 6, 1, 0, >> +       V4L2_CID_MPEG_VIDEO_H264_LOOP_FILTER_ALPHA}, >> + >> +   {LF_ALPHA, ENC, HEVC, >> +       -6, 6, 1, 0, >> +       V4L2_CID_MPEG_VIDEO_HEVC_LF_TC_OFFSET_DIV2}, >> + >> +   {LF_BETA, ENC, H264, >> +       -6, 6, 1, 0, >> +       V4L2_CID_MPEG_VIDEO_H264_LOOP_FILTER_BETA}, >> + >> +   {LF_BETA, ENC, HEVC, >> +       -6, 6, 1, 0, >> +       V4L2_CID_MPEG_VIDEO_HEVC_LF_BETA_OFFSET_DIV2}, >> + >> +   {SLICE_MODE, ENC, H264 | HEVC, >> +       V4L2_MPEG_VIDEO_MULTI_SLICE_MODE_SINGLE, >> +       V4L2_MPEG_VIDEO_MULTI_SLICE_MODE_MAX_BYTES, >> +       BIT(V4L2_MPEG_VIDEO_MULTI_SLICE_MODE_SINGLE) | >> +       BIT(V4L2_MPEG_VIDEO_MULTI_SLICE_MODE_MAX_MB) | >> +       BIT(V4L2_MPEG_VIDEO_MULTI_SLICE_MODE_MAX_BYTES), >> +       V4L2_MPEG_VIDEO_MULTI_SLICE_MODE_SINGLE, >> +       V4L2_CID_MPEG_VIDEO_MULTI_SLICE_MODE, >> +       0, >> +       CAP_FLAG_OUTPUT_PORT | CAP_FLAG_MENU}, >> + >> +   {SLICE_MAX_BYTES, ENC, H264 | HEVC, >> +       MIN_SLICE_BYTE_SIZE, MAX_SLICE_BYTE_SIZE, >> +       1, MIN_SLICE_BYTE_SIZE, >> +       V4L2_CID_MPEG_VIDEO_MULTI_SLICE_MAX_BYTES, >> +       HFI_PROP_MULTI_SLICE_BYTES_COUNT, >> +       CAP_FLAG_OUTPUT_PORT}, >> + >> +   {SLICE_MAX_MB, ENC, H264 | HEVC, >> +       1, MAX_SLICE_MB_SIZE, 1, 1, >> +       V4L2_CID_MPEG_VIDEO_MULTI_SLICE_MAX_MB, >> +       HFI_PROP_MULTI_SLICE_MB_COUNT, >> +       CAP_FLAG_OUTPUT_PORT}, >> + >> +   {MB_RC, ENC, H264 | HEVC, >> +       0, 1, 1, 1, >> +       V4L2_CID_MPEG_VIDEO_MB_RC_ENABLE, >> +       0, >> +       CAP_FLAG_OUTPUT_PORT}, >> + >> +   {TRANSFORM_8X8, ENC, H264, >> +       0, 1, 1, 1, >> +       V4L2_CID_MPEG_VIDEO_H264_8X8_TRANSFORM, >> +       HFI_PROP_8X8_TRANSFORM, >> +       CAP_FLAG_OUTPUT_PORT}, >> + >> +   {CHROMA_QP_INDEX_OFFSET, ENC, HEVC, >> +       MIN_CHROMA_QP_OFFSET, MAX_CHROMA_QP_OFFSET, >> +       1, MAX_CHROMA_QP_OFFSET, >> +       V4L2_CID_MPEG_VIDEO_H264_CHROMA_QP_INDEX_OFFSET, >> +       HFI_PROP_CHROMA_QP_OFFSET, >> +       CAP_FLAG_OUTPUT_PORT}, >> + >> +   {DISPLAY_DELAY_ENABLE, DEC, H264 | HEVC | VP9, >> +       0, 1, 1, 0, >> +       V4L2_CID_MPEG_VIDEO_DEC_DISPLAY_DELAY_ENABLE, >> +       HFI_PROP_DECODE_ORDER_OUTPUT, >> +       CAP_FLAG_INPUT_PORT}, >> + >> +   {DISPLAY_DELAY, DEC, H264 | HEVC | VP9, >> +       0, 1, 1, 0, >> +       V4L2_CID_MPEG_VIDEO_DEC_DISPLAY_DELAY, >> +       HFI_PROP_DECODE_ORDER_OUTPUT, >> +       CAP_FLAG_INPUT_PORT}, >> + >> +   {OUTPUT_ORDER, DEC, H264 | HEVC | VP9, >> +       0, 1, 1, 0, >> +       0, >> +       HFI_PROP_DECODE_ORDER_OUTPUT, >> +       CAP_FLAG_INPUT_PORT}, >> + >> +   {INPUT_BUF_HOST_MAX_COUNT, ENC | DEC, CODECS_ALL, >> +       DEFAULT_MAX_HOST_BUF_COUNT, DEFAULT_MAX_HOST_BURST_BUF_COUNT, >> +       1, DEFAULT_MAX_HOST_BUF_COUNT, >> +       0, >> +       HFI_PROP_BUFFER_HOST_MAX_COUNT, >> +       CAP_FLAG_INPUT_PORT}, >> + >> +   {OUTPUT_BUF_HOST_MAX_COUNT, ENC | DEC, CODECS_ALL, >> +       DEFAULT_MAX_HOST_BUF_COUNT, DEFAULT_MAX_HOST_BURST_BUF_COUNT, >> +       1, DEFAULT_MAX_HOST_BUF_COUNT, >> +       0, >> +       HFI_PROP_BUFFER_HOST_MAX_COUNT, >> +       CAP_FLAG_OUTPUT_PORT}, >> + >> +   {CONCEAL_COLOR_8BIT, DEC, CODECS_ALL, 0x0, 0xff3fcff, 1, >> +       DEFAULT_VIDEO_CONCEAL_COLOR_BLACK, >> +       V4L2_CID_MPEG_VIDEO_MUTE_YUV, >> +       HFI_PROP_CONCEAL_COLOR_8BIT, >> +       CAP_FLAG_INPUT_PORT}, >> + >> +   {CONCEAL_COLOR_10BIT, DEC, CODECS_ALL, 0x0, 0x3fffffff, 1, >> +       DEFAULT_VIDEO_CONCEAL_COLOR_BLACK, >> +       V4L2_CID_MPEG_VIDEO_MUTE_YUV, >> +       HFI_PROP_CONCEAL_COLOR_10BIT, >> +       CAP_FLAG_INPUT_PORT}, >> + >> +   {STAGE, DEC | ENC, CODECS_ALL, >> +       MSM_VIDC_STAGE_1, >> +       MSM_VIDC_STAGE_2, 1, >> +       MSM_VIDC_STAGE_2, >> +       0, >> +       HFI_PROP_STAGE}, >> + >> +   {PIPE, DEC | ENC, CODECS_ALL, >> +       MSM_VIDC_PIPE_1, >> +       MSM_VIDC_PIPE_4, 1, >> +       MSM_VIDC_PIPE_4, >> +       0, >> +       HFI_PROP_PIPE}, >> + >> +   {POC, DEC, H264, 0, 2, 1, 1, >> +       0, >> +       HFI_PROP_PIC_ORDER_CNT_TYPE}, >> + >> +   {QUALITY_MODE, ENC, CODECS_ALL, >> +       MSM_VIDC_MAX_QUALITY_MODE, >> +       MSM_VIDC_POWER_SAVE_MODE, 1, >> +       MSM_VIDC_POWER_SAVE_MODE}, >> + >> +   {CODED_FRAMES, DEC, H264 | HEVC, >> +       CODED_FRAMES_PROGRESSIVE, CODED_FRAMES_INTERLACE, >> +       1, CODED_FRAMES_PROGRESSIVE, >> +       0, >> +       HFI_PROP_CODED_FRAMES}, >> + >> +   {BIT_DEPTH, DEC, CODECS_ALL, BIT_DEPTH_8, BIT_DEPTH_10, 1, BIT_DEPTH_8, >> +       0, >> +       HFI_PROP_LUMA_CHROMA_BIT_DEPTH}, >> + >> +   {BITSTREAM_SIZE_OVERWRITE, DEC, CODECS_ALL, 0, INT_MAX, 1, 0, >> +       0}, >> + >> +   {DEFAULT_HEADER, DEC, CODECS_ALL, >> +       0, 1, 1, 0, >> +       0, >> +       HFI_PROP_DEC_DEFAULT_HEADER}, >> + >> +   {RAP_FRAME, DEC, CODECS_ALL, >> +       0, 1, 1, 1, >> +       0, >> +       HFI_PROP_DEC_START_FROM_RAP_FRAME, >> +       CAP_FLAG_INPUT_PORT}, >> + >> +   {SEQ_CHANGE_AT_SYNC_FRAME, DEC, CODECS_ALL, >> +       0, 1, 1, 1, >> +       0, >> +       HFI_PROP_SEQ_CHANGE_AT_SYNC_FRAME, >> +       CAP_FLAG_INPUT_PORT | CAP_FLAG_DYNAMIC_ALLOWED}, >> + >> +   {ALL_INTRA, ENC, H264 | HEVC, >> +       0, 1, 1, 0, >> +       0, >> +       0, >> +       CAP_FLAG_OUTPUT_PORT}, >> +}; >> + >> +static struct msm_platform_inst_cap_dependency >> instance_cap_dependency_data_sm8550[] = { >> +   /* {cap, domain, codec, >> +    *     children, >> +    *     adjust, set} >> +    */ >> + >> +   {PIX_FMTS, ENC, H264, >> +       {IR_PERIOD}}, >> + >> +   {PIX_FMTS, ENC, HEVC, >> +       {PROFILE, MIN_FRAME_QP, MAX_FRAME_QP, I_FRAME_QP, P_FRAME_QP, >> +           B_FRAME_QP, MIN_QUALITY, IR_PERIOD, LTR_COUNT}}, >> + >> +   {PIX_FMTS, DEC, HEVC, >> +       {PROFILE}}, >> + >> +   {FRAME_RATE, ENC, CODECS_ALL, >> +       {0}, >> +       NULL, >> +       msm_vidc_set_q16}, >> + >> +   {HFLIP, ENC, CODECS_ALL, >> +       {0}, >> +       NULL, >> +       msm_vidc_set_flip}, >> + >> +   {VFLIP, ENC, CODECS_ALL, >> +       {0}, >> +       NULL, >> +       msm_vidc_set_flip}, >> + >> +   {ROTATION, ENC, CODECS_ALL, >> +       {0}, >> +       NULL, >> +       msm_vidc_set_rotation}, >> + >> +   {HEADER_MODE, ENC, CODECS_ALL, >> +       {0}, >> +       NULL, >> +       msm_vidc_set_header_mode}, >> + >> +   {WITHOUT_STARTCODE, ENC, CODECS_ALL, >> +       {0}, >> +       NULL, >> +       msm_vidc_set_nal_length}, >> + >> +   {REQUEST_I_FRAME, ENC, H264 | HEVC, >> +       {0}, >> +       NULL, >> +       msm_vidc_set_req_sync_frame}, >> + >> +   {BIT_RATE, ENC, H264, >> +       {PEAK_BITRATE, L0_BR}, >> +       msm_vidc_adjust_bitrate, >> +       msm_vidc_set_bitrate}, >> + >> +   {BIT_RATE, ENC, HEVC, >> +       {PEAK_BITRATE, L0_BR}, >> +       msm_vidc_adjust_bitrate, >> +       msm_vidc_set_bitrate}, >> + >> +   {BITRATE_MODE, ENC, H264, >> +       {LTR_COUNT, IR_PERIOD, I_FRAME_QP, P_FRAME_QP, >> +           B_FRAME_QP, ENH_LAYER_COUNT, BIT_RATE, >> +           MIN_QUALITY, VBV_DELAY, >> +           PEAK_BITRATE, SLICE_MODE}, >> +       msm_vidc_adjust_bitrate_mode, >> +       msm_vidc_set_u32_enum}, >> + >> +   {BITRATE_MODE, ENC, HEVC, >> +       {LTR_COUNT, IR_PERIOD, I_FRAME_QP, P_FRAME_QP, >> +           B_FRAME_QP, CONSTANT_QUALITY, ENH_LAYER_COUNT, >> +           BIT_RATE, MIN_QUALITY, VBV_DELAY, >> +           PEAK_BITRATE, SLICE_MODE}, >> +       msm_vidc_adjust_bitrate_mode, >> +       msm_vidc_set_u32_enum}, >> + >> +   {CONSTANT_QUALITY, ENC, HEVC, >> +       {0}, >> +       NULL, >> +       msm_vidc_set_constant_quality}, >> + >> +   {GOP_SIZE, ENC, CODECS_ALL, >> +       {ALL_INTRA}, >> +       msm_vidc_adjust_gop_size, >> +       msm_vidc_set_gop_size}, >> + >> +   {B_FRAME, ENC, H264 | HEVC, >> +       {ALL_INTRA}, >> +       msm_vidc_adjust_b_frame, >> +       msm_vidc_set_u32}, >> + >> +   {LTR_COUNT, ENC, H264 | HEVC, >> +       {0}, >> +       msm_vidc_adjust_ltr_count, >> +       msm_vidc_set_u32}, >> + >> +   {USE_LTR, ENC, H264 | HEVC, >> +       {0}, >> +       msm_vidc_adjust_use_ltr, >> +       msm_vidc_set_use_and_mark_ltr}, >> + >> +   {MARK_LTR, ENC, H264 | HEVC, >> +       {0}, >> +       msm_vidc_adjust_mark_ltr, >> +       msm_vidc_set_use_and_mark_ltr}, >> + >> +   {IR_PERIOD, ENC, H264 | HEVC, >> +       {0}, >> +       msm_vidc_adjust_ir_period, >> +       msm_vidc_set_ir_period}, >> + >> +   {AU_DELIMITER, ENC, H264 | HEVC, >> +       {0}, >> +       NULL, >> +       msm_vidc_set_u32}, >> + >> +   {MIN_QUALITY, ENC, H264, >> +       {0}, >> +       msm_vidc_adjust_min_quality, >> +       msm_vidc_set_u32}, >> + >> +   {MIN_QUALITY, ENC, HEVC, >> +       {0}, >> +       msm_vidc_adjust_min_quality, >> +       msm_vidc_set_u32}, >> + >> +   {VBV_DELAY, ENC, H264 | HEVC, >> +       {0}, >> +       NULL, >> +       msm_vidc_set_cbr_related_properties}, >> + >> +   {PEAK_BITRATE, ENC, H264 | HEVC, >> +       {0}, >> +       msm_vidc_adjust_peak_bitrate, >> +       msm_vidc_set_cbr_related_properties}, >> + >> +   {MIN_FRAME_QP, ENC, H264, >> +       {0}, >> +       NULL, >> +       msm_vidc_set_min_qp}, >> + >> +   {MIN_FRAME_QP, ENC, HEVC, >> +       {0}, >> +       msm_vidc_adjust_hevc_min_qp, >> +       msm_vidc_set_min_qp}, >> + >> +   {MAX_FRAME_QP, ENC, H264, >> +       {0}, >> +       NULL, >> +       msm_vidc_set_max_qp}, >> + >> +   {MAX_FRAME_QP, ENC, HEVC, >> +       {0}, >> +       msm_vidc_adjust_hevc_max_qp, >> +       msm_vidc_set_max_qp}, >> + >> +   {I_FRAME_QP, ENC, HEVC, >> +       {0}, >> +       msm_vidc_adjust_hevc_i_frame_qp, >> +       msm_vidc_set_frame_qp}, >> + >> +   {I_FRAME_QP, ENC, H264, >> +       {0}, >> +       NULL, >> +       msm_vidc_set_frame_qp}, >> + >> +   {P_FRAME_QP, ENC, HEVC, >> +       {0}, >> +       msm_vidc_adjust_hevc_p_frame_qp, >> +       msm_vidc_set_frame_qp}, >> + >> +   {P_FRAME_QP, ENC, H264, >> +       {0}, >> +       NULL, >> +       msm_vidc_set_frame_qp}, >> + >> +   {B_FRAME_QP, ENC, HEVC, >> +       {0}, >> +       msm_vidc_adjust_hevc_b_frame_qp, >> +       msm_vidc_set_frame_qp}, >> + >> +   {B_FRAME_QP, ENC, H264, >> +       {0}, >> +       NULL, >> +       msm_vidc_set_frame_qp}, >> + >> +   {LAYER_TYPE, ENC, H264 | HEVC, >> +       {LTR_COUNT}}, >> + >> +   {LAYER_ENABLE, ENC, H264 | HEVC, >> +       {0}}, >> + >> +   {ENH_LAYER_COUNT, ENC, H264 | HEVC, >> +       {GOP_SIZE, B_FRAME, BIT_RATE, MIN_QUALITY, SLICE_MODE, >> +           LTR_COUNT}, >> +       msm_vidc_adjust_layer_count, >> +       msm_vidc_set_layer_count_and_type}, >> + >> +   {L0_BR, ENC, H264 | HEVC, >> +       {L1_BR}, >> +       msm_vidc_adjust_layer_bitrate, >> +       msm_vidc_set_layer_bitrate}, >> + >> +   {L1_BR, ENC, H264 | HEVC, >> +       {L2_BR}, >> +       msm_vidc_adjust_layer_bitrate, >> +       msm_vidc_set_layer_bitrate}, >> + >> +   {L2_BR, ENC, H264 | HEVC, >> +       {L3_BR}, >> +       msm_vidc_adjust_layer_bitrate, >> +       msm_vidc_set_layer_bitrate}, >> + >> +   {L3_BR, ENC, H264 | HEVC, >> +       {L4_BR}, >> +       msm_vidc_adjust_layer_bitrate, >> +       msm_vidc_set_layer_bitrate}, >> + >> +   {L4_BR, ENC, H264 | HEVC, >> +       {L5_BR}, >> +       msm_vidc_adjust_layer_bitrate, >> +       msm_vidc_set_layer_bitrate}, >> + >> +   {L5_BR, ENC, H264 | HEVC, >> +       {0}, >> +       msm_vidc_adjust_layer_bitrate, >> +       msm_vidc_set_layer_bitrate}, >> + >> +   {ENTROPY_MODE, ENC, H264, >> +       {BIT_RATE}, >> +       msm_vidc_adjust_entropy_mode, >> +       msm_vidc_set_u32}, >> + >> +   {PROFILE, ENC, H264, >> +       {ENTROPY_MODE, TRANSFORM_8X8}, >> +       NULL, >> +       msm_vidc_set_u32_enum}, >> + >> +   {PROFILE, DEC, H264, >> +       {ENTROPY_MODE}, >> +       NULL, >> +       msm_vidc_set_u32_enum}, >> + >> +   {PROFILE, ENC | DEC, HEVC, >> +       {0}, >> +       msm_vidc_adjust_profile, >> +       msm_vidc_set_u32_enum}, >> + >> +   {PROFILE, DEC, VP9, >> +       {0}, >> +       NULL, >> +       msm_vidc_set_u32_enum}, >> + >> +   {LEVEL, DEC, CODECS_ALL, >> +       {0}, >> +       NULL, >> +       msm_vidc_set_u32_enum}, >> + >> +   {LEVEL, ENC, CODECS_ALL, >> +       {0}, >> +       NULL, >> +       msm_vidc_set_level}, >> + >> +   {HEVC_TIER, ENC | DEC, HEVC, >> +       {0}, >> +       NULL, >> +       msm_vidc_set_u32_enum}, >> + >> +   {LF_MODE, ENC, CODECS_ALL, >> +       {0}, >> +       NULL, >> +       msm_vidc_set_deblock_mode}, >> + >> +   {SLICE_MODE, ENC, H264 | HEVC, >> +       {STAGE}, >> +       msm_vidc_adjust_slice_count, >> +       msm_vidc_set_slice_count}, >> + >> +   {TRANSFORM_8X8, ENC, H264, >> +       {0}, >> +       msm_vidc_adjust_transform_8x8, >> +       msm_vidc_set_u32}, >> + >> +   {CHROMA_QP_INDEX_OFFSET, ENC, HEVC, >> +       {0}, >> +       msm_vidc_adjust_chroma_qp_index_offset, >> +       msm_vidc_set_chroma_qp_index_offset}, >> + >> +   {DISPLAY_DELAY_ENABLE, DEC, H264 | HEVC | VP9, >> +       {OUTPUT_ORDER}, >> +       NULL, >> +       NULL}, >> + >> +   {DISPLAY_DELAY, DEC, H264 | HEVC | VP9, >> +       {OUTPUT_ORDER}, >> +       NULL, >> +       NULL}, >> + >> +   {OUTPUT_ORDER, DEC, H264 | HEVC | VP9, >> +       {0}, >> +       msm_vidc_adjust_output_order, >> +       msm_vidc_set_u32}, >> + >> +   {INPUT_BUF_HOST_MAX_COUNT, ENC | DEC, CODECS_ALL, >> +       {0}, >> +       msm_vidc_adjust_input_buf_host_max_count, >> +       msm_vidc_set_u32}, >> + >> +   {INPUT_BUF_HOST_MAX_COUNT, ENC, H264 | HEVC, >> +       {0}, >> +       msm_vidc_adjust_input_buf_host_max_count, >> +       msm_vidc_set_u32}, >> + >> +   {OUTPUT_BUF_HOST_MAX_COUNT, ENC | DEC, CODECS_ALL, >> +       {0}, >> +       msm_vidc_adjust_output_buf_host_max_count, >> +       msm_vidc_set_u32}, >> + >> +   {OUTPUT_BUF_HOST_MAX_COUNT, ENC, H264 | HEVC, >> +       {0}, >> +       msm_vidc_adjust_output_buf_host_max_count, >> +       msm_vidc_set_u32}, >> + >> +   {CONCEAL_COLOR_8BIT, DEC, CODECS_ALL, >> +       {0}, >> +       NULL, >> +       msm_vidc_set_u32_packed}, >> + >> +   {CONCEAL_COLOR_10BIT, DEC, CODECS_ALL, >> +       {0}, >> +       NULL, >> +       msm_vidc_set_u32_packed}, >> + >> +   {STAGE, ENC | DEC, CODECS_ALL, >> +       {0}, >> +       NULL, >> +       msm_vidc_set_stage}, >> + >> +   {STAGE, ENC, H264 | HEVC, >> +       {0}, >> +       NULL, >> +       msm_vidc_set_stage}, >> + >> +   {STAGE, DEC, H264 | HEVC | VP9, >> +       {0}, >> +       NULL, >> +       msm_vidc_set_stage}, >> + >> +   {PIPE, DEC | ENC, CODECS_ALL, >> +       {0}, >> +       NULL, >> +       msm_vidc_set_pipe}, >> + >> +   {RAP_FRAME, DEC, CODECS_ALL, >> +       {0}, >> +       NULL, >> +       msm_vidc_set_u32}, >> + >> +   {ALL_INTRA, ENC, H264 | HEVC, >> +       {LTR_COUNT, IR_PERIOD, SLICE_MODE, BIT_RATE}, >> +       msm_vidc_adjust_all_intra, >> +       NULL}, >> +}; >> + >> +/* Default UBWC config for LPDDR5 */ >> +static struct msm_vidc_ubwc_config_data ubwc_config_sm8550[] = { >> +   UBWC_CONFIG(8, 32, 16, 0, 1, 1, 1), >> +}; >> + >> +static struct msm_vidc_format_capability format_data_sm8550 = { >> +   .codec_info = codec_data_sm8550, >> +   .codec_info_size = ARRAY_SIZE(codec_data_sm8550), >> +   .color_format_info = color_format_data_sm8550, >> +   .color_format_info_size = ARRAY_SIZE(color_format_data_sm8550), >> +   .color_prim_info = color_primaries_data_sm8550, >> +   .color_prim_info_size = ARRAY_SIZE(color_primaries_data_sm8550), >> +   .transfer_char_info = transfer_char_data_sm8550, >> +   .transfer_char_info_size = ARRAY_SIZE(transfer_char_data_sm8550), >> +   .matrix_coeff_info = matrix_coeff_data_sm8550, >> +   .matrix_coeff_info_size = ARRAY_SIZE(matrix_coeff_data_sm8550), >> +}; >> + >> +/* name, min_kbps, max_kbps */ >> +static const struct bw_table sm8550_bw_table[] = { >> +   { "venus-cnoc", 1000, 1000    }, >> +   { "venus-ddr",  1000, 15000000 }, > > We have OPP tables for that. There is no need to limit the min/max, just > put it to OPP. > This table is used to vote for min and max bus bandwidth. for some test vector with bad picture order count, ref count can be huge, so DPB needs to be filled with high number of reference frames to process current frames, this needs faster frame processing so to address such cases, driver vote for max bus bandwidth. for some cases, when system is in suspend state, there might be some residual transitions happening for which driver needs to vote for min frequency during suspend state. >> +}; >> + >> +/* name */ >> +static const struct pd_table sm8550_pd_table[] = { >> +   { "iris-ctl" }, >> +   { "vcodec"  }, >> +}; >> + >> +/* name */ >> +static const char * const sm8550_opp_table[] = { "mx", "mmcx", NULL }; >> + >> +/* name, clock id, scaling */ >> +static const struct clk_table sm8550_clk_table[] = { >> +   { "gcc_video_axi0",        GCC_VIDEO_AXI0_CLK,    0 }, >> +   { "core_clk",              VIDEO_CC_MVS0C_CLK,    0 }, >> +   { "vcodec_clk",            VIDEO_CC_MVS0_CLK,     1 }, >> +}; > > This strucuture looks like a perfect candidate to be replaced by > devm_clk_bulk_get_all(). > Nice suggestion, will explore this. >> + >> +/* name, exclusive_release */ >> +static const struct clk_rst_table sm8550_clk_reset_table[] = { >> +   { "video_axi_reset",       0 }, > > Can we assume that resets are generic at least? > reset clocks can change for different hardware. >> +}; >> + >> +/* name, start, size, secure, dma_coherant, region, dma_mask */ >> +const struct context_bank_table sm8550_context_bank_table[] = { >> +   {"qcom,vidc,cb-ns", 0x25800000, 0xba800000, 0, 1, >> MSM_VIDC_NON_SECURE, 0xe0000000 - 1}, >> +   {"qcom,vidc,cb-sec-non-pxl",  0x01000000, 0x24800000, 1, 0, >> MSM_VIDC_SECURE_NONPIXEL, 0 }, > > Aren't these a properties of subdevices? If so, why are you putting them here? > Will remove these in next version. >> +}; >> + >> +/* freq */ >> +static struct freq_table sm8550_freq_table[] = { >> +   {533333333}, {444000000}, {366000000}, {338000000}, {240000000} > > OPP table contents. > we are using this freq table at multiple places apart from voting like - setting freq to turbo for few use cases - limiting the freq to NOM - changing the frequency levels based on DCVS hence this table is need. >> +}; >> + >> +/* register, value, mask */ >> +static const struct reg_preset_table sm8550_reg_preset_table[] = { >> +   { 0xB0088, 0x0, 0x11 }, >> +}; >> + >> +/* decoder properties */ >> +static const u32 sm8550_vdec_psc_avc[] = { >> +   HFI_PROP_BITSTREAM_RESOLUTION, >> +   HFI_PROP_CROP_OFFSETS, >> +   HFI_PROP_CODED_FRAMES, >> +   HFI_PROP_BUFFER_FW_MIN_OUTPUT_COUNT, >> +   HFI_PROP_PIC_ORDER_CNT_TYPE, >> +   HFI_PROP_PROFILE, >> +   HFI_PROP_LEVEL, >> +   HFI_PROP_SIGNAL_COLOR_INFO, >> +}; >> + >> +static const u32 sm8550_vdec_psc_hevc[] = { >> +   HFI_PROP_BITSTREAM_RESOLUTION, >> +   HFI_PROP_CROP_OFFSETS, >> +   HFI_PROP_LUMA_CHROMA_BIT_DEPTH, >> +   HFI_PROP_BUFFER_FW_MIN_OUTPUT_COUNT, >> +   HFI_PROP_PROFILE, >> +   HFI_PROP_LEVEL, >> +   HFI_PROP_TIER, >> +   HFI_PROP_SIGNAL_COLOR_INFO, >> +}; >> + >> +static const u32 sm8550_vdec_psc_vp9[] = { >> +   HFI_PROP_BITSTREAM_RESOLUTION, >> +   HFI_PROP_CROP_OFFSETS, >> +   HFI_PROP_LUMA_CHROMA_BIT_DEPTH, >> +   HFI_PROP_BUFFER_FW_MIN_OUTPUT_COUNT, >> +   HFI_PROP_PROFILE, >> +   HFI_PROP_LEVEL, >> +}; >> + >> +static const u32 sm8550_vdec_input_properties_avc[] = { >> +   HFI_PROP_NO_OUTPUT, >> +   HFI_PROP_SUBFRAME_INPUT, >> +}; >> + >> +static const u32 sm8550_vdec_input_properties_hevc[] = { >> +   HFI_PROP_NO_OUTPUT, >> +   HFI_PROP_SUBFRAME_INPUT, >> +}; >> + >> +static const u32 sm8550_vdec_input_properties_vp9[] = { >> +   HFI_PROP_NO_OUTPUT, >> +   HFI_PROP_SUBFRAME_INPUT, >> +}; >> + >> +static const u32 sm8550_vdec_output_properties_avc[] = { >> +   HFI_PROP_WORST_COMPRESSION_RATIO, >> +   HFI_PROP_WORST_COMPLEXITY_FACTOR, >> +   HFI_PROP_PICTURE_TYPE, >> +   HFI_PROP_DPB_LIST, >> +   HFI_PROP_CABAC_SESSION, >> +}; >> + >> +static const u32 sm8550_vdec_output_properties_hevc[] = { >> +   HFI_PROP_WORST_COMPRESSION_RATIO, >> +   HFI_PROP_WORST_COMPLEXITY_FACTOR, >> +   HFI_PROP_PICTURE_TYPE, >> +   HFI_PROP_DPB_LIST, >> +}; >> + >> +static const u32 sm8550_vdec_output_properties_vp9[] = { >> +   HFI_PROP_WORST_COMPRESSION_RATIO, >> +   HFI_PROP_WORST_COMPLEXITY_FACTOR, >> +   HFI_PROP_PICTURE_TYPE, >> +   HFI_PROP_DPB_LIST, >> +}; >> + >> +static const struct msm_vidc_platform_data sm8550_data = { >> +   /* resources dependent on other module */ >> +   .bw_tbl = sm8550_bw_table, >> +   .bw_tbl_size = ARRAY_SIZE(sm8550_bw_table), >> +   .clk_tbl = sm8550_clk_table, >> +   .clk_tbl_size = ARRAY_SIZE(sm8550_clk_table), >> +   .clk_rst_tbl = sm8550_clk_reset_table, >> +   .clk_rst_tbl_size = ARRAY_SIZE(sm8550_clk_reset_table), >> +   .subcache_tbl = NULL, >> +   .subcache_tbl_size = 0, >> + >> +   /* populate context bank */ >> +   .context_bank_tbl = sm8550_context_bank_table, >> +   .context_bank_tbl_size = ARRAY_SIZE(sm8550_context_bank_table), >> + >> +   /* populate power domain and opp table */ >> +   .pd_tbl = sm8550_pd_table, >> +   .pd_tbl_size = ARRAY_SIZE(sm8550_pd_table), >> +   .opp_tbl = sm8550_opp_table, >> +   .opp_tbl_size = ARRAY_SIZE(sm8550_opp_table), >> + >> +   /* platform specific resources */ >> +   .freq_tbl = sm8550_freq_table, >> +   .freq_tbl_size = ARRAY_SIZE(sm8550_freq_table), >> +   .reg_prst_tbl = sm8550_reg_preset_table, >> +   .reg_prst_tbl_size = ARRAY_SIZE(sm8550_reg_preset_table), >> +   .fwname = "vpu30_4v", >> +   .pas_id = 9, >> + >> +   /* caps related resorces */ >> +   .core_data = core_data_sm8550, >> +   .core_data_size = ARRAY_SIZE(core_data_sm8550), >> +   .inst_cap_data = instance_cap_data_sm8550, >> +   .inst_cap_data_size = ARRAY_SIZE(instance_cap_data_sm8550), >> +   .inst_cap_dependency_data = instance_cap_dependency_data_sm8550, >> +   .inst_cap_dependency_data_size = >> ARRAY_SIZE(instance_cap_dependency_data_sm8550), >> +   .ubwc_config = ubwc_config_sm8550, >> +   .format_data = &format_data_sm8550, >> + >> +   /* decoder properties related*/ >> +   .psc_avc_tbl = sm8550_vdec_psc_avc, >> +   .psc_avc_tbl_size = ARRAY_SIZE(sm8550_vdec_psc_avc), >> +   .psc_hevc_tbl = sm8550_vdec_psc_hevc, >> +   .psc_hevc_tbl_size = ARRAY_SIZE(sm8550_vdec_psc_hevc), >> +   .psc_vp9_tbl = sm8550_vdec_psc_vp9, >> +   .psc_vp9_tbl_size = ARRAY_SIZE(sm8550_vdec_psc_vp9), >> +   .dec_input_prop_avc = sm8550_vdec_input_properties_avc, >> +   .dec_input_prop_hevc = sm8550_vdec_input_properties_hevc, >> +   .dec_input_prop_vp9 = sm8550_vdec_input_properties_vp9, >> +   .dec_input_prop_size_avc = >> ARRAY_SIZE(sm8550_vdec_input_properties_avc), >> +   .dec_input_prop_size_hevc = >> ARRAY_SIZE(sm8550_vdec_input_properties_hevc), >> +   .dec_input_prop_size_vp9 = >> ARRAY_SIZE(sm8550_vdec_input_properties_vp9), >> +   .dec_output_prop_avc = sm8550_vdec_output_properties_avc, >> +   .dec_output_prop_hevc = sm8550_vdec_output_properties_hevc, >> +   .dec_output_prop_vp9 = sm8550_vdec_output_properties_vp9, >> +   .dec_output_prop_size_avc = >> ARRAY_SIZE(sm8550_vdec_output_properties_avc), >> +   .dec_output_prop_size_hevc = >> ARRAY_SIZE(sm8550_vdec_output_properties_hevc), >> +   .dec_output_prop_size_vp9 = >> ARRAY_SIZE(sm8550_vdec_output_properties_vp9), > > Size should come next to the array reference. correct, will fix in next version > >> +}; >> + >> +static int msm_vidc_init_data(struct msm_vidc_core *core) >> +{ >> +   d_vpr_h("%s: initialize sm8550 data\n", __func__); >> + >> +   core->platform->data = sm8550_data; >> + > > Please use of_device_match_data() instead. > Thanks for the suggestion, will implement in next version. Thanks, Dikshita >> +   return 0; >> +} >> + >> +int msm_vidc_init_platform_sm8550(struct msm_vidc_core *core) >> +{ >> +   return msm_vidc_init_data(core); >> +} >
On Mon, 14 Aug 2023 at 22:36, Dikshita Agarwal <quic_dikshita@quicinc.com> wrote: > > > > On 7/28/2023 7:43 PM, Dmitry Baryshkov wrote: > > On 28/07/2023 16:23, Vikash Garodia wrote: > >> From: Dikshita Agarwal <quic_dikshita@quicinc.com> > >> > >> This implements all the capabilities supported by sm8550. > >> > >> Signed-off-by: Dikshita Agarwal <quic_dikshita@quicinc.com> > >> Signed-off-by: Vikash Garodia <quic_vgarodia@quicinc.com> > >> --- > >> .../iris/platform/sm8550/inc/msm_vidc_sm8550.h | 14 + > >> .../iris/platform/sm8550/src/msm_vidc_sm8550.c | 1727 > >> ++++++++++++++++++++ > >> 2 files changed, 1741 insertions(+) > >> create mode 100644 > >> drivers/media/platform/qcom/iris/platform/sm8550/inc/msm_vidc_sm8550.h > >> create mode 100644 > >> drivers/media/platform/qcom/iris/platform/sm8550/src/msm_vidc_sm8550.c > >> > >> diff --git > >> a/drivers/media/platform/qcom/iris/platform/sm8550/inc/msm_vidc_sm8550.h > >> b/drivers/media/platform/qcom/iris/platform/sm8550/inc/msm_vidc_sm8550.h > >> new file mode 100644 > >> index 0000000..0a2f172 > >> --- /dev/null > >> +++ b/drivers/media/platform/qcom/iris/platform/sm8550/inc/msm_vidc_sm8550.h > >> @@ -0,0 +1,14 @@ > >> +/* SPDX-License-Identifier: GPL-2.0-only */ > >> +/* > >> + * Copyright (c) 2020-2021, The Linux Foundation. All rights reserved. > >> + * Copyright (c) 2021-2023 Qualcomm Innovation Center, Inc. All rights > >> reserved. > >> + */ > >> + > >> +#ifndef _MSM_VIDC_SM8550_H_ > >> +#define _MSM_VIDC_SM8550_H_ > >> + > >> +#include "msm_vidc_core.h" > >> + > >> +int msm_vidc_init_platform_sm8550(struct msm_vidc_core *core); > >> + > >> +#endif // _MSM_VIDC_SM8550_H_ > >> diff --git > >> a/drivers/media/platform/qcom/iris/platform/sm8550/src/msm_vidc_sm8550.c > >> b/drivers/media/platform/qcom/iris/platform/sm8550/src/msm_vidc_sm8550.c > >> new file mode 100644 > >> index 0000000..2408556 > >> --- /dev/null > >> +++ b/drivers/media/platform/qcom/iris/platform/sm8550/src/msm_vidc_sm8550.c > >> @@ -0,0 +1,1727 @@ > >> +// SPDX-License-Identifier: GPL-2.0-only > >> +/* > >> + * Copyright (c) 2020-2021, The Linux Foundation. All rights reserved. > >> + * Copyright (c) 2021-2023 Qualcomm Innovation Center, Inc. All rights > >> reserved. > >> + */ > >> + > >> +#include <dt-bindings/clock/qcom,sm8550-gcc.h> > >> +#include <dt-bindings/clock/qcom,sm8450-videocc.h> > >> + > >> +#include "hfi_command.h" > >> +#include "hfi_property.h" > >> +#include "msm_vidc_control.h" > >> +#include "msm_vidc_debug.h" > >> +#include "msm_vidc_iris3.h" > >> +#include "msm_vidc_sm8550.h" > >> +#include "msm_vidc_platform.h" > >> + > >> +/* version: major[24:31], minor[16:23], revision[0:15] */ > >> +#define DRIVER_VERSION 0x04000000 > >> +#define DEFAULT_VIDEO_CONCEAL_COLOR_BLACK 0x8020010 > >> +#define MAX_BASE_LAYER_PRIORITY_ID 63 > >> +#define MAX_OP_POINT 31 > >> +#define MAX_BITRATE 245000000 > >> +#define DEFAULT_BITRATE 20000000 > >> +#define MINIMUM_FPS 1 > >> +#define MAXIMUM_FPS 480 > >> +#define MAXIMUM_DEC_FPS 960 > >> +#define MAX_QP 51 > >> +#define DEFAULT_QP 20 > >> +#define MAX_CONSTANT_QUALITY 100 > >> +#define MIN_SLICE_BYTE_SIZE 512 > >> +#define MAX_SLICE_BYTE_SIZE \ > >> + ((MAX_BITRATE) >> 3) > >> +#define MAX_SLICE_MB_SIZE \ > >> + (((4096 + 15) >> 4) * ((2304 + 15) >> 4)) > >> + > >> +#define ENC MSM_VIDC_ENCODER > >> +#define DEC MSM_VIDC_DECODER > >> +#define H264 MSM_VIDC_H264 > >> +#define HEVC MSM_VIDC_HEVC > >> +#define VP9 MSM_VIDC_VP9 > > > > Another redefinition. Inline it. > > >> +#define CODECS_ALL (H264 | HEVC | VP9) > >> +#define MAXIMUM_OVERRIDE_VP9_FPS 200 > >> + > >> +static struct codec_info codec_data_sm8550[] = { > >> + { > >> + .v4l2_codec = V4L2_PIX_FMT_H264, > >> + .vidc_codec = MSM_VIDC_H264, > >> + .pixfmt_name = "AVC", > > > > Have you considered using existing code which enumerates formats? For > > example, it is much better to refactor v4l_fill_fmtdesc() to allow getting > > the description instead of adding your own names here. > > Not to mention that printk supports %p4cc for printing fourcc values. I > > hope you knew that. > > > Sure, will explore more on this. > >> + }, > >> + { > >> + .v4l2_codec = V4L2_PIX_FMT_HEVC, > >> + .vidc_codec = MSM_VIDC_HEVC, > >> + .pixfmt_name = "HEVC", > >> + }, > >> + { > >> + .v4l2_codec = V4L2_PIX_FMT_VP9, > >> + .vidc_codec = MSM_VIDC_VP9, > >> + .pixfmt_name = "VP9", > >> + }, > >> +}; > >> + > >> +static struct color_format_info color_format_data_sm8550[] = { > >> + { > >> + .v4l2_color_format = V4L2_PIX_FMT_NV12, > >> + .vidc_color_format = MSM_VIDC_FMT_NV12, > >> + .pixfmt_name = "NV12", > >> + }, > >> + { > >> + .v4l2_color_format = V4L2_PIX_FMT_NV21, > >> + .vidc_color_format = MSM_VIDC_FMT_NV21, > >> + .pixfmt_name = "NV21", > >> + }, > >> + { > >> + .v4l2_color_format = V4L2_PIX_FMT_QC08C, > >> + .vidc_color_format = MSM_VIDC_FMT_NV12C, > >> + .pixfmt_name = "NV12C", > >> + }, > >> + { > >> + .v4l2_color_format = V4L2_PIX_FMT_QC10C, > >> + .vidc_color_format = MSM_VIDC_FMT_TP10C, > >> + .pixfmt_name = "TP10C", > >> + }, > >> + { > >> + .v4l2_color_format = V4L2_PIX_FMT_RGBA32, > >> + .vidc_color_format = MSM_VIDC_FMT_RGBA8888, > >> + .pixfmt_name = "RGBA", > >> + }, > >> +}; > >> + > >> +static struct color_primaries_info color_primaries_data_sm8550[] = { > >> + { > >> + .v4l2_color_primaries = V4L2_COLORSPACE_DEFAULT, > >> + .vidc_color_primaries = MSM_VIDC_PRIMARIES_RESERVED, > >> + }, > >> + { > >> + .v4l2_color_primaries = V4L2_COLORSPACE_REC709, > >> + .vidc_color_primaries = MSM_VIDC_PRIMARIES_BT709, > >> + }, > >> + { > >> + .v4l2_color_primaries = V4L2_COLORSPACE_470_SYSTEM_M, > >> + .vidc_color_primaries = MSM_VIDC_PRIMARIES_BT470_SYSTEM_M, > >> + }, > >> + { > >> + .v4l2_color_primaries = V4L2_COLORSPACE_470_SYSTEM_BG, > >> + .vidc_color_primaries = MSM_VIDC_PRIMARIES_BT470_SYSTEM_BG, > >> + }, > >> + { > >> + .v4l2_color_primaries = V4L2_COLORSPACE_SMPTE170M, > >> + .vidc_color_primaries = MSM_VIDC_PRIMARIES_BT601_525, > >> + }, > >> + { > >> + .v4l2_color_primaries = V4L2_COLORSPACE_SMPTE240M, > >> + .vidc_color_primaries = MSM_VIDC_PRIMARIES_SMPTE_ST240M, > >> + }, > >> + { > >> + .v4l2_color_primaries = V4L2_COLORSPACE_BT2020, > >> + .vidc_color_primaries = MSM_VIDC_PRIMARIES_BT2020, > >> + }, > >> + { > >> + .v4l2_color_primaries = V4L2_COLORSPACE_DCI_P3, > >> + .vidc_color_primaries = MSM_VIDC_PRIMARIES_SMPTE_RP431_2, > >> + }, > >> +}; > >> + > >> +static struct transfer_char_info transfer_char_data_sm8550[] = { > >> + { > >> + .v4l2_transfer_char = V4L2_XFER_FUNC_DEFAULT, > >> + .vidc_transfer_char = MSM_VIDC_TRANSFER_RESERVED, > >> + }, > >> + { > >> + .v4l2_transfer_char = V4L2_XFER_FUNC_709, > >> + .vidc_transfer_char = MSM_VIDC_TRANSFER_BT709, > >> + }, > >> + { > >> + .v4l2_transfer_char = V4L2_XFER_FUNC_SMPTE240M, > >> + .vidc_transfer_char = MSM_VIDC_TRANSFER_SMPTE_ST240M, > >> + }, > >> + { > >> + .v4l2_transfer_char = V4L2_XFER_FUNC_SRGB, > >> + .vidc_transfer_char = MSM_VIDC_TRANSFER_SRGB_SYCC, > >> + }, > >> + { > >> + .v4l2_transfer_char = V4L2_XFER_FUNC_SMPTE2084, > >> + .vidc_transfer_char = MSM_VIDC_TRANSFER_SMPTE_ST2084_PQ, > >> + }, > >> +}; > >> + > >> +static struct matrix_coeff_info matrix_coeff_data_sm8550[] = { > >> + { > >> + .v4l2_matrix_coeff = V4L2_YCBCR_ENC_DEFAULT, > >> + .vidc_matrix_coeff = MSM_VIDC_MATRIX_COEFF_RESERVED, > >> + }, > >> + { > >> + .v4l2_matrix_coeff = V4L2_YCBCR_ENC_709, > >> + .vidc_matrix_coeff = MSM_VIDC_MATRIX_COEFF_BT709, > >> + }, > >> + { > >> + .v4l2_matrix_coeff = V4L2_YCBCR_ENC_XV709, > >> + .vidc_matrix_coeff = MSM_VIDC_MATRIX_COEFF_BT709, > >> + }, > >> + { > >> + .v4l2_matrix_coeff = V4L2_YCBCR_ENC_XV601, > >> + .vidc_matrix_coeff = > >> MSM_VIDC_MATRIX_COEFF_BT470_SYS_BG_OR_BT601_625, > >> + }, > >> + { > >> + .v4l2_matrix_coeff = V4L2_YCBCR_ENC_601, > >> + .vidc_matrix_coeff = > >> MSM_VIDC_MATRIX_COEFF_BT601_525_BT1358_525_OR_625, > >> + }, > >> + { > >> + .v4l2_matrix_coeff = V4L2_YCBCR_ENC_SMPTE240M, > >> + .vidc_matrix_coeff = MSM_VIDC_MATRIX_COEFF_SMPTE_ST240, > >> + }, > >> + { > >> + .v4l2_matrix_coeff = V4L2_YCBCR_ENC_BT2020, > >> + .vidc_matrix_coeff = MSM_VIDC_MATRIX_COEFF_BT2020_NON_CONSTANT, > >> + }, > >> + { > >> + .v4l2_matrix_coeff = V4L2_YCBCR_ENC_BT2020_CONST_LUM, > >> + .vidc_matrix_coeff = MSM_VIDC_MATRIX_COEFF_BT2020_CONSTANT, > >> + }, > >> +}; > > > > Are you going to say that these tables are platform-specific instead of > > being generic to the driver? > > > future platform can support new codec and that will require new color > primaries. So, yes these can differ for different platforms. Please do not try to implement support for not-yet-existing hardware. Move this table into the generic code until you have a real cause of disagreement about matrix coefficients. Otherwise the table can simply be expanded to add new color primaries support. > >> + > >> +static struct msm_platform_core_capability core_data_sm8550[] = { > >> + /* {type, value} */ > >> + {ENC_CODECS, H264 | HEVC}, > >> + {DEC_CODECS, H264 | HEVC | VP9}, > >> + {MAX_SESSION_COUNT, 16}, > >> + {MAX_NUM_720P_SESSIONS, 16}, > >> + {MAX_NUM_1080P_SESSIONS, 16}, > >> + {MAX_NUM_4K_SESSIONS, 8}, > >> + {MAX_NUM_8K_SESSIONS, 2}, > >> + {MAX_RT_MBPF, 174080}, /* (8192x4352)/256 + (4096x2176)/256*/ > >> + {MAX_MBPF, 278528}, /* ((8192x4352)/256) * 2 */ > >> + {MAX_MBPS, 7833600}, /* max_load > >> + * 7680x4320@60fps or 3840x2176@240fps > >> + * which is greater than 4096x2176@120fps, > >> + * 8192x4320@48fps > >> + */ > >> + {MAX_MBPF_HQ, 8160}, /* ((1920x1088)/256) */ > >> + {MAX_MBPS_HQ, 489600}, /* ((1920x1088)/256)@60fps */ > >> + {MAX_MBPF_B_FRAME, 32640}, /* 3840x2176/256 */ > >> + {MAX_MBPS_B_FRAME, 1958400}, /* 3840x2176/256 MBs@60fps */ > >> + {MAX_MBPS_ALL_INTRA, 1044480}, /* 4096x2176/256 MBs@30fps */ > >> + {MAX_ENH_LAYER_COUNT, 5}, > >> + {NUM_VPP_PIPE, 4}, > >> + {SW_PC, 1}, > >> + {FW_UNLOAD, 0}, > >> + {HW_RESPONSE_TIMEOUT, HW_RESPONSE_TIMEOUT_VALUE}, /* 1000 ms */ > >> + {SW_PC_DELAY, SW_PC_DELAY_VALUE }, /* 1500 ms > >> (>HW_RESPONSE_TIMEOUT)*/ > >> + {FW_UNLOAD_DELAY, FW_UNLOAD_DELAY_VALUE }, /* 3000 ms > >> (>SW_PC_DELAY)*/ > >> + {DCVS, 1}, > >> + {DECODE_BATCH, 1}, > >> + {DECODE_BATCH_TIMEOUT, 200}, > >> + {STATS_TIMEOUT_MS, 2000}, > >> + {NON_FATAL_FAULTS, 1}, > >> + {DEVICE_CAPS, V4L2_CAP_VIDEO_M2M_MPLANE | V4L2_CAP_STREAMING}, > > > > Unless there is a good reason, please change this to be a proper data > > structure instead of being a type-value array. With the T-V it is > > impossible to notice if the value is missing or duplicated. This comment > > also applies to the next 'capability' array. > > > Core has set of caps. All caps might not be supported for all the hardware. > So it's quite valid to miss a cap entry if its not applicable for that > hardware. > subsequently with caps as enum, it will become easy to copy these caps from > platform to core. ... and it becomes harder to check them (e.g. for duplicates). Please use nested structures and omit values for undefined capabilities. > > please check msm_vidc_init_core_caps API in [1] > > [1] > https://patchwork.linuxtv.org/project/linux-media/patch/1690550624-14642-11-git-send-email-quic_vgarodia@quicinc.com/ In that patch I see that capabilities are enumerated as an array. Which is already much better than plain tag-value data structure. But please drop both implementations and use existing C language constructions. > > >> +}; > >> + > >> +static struct msm_platform_inst_capability instance_cap_data_sm8550[] = { > >> + /* {cap, domain, codec, > >> + * min, max, step_or_mask, value, > >> + * v4l2_id, > >> + * hfi_id, > >> + * flags} > >> + */ > >> + {FRAME_WIDTH, DEC, CODECS_ALL, 96, 8192, 1, 1920}, > >> + > >> + {FRAME_WIDTH, DEC, VP9, 96, 4096, 1, 1920}, > >> + > >> + {FRAME_WIDTH, ENC, CODECS_ALL, 128, 8192, 1, 1920}, > >> + > >> + {FRAME_WIDTH, ENC, HEVC, 96, 8192, 1, 1920}, > >> + > >> + {LOSSLESS_FRAME_WIDTH, ENC, CODECS_ALL, 128, 4096, 1, 1920}, > >> + > >> + {LOSSLESS_FRAME_WIDTH, ENC, HEVC, 96, 4096, 1, 1920}, > >> + > >> + {FRAME_HEIGHT, DEC, CODECS_ALL, 96, 8192, 1, 1080}, > >> + > >> + {FRAME_HEIGHT, DEC, VP9, 96, 4096, 1, 1080}, > >> + > >> + {FRAME_HEIGHT, ENC, CODECS_ALL, 128, 8192, 1, 1080}, > >> + > >> + {FRAME_HEIGHT, ENC, HEVC, 96, 8192, 1, 1080}, > >> + > >> + {LOSSLESS_FRAME_HEIGHT, ENC, CODECS_ALL, 128, 4096, 1, 1080}, > >> + > >> + {LOSSLESS_FRAME_HEIGHT, ENC, HEVC, 96, 4096, 1, 1080}, > >> + > >> + {PIX_FMTS, ENC | DEC, H264, > >> + MSM_VIDC_FMT_NV12, > >> + MSM_VIDC_FMT_NV12C, > >> + MSM_VIDC_FMT_NV12 | MSM_VIDC_FMT_NV21 | MSM_VIDC_FMT_NV12C, > >> + MSM_VIDC_FMT_NV12C}, > >> + > >> + {PIX_FMTS, ENC | DEC, HEVC | VP9, > >> + MSM_VIDC_FMT_NV12, > >> + MSM_VIDC_FMT_TP10C, > >> + MSM_VIDC_FMT_NV12 | MSM_VIDC_FMT_NV21 | MSM_VIDC_FMT_NV12C | > >> + MSM_VIDC_FMT_TP10C, > >> + MSM_VIDC_FMT_NV12C}, > >> + > >> + {MIN_BUFFERS_INPUT, ENC | DEC, CODECS_ALL, 0, 64, 1, 4, > >> + V4L2_CID_MIN_BUFFERS_FOR_OUTPUT, > >> + 0, > >> + CAP_FLAG_VOLATILE}, > >> + > >> + {MIN_BUFFERS_OUTPUT, ENC | DEC, CODECS_ALL, > >> + 0, 64, 1, 4, > >> + V4L2_CID_MIN_BUFFERS_FOR_CAPTURE, > >> + HFI_PROP_BUFFER_FW_MIN_OUTPUT_COUNT, > >> + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_VOLATILE}, > >> + > >> + /* (8192 * 4320) / 256 */ > >> + {MBPF, ENC, CODECS_ALL, 64, 138240, 1, 138240}, > >> + > >> + {MBPF, ENC, HEVC, 36, 138240, 1, 138240}, > >> + > >> + {MBPF, DEC, CODECS_ALL, 36, 138240, 1, 138240}, > >> + > >> + /* (4096 * 2304) / 256 */ > >> + {MBPF, DEC, VP9, 36, 36864, 1, 36864}, > >> + > >> + /* (4096 * 2304) / 256 */ > >> + {LOSSLESS_MBPF, ENC, H264 | HEVC, 64, 36864, 1, 36864}, > >> + > >> + /* Batch Mode Decode */ > >> + /* TODO: update with new values based on updated voltage corner */ > >> + {BATCH_MBPF, DEC, H264 | HEVC | VP9, 64, 34816, 1, 34816}, > >> + > >> + /* (4096 * 2304) / 256 */ > >> + {BATCH_FPS, DEC, H264 | HEVC | VP9, 1, 120, 1, 120}, > >> + > >> + {FRAME_RATE, ENC | DEC, CODECS_ALL, > >> + (MINIMUM_FPS << 16), (MAXIMUM_FPS << 16), > >> + 1, (DEFAULT_FPS << 16), > >> + 0, > >> + HFI_PROP_FRAME_RATE, > >> + CAP_FLAG_OUTPUT_PORT}, > >> + > >> + {OPERATING_RATE, ENC | DEC, CODECS_ALL, > >> + (MINIMUM_FPS << 16), (MAXIMUM_FPS << 16), > >> + 1, (DEFAULT_FPS << 16)}, > >> + > >> + {INPUT_RATE, ENC | DEC, CODECS_ALL, > >> + (MINIMUM_FPS << 16), INT_MAX, > >> + 1, (DEFAULT_FPS << 16)}, > >> + > >> + {TIMESTAMP_RATE, ENC | DEC, CODECS_ALL, > >> + (MINIMUM_FPS << 16), INT_MAX, > >> + 1, (DEFAULT_FPS << 16)}, > >> + > >> + {SCALE_FACTOR, ENC, H264 | HEVC, 1, 8, 1, 8}, > >> + > >> + {MB_CYCLES_VSP, ENC, CODECS_ALL, 25, 25, 1, 25}, > >> + > >> + {MB_CYCLES_VSP, DEC, CODECS_ALL, 25, 25, 1, 25}, > >> + > >> + {MB_CYCLES_VSP, DEC, VP9, 60, 60, 1, 60}, > >> + > >> + {MB_CYCLES_VPP, ENC, CODECS_ALL, 675, 675, 1, 675}, > >> + > >> + {MB_CYCLES_VPP, DEC, CODECS_ALL, 200, 200, 1, 200}, > >> + > >> + {MB_CYCLES_LP, ENC, CODECS_ALL, 320, 320, 1, 320}, > >> + > >> + {MB_CYCLES_LP, DEC, CODECS_ALL, 200, 200, 1, 200}, > >> + > >> + {MB_CYCLES_FW, ENC | DEC, CODECS_ALL, 489583, 489583, 1, 489583}, > >> + > >> + {MB_CYCLES_FW_VPP, ENC, CODECS_ALL, 48405, 48405, 1, 48405}, > >> + > >> + {MB_CYCLES_FW_VPP, DEC, CODECS_ALL, 66234, 66234, 1, 66234}, > >> + > >> + {HFLIP, ENC, CODECS_ALL, > >> + 0, 1, 1, 0, > >> + V4L2_CID_HFLIP, > >> + HFI_PROP_FLIP, > >> + CAP_FLAG_OUTPUT_PORT | > >> + CAP_FLAG_INPUT_PORT | CAP_FLAG_DYNAMIC_ALLOWED}, > >> + > >> + {VFLIP, ENC, CODECS_ALL, > >> + 0, 1, 1, 0, > >> + V4L2_CID_VFLIP, > >> + HFI_PROP_FLIP, > >> + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT | > >> + CAP_FLAG_DYNAMIC_ALLOWED}, > >> + > >> + {ROTATION, ENC, CODECS_ALL, > >> + 0, 270, 90, 0, > >> + V4L2_CID_ROTATE, > >> + HFI_PROP_ROTATION, > >> + CAP_FLAG_OUTPUT_PORT}, > >> + > >> + {HEADER_MODE, ENC, CODECS_ALL, > >> + V4L2_MPEG_VIDEO_HEADER_MODE_SEPARATE, > >> + V4L2_MPEG_VIDEO_HEADER_MODE_JOINED_WITH_1ST_FRAME, > >> + BIT(V4L2_MPEG_VIDEO_HEADER_MODE_SEPARATE) | > >> + BIT(V4L2_MPEG_VIDEO_HEADER_MODE_JOINED_WITH_1ST_FRAME), > >> + V4L2_MPEG_VIDEO_HEADER_MODE_SEPARATE, > >> + V4L2_CID_MPEG_VIDEO_HEADER_MODE, > >> + HFI_PROP_SEQ_HEADER_MODE, > >> + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_MENU}, > >> + > >> + {PREPEND_SPSPPS_TO_IDR, ENC, CODECS_ALL, > >> + 0, 1, 1, 0, > >> + V4L2_CID_MPEG_VIDEO_PREPEND_SPSPPS_TO_IDR}, > >> + > >> + {WITHOUT_STARTCODE, ENC, CODECS_ALL, > >> + 0, 1, 1, 0, > >> + V4L2_CID_MPEG_VIDEO_HEVC_WITHOUT_STARTCODE, > >> + HFI_PROP_NAL_LENGTH_FIELD, > >> + CAP_FLAG_OUTPUT_PORT}, > >> + > >> + {NAL_LENGTH_FIELD, ENC, CODECS_ALL, > >> + V4L2_MPEG_VIDEO_HEVC_SIZE_0, > >> + V4L2_MPEG_VIDEO_HEVC_SIZE_4, > >> + BIT(V4L2_MPEG_VIDEO_HEVC_SIZE_0) | > >> + BIT(V4L2_MPEG_VIDEO_HEVC_SIZE_4), > >> + V4L2_MPEG_VIDEO_HEVC_SIZE_0, > >> + V4L2_CID_MPEG_VIDEO_HEVC_SIZE_OF_LENGTH_FIELD, > >> + HFI_PROP_NAL_LENGTH_FIELD, > >> + CAP_FLAG_MENU | CAP_FLAG_OUTPUT_PORT}, > >> + > >> + /* TODO: Firmware introduced enumeration type for this > >> + * with and without seq header. > >> + */ > >> + {REQUEST_I_FRAME, ENC, H264 | HEVC, > >> + 0, 0, 0, 0, > >> + V4L2_CID_MPEG_VIDEO_FORCE_KEY_FRAME, > >> + HFI_PROP_REQUEST_SYNC_FRAME, > >> + CAP_FLAG_INPUT_PORT | CAP_FLAG_DYNAMIC_ALLOWED}, > >> + > >> + /* Enc: Keeping CABAC and CAVLC as same bitrate. > >> + * Dec: there's no use of Bitrate cap > >> + */ > >> + {BIT_RATE, ENC, H264 | HEVC, > >> + 1, MAX_BITRATE, 1, DEFAULT_BITRATE, > >> + V4L2_CID_MPEG_VIDEO_BITRATE, > >> + HFI_PROP_TOTAL_BITRATE, > >> + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT | > >> + CAP_FLAG_DYNAMIC_ALLOWED}, > >> + > >> + {BITRATE_MODE, ENC, H264, > >> + V4L2_MPEG_VIDEO_BITRATE_MODE_VBR, > >> + V4L2_MPEG_VIDEO_BITRATE_MODE_CBR, > >> + BIT(V4L2_MPEG_VIDEO_BITRATE_MODE_VBR) | > >> + BIT(V4L2_MPEG_VIDEO_BITRATE_MODE_CBR), > >> + V4L2_MPEG_VIDEO_BITRATE_MODE_VBR, > >> + V4L2_CID_MPEG_VIDEO_BITRATE_MODE, > >> + HFI_PROP_RATE_CONTROL, > >> + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_MENU}, > >> + > >> + {BITRATE_MODE, ENC, HEVC, > >> + V4L2_MPEG_VIDEO_BITRATE_MODE_VBR, > >> + V4L2_MPEG_VIDEO_BITRATE_MODE_CQ, > >> + BIT(V4L2_MPEG_VIDEO_BITRATE_MODE_VBR) | > >> + BIT(V4L2_MPEG_VIDEO_BITRATE_MODE_CBR) | > >> + BIT(V4L2_MPEG_VIDEO_BITRATE_MODE_CQ), > >> + V4L2_MPEG_VIDEO_BITRATE_MODE_VBR, > >> + V4L2_CID_MPEG_VIDEO_BITRATE_MODE, > >> + HFI_PROP_RATE_CONTROL, > >> + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_MENU}, > >> + > >> + {CABAC_MAX_BITRATE, ENC, H264 | HEVC, 0, > >> + 160000000, 1, 160000000}, > >> + > >> + {CAVLC_MAX_BITRATE, ENC, H264, 0, > >> + 220000000, 1, 220000000}, > >> + > >> + {ALLINTRA_MAX_BITRATE, ENC, H264 | HEVC, 0, > >> + 245000000, 1, 245000000}, > >> + > >> + {NUM_COMV, DEC, CODECS_ALL, > >> + 0, INT_MAX, 1, 0}, > >> + > >> + {LOSSLESS, ENC, HEVC, > >> + 0, 1, 1, 0, > >> + V4L2_CID_MPEG_VIDEO_HEVC_LOSSLESS_CU}, > >> + > >> + {FRAME_SKIP_MODE, ENC, H264 | HEVC, > >> + V4L2_MPEG_VIDEO_FRAME_SKIP_MODE_DISABLED, > >> + V4L2_MPEG_VIDEO_FRAME_SKIP_MODE_BUF_LIMIT, > >> + BIT(V4L2_MPEG_VIDEO_FRAME_SKIP_MODE_DISABLED) | > >> + BIT(V4L2_MPEG_VIDEO_FRAME_SKIP_MODE_LEVEL_LIMIT) | > >> + BIT(V4L2_MPEG_VIDEO_FRAME_SKIP_MODE_BUF_LIMIT), > >> + V4L2_MPEG_VIDEO_FRAME_SKIP_MODE_DISABLED, > >> + V4L2_CID_MPEG_VIDEO_FRAME_SKIP_MODE, > >> + 0, > >> + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_MENU}, > >> + > >> + {FRAME_RC_ENABLE, ENC, H264 | HEVC, > >> + 0, 1, 1, 1, > >> + V4L2_CID_MPEG_VIDEO_FRAME_RC_ENABLE}, > >> + > >> + {CONSTANT_QUALITY, ENC, HEVC, > >> + 1, MAX_CONSTANT_QUALITY, 1, 90, > >> + V4L2_CID_MPEG_VIDEO_CONSTANT_QUALITY, > >> + HFI_PROP_CONSTANT_QUALITY, > >> + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT | > >> + CAP_FLAG_DYNAMIC_ALLOWED}, > >> + > >> + {GOP_SIZE, ENC, CODECS_ALL, > >> + 0, INT_MAX, 1, 2 * DEFAULT_FPS - 1, > >> + V4L2_CID_MPEG_VIDEO_GOP_SIZE, > >> + HFI_PROP_MAX_GOP_FRAMES, > >> + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT | > >> + CAP_FLAG_DYNAMIC_ALLOWED}, > >> + > >> + {GOP_CLOSURE, ENC, H264 | HEVC, > >> + 0, 1, 1, 1, > >> + V4L2_CID_MPEG_VIDEO_GOP_CLOSURE, > >> + 0}, > >> + > >> + {B_FRAME, ENC, H264 | HEVC, > >> + 0, 7, 1, 0, > >> + V4L2_CID_MPEG_VIDEO_B_FRAMES, > >> + HFI_PROP_MAX_B_FRAMES, > >> + CAP_FLAG_OUTPUT_PORT}, > >> + > >> + {LTR_COUNT, ENC, H264 | HEVC, > >> + 0, MAX_LTR_FRAME_COUNT_2, 1, 0, > >> + V4L2_CID_MPEG_VIDEO_LTR_COUNT, > >> + HFI_PROP_LTR_COUNT, > >> + CAP_FLAG_OUTPUT_PORT}, > >> + > >> + {USE_LTR, ENC, H264 | HEVC, > >> + 0, > >> + ((1 << MAX_LTR_FRAME_COUNT_2) - 1), > >> + 0, 0, > >> + V4L2_CID_MPEG_VIDEO_USE_LTR_FRAMES, > >> + HFI_PROP_LTR_USE, > >> + CAP_FLAG_INPUT_PORT | CAP_FLAG_DYNAMIC_ALLOWED}, > >> + > >> + {MARK_LTR, ENC, H264 | HEVC, > >> + INVALID_DEFAULT_MARK_OR_USE_LTR, > >> + (MAX_LTR_FRAME_COUNT_2 - 1), > >> + 1, INVALID_DEFAULT_MARK_OR_USE_LTR, > >> + V4L2_CID_MPEG_VIDEO_FRAME_LTR_INDEX, > >> + HFI_PROP_LTR_MARK, > >> + CAP_FLAG_INPUT_PORT | CAP_FLAG_DYNAMIC_ALLOWED}, > >> + > >> + {BASELAYER_PRIORITY, ENC, H264, > >> + 0, MAX_BASE_LAYER_PRIORITY_ID, 1, 0, > >> + V4L2_CID_MPEG_VIDEO_BASELAYER_PRIORITY_ID, > >> + HFI_PROP_BASELAYER_PRIORITYID, > >> + CAP_FLAG_OUTPUT_PORT}, > >> + > >> + {IR_TYPE, ENC, H264 | HEVC, > >> + V4L2_CID_MPEG_VIDEO_INTRA_REFRESH_PERIOD_TYPE_RANDOM, > >> + V4L2_CID_MPEG_VIDEO_INTRA_REFRESH_PERIOD_TYPE_CYCLIC, > >> + BIT(V4L2_CID_MPEG_VIDEO_INTRA_REFRESH_PERIOD_TYPE_RANDOM) | > >> + BIT(V4L2_CID_MPEG_VIDEO_INTRA_REFRESH_PERIOD_TYPE_CYCLIC), > >> + V4L2_CID_MPEG_VIDEO_INTRA_REFRESH_PERIOD_TYPE_RANDOM, > >> + V4L2_CID_MPEG_VIDEO_INTRA_REFRESH_PERIOD_TYPE, > >> + 0, > >> + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_MENU}, > >> + > >> + {IR_PERIOD, ENC, H264 | HEVC, > >> + 0, INT_MAX, 1, 0, > >> + V4L2_CID_MPEG_VIDEO_INTRA_REFRESH_PERIOD, > >> + 0, > >> + CAP_FLAG_INPUT_PORT | CAP_FLAG_OUTPUT_PORT | > >> + CAP_FLAG_DYNAMIC_ALLOWED}, > >> + > >> + {AU_DELIMITER, ENC, H264 | HEVC, > >> + 0, 1, 1, 0, > >> + V4L2_CID_MPEG_VIDEO_AU_DELIMITER, > >> + HFI_PROP_AUD, > >> + CAP_FLAG_OUTPUT_PORT}, > >> + > >> + {MIN_QUALITY, ENC, H264 | HEVC, > >> + 0, MAX_SUPPORTED_MIN_QUALITY, 70, MAX_SUPPORTED_MIN_QUALITY, > >> + 0, > >> + HFI_PROP_MAINTAIN_MIN_QUALITY, > >> + CAP_FLAG_OUTPUT_PORT}, > >> + > >> + {VBV_DELAY, ENC, H264 | HEVC, > >> + 200, 300, 100, 300, > >> + V4L2_CID_MPEG_VIDEO_VBV_DELAY, > >> + HFI_PROP_VBV_DELAY, > >> + CAP_FLAG_OUTPUT_PORT}, > >> + > >> + {PEAK_BITRATE, ENC, H264 | HEVC, > >> + /* default peak bitrate is 10% larger than avg bitrate */ > >> + 1, MAX_BITRATE, 1, DEFAULT_BITRATE, > >> + V4L2_CID_MPEG_VIDEO_BITRATE_PEAK, > >> + HFI_PROP_TOTAL_PEAK_BITRATE, > >> + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT | > >> + CAP_FLAG_DYNAMIC_ALLOWED}, > >> + > >> + {MIN_FRAME_QP, ENC, H264, > >> + MIN_QP_8BIT, MAX_QP, 1, MIN_QP_8BIT, > >> + V4L2_CID_MPEG_VIDEO_H264_MIN_QP, > >> + HFI_PROP_MIN_QP_PACKED, > >> + CAP_FLAG_OUTPUT_PORT}, > >> + > >> + {MIN_FRAME_QP, ENC, HEVC, > >> + MIN_QP_10BIT, MAX_QP, 1, MIN_QP_10BIT, > >> + V4L2_CID_MPEG_VIDEO_HEVC_MIN_QP, > >> + HFI_PROP_MIN_QP_PACKED, > >> + CAP_FLAG_OUTPUT_PORT}, > >> + > >> + {I_FRAME_MIN_QP, ENC, H264, > >> + MIN_QP_8BIT, MAX_QP, 1, MIN_QP_8BIT, > >> + V4L2_CID_MPEG_VIDEO_H264_I_FRAME_MIN_QP}, > >> + > >> + {I_FRAME_MIN_QP, ENC, HEVC, > >> + MIN_QP_10BIT, MAX_QP, 1, MIN_QP_10BIT, > >> + V4L2_CID_MPEG_VIDEO_HEVC_I_FRAME_MIN_QP}, > >> + > >> + {P_FRAME_MIN_QP, ENC, H264, > >> + MIN_QP_8BIT, MAX_QP, 1, MIN_QP_8BIT, > >> + V4L2_CID_MPEG_VIDEO_H264_P_FRAME_MIN_QP}, > >> + > >> + {P_FRAME_MIN_QP, ENC, HEVC, > >> + MIN_QP_10BIT, MAX_QP, 1, MIN_QP_10BIT, > >> + V4L2_CID_MPEG_VIDEO_HEVC_P_FRAME_MIN_QP}, > >> + > >> + {B_FRAME_MIN_QP, ENC, H264, > >> + MIN_QP_8BIT, MAX_QP, 1, MIN_QP_8BIT, > >> + V4L2_CID_MPEG_VIDEO_H264_B_FRAME_MIN_QP}, > >> + > >> + {B_FRAME_MIN_QP, ENC, HEVC, > >> + MIN_QP_10BIT, MAX_QP, 1, MIN_QP_10BIT, > >> + V4L2_CID_MPEG_VIDEO_HEVC_B_FRAME_MIN_QP}, > >> + > >> + {MAX_FRAME_QP, ENC, H264, > >> + MIN_QP_8BIT, MAX_QP, 1, MAX_QP, > >> + V4L2_CID_MPEG_VIDEO_H264_MAX_QP, > >> + HFI_PROP_MAX_QP_PACKED, > >> + CAP_FLAG_OUTPUT_PORT}, > >> + > >> + {MAX_FRAME_QP, ENC, HEVC, > >> + MIN_QP_10BIT, MAX_QP, 1, MAX_QP, > >> + V4L2_CID_MPEG_VIDEO_HEVC_MAX_QP, > >> + HFI_PROP_MAX_QP_PACKED, > >> + CAP_FLAG_OUTPUT_PORT}, > >> + > >> + {I_FRAME_MAX_QP, ENC, H264, > >> + MIN_QP_8BIT, MAX_QP, 1, MAX_QP, > >> + V4L2_CID_MPEG_VIDEO_H264_I_FRAME_MAX_QP}, > >> + > >> + {I_FRAME_MAX_QP, ENC, HEVC, > >> + MIN_QP_10BIT, MAX_QP, 1, MAX_QP, > >> + V4L2_CID_MPEG_VIDEO_HEVC_I_FRAME_MAX_QP}, > >> + > >> + {P_FRAME_MAX_QP, ENC, H264, > >> + MIN_QP_8BIT, MAX_QP, 1, MAX_QP, > >> + V4L2_CID_MPEG_VIDEO_H264_P_FRAME_MAX_QP}, > >> + > >> + {P_FRAME_MAX_QP, ENC, HEVC, > >> + MIN_QP_10BIT, MAX_QP, 1, MAX_QP, > >> + V4L2_CID_MPEG_VIDEO_HEVC_P_FRAME_MAX_QP}, > >> + > >> + {B_FRAME_MAX_QP, ENC, H264, > >> + MIN_QP_8BIT, MAX_QP, 1, MAX_QP, > >> + V4L2_CID_MPEG_VIDEO_H264_B_FRAME_MAX_QP}, > >> + > >> + {B_FRAME_MAX_QP, ENC, HEVC, > >> + MIN_QP_10BIT, MAX_QP, 1, MAX_QP, > >> + V4L2_CID_MPEG_VIDEO_HEVC_B_FRAME_MAX_QP}, > >> + > >> + {I_FRAME_QP, ENC, HEVC, > >> + MIN_QP_10BIT, MAX_QP, 1, DEFAULT_QP, > >> + V4L2_CID_MPEG_VIDEO_HEVC_I_FRAME_QP, > >> + HFI_PROP_QP_PACKED, > >> + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT | > >> + CAP_FLAG_DYNAMIC_ALLOWED}, > >> + > >> + {I_FRAME_QP, ENC, H264, > >> + MIN_QP_8BIT, MAX_QP, 1, DEFAULT_QP, > >> + V4L2_CID_MPEG_VIDEO_H264_I_FRAME_QP, > >> + HFI_PROP_QP_PACKED, > >> + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT | > >> + CAP_FLAG_DYNAMIC_ALLOWED}, > >> + > >> + {P_FRAME_QP, ENC, HEVC, > >> + MIN_QP_10BIT, MAX_QP, 1, DEFAULT_QP, > >> + V4L2_CID_MPEG_VIDEO_HEVC_P_FRAME_QP, > >> + HFI_PROP_QP_PACKED, > >> + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT | > >> + CAP_FLAG_DYNAMIC_ALLOWED}, > >> + > >> + {P_FRAME_QP, ENC, H264, > >> + MIN_QP_8BIT, MAX_QP, 1, DEFAULT_QP, > >> + V4L2_CID_MPEG_VIDEO_H264_P_FRAME_QP, > >> + HFI_PROP_QP_PACKED, > >> + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT | > >> + CAP_FLAG_DYNAMIC_ALLOWED}, > >> + > >> + {B_FRAME_QP, ENC, HEVC, > >> + MIN_QP_10BIT, MAX_QP, 1, DEFAULT_QP, > >> + V4L2_CID_MPEG_VIDEO_HEVC_B_FRAME_QP, > >> + HFI_PROP_QP_PACKED, > >> + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT | > >> + CAP_FLAG_DYNAMIC_ALLOWED}, > >> + > >> + {B_FRAME_QP, ENC, H264, > >> + MIN_QP_8BIT, MAX_QP, 1, DEFAULT_QP, > >> + V4L2_CID_MPEG_VIDEO_H264_B_FRAME_QP, > >> + HFI_PROP_QP_PACKED, > >> + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT | > >> + CAP_FLAG_DYNAMIC_ALLOWED}, > >> + > >> + {LAYER_TYPE, ENC, HEVC, > >> + V4L2_MPEG_VIDEO_HEVC_HIERARCHICAL_CODING_B, > >> + V4L2_MPEG_VIDEO_HEVC_HIERARCHICAL_CODING_P, > >> + BIT(V4L2_MPEG_VIDEO_HEVC_HIERARCHICAL_CODING_B) | > >> + BIT(V4L2_MPEG_VIDEO_HEVC_HIERARCHICAL_CODING_P), > >> + V4L2_MPEG_VIDEO_HEVC_HIERARCHICAL_CODING_P, > >> + V4L2_CID_MPEG_VIDEO_HEVC_HIER_CODING_TYPE, > >> + HFI_PROP_LAYER_ENCODING_TYPE, > >> + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_MENU}, > >> + > >> + {LAYER_TYPE, ENC, H264, > >> + V4L2_MPEG_VIDEO_H264_HIERARCHICAL_CODING_B, > >> + V4L2_MPEG_VIDEO_H264_HIERARCHICAL_CODING_P, > >> + BIT(V4L2_MPEG_VIDEO_H264_HIERARCHICAL_CODING_B) | > >> + BIT(V4L2_MPEG_VIDEO_H264_HIERARCHICAL_CODING_P), > >> + V4L2_MPEG_VIDEO_H264_HIERARCHICAL_CODING_P, > >> + V4L2_CID_MPEG_VIDEO_H264_HIERARCHICAL_CODING_TYPE, > >> + HFI_PROP_LAYER_ENCODING_TYPE, > >> + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_MENU}, > >> + > >> + {LAYER_ENABLE, ENC, H264, > >> + 0, 1, 1, 0, > >> + V4L2_CID_MPEG_VIDEO_H264_HIERARCHICAL_CODING, > >> + HFI_PROP_LAYER_ENCODING_TYPE, > >> + CAP_FLAG_OUTPUT_PORT}, > >> + > >> + {LAYER_ENABLE, ENC, HEVC, > >> + 0, 1, 1, 0, > >> + 0, > >> + 0, > >> + CAP_FLAG_OUTPUT_PORT}, > >> + > >> + {ENH_LAYER_COUNT, ENC, HEVC, > >> + 0, 5, 1, 0, > >> + V4L2_CID_MPEG_VIDEO_HEVC_HIER_CODING_LAYER, > >> + HFI_PROP_LAYER_COUNT, > >> + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT | > >> + CAP_FLAG_DYNAMIC_ALLOWED}, > >> + > >> + {ENH_LAYER_COUNT, ENC, H264, > >> + 0, 5, 1, 0, > >> + V4L2_CID_MPEG_VIDEO_H264_HIERARCHICAL_CODING_LAYER, > >> + HFI_PROP_LAYER_COUNT, > >> + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT | > >> + CAP_FLAG_DYNAMIC_ALLOWED}, > >> + > >> + {L0_BR, ENC, H264, > >> + 1, MAX_BITRATE, 1, DEFAULT_BITRATE, > >> + V4L2_CID_MPEG_VIDEO_H264_HIER_CODING_L0_BR, > >> + HFI_PROP_BITRATE_LAYER1, > >> + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT | > >> + CAP_FLAG_DYNAMIC_ALLOWED}, > >> + > >> + {L0_BR, ENC, HEVC, > >> + 1, MAX_BITRATE, 1, DEFAULT_BITRATE, > >> + V4L2_CID_MPEG_VIDEO_HEVC_HIER_CODING_L0_BR, > >> + HFI_PROP_BITRATE_LAYER1, > >> + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT | > >> + CAP_FLAG_DYNAMIC_ALLOWED}, > >> + > >> + {L1_BR, ENC, H264, > >> + 1, MAX_BITRATE, 1, DEFAULT_BITRATE, > >> + V4L2_CID_MPEG_VIDEO_H264_HIER_CODING_L1_BR, > >> + HFI_PROP_BITRATE_LAYER2, > >> + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT | > >> + CAP_FLAG_DYNAMIC_ALLOWED}, > >> + > >> + {L1_BR, ENC, HEVC, > >> + 1, MAX_BITRATE, 1, DEFAULT_BITRATE, > >> + V4L2_CID_MPEG_VIDEO_HEVC_HIER_CODING_L1_BR, > >> + HFI_PROP_BITRATE_LAYER2, > >> + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT | > >> + CAP_FLAG_DYNAMIC_ALLOWED}, > >> + > >> + {L2_BR, ENC, H264, > >> + 1, MAX_BITRATE, 1, DEFAULT_BITRATE, > >> + V4L2_CID_MPEG_VIDEO_H264_HIER_CODING_L2_BR, > >> + HFI_PROP_BITRATE_LAYER3, > >> + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT | > >> + CAP_FLAG_DYNAMIC_ALLOWED}, > >> + > >> + {L2_BR, ENC, HEVC, > >> + 1, MAX_BITRATE, 1, DEFAULT_BITRATE, > >> + V4L2_CID_MPEG_VIDEO_HEVC_HIER_CODING_L2_BR, > >> + HFI_PROP_BITRATE_LAYER3, > >> + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT | > >> + CAP_FLAG_DYNAMIC_ALLOWED}, > >> + > >> + {L3_BR, ENC, H264, > >> + 1, MAX_BITRATE, 1, DEFAULT_BITRATE, > >> + V4L2_CID_MPEG_VIDEO_H264_HIER_CODING_L3_BR, > >> + HFI_PROP_BITRATE_LAYER4, > >> + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT | > >> + CAP_FLAG_DYNAMIC_ALLOWED}, > >> + {L3_BR, ENC, HEVC, > >> + 1, MAX_BITRATE, 1, DEFAULT_BITRATE, > >> + V4L2_CID_MPEG_VIDEO_HEVC_HIER_CODING_L3_BR, > >> + HFI_PROP_BITRATE_LAYER4, > >> + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT | > >> + CAP_FLAG_DYNAMIC_ALLOWED}, > >> + > >> + {L4_BR, ENC, H264, > >> + 1, MAX_BITRATE, 1, DEFAULT_BITRATE, > >> + V4L2_CID_MPEG_VIDEO_H264_HIER_CODING_L4_BR, > >> + HFI_PROP_BITRATE_LAYER5, > >> + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT | > >> + CAP_FLAG_DYNAMIC_ALLOWED}, > >> + > >> + {L4_BR, ENC, HEVC, > >> + 1, MAX_BITRATE, 1, DEFAULT_BITRATE, > >> + V4L2_CID_MPEG_VIDEO_HEVC_HIER_CODING_L4_BR, > >> + HFI_PROP_BITRATE_LAYER5, > >> + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT | > >> + CAP_FLAG_DYNAMIC_ALLOWED}, > >> + > >> + {L5_BR, ENC, H264, > >> + 1, MAX_BITRATE, 1, DEFAULT_BITRATE, > >> + V4L2_CID_MPEG_VIDEO_H264_HIER_CODING_L5_BR, > >> + HFI_PROP_BITRATE_LAYER6, > >> + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT | > >> + CAP_FLAG_DYNAMIC_ALLOWED}, > >> + > >> + {L5_BR, ENC, HEVC, > >> + 1, MAX_BITRATE, 1, DEFAULT_BITRATE, > >> + V4L2_CID_MPEG_VIDEO_HEVC_HIER_CODING_L5_BR, > >> + HFI_PROP_BITRATE_LAYER6, > >> + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT | > >> + CAP_FLAG_DYNAMIC_ALLOWED}, > >> + > >> + {ENTROPY_MODE, ENC, H264, > >> + V4L2_MPEG_VIDEO_H264_ENTROPY_MODE_CAVLC, > >> + V4L2_MPEG_VIDEO_H264_ENTROPY_MODE_CABAC, > >> + BIT(V4L2_MPEG_VIDEO_H264_ENTROPY_MODE_CAVLC) | > >> + BIT(V4L2_MPEG_VIDEO_H264_ENTROPY_MODE_CABAC), > >> + V4L2_MPEG_VIDEO_H264_ENTROPY_MODE_CABAC, > >> + V4L2_CID_MPEG_VIDEO_H264_ENTROPY_MODE, > >> + HFI_PROP_CABAC_SESSION, > >> + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_MENU}, > >> + > >> + {ENTROPY_MODE, DEC, H264 | HEVC | VP9, > >> + V4L2_MPEG_VIDEO_H264_ENTROPY_MODE_CAVLC, > >> + V4L2_MPEG_VIDEO_H264_ENTROPY_MODE_CABAC, > >> + BIT(V4L2_MPEG_VIDEO_H264_ENTROPY_MODE_CAVLC) | > >> + BIT(V4L2_MPEG_VIDEO_H264_ENTROPY_MODE_CABAC), > >> + V4L2_MPEG_VIDEO_H264_ENTROPY_MODE_CABAC, > >> + 0, > >> + HFI_PROP_CABAC_SESSION}, > >> + > >> + {PROFILE, ENC | DEC, H264, > >> + V4L2_MPEG_VIDEO_H264_PROFILE_BASELINE, > >> + V4L2_MPEG_VIDEO_H264_PROFILE_CONSTRAINED_HIGH, > >> + BIT(V4L2_MPEG_VIDEO_H264_PROFILE_BASELINE) | > >> + BIT(V4L2_MPEG_VIDEO_H264_PROFILE_CONSTRAINED_HIGH) | > >> + BIT(V4L2_MPEG_VIDEO_H264_PROFILE_CONSTRAINED_BASELINE) | > >> + BIT(V4L2_MPEG_VIDEO_H264_PROFILE_MAIN) | > >> + BIT(V4L2_MPEG_VIDEO_H264_PROFILE_HIGH), > >> + V4L2_MPEG_VIDEO_H264_PROFILE_HIGH, > >> + V4L2_CID_MPEG_VIDEO_H264_PROFILE, > >> + HFI_PROP_PROFILE, > >> + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_MENU}, > >> + > >> + {PROFILE, ENC | DEC, HEVC, > >> + V4L2_MPEG_VIDEO_HEVC_PROFILE_MAIN, > >> + V4L2_MPEG_VIDEO_HEVC_PROFILE_MAIN_10, > >> + BIT(V4L2_MPEG_VIDEO_HEVC_PROFILE_MAIN) | > >> + BIT(V4L2_MPEG_VIDEO_HEVC_PROFILE_MAIN_STILL_PICTURE) | > >> + BIT(V4L2_MPEG_VIDEO_HEVC_PROFILE_MAIN_10), > >> + V4L2_MPEG_VIDEO_HEVC_PROFILE_MAIN, > >> + V4L2_CID_MPEG_VIDEO_HEVC_PROFILE, > >> + HFI_PROP_PROFILE, > >> + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_MENU}, > >> + > >> + {PROFILE, DEC, VP9, > >> + V4L2_MPEG_VIDEO_VP9_PROFILE_0, > >> + V4L2_MPEG_VIDEO_VP9_PROFILE_2, > >> + BIT(V4L2_MPEG_VIDEO_VP9_PROFILE_0) | > >> + BIT(V4L2_MPEG_VIDEO_VP9_PROFILE_2), > >> + V4L2_MPEG_VIDEO_VP9_PROFILE_0, > >> + V4L2_CID_MPEG_VIDEO_VP9_PROFILE, > >> + HFI_PROP_PROFILE, > >> + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_MENU}, > >> + > >> + {LEVEL, ENC, H264, > >> + V4L2_MPEG_VIDEO_H264_LEVEL_1_0, > >> + V4L2_MPEG_VIDEO_H264_LEVEL_6_0, > >> + BIT(V4L2_MPEG_VIDEO_H264_LEVEL_1_0) | > >> + BIT(V4L2_MPEG_VIDEO_H264_LEVEL_1B) | > >> + BIT(V4L2_MPEG_VIDEO_H264_LEVEL_1_1) | > >> + BIT(V4L2_MPEG_VIDEO_H264_LEVEL_1_2) | > >> + BIT(V4L2_MPEG_VIDEO_H264_LEVEL_1_3) | > >> + BIT(V4L2_MPEG_VIDEO_H264_LEVEL_2_0) | > >> + BIT(V4L2_MPEG_VIDEO_H264_LEVEL_2_1) | > >> + BIT(V4L2_MPEG_VIDEO_H264_LEVEL_2_2) | > >> + BIT(V4L2_MPEG_VIDEO_H264_LEVEL_3_0) | > >> + BIT(V4L2_MPEG_VIDEO_H264_LEVEL_3_1) | > >> + BIT(V4L2_MPEG_VIDEO_H264_LEVEL_3_2) | > >> + BIT(V4L2_MPEG_VIDEO_H264_LEVEL_4_0) | > >> + BIT(V4L2_MPEG_VIDEO_H264_LEVEL_4_1) | > >> + BIT(V4L2_MPEG_VIDEO_H264_LEVEL_4_2) | > >> + BIT(V4L2_MPEG_VIDEO_H264_LEVEL_5_0) | > >> + BIT(V4L2_MPEG_VIDEO_H264_LEVEL_5_1) | > >> + BIT(V4L2_MPEG_VIDEO_H264_LEVEL_5_2) | > >> + BIT(V4L2_MPEG_VIDEO_H264_LEVEL_6_0), > >> + V4L2_MPEG_VIDEO_H264_LEVEL_5_0, > >> + V4L2_CID_MPEG_VIDEO_H264_LEVEL, > >> + HFI_PROP_LEVEL, > >> + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_MENU}, > >> + > >> + {LEVEL, ENC, HEVC, > >> + V4L2_MPEG_VIDEO_HEVC_LEVEL_1, > >> + V4L2_MPEG_VIDEO_HEVC_LEVEL_6_2, > >> + BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_1) | > >> + BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_2) | > >> + BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_2_1) | > >> + BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_3) | > >> + BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_3_1) | > >> + BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_4) | > >> + BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_4_1) | > >> + BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_5) | > >> + BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_5_1) | > >> + BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_5_2) | > >> + BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_6) | > >> + BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_6_1) | > >> + BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_6_2), > >> + V4L2_MPEG_VIDEO_HEVC_LEVEL_5, > >> + V4L2_CID_MPEG_VIDEO_HEVC_LEVEL, > >> + HFI_PROP_LEVEL, > >> + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_MENU}, > >> + > >> + {LEVEL, DEC, H264, > >> + V4L2_MPEG_VIDEO_H264_LEVEL_1_0, > >> + V4L2_MPEG_VIDEO_H264_LEVEL_6_2, > >> + BIT(V4L2_MPEG_VIDEO_H264_LEVEL_1_0) | > >> + BIT(V4L2_MPEG_VIDEO_H264_LEVEL_1B) | > >> + BIT(V4L2_MPEG_VIDEO_H264_LEVEL_1_1) | > >> + BIT(V4L2_MPEG_VIDEO_H264_LEVEL_1_2) | > >> + BIT(V4L2_MPEG_VIDEO_H264_LEVEL_1_3) | > >> + BIT(V4L2_MPEG_VIDEO_H264_LEVEL_2_0) | > >> + BIT(V4L2_MPEG_VIDEO_H264_LEVEL_2_1) | > >> + BIT(V4L2_MPEG_VIDEO_H264_LEVEL_2_2) | > >> + BIT(V4L2_MPEG_VIDEO_H264_LEVEL_3_0) | > >> + BIT(V4L2_MPEG_VIDEO_H264_LEVEL_3_1) | > >> + BIT(V4L2_MPEG_VIDEO_H264_LEVEL_3_2) | > >> + BIT(V4L2_MPEG_VIDEO_H264_LEVEL_4_0) | > >> + BIT(V4L2_MPEG_VIDEO_H264_LEVEL_4_1) | > >> + BIT(V4L2_MPEG_VIDEO_H264_LEVEL_4_2) | > >> + BIT(V4L2_MPEG_VIDEO_H264_LEVEL_5_0) | > >> + BIT(V4L2_MPEG_VIDEO_H264_LEVEL_5_1) | > >> + BIT(V4L2_MPEG_VIDEO_H264_LEVEL_5_2) | > >> + BIT(V4L2_MPEG_VIDEO_H264_LEVEL_6_0) | > >> + BIT(V4L2_MPEG_VIDEO_H264_LEVEL_6_1) | > >> + BIT(V4L2_MPEG_VIDEO_H264_LEVEL_6_2), > >> + V4L2_MPEG_VIDEO_H264_LEVEL_6_1, > >> + V4L2_CID_MPEG_VIDEO_H264_LEVEL, > >> + HFI_PROP_LEVEL, > >> + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_MENU}, > >> + > >> + {LEVEL, DEC, HEVC, > >> + V4L2_MPEG_VIDEO_HEVC_LEVEL_1, > >> + V4L2_MPEG_VIDEO_HEVC_LEVEL_6_2, > >> + BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_1) | > >> + BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_2) | > >> + BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_2_1) | > >> + BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_3) | > >> + BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_3_1) | > >> + BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_4) | > >> + BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_4_1) | > >> + BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_5) | > >> + BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_5_1) | > >> + BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_5_2) | > >> + BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_6) | > >> + BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_6_1) | > >> + BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_6_2), > >> + V4L2_MPEG_VIDEO_HEVC_LEVEL_6_1, > >> + V4L2_CID_MPEG_VIDEO_HEVC_LEVEL, > >> + HFI_PROP_LEVEL, > >> + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_MENU}, > >> + > >> + {LEVEL, DEC, VP9, > >> + V4L2_MPEG_VIDEO_VP9_LEVEL_1_0, > >> + V4L2_MPEG_VIDEO_VP9_LEVEL_6_0, > >> + BIT(V4L2_MPEG_VIDEO_VP9_LEVEL_1_0) | > >> + BIT(V4L2_MPEG_VIDEO_VP9_LEVEL_1_1) | > >> + BIT(V4L2_MPEG_VIDEO_VP9_LEVEL_2_0) | > >> + BIT(V4L2_MPEG_VIDEO_VP9_LEVEL_2_1) | > >> + BIT(V4L2_MPEG_VIDEO_VP9_LEVEL_3_0) | > >> + BIT(V4L2_MPEG_VIDEO_VP9_LEVEL_3_1) | > >> + BIT(V4L2_MPEG_VIDEO_VP9_LEVEL_4_0) | > >> + BIT(V4L2_MPEG_VIDEO_VP9_LEVEL_4_1) | > >> + BIT(V4L2_MPEG_VIDEO_VP9_LEVEL_5_0) | > >> + BIT(V4L2_MPEG_VIDEO_VP9_LEVEL_5_1) | > >> + BIT(V4L2_MPEG_VIDEO_VP9_LEVEL_5_2) | > >> + BIT(V4L2_MPEG_VIDEO_VP9_LEVEL_6_0), > >> + V4L2_MPEG_VIDEO_VP9_LEVEL_6_0, > >> + V4L2_CID_MPEG_VIDEO_VP9_LEVEL, > >> + HFI_PROP_LEVEL, > >> + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_MENU}, > >> + > >> + {HEVC_TIER, ENC | DEC, HEVC, > >> + V4L2_MPEG_VIDEO_HEVC_TIER_MAIN, > >> + V4L2_MPEG_VIDEO_HEVC_TIER_HIGH, > >> + BIT(V4L2_MPEG_VIDEO_HEVC_TIER_MAIN) | > >> + BIT(V4L2_MPEG_VIDEO_HEVC_TIER_HIGH), > >> + V4L2_MPEG_VIDEO_HEVC_TIER_HIGH, > >> + V4L2_CID_MPEG_VIDEO_HEVC_TIER, > >> + HFI_PROP_TIER, > >> + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_MENU}, > >> + > >> + {LF_MODE, ENC, H264, > >> + V4L2_MPEG_VIDEO_H264_LOOP_FILTER_MODE_ENABLED, > >> + DB_H264_DISABLE_SLICE_BOUNDARY, > >> + BIT(V4L2_MPEG_VIDEO_H264_LOOP_FILTER_MODE_ENABLED) | > >> + BIT(V4L2_MPEG_VIDEO_H264_LOOP_FILTER_MODE_DISABLED) | > >> + BIT(DB_H264_DISABLE_SLICE_BOUNDARY), > >> + V4L2_MPEG_VIDEO_H264_LOOP_FILTER_MODE_ENABLED, > >> + V4L2_CID_MPEG_VIDEO_H264_LOOP_FILTER_MODE, > >> + HFI_PROP_DEBLOCKING_MODE, > >> + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_MENU}, > >> + > >> + {LF_MODE, ENC, HEVC, > >> + V4L2_MPEG_VIDEO_HEVC_LOOP_FILTER_MODE_DISABLED, > >> + DB_HEVC_DISABLE_SLICE_BOUNDARY, > >> + BIT(V4L2_MPEG_VIDEO_HEVC_LOOP_FILTER_MODE_DISABLED) | > >> + BIT(V4L2_MPEG_VIDEO_HEVC_LOOP_FILTER_MODE_ENABLED) | > >> + BIT(DB_HEVC_DISABLE_SLICE_BOUNDARY), > >> + V4L2_MPEG_VIDEO_HEVC_LOOP_FILTER_MODE_ENABLED, > >> + V4L2_CID_MPEG_VIDEO_HEVC_LOOP_FILTER_MODE, > >> + HFI_PROP_DEBLOCKING_MODE, > >> + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_MENU}, > >> + > >> + {LF_ALPHA, ENC, H264, > >> + -6, 6, 1, 0, > >> + V4L2_CID_MPEG_VIDEO_H264_LOOP_FILTER_ALPHA}, > >> + > >> + {LF_ALPHA, ENC, HEVC, > >> + -6, 6, 1, 0, > >> + V4L2_CID_MPEG_VIDEO_HEVC_LF_TC_OFFSET_DIV2}, > >> + > >> + {LF_BETA, ENC, H264, > >> + -6, 6, 1, 0, > >> + V4L2_CID_MPEG_VIDEO_H264_LOOP_FILTER_BETA}, > >> + > >> + {LF_BETA, ENC, HEVC, > >> + -6, 6, 1, 0, > >> + V4L2_CID_MPEG_VIDEO_HEVC_LF_BETA_OFFSET_DIV2}, > >> + > >> + {SLICE_MODE, ENC, H264 | HEVC, > >> + V4L2_MPEG_VIDEO_MULTI_SLICE_MODE_SINGLE, > >> + V4L2_MPEG_VIDEO_MULTI_SLICE_MODE_MAX_BYTES, > >> + BIT(V4L2_MPEG_VIDEO_MULTI_SLICE_MODE_SINGLE) | > >> + BIT(V4L2_MPEG_VIDEO_MULTI_SLICE_MODE_MAX_MB) | > >> + BIT(V4L2_MPEG_VIDEO_MULTI_SLICE_MODE_MAX_BYTES), > >> + V4L2_MPEG_VIDEO_MULTI_SLICE_MODE_SINGLE, > >> + V4L2_CID_MPEG_VIDEO_MULTI_SLICE_MODE, > >> + 0, > >> + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_MENU}, > >> + > >> + {SLICE_MAX_BYTES, ENC, H264 | HEVC, > >> + MIN_SLICE_BYTE_SIZE, MAX_SLICE_BYTE_SIZE, > >> + 1, MIN_SLICE_BYTE_SIZE, > >> + V4L2_CID_MPEG_VIDEO_MULTI_SLICE_MAX_BYTES, > >> + HFI_PROP_MULTI_SLICE_BYTES_COUNT, > >> + CAP_FLAG_OUTPUT_PORT}, > >> + > >> + {SLICE_MAX_MB, ENC, H264 | HEVC, > >> + 1, MAX_SLICE_MB_SIZE, 1, 1, > >> + V4L2_CID_MPEG_VIDEO_MULTI_SLICE_MAX_MB, > >> + HFI_PROP_MULTI_SLICE_MB_COUNT, > >> + CAP_FLAG_OUTPUT_PORT}, > >> + > >> + {MB_RC, ENC, H264 | HEVC, > >> + 0, 1, 1, 1, > >> + V4L2_CID_MPEG_VIDEO_MB_RC_ENABLE, > >> + 0, > >> + CAP_FLAG_OUTPUT_PORT}, > >> + > >> + {TRANSFORM_8X8, ENC, H264, > >> + 0, 1, 1, 1, > >> + V4L2_CID_MPEG_VIDEO_H264_8X8_TRANSFORM, > >> + HFI_PROP_8X8_TRANSFORM, > >> + CAP_FLAG_OUTPUT_PORT}, > >> + > >> + {CHROMA_QP_INDEX_OFFSET, ENC, HEVC, > >> + MIN_CHROMA_QP_OFFSET, MAX_CHROMA_QP_OFFSET, > >> + 1, MAX_CHROMA_QP_OFFSET, > >> + V4L2_CID_MPEG_VIDEO_H264_CHROMA_QP_INDEX_OFFSET, > >> + HFI_PROP_CHROMA_QP_OFFSET, > >> + CAP_FLAG_OUTPUT_PORT}, > >> + > >> + {DISPLAY_DELAY_ENABLE, DEC, H264 | HEVC | VP9, > >> + 0, 1, 1, 0, > >> + V4L2_CID_MPEG_VIDEO_DEC_DISPLAY_DELAY_ENABLE, > >> + HFI_PROP_DECODE_ORDER_OUTPUT, > >> + CAP_FLAG_INPUT_PORT}, > >> + > >> + {DISPLAY_DELAY, DEC, H264 | HEVC | VP9, > >> + 0, 1, 1, 0, > >> + V4L2_CID_MPEG_VIDEO_DEC_DISPLAY_DELAY, > >> + HFI_PROP_DECODE_ORDER_OUTPUT, > >> + CAP_FLAG_INPUT_PORT}, > >> + > >> + {OUTPUT_ORDER, DEC, H264 | HEVC | VP9, > >> + 0, 1, 1, 0, > >> + 0, > >> + HFI_PROP_DECODE_ORDER_OUTPUT, > >> + CAP_FLAG_INPUT_PORT}, > >> + > >> + {INPUT_BUF_HOST_MAX_COUNT, ENC | DEC, CODECS_ALL, > >> + DEFAULT_MAX_HOST_BUF_COUNT, DEFAULT_MAX_HOST_BURST_BUF_COUNT, > >> + 1, DEFAULT_MAX_HOST_BUF_COUNT, > >> + 0, > >> + HFI_PROP_BUFFER_HOST_MAX_COUNT, > >> + CAP_FLAG_INPUT_PORT}, > >> + > >> + {OUTPUT_BUF_HOST_MAX_COUNT, ENC | DEC, CODECS_ALL, > >> + DEFAULT_MAX_HOST_BUF_COUNT, DEFAULT_MAX_HOST_BURST_BUF_COUNT, > >> + 1, DEFAULT_MAX_HOST_BUF_COUNT, > >> + 0, > >> + HFI_PROP_BUFFER_HOST_MAX_COUNT, > >> + CAP_FLAG_OUTPUT_PORT}, > >> + > >> + {CONCEAL_COLOR_8BIT, DEC, CODECS_ALL, 0x0, 0xff3fcff, 1, > >> + DEFAULT_VIDEO_CONCEAL_COLOR_BLACK, > >> + V4L2_CID_MPEG_VIDEO_MUTE_YUV, > >> + HFI_PROP_CONCEAL_COLOR_8BIT, > >> + CAP_FLAG_INPUT_PORT}, > >> + > >> + {CONCEAL_COLOR_10BIT, DEC, CODECS_ALL, 0x0, 0x3fffffff, 1, > >> + DEFAULT_VIDEO_CONCEAL_COLOR_BLACK, > >> + V4L2_CID_MPEG_VIDEO_MUTE_YUV, > >> + HFI_PROP_CONCEAL_COLOR_10BIT, > >> + CAP_FLAG_INPUT_PORT}, > >> + > >> + {STAGE, DEC | ENC, CODECS_ALL, > >> + MSM_VIDC_STAGE_1, > >> + MSM_VIDC_STAGE_2, 1, > >> + MSM_VIDC_STAGE_2, > >> + 0, > >> + HFI_PROP_STAGE}, > >> + > >> + {PIPE, DEC | ENC, CODECS_ALL, > >> + MSM_VIDC_PIPE_1, > >> + MSM_VIDC_PIPE_4, 1, > >> + MSM_VIDC_PIPE_4, > >> + 0, > >> + HFI_PROP_PIPE}, > >> + > >> + {POC, DEC, H264, 0, 2, 1, 1, > >> + 0, > >> + HFI_PROP_PIC_ORDER_CNT_TYPE}, > >> + > >> + {QUALITY_MODE, ENC, CODECS_ALL, > >> + MSM_VIDC_MAX_QUALITY_MODE, > >> + MSM_VIDC_POWER_SAVE_MODE, 1, > >> + MSM_VIDC_POWER_SAVE_MODE}, > >> + > >> + {CODED_FRAMES, DEC, H264 | HEVC, > >> + CODED_FRAMES_PROGRESSIVE, CODED_FRAMES_INTERLACE, > >> + 1, CODED_FRAMES_PROGRESSIVE, > >> + 0, > >> + HFI_PROP_CODED_FRAMES}, > >> + > >> + {BIT_DEPTH, DEC, CODECS_ALL, BIT_DEPTH_8, BIT_DEPTH_10, 1, BIT_DEPTH_8, > >> + 0, > >> + HFI_PROP_LUMA_CHROMA_BIT_DEPTH}, > >> + > >> + {BITSTREAM_SIZE_OVERWRITE, DEC, CODECS_ALL, 0, INT_MAX, 1, 0, > >> + 0}, > >> + > >> + {DEFAULT_HEADER, DEC, CODECS_ALL, > >> + 0, 1, 1, 0, > >> + 0, > >> + HFI_PROP_DEC_DEFAULT_HEADER}, > >> + > >> + {RAP_FRAME, DEC, CODECS_ALL, > >> + 0, 1, 1, 1, > >> + 0, > >> + HFI_PROP_DEC_START_FROM_RAP_FRAME, > >> + CAP_FLAG_INPUT_PORT}, > >> + > >> + {SEQ_CHANGE_AT_SYNC_FRAME, DEC, CODECS_ALL, > >> + 0, 1, 1, 1, > >> + 0, > >> + HFI_PROP_SEQ_CHANGE_AT_SYNC_FRAME, > >> + CAP_FLAG_INPUT_PORT | CAP_FLAG_DYNAMIC_ALLOWED}, > >> + > >> + {ALL_INTRA, ENC, H264 | HEVC, > >> + 0, 1, 1, 0, > >> + 0, > >> + 0, > >> + CAP_FLAG_OUTPUT_PORT}, > >> +}; > >> + > >> +static struct msm_platform_inst_cap_dependency > >> instance_cap_dependency_data_sm8550[] = { > >> + /* {cap, domain, codec, > >> + * children, > >> + * adjust, set} > >> + */ > >> + > >> + {PIX_FMTS, ENC, H264, > >> + {IR_PERIOD}}, > >> + > >> + {PIX_FMTS, ENC, HEVC, > >> + {PROFILE, MIN_FRAME_QP, MAX_FRAME_QP, I_FRAME_QP, P_FRAME_QP, > >> + B_FRAME_QP, MIN_QUALITY, IR_PERIOD, LTR_COUNT}}, > >> + > >> + {PIX_FMTS, DEC, HEVC, > >> + {PROFILE}}, > >> + > >> + {FRAME_RATE, ENC, CODECS_ALL, > >> + {0}, > >> + NULL, > >> + msm_vidc_set_q16}, > >> + > >> + {HFLIP, ENC, CODECS_ALL, > >> + {0}, > >> + NULL, > >> + msm_vidc_set_flip}, > >> + > >> + {VFLIP, ENC, CODECS_ALL, > >> + {0}, > >> + NULL, > >> + msm_vidc_set_flip}, > >> + > >> + {ROTATION, ENC, CODECS_ALL, > >> + {0}, > >> + NULL, > >> + msm_vidc_set_rotation}, > >> + > >> + {HEADER_MODE, ENC, CODECS_ALL, > >> + {0}, > >> + NULL, > >> + msm_vidc_set_header_mode}, > >> + > >> + {WITHOUT_STARTCODE, ENC, CODECS_ALL, > >> + {0}, > >> + NULL, > >> + msm_vidc_set_nal_length}, > >> + > >> + {REQUEST_I_FRAME, ENC, H264 | HEVC, > >> + {0}, > >> + NULL, > >> + msm_vidc_set_req_sync_frame}, > >> + > >> + {BIT_RATE, ENC, H264, > >> + {PEAK_BITRATE, L0_BR}, > >> + msm_vidc_adjust_bitrate, > >> + msm_vidc_set_bitrate}, > >> + > >> + {BIT_RATE, ENC, HEVC, > >> + {PEAK_BITRATE, L0_BR}, > >> + msm_vidc_adjust_bitrate, > >> + msm_vidc_set_bitrate}, > >> + > >> + {BITRATE_MODE, ENC, H264, > >> + {LTR_COUNT, IR_PERIOD, I_FRAME_QP, P_FRAME_QP, > >> + B_FRAME_QP, ENH_LAYER_COUNT, BIT_RATE, > >> + MIN_QUALITY, VBV_DELAY, > >> + PEAK_BITRATE, SLICE_MODE}, > >> + msm_vidc_adjust_bitrate_mode, > >> + msm_vidc_set_u32_enum}, > >> + > >> + {BITRATE_MODE, ENC, HEVC, > >> + {LTR_COUNT, IR_PERIOD, I_FRAME_QP, P_FRAME_QP, > >> + B_FRAME_QP, CONSTANT_QUALITY, ENH_LAYER_COUNT, > >> + BIT_RATE, MIN_QUALITY, VBV_DELAY, > >> + PEAK_BITRATE, SLICE_MODE}, > >> + msm_vidc_adjust_bitrate_mode, > >> + msm_vidc_set_u32_enum}, > >> + > >> + {CONSTANT_QUALITY, ENC, HEVC, > >> + {0}, > >> + NULL, > >> + msm_vidc_set_constant_quality}, > >> + > >> + {GOP_SIZE, ENC, CODECS_ALL, > >> + {ALL_INTRA}, > >> + msm_vidc_adjust_gop_size, > >> + msm_vidc_set_gop_size}, > >> + > >> + {B_FRAME, ENC, H264 | HEVC, > >> + {ALL_INTRA}, > >> + msm_vidc_adjust_b_frame, > >> + msm_vidc_set_u32}, > >> + > >> + {LTR_COUNT, ENC, H264 | HEVC, > >> + {0}, > >> + msm_vidc_adjust_ltr_count, > >> + msm_vidc_set_u32}, > >> + > >> + {USE_LTR, ENC, H264 | HEVC, > >> + {0}, > >> + msm_vidc_adjust_use_ltr, > >> + msm_vidc_set_use_and_mark_ltr}, > >> + > >> + {MARK_LTR, ENC, H264 | HEVC, > >> + {0}, > >> + msm_vidc_adjust_mark_ltr, > >> + msm_vidc_set_use_and_mark_ltr}, > >> + > >> + {IR_PERIOD, ENC, H264 | HEVC, > >> + {0}, > >> + msm_vidc_adjust_ir_period, > >> + msm_vidc_set_ir_period}, > >> + > >> + {AU_DELIMITER, ENC, H264 | HEVC, > >> + {0}, > >> + NULL, > >> + msm_vidc_set_u32}, > >> + > >> + {MIN_QUALITY, ENC, H264, > >> + {0}, > >> + msm_vidc_adjust_min_quality, > >> + msm_vidc_set_u32}, > >> + > >> + {MIN_QUALITY, ENC, HEVC, > >> + {0}, > >> + msm_vidc_adjust_min_quality, > >> + msm_vidc_set_u32}, > >> + > >> + {VBV_DELAY, ENC, H264 | HEVC, > >> + {0}, > >> + NULL, > >> + msm_vidc_set_cbr_related_properties}, > >> + > >> + {PEAK_BITRATE, ENC, H264 | HEVC, > >> + {0}, > >> + msm_vidc_adjust_peak_bitrate, > >> + msm_vidc_set_cbr_related_properties}, > >> + > >> + {MIN_FRAME_QP, ENC, H264, > >> + {0}, > >> + NULL, > >> + msm_vidc_set_min_qp}, > >> + > >> + {MIN_FRAME_QP, ENC, HEVC, > >> + {0}, > >> + msm_vidc_adjust_hevc_min_qp, > >> + msm_vidc_set_min_qp}, > >> + > >> + {MAX_FRAME_QP, ENC, H264, > >> + {0}, > >> + NULL, > >> + msm_vidc_set_max_qp}, > >> + > >> + {MAX_FRAME_QP, ENC, HEVC, > >> + {0}, > >> + msm_vidc_adjust_hevc_max_qp, > >> + msm_vidc_set_max_qp}, > >> + > >> + {I_FRAME_QP, ENC, HEVC, > >> + {0}, > >> + msm_vidc_adjust_hevc_i_frame_qp, > >> + msm_vidc_set_frame_qp}, > >> + > >> + {I_FRAME_QP, ENC, H264, > >> + {0}, > >> + NULL, > >> + msm_vidc_set_frame_qp}, > >> + > >> + {P_FRAME_QP, ENC, HEVC, > >> + {0}, > >> + msm_vidc_adjust_hevc_p_frame_qp, > >> + msm_vidc_set_frame_qp}, > >> + > >> + {P_FRAME_QP, ENC, H264, > >> + {0}, > >> + NULL, > >> + msm_vidc_set_frame_qp}, > >> + > >> + {B_FRAME_QP, ENC, HEVC, > >> + {0}, > >> + msm_vidc_adjust_hevc_b_frame_qp, > >> + msm_vidc_set_frame_qp}, > >> + > >> + {B_FRAME_QP, ENC, H264, > >> + {0}, > >> + NULL, > >> + msm_vidc_set_frame_qp}, > >> + > >> + {LAYER_TYPE, ENC, H264 | HEVC, > >> + {LTR_COUNT}}, > >> + > >> + {LAYER_ENABLE, ENC, H264 | HEVC, > >> + {0}}, > >> + > >> + {ENH_LAYER_COUNT, ENC, H264 | HEVC, > >> + {GOP_SIZE, B_FRAME, BIT_RATE, MIN_QUALITY, SLICE_MODE, > >> + LTR_COUNT}, > >> + msm_vidc_adjust_layer_count, > >> + msm_vidc_set_layer_count_and_type}, > >> + > >> + {L0_BR, ENC, H264 | HEVC, > >> + {L1_BR}, > >> + msm_vidc_adjust_layer_bitrate, > >> + msm_vidc_set_layer_bitrate}, > >> + > >> + {L1_BR, ENC, H264 | HEVC, > >> + {L2_BR}, > >> + msm_vidc_adjust_layer_bitrate, > >> + msm_vidc_set_layer_bitrate}, > >> + > >> + {L2_BR, ENC, H264 | HEVC, > >> + {L3_BR}, > >> + msm_vidc_adjust_layer_bitrate, > >> + msm_vidc_set_layer_bitrate}, > >> + > >> + {L3_BR, ENC, H264 | HEVC, > >> + {L4_BR}, > >> + msm_vidc_adjust_layer_bitrate, > >> + msm_vidc_set_layer_bitrate}, > >> + > >> + {L4_BR, ENC, H264 | HEVC, > >> + {L5_BR}, > >> + msm_vidc_adjust_layer_bitrate, > >> + msm_vidc_set_layer_bitrate}, > >> + > >> + {L5_BR, ENC, H264 | HEVC, > >> + {0}, > >> + msm_vidc_adjust_layer_bitrate, > >> + msm_vidc_set_layer_bitrate}, > >> + > >> + {ENTROPY_MODE, ENC, H264, > >> + {BIT_RATE}, > >> + msm_vidc_adjust_entropy_mode, > >> + msm_vidc_set_u32}, > >> + > >> + {PROFILE, ENC, H264, > >> + {ENTROPY_MODE, TRANSFORM_8X8}, > >> + NULL, > >> + msm_vidc_set_u32_enum}, > >> + > >> + {PROFILE, DEC, H264, > >> + {ENTROPY_MODE}, > >> + NULL, > >> + msm_vidc_set_u32_enum}, > >> + > >> + {PROFILE, ENC | DEC, HEVC, > >> + {0}, > >> + msm_vidc_adjust_profile, > >> + msm_vidc_set_u32_enum}, > >> + > >> + {PROFILE, DEC, VP9, > >> + {0}, > >> + NULL, > >> + msm_vidc_set_u32_enum}, > >> + > >> + {LEVEL, DEC, CODECS_ALL, > >> + {0}, > >> + NULL, > >> + msm_vidc_set_u32_enum}, > >> + > >> + {LEVEL, ENC, CODECS_ALL, > >> + {0}, > >> + NULL, > >> + msm_vidc_set_level}, > >> + > >> + {HEVC_TIER, ENC | DEC, HEVC, > >> + {0}, > >> + NULL, > >> + msm_vidc_set_u32_enum}, > >> + > >> + {LF_MODE, ENC, CODECS_ALL, > >> + {0}, > >> + NULL, > >> + msm_vidc_set_deblock_mode}, > >> + > >> + {SLICE_MODE, ENC, H264 | HEVC, > >> + {STAGE}, > >> + msm_vidc_adjust_slice_count, > >> + msm_vidc_set_slice_count}, > >> + > >> + {TRANSFORM_8X8, ENC, H264, > >> + {0}, > >> + msm_vidc_adjust_transform_8x8, > >> + msm_vidc_set_u32}, > >> + > >> + {CHROMA_QP_INDEX_OFFSET, ENC, HEVC, > >> + {0}, > >> + msm_vidc_adjust_chroma_qp_index_offset, > >> + msm_vidc_set_chroma_qp_index_offset}, > >> + > >> + {DISPLAY_DELAY_ENABLE, DEC, H264 | HEVC | VP9, > >> + {OUTPUT_ORDER}, > >> + NULL, > >> + NULL}, > >> + > >> + {DISPLAY_DELAY, DEC, H264 | HEVC | VP9, > >> + {OUTPUT_ORDER}, > >> + NULL, > >> + NULL}, > >> + > >> + {OUTPUT_ORDER, DEC, H264 | HEVC | VP9, > >> + {0}, > >> + msm_vidc_adjust_output_order, > >> + msm_vidc_set_u32}, > >> + > >> + {INPUT_BUF_HOST_MAX_COUNT, ENC | DEC, CODECS_ALL, > >> + {0}, > >> + msm_vidc_adjust_input_buf_host_max_count, > >> + msm_vidc_set_u32}, > >> + > >> + {INPUT_BUF_HOST_MAX_COUNT, ENC, H264 | HEVC, > >> + {0}, > >> + msm_vidc_adjust_input_buf_host_max_count, > >> + msm_vidc_set_u32}, > >> + > >> + {OUTPUT_BUF_HOST_MAX_COUNT, ENC | DEC, CODECS_ALL, > >> + {0}, > >> + msm_vidc_adjust_output_buf_host_max_count, > >> + msm_vidc_set_u32}, > >> + > >> + {OUTPUT_BUF_HOST_MAX_COUNT, ENC, H264 | HEVC, > >> + {0}, > >> + msm_vidc_adjust_output_buf_host_max_count, > >> + msm_vidc_set_u32}, > >> + > >> + {CONCEAL_COLOR_8BIT, DEC, CODECS_ALL, > >> + {0}, > >> + NULL, > >> + msm_vidc_set_u32_packed}, > >> + > >> + {CONCEAL_COLOR_10BIT, DEC, CODECS_ALL, > >> + {0}, > >> + NULL, > >> + msm_vidc_set_u32_packed}, > >> + > >> + {STAGE, ENC | DEC, CODECS_ALL, > >> + {0}, > >> + NULL, > >> + msm_vidc_set_stage}, > >> + > >> + {STAGE, ENC, H264 | HEVC, > >> + {0}, > >> + NULL, > >> + msm_vidc_set_stage}, > >> + > >> + {STAGE, DEC, H264 | HEVC | VP9, > >> + {0}, > >> + NULL, > >> + msm_vidc_set_stage}, > >> + > >> + {PIPE, DEC | ENC, CODECS_ALL, > >> + {0}, > >> + NULL, > >> + msm_vidc_set_pipe}, > >> + > >> + {RAP_FRAME, DEC, CODECS_ALL, > >> + {0}, > >> + NULL, > >> + msm_vidc_set_u32}, > >> + > >> + {ALL_INTRA, ENC, H264 | HEVC, > >> + {LTR_COUNT, IR_PERIOD, SLICE_MODE, BIT_RATE}, > >> + msm_vidc_adjust_all_intra, > >> + NULL}, > >> +}; > >> + > >> +/* Default UBWC config for LPDDR5 */ > >> +static struct msm_vidc_ubwc_config_data ubwc_config_sm8550[] = { > >> + UBWC_CONFIG(8, 32, 16, 0, 1, 1, 1), > >> +}; > >> + > >> +static struct msm_vidc_format_capability format_data_sm8550 = { > >> + .codec_info = codec_data_sm8550, > >> + .codec_info_size = ARRAY_SIZE(codec_data_sm8550), > >> + .color_format_info = color_format_data_sm8550, > >> + .color_format_info_size = ARRAY_SIZE(color_format_data_sm8550), > >> + .color_prim_info = color_primaries_data_sm8550, > >> + .color_prim_info_size = ARRAY_SIZE(color_primaries_data_sm8550), > >> + .transfer_char_info = transfer_char_data_sm8550, > >> + .transfer_char_info_size = ARRAY_SIZE(transfer_char_data_sm8550), > >> + .matrix_coeff_info = matrix_coeff_data_sm8550, > >> + .matrix_coeff_info_size = ARRAY_SIZE(matrix_coeff_data_sm8550), > >> +}; > >> + > >> +/* name, min_kbps, max_kbps */ > >> +static const struct bw_table sm8550_bw_table[] = { > >> + { "venus-cnoc", 1000, 1000 }, > >> + { "venus-ddr", 1000, 15000000 }, > > > > We have OPP tables for that. There is no need to limit the min/max, just > > put it to OPP. > > > This table is used to vote for min and max bus bandwidth. > for some test vector with bad picture order count, ref count can be huge, > so DPB needs to be filled with high number of reference frames to process > current frames, this needs faster frame processing so to address such > cases, driver vote for max bus bandwidth. > for some cases, when system is in suspend state, there might be some > residual transitions happening for which driver needs to vote for min > frequency during suspend state. So? This can all be handled as a code handling OPP tables. I'm not judging your voting code. I'm asking you to drop custom table and use existing kernel mechanism for defining frequency / bandwidth tables. > >> +}; > >> + > >> +/* name */ > >> +static const struct pd_table sm8550_pd_table[] = { > >> + { "iris-ctl" }, > >> + { "vcodec" }, > >> +}; > >> + > >> +/* name */ > >> +static const char * const sm8550_opp_table[] = { "mx", "mmcx", NULL }; > >> + > >> +/* name, clock id, scaling */ > >> +static const struct clk_table sm8550_clk_table[] = { > >> + { "gcc_video_axi0", GCC_VIDEO_AXI0_CLK, 0 }, > >> + { "core_clk", VIDEO_CC_MVS0C_CLK, 0 }, > >> + { "vcodec_clk", VIDEO_CC_MVS0_CLK, 1 }, > >> +}; > > > > This strucuture looks like a perfect candidate to be replaced by > > devm_clk_bulk_get_all(). > > > Nice suggestion, will explore this. > >> + > >> +/* name, exclusive_release */ > >> +static const struct clk_rst_table sm8550_clk_reset_table[] = { > >> + { "video_axi_reset", 0 }, > > > > Can we assume that resets are generic at least? > > > reset clocks can change for different hardware. They can. But do they change for existing hardware? > >> +}; > >> + > >> +/* name, start, size, secure, dma_coherant, region, dma_mask */ > >> +const struct context_bank_table sm8550_context_bank_table[] = { > >> + {"qcom,vidc,cb-ns", 0x25800000, 0xba800000, 0, 1, > >> MSM_VIDC_NON_SECURE, 0xe0000000 - 1}, > >> + {"qcom,vidc,cb-sec-non-pxl", 0x01000000, 0x24800000, 1, 0, > >> MSM_VIDC_SECURE_NONPIXEL, 0 }, > > > > Aren't these a properties of subdevices? If so, why are you putting them here? > > > Will remove these in next version. > >> +}; > >> + > >> +/* freq */ > >> +static struct freq_table sm8550_freq_table[] = { > >> + {533333333}, {444000000}, {366000000}, {338000000}, {240000000} > > > > OPP table contents. > > > we are using this freq table at multiple places apart from voting like > - setting freq to turbo for few use cases > - limiting the freq to NOM > - changing the frequency levels based on DCVS > hence this table is need. And it doesn't stop it from being encoded as OPP table. We have devfreq for DCVS, and OPP has a notion of turbo / nominal values. > >> +}; > >> + > >> +/* register, value, mask */ > >> +static const struct reg_preset_table sm8550_reg_preset_table[] = { > >> + { 0xB0088, 0x0, 0x11 }, > >> +}; > >> + > >> +/* decoder properties */ > >> +static const u32 sm8550_vdec_psc_avc[] = { > >> + HFI_PROP_BITSTREAM_RESOLUTION, > >> + HFI_PROP_CROP_OFFSETS, > >> + HFI_PROP_CODED_FRAMES, > >> + HFI_PROP_BUFFER_FW_MIN_OUTPUT_COUNT, > >> + HFI_PROP_PIC_ORDER_CNT_TYPE, > >> + HFI_PROP_PROFILE, > >> + HFI_PROP_LEVEL, > >> + HFI_PROP_SIGNAL_COLOR_INFO, > >> +}; > >> + > >> +static const u32 sm8550_vdec_psc_hevc[] = { > >> + HFI_PROP_BITSTREAM_RESOLUTION, > >> + HFI_PROP_CROP_OFFSETS, > >> + HFI_PROP_LUMA_CHROMA_BIT_DEPTH, > >> + HFI_PROP_BUFFER_FW_MIN_OUTPUT_COUNT, > >> + HFI_PROP_PROFILE, > >> + HFI_PROP_LEVEL, > >> + HFI_PROP_TIER, > >> + HFI_PROP_SIGNAL_COLOR_INFO, > >> +}; > >> + > >> +static const u32 sm8550_vdec_psc_vp9[] = { > >> + HFI_PROP_BITSTREAM_RESOLUTION, > >> + HFI_PROP_CROP_OFFSETS, > >> + HFI_PROP_LUMA_CHROMA_BIT_DEPTH, > >> + HFI_PROP_BUFFER_FW_MIN_OUTPUT_COUNT, > >> + HFI_PROP_PROFILE, > >> + HFI_PROP_LEVEL, > >> +}; > >> + > >> +static const u32 sm8550_vdec_input_properties_avc[] = { > >> + HFI_PROP_NO_OUTPUT, > >> + HFI_PROP_SUBFRAME_INPUT, > >> +}; > >> + > >> +static const u32 sm8550_vdec_input_properties_hevc[] = { > >> + HFI_PROP_NO_OUTPUT, > >> + HFI_PROP_SUBFRAME_INPUT, > >> +}; > >> + > >> +static const u32 sm8550_vdec_input_properties_vp9[] = { > >> + HFI_PROP_NO_OUTPUT, > >> + HFI_PROP_SUBFRAME_INPUT, > >> +}; > >> + > >> +static const u32 sm8550_vdec_output_properties_avc[] = { > >> + HFI_PROP_WORST_COMPRESSION_RATIO, > >> + HFI_PROP_WORST_COMPLEXITY_FACTOR, > >> + HFI_PROP_PICTURE_TYPE, > >> + HFI_PROP_DPB_LIST, > >> + HFI_PROP_CABAC_SESSION, > >> +}; > >> + > >> +static const u32 sm8550_vdec_output_properties_hevc[] = { > >> + HFI_PROP_WORST_COMPRESSION_RATIO, > >> + HFI_PROP_WORST_COMPLEXITY_FACTOR, > >> + HFI_PROP_PICTURE_TYPE, > >> + HFI_PROP_DPB_LIST, > >> +}; > >> + > >> +static const u32 sm8550_vdec_output_properties_vp9[] = { > >> + HFI_PROP_WORST_COMPRESSION_RATIO, > >> + HFI_PROP_WORST_COMPLEXITY_FACTOR, > >> + HFI_PROP_PICTURE_TYPE, > >> + HFI_PROP_DPB_LIST, > >> +}; > >> + > >> +static const struct msm_vidc_platform_data sm8550_data = { > >> + /* resources dependent on other module */ > >> + .bw_tbl = sm8550_bw_table, > >> + .bw_tbl_size = ARRAY_SIZE(sm8550_bw_table), > >> + .clk_tbl = sm8550_clk_table, > >> + .clk_tbl_size = ARRAY_SIZE(sm8550_clk_table), > >> + .clk_rst_tbl = sm8550_clk_reset_table, > >> + .clk_rst_tbl_size = ARRAY_SIZE(sm8550_clk_reset_table), > >> + .subcache_tbl = NULL, > >> + .subcache_tbl_size = 0, > >> + > >> + /* populate context bank */ > >> + .context_bank_tbl = sm8550_context_bank_table, > >> + .context_bank_tbl_size = ARRAY_SIZE(sm8550_context_bank_table), > >> + > >> + /* populate power domain and opp table */ > >> + .pd_tbl = sm8550_pd_table, > >> + .pd_tbl_size = ARRAY_SIZE(sm8550_pd_table), > >> + .opp_tbl = sm8550_opp_table, > >> + .opp_tbl_size = ARRAY_SIZE(sm8550_opp_table), > >> + > >> + /* platform specific resources */ > >> + .freq_tbl = sm8550_freq_table, > >> + .freq_tbl_size = ARRAY_SIZE(sm8550_freq_table), > >> + .reg_prst_tbl = sm8550_reg_preset_table, > >> + .reg_prst_tbl_size = ARRAY_SIZE(sm8550_reg_preset_table), > >> + .fwname = "vpu30_4v", > >> + .pas_id = 9, > >> + > >> + /* caps related resorces */ > >> + .core_data = core_data_sm8550, > >> + .core_data_size = ARRAY_SIZE(core_data_sm8550), > >> + .inst_cap_data = instance_cap_data_sm8550, > >> + .inst_cap_data_size = ARRAY_SIZE(instance_cap_data_sm8550), > >> + .inst_cap_dependency_data = instance_cap_dependency_data_sm8550, > >> + .inst_cap_dependency_data_size = > >> ARRAY_SIZE(instance_cap_dependency_data_sm8550), > >> + .ubwc_config = ubwc_config_sm8550, > >> + .format_data = &format_data_sm8550, > >> + > >> + /* decoder properties related*/ > >> + .psc_avc_tbl = sm8550_vdec_psc_avc, > >> + .psc_avc_tbl_size = ARRAY_SIZE(sm8550_vdec_psc_avc), > >> + .psc_hevc_tbl = sm8550_vdec_psc_hevc, > >> + .psc_hevc_tbl_size = ARRAY_SIZE(sm8550_vdec_psc_hevc), > >> + .psc_vp9_tbl = sm8550_vdec_psc_vp9, > >> + .psc_vp9_tbl_size = ARRAY_SIZE(sm8550_vdec_psc_vp9), > >> + .dec_input_prop_avc = sm8550_vdec_input_properties_avc, > >> + .dec_input_prop_hevc = sm8550_vdec_input_properties_hevc, > >> + .dec_input_prop_vp9 = sm8550_vdec_input_properties_vp9, > >> + .dec_input_prop_size_avc = > >> ARRAY_SIZE(sm8550_vdec_input_properties_avc), > >> + .dec_input_prop_size_hevc = > >> ARRAY_SIZE(sm8550_vdec_input_properties_hevc), > >> + .dec_input_prop_size_vp9 = > >> ARRAY_SIZE(sm8550_vdec_input_properties_vp9), > >> + .dec_output_prop_avc = sm8550_vdec_output_properties_avc, > >> + .dec_output_prop_hevc = sm8550_vdec_output_properties_hevc, > >> + .dec_output_prop_vp9 = sm8550_vdec_output_properties_vp9, > >> + .dec_output_prop_size_avc = > >> ARRAY_SIZE(sm8550_vdec_output_properties_avc), > >> + .dec_output_prop_size_hevc = > >> ARRAY_SIZE(sm8550_vdec_output_properties_hevc), > >> + .dec_output_prop_size_vp9 = > >> ARRAY_SIZE(sm8550_vdec_output_properties_vp9), > > > > Size should come next to the array reference. > correct, will fix in next version > > > >> +}; > >> + > >> +static int msm_vidc_init_data(struct msm_vidc_core *core) > >> +{ > >> + d_vpr_h("%s: initialize sm8550 data\n", __func__); > >> + > >> + core->platform->data = sm8550_data; > >> + > > > > Please use of_device_match_data() instead. > > > Thanks for the suggestion, will implement in next version. BTW: could you please fix your mailer so that it doesn't insert extra white space after your quoting level? > > Thanks, > Dikshita > >> + return 0; > >> +} > >> + > >> +int msm_vidc_init_platform_sm8550(struct msm_vidc_core *core) > >> +{ > >> + return msm_vidc_init_data(core); > >> +} > >
diff --git a/drivers/media/platform/qcom/iris/platform/sm8550/inc/msm_vidc_sm8550.h b/drivers/media/platform/qcom/iris/platform/sm8550/inc/msm_vidc_sm8550.h new file mode 100644 index 0000000..0a2f172 --- /dev/null +++ b/drivers/media/platform/qcom/iris/platform/sm8550/inc/msm_vidc_sm8550.h @@ -0,0 +1,14 @@ +/* SPDX-License-Identifier: GPL-2.0-only */ +/* + * Copyright (c) 2020-2021, The Linux Foundation. All rights reserved. + * Copyright (c) 2021-2023 Qualcomm Innovation Center, Inc. All rights reserved. + */ + +#ifndef _MSM_VIDC_SM8550_H_ +#define _MSM_VIDC_SM8550_H_ + +#include "msm_vidc_core.h" + +int msm_vidc_init_platform_sm8550(struct msm_vidc_core *core); + +#endif // _MSM_VIDC_SM8550_H_ diff --git a/drivers/media/platform/qcom/iris/platform/sm8550/src/msm_vidc_sm8550.c b/drivers/media/platform/qcom/iris/platform/sm8550/src/msm_vidc_sm8550.c new file mode 100644 index 0000000..2408556 --- /dev/null +++ b/drivers/media/platform/qcom/iris/platform/sm8550/src/msm_vidc_sm8550.c @@ -0,0 +1,1727 @@ +// SPDX-License-Identifier: GPL-2.0-only +/* + * Copyright (c) 2020-2021, The Linux Foundation. All rights reserved. + * Copyright (c) 2021-2023 Qualcomm Innovation Center, Inc. All rights reserved. + */ + +#include <dt-bindings/clock/qcom,sm8550-gcc.h> +#include <dt-bindings/clock/qcom,sm8450-videocc.h> + +#include "hfi_command.h" +#include "hfi_property.h" +#include "msm_vidc_control.h" +#include "msm_vidc_debug.h" +#include "msm_vidc_iris3.h" +#include "msm_vidc_sm8550.h" +#include "msm_vidc_platform.h" + +/* version: major[24:31], minor[16:23], revision[0:15] */ +#define DRIVER_VERSION 0x04000000 +#define DEFAULT_VIDEO_CONCEAL_COLOR_BLACK 0x8020010 +#define MAX_BASE_LAYER_PRIORITY_ID 63 +#define MAX_OP_POINT 31 +#define MAX_BITRATE 245000000 +#define DEFAULT_BITRATE 20000000 +#define MINIMUM_FPS 1 +#define MAXIMUM_FPS 480 +#define MAXIMUM_DEC_FPS 960 +#define MAX_QP 51 +#define DEFAULT_QP 20 +#define MAX_CONSTANT_QUALITY 100 +#define MIN_SLICE_BYTE_SIZE 512 +#define MAX_SLICE_BYTE_SIZE \ + ((MAX_BITRATE) >> 3) +#define MAX_SLICE_MB_SIZE \ + (((4096 + 15) >> 4) * ((2304 + 15) >> 4)) + +#define ENC MSM_VIDC_ENCODER +#define DEC MSM_VIDC_DECODER +#define H264 MSM_VIDC_H264 +#define HEVC MSM_VIDC_HEVC +#define VP9 MSM_VIDC_VP9 +#define CODECS_ALL (H264 | HEVC | VP9) +#define MAXIMUM_OVERRIDE_VP9_FPS 200 + +static struct codec_info codec_data_sm8550[] = { + { + .v4l2_codec = V4L2_PIX_FMT_H264, + .vidc_codec = MSM_VIDC_H264, + .pixfmt_name = "AVC", + }, + { + .v4l2_codec = V4L2_PIX_FMT_HEVC, + .vidc_codec = MSM_VIDC_HEVC, + .pixfmt_name = "HEVC", + }, + { + .v4l2_codec = V4L2_PIX_FMT_VP9, + .vidc_codec = MSM_VIDC_VP9, + .pixfmt_name = "VP9", + }, +}; + +static struct color_format_info color_format_data_sm8550[] = { + { + .v4l2_color_format = V4L2_PIX_FMT_NV12, + .vidc_color_format = MSM_VIDC_FMT_NV12, + .pixfmt_name = "NV12", + }, + { + .v4l2_color_format = V4L2_PIX_FMT_NV21, + .vidc_color_format = MSM_VIDC_FMT_NV21, + .pixfmt_name = "NV21", + }, + { + .v4l2_color_format = V4L2_PIX_FMT_QC08C, + .vidc_color_format = MSM_VIDC_FMT_NV12C, + .pixfmt_name = "NV12C", + }, + { + .v4l2_color_format = V4L2_PIX_FMT_QC10C, + .vidc_color_format = MSM_VIDC_FMT_TP10C, + .pixfmt_name = "TP10C", + }, + { + .v4l2_color_format = V4L2_PIX_FMT_RGBA32, + .vidc_color_format = MSM_VIDC_FMT_RGBA8888, + .pixfmt_name = "RGBA", + }, +}; + +static struct color_primaries_info color_primaries_data_sm8550[] = { + { + .v4l2_color_primaries = V4L2_COLORSPACE_DEFAULT, + .vidc_color_primaries = MSM_VIDC_PRIMARIES_RESERVED, + }, + { + .v4l2_color_primaries = V4L2_COLORSPACE_REC709, + .vidc_color_primaries = MSM_VIDC_PRIMARIES_BT709, + }, + { + .v4l2_color_primaries = V4L2_COLORSPACE_470_SYSTEM_M, + .vidc_color_primaries = MSM_VIDC_PRIMARIES_BT470_SYSTEM_M, + }, + { + .v4l2_color_primaries = V4L2_COLORSPACE_470_SYSTEM_BG, + .vidc_color_primaries = MSM_VIDC_PRIMARIES_BT470_SYSTEM_BG, + }, + { + .v4l2_color_primaries = V4L2_COLORSPACE_SMPTE170M, + .vidc_color_primaries = MSM_VIDC_PRIMARIES_BT601_525, + }, + { + .v4l2_color_primaries = V4L2_COLORSPACE_SMPTE240M, + .vidc_color_primaries = MSM_VIDC_PRIMARIES_SMPTE_ST240M, + }, + { + .v4l2_color_primaries = V4L2_COLORSPACE_BT2020, + .vidc_color_primaries = MSM_VIDC_PRIMARIES_BT2020, + }, + { + .v4l2_color_primaries = V4L2_COLORSPACE_DCI_P3, + .vidc_color_primaries = MSM_VIDC_PRIMARIES_SMPTE_RP431_2, + }, +}; + +static struct transfer_char_info transfer_char_data_sm8550[] = { + { + .v4l2_transfer_char = V4L2_XFER_FUNC_DEFAULT, + .vidc_transfer_char = MSM_VIDC_TRANSFER_RESERVED, + }, + { + .v4l2_transfer_char = V4L2_XFER_FUNC_709, + .vidc_transfer_char = MSM_VIDC_TRANSFER_BT709, + }, + { + .v4l2_transfer_char = V4L2_XFER_FUNC_SMPTE240M, + .vidc_transfer_char = MSM_VIDC_TRANSFER_SMPTE_ST240M, + }, + { + .v4l2_transfer_char = V4L2_XFER_FUNC_SRGB, + .vidc_transfer_char = MSM_VIDC_TRANSFER_SRGB_SYCC, + }, + { + .v4l2_transfer_char = V4L2_XFER_FUNC_SMPTE2084, + .vidc_transfer_char = MSM_VIDC_TRANSFER_SMPTE_ST2084_PQ, + }, +}; + +static struct matrix_coeff_info matrix_coeff_data_sm8550[] = { + { + .v4l2_matrix_coeff = V4L2_YCBCR_ENC_DEFAULT, + .vidc_matrix_coeff = MSM_VIDC_MATRIX_COEFF_RESERVED, + }, + { + .v4l2_matrix_coeff = V4L2_YCBCR_ENC_709, + .vidc_matrix_coeff = MSM_VIDC_MATRIX_COEFF_BT709, + }, + { + .v4l2_matrix_coeff = V4L2_YCBCR_ENC_XV709, + .vidc_matrix_coeff = MSM_VIDC_MATRIX_COEFF_BT709, + }, + { + .v4l2_matrix_coeff = V4L2_YCBCR_ENC_XV601, + .vidc_matrix_coeff = MSM_VIDC_MATRIX_COEFF_BT470_SYS_BG_OR_BT601_625, + }, + { + .v4l2_matrix_coeff = V4L2_YCBCR_ENC_601, + .vidc_matrix_coeff = MSM_VIDC_MATRIX_COEFF_BT601_525_BT1358_525_OR_625, + }, + { + .v4l2_matrix_coeff = V4L2_YCBCR_ENC_SMPTE240M, + .vidc_matrix_coeff = MSM_VIDC_MATRIX_COEFF_SMPTE_ST240, + }, + { + .v4l2_matrix_coeff = V4L2_YCBCR_ENC_BT2020, + .vidc_matrix_coeff = MSM_VIDC_MATRIX_COEFF_BT2020_NON_CONSTANT, + }, + { + .v4l2_matrix_coeff = V4L2_YCBCR_ENC_BT2020_CONST_LUM, + .vidc_matrix_coeff = MSM_VIDC_MATRIX_COEFF_BT2020_CONSTANT, + }, +}; + +static struct msm_platform_core_capability core_data_sm8550[] = { + /* {type, value} */ + {ENC_CODECS, H264 | HEVC}, + {DEC_CODECS, H264 | HEVC | VP9}, + {MAX_SESSION_COUNT, 16}, + {MAX_NUM_720P_SESSIONS, 16}, + {MAX_NUM_1080P_SESSIONS, 16}, + {MAX_NUM_4K_SESSIONS, 8}, + {MAX_NUM_8K_SESSIONS, 2}, + {MAX_RT_MBPF, 174080}, /* (8192x4352)/256 + (4096x2176)/256*/ + {MAX_MBPF, 278528}, /* ((8192x4352)/256) * 2 */ + {MAX_MBPS, 7833600}, /* max_load + * 7680x4320@60fps or 3840x2176@240fps + * which is greater than 4096x2176@120fps, + * 8192x4320@48fps + */ + {MAX_MBPF_HQ, 8160}, /* ((1920x1088)/256) */ + {MAX_MBPS_HQ, 489600}, /* ((1920x1088)/256)@60fps */ + {MAX_MBPF_B_FRAME, 32640}, /* 3840x2176/256 */ + {MAX_MBPS_B_FRAME, 1958400}, /* 3840x2176/256 MBs@60fps */ + {MAX_MBPS_ALL_INTRA, 1044480}, /* 4096x2176/256 MBs@30fps */ + {MAX_ENH_LAYER_COUNT, 5}, + {NUM_VPP_PIPE, 4}, + {SW_PC, 1}, + {FW_UNLOAD, 0}, + {HW_RESPONSE_TIMEOUT, HW_RESPONSE_TIMEOUT_VALUE}, /* 1000 ms */ + {SW_PC_DELAY, SW_PC_DELAY_VALUE }, /* 1500 ms (>HW_RESPONSE_TIMEOUT)*/ + {FW_UNLOAD_DELAY, FW_UNLOAD_DELAY_VALUE }, /* 3000 ms (>SW_PC_DELAY)*/ + {DCVS, 1}, + {DECODE_BATCH, 1}, + {DECODE_BATCH_TIMEOUT, 200}, + {STATS_TIMEOUT_MS, 2000}, + {NON_FATAL_FAULTS, 1}, + {DEVICE_CAPS, V4L2_CAP_VIDEO_M2M_MPLANE | V4L2_CAP_STREAMING}, +}; + +static struct msm_platform_inst_capability instance_cap_data_sm8550[] = { + /* {cap, domain, codec, + * min, max, step_or_mask, value, + * v4l2_id, + * hfi_id, + * flags} + */ + {FRAME_WIDTH, DEC, CODECS_ALL, 96, 8192, 1, 1920}, + + {FRAME_WIDTH, DEC, VP9, 96, 4096, 1, 1920}, + + {FRAME_WIDTH, ENC, CODECS_ALL, 128, 8192, 1, 1920}, + + {FRAME_WIDTH, ENC, HEVC, 96, 8192, 1, 1920}, + + {LOSSLESS_FRAME_WIDTH, ENC, CODECS_ALL, 128, 4096, 1, 1920}, + + {LOSSLESS_FRAME_WIDTH, ENC, HEVC, 96, 4096, 1, 1920}, + + {FRAME_HEIGHT, DEC, CODECS_ALL, 96, 8192, 1, 1080}, + + {FRAME_HEIGHT, DEC, VP9, 96, 4096, 1, 1080}, + + {FRAME_HEIGHT, ENC, CODECS_ALL, 128, 8192, 1, 1080}, + + {FRAME_HEIGHT, ENC, HEVC, 96, 8192, 1, 1080}, + + {LOSSLESS_FRAME_HEIGHT, ENC, CODECS_ALL, 128, 4096, 1, 1080}, + + {LOSSLESS_FRAME_HEIGHT, ENC, HEVC, 96, 4096, 1, 1080}, + + {PIX_FMTS, ENC | DEC, H264, + MSM_VIDC_FMT_NV12, + MSM_VIDC_FMT_NV12C, + MSM_VIDC_FMT_NV12 | MSM_VIDC_FMT_NV21 | MSM_VIDC_FMT_NV12C, + MSM_VIDC_FMT_NV12C}, + + {PIX_FMTS, ENC | DEC, HEVC | VP9, + MSM_VIDC_FMT_NV12, + MSM_VIDC_FMT_TP10C, + MSM_VIDC_FMT_NV12 | MSM_VIDC_FMT_NV21 | MSM_VIDC_FMT_NV12C | + MSM_VIDC_FMT_TP10C, + MSM_VIDC_FMT_NV12C}, + + {MIN_BUFFERS_INPUT, ENC | DEC, CODECS_ALL, 0, 64, 1, 4, + V4L2_CID_MIN_BUFFERS_FOR_OUTPUT, + 0, + CAP_FLAG_VOLATILE}, + + {MIN_BUFFERS_OUTPUT, ENC | DEC, CODECS_ALL, + 0, 64, 1, 4, + V4L2_CID_MIN_BUFFERS_FOR_CAPTURE, + HFI_PROP_BUFFER_FW_MIN_OUTPUT_COUNT, + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_VOLATILE}, + + /* (8192 * 4320) / 256 */ + {MBPF, ENC, CODECS_ALL, 64, 138240, 1, 138240}, + + {MBPF, ENC, HEVC, 36, 138240, 1, 138240}, + + {MBPF, DEC, CODECS_ALL, 36, 138240, 1, 138240}, + + /* (4096 * 2304) / 256 */ + {MBPF, DEC, VP9, 36, 36864, 1, 36864}, + + /* (4096 * 2304) / 256 */ + {LOSSLESS_MBPF, ENC, H264 | HEVC, 64, 36864, 1, 36864}, + + /* Batch Mode Decode */ + /* TODO: update with new values based on updated voltage corner */ + {BATCH_MBPF, DEC, H264 | HEVC | VP9, 64, 34816, 1, 34816}, + + /* (4096 * 2304) / 256 */ + {BATCH_FPS, DEC, H264 | HEVC | VP9, 1, 120, 1, 120}, + + {FRAME_RATE, ENC | DEC, CODECS_ALL, + (MINIMUM_FPS << 16), (MAXIMUM_FPS << 16), + 1, (DEFAULT_FPS << 16), + 0, + HFI_PROP_FRAME_RATE, + CAP_FLAG_OUTPUT_PORT}, + + {OPERATING_RATE, ENC | DEC, CODECS_ALL, + (MINIMUM_FPS << 16), (MAXIMUM_FPS << 16), + 1, (DEFAULT_FPS << 16)}, + + {INPUT_RATE, ENC | DEC, CODECS_ALL, + (MINIMUM_FPS << 16), INT_MAX, + 1, (DEFAULT_FPS << 16)}, + + {TIMESTAMP_RATE, ENC | DEC, CODECS_ALL, + (MINIMUM_FPS << 16), INT_MAX, + 1, (DEFAULT_FPS << 16)}, + + {SCALE_FACTOR, ENC, H264 | HEVC, 1, 8, 1, 8}, + + {MB_CYCLES_VSP, ENC, CODECS_ALL, 25, 25, 1, 25}, + + {MB_CYCLES_VSP, DEC, CODECS_ALL, 25, 25, 1, 25}, + + {MB_CYCLES_VSP, DEC, VP9, 60, 60, 1, 60}, + + {MB_CYCLES_VPP, ENC, CODECS_ALL, 675, 675, 1, 675}, + + {MB_CYCLES_VPP, DEC, CODECS_ALL, 200, 200, 1, 200}, + + {MB_CYCLES_LP, ENC, CODECS_ALL, 320, 320, 1, 320}, + + {MB_CYCLES_LP, DEC, CODECS_ALL, 200, 200, 1, 200}, + + {MB_CYCLES_FW, ENC | DEC, CODECS_ALL, 489583, 489583, 1, 489583}, + + {MB_CYCLES_FW_VPP, ENC, CODECS_ALL, 48405, 48405, 1, 48405}, + + {MB_CYCLES_FW_VPP, DEC, CODECS_ALL, 66234, 66234, 1, 66234}, + + {HFLIP, ENC, CODECS_ALL, + 0, 1, 1, 0, + V4L2_CID_HFLIP, + HFI_PROP_FLIP, + CAP_FLAG_OUTPUT_PORT | + CAP_FLAG_INPUT_PORT | CAP_FLAG_DYNAMIC_ALLOWED}, + + {VFLIP, ENC, CODECS_ALL, + 0, 1, 1, 0, + V4L2_CID_VFLIP, + HFI_PROP_FLIP, + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT | + CAP_FLAG_DYNAMIC_ALLOWED}, + + {ROTATION, ENC, CODECS_ALL, + 0, 270, 90, 0, + V4L2_CID_ROTATE, + HFI_PROP_ROTATION, + CAP_FLAG_OUTPUT_PORT}, + + {HEADER_MODE, ENC, CODECS_ALL, + V4L2_MPEG_VIDEO_HEADER_MODE_SEPARATE, + V4L2_MPEG_VIDEO_HEADER_MODE_JOINED_WITH_1ST_FRAME, + BIT(V4L2_MPEG_VIDEO_HEADER_MODE_SEPARATE) | + BIT(V4L2_MPEG_VIDEO_HEADER_MODE_JOINED_WITH_1ST_FRAME), + V4L2_MPEG_VIDEO_HEADER_MODE_SEPARATE, + V4L2_CID_MPEG_VIDEO_HEADER_MODE, + HFI_PROP_SEQ_HEADER_MODE, + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_MENU}, + + {PREPEND_SPSPPS_TO_IDR, ENC, CODECS_ALL, + 0, 1, 1, 0, + V4L2_CID_MPEG_VIDEO_PREPEND_SPSPPS_TO_IDR}, + + {WITHOUT_STARTCODE, ENC, CODECS_ALL, + 0, 1, 1, 0, + V4L2_CID_MPEG_VIDEO_HEVC_WITHOUT_STARTCODE, + HFI_PROP_NAL_LENGTH_FIELD, + CAP_FLAG_OUTPUT_PORT}, + + {NAL_LENGTH_FIELD, ENC, CODECS_ALL, + V4L2_MPEG_VIDEO_HEVC_SIZE_0, + V4L2_MPEG_VIDEO_HEVC_SIZE_4, + BIT(V4L2_MPEG_VIDEO_HEVC_SIZE_0) | + BIT(V4L2_MPEG_VIDEO_HEVC_SIZE_4), + V4L2_MPEG_VIDEO_HEVC_SIZE_0, + V4L2_CID_MPEG_VIDEO_HEVC_SIZE_OF_LENGTH_FIELD, + HFI_PROP_NAL_LENGTH_FIELD, + CAP_FLAG_MENU | CAP_FLAG_OUTPUT_PORT}, + + /* TODO: Firmware introduced enumeration type for this + * with and without seq header. + */ + {REQUEST_I_FRAME, ENC, H264 | HEVC, + 0, 0, 0, 0, + V4L2_CID_MPEG_VIDEO_FORCE_KEY_FRAME, + HFI_PROP_REQUEST_SYNC_FRAME, + CAP_FLAG_INPUT_PORT | CAP_FLAG_DYNAMIC_ALLOWED}, + + /* Enc: Keeping CABAC and CAVLC as same bitrate. + * Dec: there's no use of Bitrate cap + */ + {BIT_RATE, ENC, H264 | HEVC, + 1, MAX_BITRATE, 1, DEFAULT_BITRATE, + V4L2_CID_MPEG_VIDEO_BITRATE, + HFI_PROP_TOTAL_BITRATE, + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT | + CAP_FLAG_DYNAMIC_ALLOWED}, + + {BITRATE_MODE, ENC, H264, + V4L2_MPEG_VIDEO_BITRATE_MODE_VBR, + V4L2_MPEG_VIDEO_BITRATE_MODE_CBR, + BIT(V4L2_MPEG_VIDEO_BITRATE_MODE_VBR) | + BIT(V4L2_MPEG_VIDEO_BITRATE_MODE_CBR), + V4L2_MPEG_VIDEO_BITRATE_MODE_VBR, + V4L2_CID_MPEG_VIDEO_BITRATE_MODE, + HFI_PROP_RATE_CONTROL, + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_MENU}, + + {BITRATE_MODE, ENC, HEVC, + V4L2_MPEG_VIDEO_BITRATE_MODE_VBR, + V4L2_MPEG_VIDEO_BITRATE_MODE_CQ, + BIT(V4L2_MPEG_VIDEO_BITRATE_MODE_VBR) | + BIT(V4L2_MPEG_VIDEO_BITRATE_MODE_CBR) | + BIT(V4L2_MPEG_VIDEO_BITRATE_MODE_CQ), + V4L2_MPEG_VIDEO_BITRATE_MODE_VBR, + V4L2_CID_MPEG_VIDEO_BITRATE_MODE, + HFI_PROP_RATE_CONTROL, + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_MENU}, + + {CABAC_MAX_BITRATE, ENC, H264 | HEVC, 0, + 160000000, 1, 160000000}, + + {CAVLC_MAX_BITRATE, ENC, H264, 0, + 220000000, 1, 220000000}, + + {ALLINTRA_MAX_BITRATE, ENC, H264 | HEVC, 0, + 245000000, 1, 245000000}, + + {NUM_COMV, DEC, CODECS_ALL, + 0, INT_MAX, 1, 0}, + + {LOSSLESS, ENC, HEVC, + 0, 1, 1, 0, + V4L2_CID_MPEG_VIDEO_HEVC_LOSSLESS_CU}, + + {FRAME_SKIP_MODE, ENC, H264 | HEVC, + V4L2_MPEG_VIDEO_FRAME_SKIP_MODE_DISABLED, + V4L2_MPEG_VIDEO_FRAME_SKIP_MODE_BUF_LIMIT, + BIT(V4L2_MPEG_VIDEO_FRAME_SKIP_MODE_DISABLED) | + BIT(V4L2_MPEG_VIDEO_FRAME_SKIP_MODE_LEVEL_LIMIT) | + BIT(V4L2_MPEG_VIDEO_FRAME_SKIP_MODE_BUF_LIMIT), + V4L2_MPEG_VIDEO_FRAME_SKIP_MODE_DISABLED, + V4L2_CID_MPEG_VIDEO_FRAME_SKIP_MODE, + 0, + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_MENU}, + + {FRAME_RC_ENABLE, ENC, H264 | HEVC, + 0, 1, 1, 1, + V4L2_CID_MPEG_VIDEO_FRAME_RC_ENABLE}, + + {CONSTANT_QUALITY, ENC, HEVC, + 1, MAX_CONSTANT_QUALITY, 1, 90, + V4L2_CID_MPEG_VIDEO_CONSTANT_QUALITY, + HFI_PROP_CONSTANT_QUALITY, + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT | + CAP_FLAG_DYNAMIC_ALLOWED}, + + {GOP_SIZE, ENC, CODECS_ALL, + 0, INT_MAX, 1, 2 * DEFAULT_FPS - 1, + V4L2_CID_MPEG_VIDEO_GOP_SIZE, + HFI_PROP_MAX_GOP_FRAMES, + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT | + CAP_FLAG_DYNAMIC_ALLOWED}, + + {GOP_CLOSURE, ENC, H264 | HEVC, + 0, 1, 1, 1, + V4L2_CID_MPEG_VIDEO_GOP_CLOSURE, + 0}, + + {B_FRAME, ENC, H264 | HEVC, + 0, 7, 1, 0, + V4L2_CID_MPEG_VIDEO_B_FRAMES, + HFI_PROP_MAX_B_FRAMES, + CAP_FLAG_OUTPUT_PORT}, + + {LTR_COUNT, ENC, H264 | HEVC, + 0, MAX_LTR_FRAME_COUNT_2, 1, 0, + V4L2_CID_MPEG_VIDEO_LTR_COUNT, + HFI_PROP_LTR_COUNT, + CAP_FLAG_OUTPUT_PORT}, + + {USE_LTR, ENC, H264 | HEVC, + 0, + ((1 << MAX_LTR_FRAME_COUNT_2) - 1), + 0, 0, + V4L2_CID_MPEG_VIDEO_USE_LTR_FRAMES, + HFI_PROP_LTR_USE, + CAP_FLAG_INPUT_PORT | CAP_FLAG_DYNAMIC_ALLOWED}, + + {MARK_LTR, ENC, H264 | HEVC, + INVALID_DEFAULT_MARK_OR_USE_LTR, + (MAX_LTR_FRAME_COUNT_2 - 1), + 1, INVALID_DEFAULT_MARK_OR_USE_LTR, + V4L2_CID_MPEG_VIDEO_FRAME_LTR_INDEX, + HFI_PROP_LTR_MARK, + CAP_FLAG_INPUT_PORT | CAP_FLAG_DYNAMIC_ALLOWED}, + + {BASELAYER_PRIORITY, ENC, H264, + 0, MAX_BASE_LAYER_PRIORITY_ID, 1, 0, + V4L2_CID_MPEG_VIDEO_BASELAYER_PRIORITY_ID, + HFI_PROP_BASELAYER_PRIORITYID, + CAP_FLAG_OUTPUT_PORT}, + + {IR_TYPE, ENC, H264 | HEVC, + V4L2_CID_MPEG_VIDEO_INTRA_REFRESH_PERIOD_TYPE_RANDOM, + V4L2_CID_MPEG_VIDEO_INTRA_REFRESH_PERIOD_TYPE_CYCLIC, + BIT(V4L2_CID_MPEG_VIDEO_INTRA_REFRESH_PERIOD_TYPE_RANDOM) | + BIT(V4L2_CID_MPEG_VIDEO_INTRA_REFRESH_PERIOD_TYPE_CYCLIC), + V4L2_CID_MPEG_VIDEO_INTRA_REFRESH_PERIOD_TYPE_RANDOM, + V4L2_CID_MPEG_VIDEO_INTRA_REFRESH_PERIOD_TYPE, + 0, + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_MENU}, + + {IR_PERIOD, ENC, H264 | HEVC, + 0, INT_MAX, 1, 0, + V4L2_CID_MPEG_VIDEO_INTRA_REFRESH_PERIOD, + 0, + CAP_FLAG_INPUT_PORT | CAP_FLAG_OUTPUT_PORT | + CAP_FLAG_DYNAMIC_ALLOWED}, + + {AU_DELIMITER, ENC, H264 | HEVC, + 0, 1, 1, 0, + V4L2_CID_MPEG_VIDEO_AU_DELIMITER, + HFI_PROP_AUD, + CAP_FLAG_OUTPUT_PORT}, + + {MIN_QUALITY, ENC, H264 | HEVC, + 0, MAX_SUPPORTED_MIN_QUALITY, 70, MAX_SUPPORTED_MIN_QUALITY, + 0, + HFI_PROP_MAINTAIN_MIN_QUALITY, + CAP_FLAG_OUTPUT_PORT}, + + {VBV_DELAY, ENC, H264 | HEVC, + 200, 300, 100, 300, + V4L2_CID_MPEG_VIDEO_VBV_DELAY, + HFI_PROP_VBV_DELAY, + CAP_FLAG_OUTPUT_PORT}, + + {PEAK_BITRATE, ENC, H264 | HEVC, + /* default peak bitrate is 10% larger than avg bitrate */ + 1, MAX_BITRATE, 1, DEFAULT_BITRATE, + V4L2_CID_MPEG_VIDEO_BITRATE_PEAK, + HFI_PROP_TOTAL_PEAK_BITRATE, + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT | + CAP_FLAG_DYNAMIC_ALLOWED}, + + {MIN_FRAME_QP, ENC, H264, + MIN_QP_8BIT, MAX_QP, 1, MIN_QP_8BIT, + V4L2_CID_MPEG_VIDEO_H264_MIN_QP, + HFI_PROP_MIN_QP_PACKED, + CAP_FLAG_OUTPUT_PORT}, + + {MIN_FRAME_QP, ENC, HEVC, + MIN_QP_10BIT, MAX_QP, 1, MIN_QP_10BIT, + V4L2_CID_MPEG_VIDEO_HEVC_MIN_QP, + HFI_PROP_MIN_QP_PACKED, + CAP_FLAG_OUTPUT_PORT}, + + {I_FRAME_MIN_QP, ENC, H264, + MIN_QP_8BIT, MAX_QP, 1, MIN_QP_8BIT, + V4L2_CID_MPEG_VIDEO_H264_I_FRAME_MIN_QP}, + + {I_FRAME_MIN_QP, ENC, HEVC, + MIN_QP_10BIT, MAX_QP, 1, MIN_QP_10BIT, + V4L2_CID_MPEG_VIDEO_HEVC_I_FRAME_MIN_QP}, + + {P_FRAME_MIN_QP, ENC, H264, + MIN_QP_8BIT, MAX_QP, 1, MIN_QP_8BIT, + V4L2_CID_MPEG_VIDEO_H264_P_FRAME_MIN_QP}, + + {P_FRAME_MIN_QP, ENC, HEVC, + MIN_QP_10BIT, MAX_QP, 1, MIN_QP_10BIT, + V4L2_CID_MPEG_VIDEO_HEVC_P_FRAME_MIN_QP}, + + {B_FRAME_MIN_QP, ENC, H264, + MIN_QP_8BIT, MAX_QP, 1, MIN_QP_8BIT, + V4L2_CID_MPEG_VIDEO_H264_B_FRAME_MIN_QP}, + + {B_FRAME_MIN_QP, ENC, HEVC, + MIN_QP_10BIT, MAX_QP, 1, MIN_QP_10BIT, + V4L2_CID_MPEG_VIDEO_HEVC_B_FRAME_MIN_QP}, + + {MAX_FRAME_QP, ENC, H264, + MIN_QP_8BIT, MAX_QP, 1, MAX_QP, + V4L2_CID_MPEG_VIDEO_H264_MAX_QP, + HFI_PROP_MAX_QP_PACKED, + CAP_FLAG_OUTPUT_PORT}, + + {MAX_FRAME_QP, ENC, HEVC, + MIN_QP_10BIT, MAX_QP, 1, MAX_QP, + V4L2_CID_MPEG_VIDEO_HEVC_MAX_QP, + HFI_PROP_MAX_QP_PACKED, + CAP_FLAG_OUTPUT_PORT}, + + {I_FRAME_MAX_QP, ENC, H264, + MIN_QP_8BIT, MAX_QP, 1, MAX_QP, + V4L2_CID_MPEG_VIDEO_H264_I_FRAME_MAX_QP}, + + {I_FRAME_MAX_QP, ENC, HEVC, + MIN_QP_10BIT, MAX_QP, 1, MAX_QP, + V4L2_CID_MPEG_VIDEO_HEVC_I_FRAME_MAX_QP}, + + {P_FRAME_MAX_QP, ENC, H264, + MIN_QP_8BIT, MAX_QP, 1, MAX_QP, + V4L2_CID_MPEG_VIDEO_H264_P_FRAME_MAX_QP}, + + {P_FRAME_MAX_QP, ENC, HEVC, + MIN_QP_10BIT, MAX_QP, 1, MAX_QP, + V4L2_CID_MPEG_VIDEO_HEVC_P_FRAME_MAX_QP}, + + {B_FRAME_MAX_QP, ENC, H264, + MIN_QP_8BIT, MAX_QP, 1, MAX_QP, + V4L2_CID_MPEG_VIDEO_H264_B_FRAME_MAX_QP}, + + {B_FRAME_MAX_QP, ENC, HEVC, + MIN_QP_10BIT, MAX_QP, 1, MAX_QP, + V4L2_CID_MPEG_VIDEO_HEVC_B_FRAME_MAX_QP}, + + {I_FRAME_QP, ENC, HEVC, + MIN_QP_10BIT, MAX_QP, 1, DEFAULT_QP, + V4L2_CID_MPEG_VIDEO_HEVC_I_FRAME_QP, + HFI_PROP_QP_PACKED, + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT | + CAP_FLAG_DYNAMIC_ALLOWED}, + + {I_FRAME_QP, ENC, H264, + MIN_QP_8BIT, MAX_QP, 1, DEFAULT_QP, + V4L2_CID_MPEG_VIDEO_H264_I_FRAME_QP, + HFI_PROP_QP_PACKED, + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT | + CAP_FLAG_DYNAMIC_ALLOWED}, + + {P_FRAME_QP, ENC, HEVC, + MIN_QP_10BIT, MAX_QP, 1, DEFAULT_QP, + V4L2_CID_MPEG_VIDEO_HEVC_P_FRAME_QP, + HFI_PROP_QP_PACKED, + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT | + CAP_FLAG_DYNAMIC_ALLOWED}, + + {P_FRAME_QP, ENC, H264, + MIN_QP_8BIT, MAX_QP, 1, DEFAULT_QP, + V4L2_CID_MPEG_VIDEO_H264_P_FRAME_QP, + HFI_PROP_QP_PACKED, + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT | + CAP_FLAG_DYNAMIC_ALLOWED}, + + {B_FRAME_QP, ENC, HEVC, + MIN_QP_10BIT, MAX_QP, 1, DEFAULT_QP, + V4L2_CID_MPEG_VIDEO_HEVC_B_FRAME_QP, + HFI_PROP_QP_PACKED, + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT | + CAP_FLAG_DYNAMIC_ALLOWED}, + + {B_FRAME_QP, ENC, H264, + MIN_QP_8BIT, MAX_QP, 1, DEFAULT_QP, + V4L2_CID_MPEG_VIDEO_H264_B_FRAME_QP, + HFI_PROP_QP_PACKED, + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT | + CAP_FLAG_DYNAMIC_ALLOWED}, + + {LAYER_TYPE, ENC, HEVC, + V4L2_MPEG_VIDEO_HEVC_HIERARCHICAL_CODING_B, + V4L2_MPEG_VIDEO_HEVC_HIERARCHICAL_CODING_P, + BIT(V4L2_MPEG_VIDEO_HEVC_HIERARCHICAL_CODING_B) | + BIT(V4L2_MPEG_VIDEO_HEVC_HIERARCHICAL_CODING_P), + V4L2_MPEG_VIDEO_HEVC_HIERARCHICAL_CODING_P, + V4L2_CID_MPEG_VIDEO_HEVC_HIER_CODING_TYPE, + HFI_PROP_LAYER_ENCODING_TYPE, + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_MENU}, + + {LAYER_TYPE, ENC, H264, + V4L2_MPEG_VIDEO_H264_HIERARCHICAL_CODING_B, + V4L2_MPEG_VIDEO_H264_HIERARCHICAL_CODING_P, + BIT(V4L2_MPEG_VIDEO_H264_HIERARCHICAL_CODING_B) | + BIT(V4L2_MPEG_VIDEO_H264_HIERARCHICAL_CODING_P), + V4L2_MPEG_VIDEO_H264_HIERARCHICAL_CODING_P, + V4L2_CID_MPEG_VIDEO_H264_HIERARCHICAL_CODING_TYPE, + HFI_PROP_LAYER_ENCODING_TYPE, + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_MENU}, + + {LAYER_ENABLE, ENC, H264, + 0, 1, 1, 0, + V4L2_CID_MPEG_VIDEO_H264_HIERARCHICAL_CODING, + HFI_PROP_LAYER_ENCODING_TYPE, + CAP_FLAG_OUTPUT_PORT}, + + {LAYER_ENABLE, ENC, HEVC, + 0, 1, 1, 0, + 0, + 0, + CAP_FLAG_OUTPUT_PORT}, + + {ENH_LAYER_COUNT, ENC, HEVC, + 0, 5, 1, 0, + V4L2_CID_MPEG_VIDEO_HEVC_HIER_CODING_LAYER, + HFI_PROP_LAYER_COUNT, + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT | + CAP_FLAG_DYNAMIC_ALLOWED}, + + {ENH_LAYER_COUNT, ENC, H264, + 0, 5, 1, 0, + V4L2_CID_MPEG_VIDEO_H264_HIERARCHICAL_CODING_LAYER, + HFI_PROP_LAYER_COUNT, + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT | + CAP_FLAG_DYNAMIC_ALLOWED}, + + {L0_BR, ENC, H264, + 1, MAX_BITRATE, 1, DEFAULT_BITRATE, + V4L2_CID_MPEG_VIDEO_H264_HIER_CODING_L0_BR, + HFI_PROP_BITRATE_LAYER1, + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT | + CAP_FLAG_DYNAMIC_ALLOWED}, + + {L0_BR, ENC, HEVC, + 1, MAX_BITRATE, 1, DEFAULT_BITRATE, + V4L2_CID_MPEG_VIDEO_HEVC_HIER_CODING_L0_BR, + HFI_PROP_BITRATE_LAYER1, + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT | + CAP_FLAG_DYNAMIC_ALLOWED}, + + {L1_BR, ENC, H264, + 1, MAX_BITRATE, 1, DEFAULT_BITRATE, + V4L2_CID_MPEG_VIDEO_H264_HIER_CODING_L1_BR, + HFI_PROP_BITRATE_LAYER2, + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT | + CAP_FLAG_DYNAMIC_ALLOWED}, + + {L1_BR, ENC, HEVC, + 1, MAX_BITRATE, 1, DEFAULT_BITRATE, + V4L2_CID_MPEG_VIDEO_HEVC_HIER_CODING_L1_BR, + HFI_PROP_BITRATE_LAYER2, + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT | + CAP_FLAG_DYNAMIC_ALLOWED}, + + {L2_BR, ENC, H264, + 1, MAX_BITRATE, 1, DEFAULT_BITRATE, + V4L2_CID_MPEG_VIDEO_H264_HIER_CODING_L2_BR, + HFI_PROP_BITRATE_LAYER3, + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT | + CAP_FLAG_DYNAMIC_ALLOWED}, + + {L2_BR, ENC, HEVC, + 1, MAX_BITRATE, 1, DEFAULT_BITRATE, + V4L2_CID_MPEG_VIDEO_HEVC_HIER_CODING_L2_BR, + HFI_PROP_BITRATE_LAYER3, + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT | + CAP_FLAG_DYNAMIC_ALLOWED}, + + {L3_BR, ENC, H264, + 1, MAX_BITRATE, 1, DEFAULT_BITRATE, + V4L2_CID_MPEG_VIDEO_H264_HIER_CODING_L3_BR, + HFI_PROP_BITRATE_LAYER4, + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT | + CAP_FLAG_DYNAMIC_ALLOWED}, + {L3_BR, ENC, HEVC, + 1, MAX_BITRATE, 1, DEFAULT_BITRATE, + V4L2_CID_MPEG_VIDEO_HEVC_HIER_CODING_L3_BR, + HFI_PROP_BITRATE_LAYER4, + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT | + CAP_FLAG_DYNAMIC_ALLOWED}, + + {L4_BR, ENC, H264, + 1, MAX_BITRATE, 1, DEFAULT_BITRATE, + V4L2_CID_MPEG_VIDEO_H264_HIER_CODING_L4_BR, + HFI_PROP_BITRATE_LAYER5, + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT | + CAP_FLAG_DYNAMIC_ALLOWED}, + + {L4_BR, ENC, HEVC, + 1, MAX_BITRATE, 1, DEFAULT_BITRATE, + V4L2_CID_MPEG_VIDEO_HEVC_HIER_CODING_L4_BR, + HFI_PROP_BITRATE_LAYER5, + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT | + CAP_FLAG_DYNAMIC_ALLOWED}, + + {L5_BR, ENC, H264, + 1, MAX_BITRATE, 1, DEFAULT_BITRATE, + V4L2_CID_MPEG_VIDEO_H264_HIER_CODING_L5_BR, + HFI_PROP_BITRATE_LAYER6, + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT | + CAP_FLAG_DYNAMIC_ALLOWED}, + + {L5_BR, ENC, HEVC, + 1, MAX_BITRATE, 1, DEFAULT_BITRATE, + V4L2_CID_MPEG_VIDEO_HEVC_HIER_CODING_L5_BR, + HFI_PROP_BITRATE_LAYER6, + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT | + CAP_FLAG_DYNAMIC_ALLOWED}, + + {ENTROPY_MODE, ENC, H264, + V4L2_MPEG_VIDEO_H264_ENTROPY_MODE_CAVLC, + V4L2_MPEG_VIDEO_H264_ENTROPY_MODE_CABAC, + BIT(V4L2_MPEG_VIDEO_H264_ENTROPY_MODE_CAVLC) | + BIT(V4L2_MPEG_VIDEO_H264_ENTROPY_MODE_CABAC), + V4L2_MPEG_VIDEO_H264_ENTROPY_MODE_CABAC, + V4L2_CID_MPEG_VIDEO_H264_ENTROPY_MODE, + HFI_PROP_CABAC_SESSION, + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_MENU}, + + {ENTROPY_MODE, DEC, H264 | HEVC | VP9, + V4L2_MPEG_VIDEO_H264_ENTROPY_MODE_CAVLC, + V4L2_MPEG_VIDEO_H264_ENTROPY_MODE_CABAC, + BIT(V4L2_MPEG_VIDEO_H264_ENTROPY_MODE_CAVLC) | + BIT(V4L2_MPEG_VIDEO_H264_ENTROPY_MODE_CABAC), + V4L2_MPEG_VIDEO_H264_ENTROPY_MODE_CABAC, + 0, + HFI_PROP_CABAC_SESSION}, + + {PROFILE, ENC | DEC, H264, + V4L2_MPEG_VIDEO_H264_PROFILE_BASELINE, + V4L2_MPEG_VIDEO_H264_PROFILE_CONSTRAINED_HIGH, + BIT(V4L2_MPEG_VIDEO_H264_PROFILE_BASELINE) | + BIT(V4L2_MPEG_VIDEO_H264_PROFILE_CONSTRAINED_HIGH) | + BIT(V4L2_MPEG_VIDEO_H264_PROFILE_CONSTRAINED_BASELINE) | + BIT(V4L2_MPEG_VIDEO_H264_PROFILE_MAIN) | + BIT(V4L2_MPEG_VIDEO_H264_PROFILE_HIGH), + V4L2_MPEG_VIDEO_H264_PROFILE_HIGH, + V4L2_CID_MPEG_VIDEO_H264_PROFILE, + HFI_PROP_PROFILE, + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_MENU}, + + {PROFILE, ENC | DEC, HEVC, + V4L2_MPEG_VIDEO_HEVC_PROFILE_MAIN, + V4L2_MPEG_VIDEO_HEVC_PROFILE_MAIN_10, + BIT(V4L2_MPEG_VIDEO_HEVC_PROFILE_MAIN) | + BIT(V4L2_MPEG_VIDEO_HEVC_PROFILE_MAIN_STILL_PICTURE) | + BIT(V4L2_MPEG_VIDEO_HEVC_PROFILE_MAIN_10), + V4L2_MPEG_VIDEO_HEVC_PROFILE_MAIN, + V4L2_CID_MPEG_VIDEO_HEVC_PROFILE, + HFI_PROP_PROFILE, + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_MENU}, + + {PROFILE, DEC, VP9, + V4L2_MPEG_VIDEO_VP9_PROFILE_0, + V4L2_MPEG_VIDEO_VP9_PROFILE_2, + BIT(V4L2_MPEG_VIDEO_VP9_PROFILE_0) | + BIT(V4L2_MPEG_VIDEO_VP9_PROFILE_2), + V4L2_MPEG_VIDEO_VP9_PROFILE_0, + V4L2_CID_MPEG_VIDEO_VP9_PROFILE, + HFI_PROP_PROFILE, + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_MENU}, + + {LEVEL, ENC, H264, + V4L2_MPEG_VIDEO_H264_LEVEL_1_0, + V4L2_MPEG_VIDEO_H264_LEVEL_6_0, + BIT(V4L2_MPEG_VIDEO_H264_LEVEL_1_0) | + BIT(V4L2_MPEG_VIDEO_H264_LEVEL_1B) | + BIT(V4L2_MPEG_VIDEO_H264_LEVEL_1_1) | + BIT(V4L2_MPEG_VIDEO_H264_LEVEL_1_2) | + BIT(V4L2_MPEG_VIDEO_H264_LEVEL_1_3) | + BIT(V4L2_MPEG_VIDEO_H264_LEVEL_2_0) | + BIT(V4L2_MPEG_VIDEO_H264_LEVEL_2_1) | + BIT(V4L2_MPEG_VIDEO_H264_LEVEL_2_2) | + BIT(V4L2_MPEG_VIDEO_H264_LEVEL_3_0) | + BIT(V4L2_MPEG_VIDEO_H264_LEVEL_3_1) | + BIT(V4L2_MPEG_VIDEO_H264_LEVEL_3_2) | + BIT(V4L2_MPEG_VIDEO_H264_LEVEL_4_0) | + BIT(V4L2_MPEG_VIDEO_H264_LEVEL_4_1) | + BIT(V4L2_MPEG_VIDEO_H264_LEVEL_4_2) | + BIT(V4L2_MPEG_VIDEO_H264_LEVEL_5_0) | + BIT(V4L2_MPEG_VIDEO_H264_LEVEL_5_1) | + BIT(V4L2_MPEG_VIDEO_H264_LEVEL_5_2) | + BIT(V4L2_MPEG_VIDEO_H264_LEVEL_6_0), + V4L2_MPEG_VIDEO_H264_LEVEL_5_0, + V4L2_CID_MPEG_VIDEO_H264_LEVEL, + HFI_PROP_LEVEL, + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_MENU}, + + {LEVEL, ENC, HEVC, + V4L2_MPEG_VIDEO_HEVC_LEVEL_1, + V4L2_MPEG_VIDEO_HEVC_LEVEL_6_2, + BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_1) | + BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_2) | + BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_2_1) | + BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_3) | + BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_3_1) | + BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_4) | + BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_4_1) | + BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_5) | + BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_5_1) | + BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_5_2) | + BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_6) | + BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_6_1) | + BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_6_2), + V4L2_MPEG_VIDEO_HEVC_LEVEL_5, + V4L2_CID_MPEG_VIDEO_HEVC_LEVEL, + HFI_PROP_LEVEL, + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_MENU}, + + {LEVEL, DEC, H264, + V4L2_MPEG_VIDEO_H264_LEVEL_1_0, + V4L2_MPEG_VIDEO_H264_LEVEL_6_2, + BIT(V4L2_MPEG_VIDEO_H264_LEVEL_1_0) | + BIT(V4L2_MPEG_VIDEO_H264_LEVEL_1B) | + BIT(V4L2_MPEG_VIDEO_H264_LEVEL_1_1) | + BIT(V4L2_MPEG_VIDEO_H264_LEVEL_1_2) | + BIT(V4L2_MPEG_VIDEO_H264_LEVEL_1_3) | + BIT(V4L2_MPEG_VIDEO_H264_LEVEL_2_0) | + BIT(V4L2_MPEG_VIDEO_H264_LEVEL_2_1) | + BIT(V4L2_MPEG_VIDEO_H264_LEVEL_2_2) | + BIT(V4L2_MPEG_VIDEO_H264_LEVEL_3_0) | + BIT(V4L2_MPEG_VIDEO_H264_LEVEL_3_1) | + BIT(V4L2_MPEG_VIDEO_H264_LEVEL_3_2) | + BIT(V4L2_MPEG_VIDEO_H264_LEVEL_4_0) | + BIT(V4L2_MPEG_VIDEO_H264_LEVEL_4_1) | + BIT(V4L2_MPEG_VIDEO_H264_LEVEL_4_2) | + BIT(V4L2_MPEG_VIDEO_H264_LEVEL_5_0) | + BIT(V4L2_MPEG_VIDEO_H264_LEVEL_5_1) | + BIT(V4L2_MPEG_VIDEO_H264_LEVEL_5_2) | + BIT(V4L2_MPEG_VIDEO_H264_LEVEL_6_0) | + BIT(V4L2_MPEG_VIDEO_H264_LEVEL_6_1) | + BIT(V4L2_MPEG_VIDEO_H264_LEVEL_6_2), + V4L2_MPEG_VIDEO_H264_LEVEL_6_1, + V4L2_CID_MPEG_VIDEO_H264_LEVEL, + HFI_PROP_LEVEL, + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_MENU}, + + {LEVEL, DEC, HEVC, + V4L2_MPEG_VIDEO_HEVC_LEVEL_1, + V4L2_MPEG_VIDEO_HEVC_LEVEL_6_2, + BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_1) | + BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_2) | + BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_2_1) | + BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_3) | + BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_3_1) | + BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_4) | + BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_4_1) | + BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_5) | + BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_5_1) | + BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_5_2) | + BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_6) | + BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_6_1) | + BIT(V4L2_MPEG_VIDEO_HEVC_LEVEL_6_2), + V4L2_MPEG_VIDEO_HEVC_LEVEL_6_1, + V4L2_CID_MPEG_VIDEO_HEVC_LEVEL, + HFI_PROP_LEVEL, + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_MENU}, + + {LEVEL, DEC, VP9, + V4L2_MPEG_VIDEO_VP9_LEVEL_1_0, + V4L2_MPEG_VIDEO_VP9_LEVEL_6_0, + BIT(V4L2_MPEG_VIDEO_VP9_LEVEL_1_0) | + BIT(V4L2_MPEG_VIDEO_VP9_LEVEL_1_1) | + BIT(V4L2_MPEG_VIDEO_VP9_LEVEL_2_0) | + BIT(V4L2_MPEG_VIDEO_VP9_LEVEL_2_1) | + BIT(V4L2_MPEG_VIDEO_VP9_LEVEL_3_0) | + BIT(V4L2_MPEG_VIDEO_VP9_LEVEL_3_1) | + BIT(V4L2_MPEG_VIDEO_VP9_LEVEL_4_0) | + BIT(V4L2_MPEG_VIDEO_VP9_LEVEL_4_1) | + BIT(V4L2_MPEG_VIDEO_VP9_LEVEL_5_0) | + BIT(V4L2_MPEG_VIDEO_VP9_LEVEL_5_1) | + BIT(V4L2_MPEG_VIDEO_VP9_LEVEL_5_2) | + BIT(V4L2_MPEG_VIDEO_VP9_LEVEL_6_0), + V4L2_MPEG_VIDEO_VP9_LEVEL_6_0, + V4L2_CID_MPEG_VIDEO_VP9_LEVEL, + HFI_PROP_LEVEL, + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_MENU}, + + {HEVC_TIER, ENC | DEC, HEVC, + V4L2_MPEG_VIDEO_HEVC_TIER_MAIN, + V4L2_MPEG_VIDEO_HEVC_TIER_HIGH, + BIT(V4L2_MPEG_VIDEO_HEVC_TIER_MAIN) | + BIT(V4L2_MPEG_VIDEO_HEVC_TIER_HIGH), + V4L2_MPEG_VIDEO_HEVC_TIER_HIGH, + V4L2_CID_MPEG_VIDEO_HEVC_TIER, + HFI_PROP_TIER, + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_MENU}, + + {LF_MODE, ENC, H264, + V4L2_MPEG_VIDEO_H264_LOOP_FILTER_MODE_ENABLED, + DB_H264_DISABLE_SLICE_BOUNDARY, + BIT(V4L2_MPEG_VIDEO_H264_LOOP_FILTER_MODE_ENABLED) | + BIT(V4L2_MPEG_VIDEO_H264_LOOP_FILTER_MODE_DISABLED) | + BIT(DB_H264_DISABLE_SLICE_BOUNDARY), + V4L2_MPEG_VIDEO_H264_LOOP_FILTER_MODE_ENABLED, + V4L2_CID_MPEG_VIDEO_H264_LOOP_FILTER_MODE, + HFI_PROP_DEBLOCKING_MODE, + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_MENU}, + + {LF_MODE, ENC, HEVC, + V4L2_MPEG_VIDEO_HEVC_LOOP_FILTER_MODE_DISABLED, + DB_HEVC_DISABLE_SLICE_BOUNDARY, + BIT(V4L2_MPEG_VIDEO_HEVC_LOOP_FILTER_MODE_DISABLED) | + BIT(V4L2_MPEG_VIDEO_HEVC_LOOP_FILTER_MODE_ENABLED) | + BIT(DB_HEVC_DISABLE_SLICE_BOUNDARY), + V4L2_MPEG_VIDEO_HEVC_LOOP_FILTER_MODE_ENABLED, + V4L2_CID_MPEG_VIDEO_HEVC_LOOP_FILTER_MODE, + HFI_PROP_DEBLOCKING_MODE, + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_MENU}, + + {LF_ALPHA, ENC, H264, + -6, 6, 1, 0, + V4L2_CID_MPEG_VIDEO_H264_LOOP_FILTER_ALPHA}, + + {LF_ALPHA, ENC, HEVC, + -6, 6, 1, 0, + V4L2_CID_MPEG_VIDEO_HEVC_LF_TC_OFFSET_DIV2}, + + {LF_BETA, ENC, H264, + -6, 6, 1, 0, + V4L2_CID_MPEG_VIDEO_H264_LOOP_FILTER_BETA}, + + {LF_BETA, ENC, HEVC, + -6, 6, 1, 0, + V4L2_CID_MPEG_VIDEO_HEVC_LF_BETA_OFFSET_DIV2}, + + {SLICE_MODE, ENC, H264 | HEVC, + V4L2_MPEG_VIDEO_MULTI_SLICE_MODE_SINGLE, + V4L2_MPEG_VIDEO_MULTI_SLICE_MODE_MAX_BYTES, + BIT(V4L2_MPEG_VIDEO_MULTI_SLICE_MODE_SINGLE) | + BIT(V4L2_MPEG_VIDEO_MULTI_SLICE_MODE_MAX_MB) | + BIT(V4L2_MPEG_VIDEO_MULTI_SLICE_MODE_MAX_BYTES), + V4L2_MPEG_VIDEO_MULTI_SLICE_MODE_SINGLE, + V4L2_CID_MPEG_VIDEO_MULTI_SLICE_MODE, + 0, + CAP_FLAG_OUTPUT_PORT | CAP_FLAG_MENU}, + + {SLICE_MAX_BYTES, ENC, H264 | HEVC, + MIN_SLICE_BYTE_SIZE, MAX_SLICE_BYTE_SIZE, + 1, MIN_SLICE_BYTE_SIZE, + V4L2_CID_MPEG_VIDEO_MULTI_SLICE_MAX_BYTES, + HFI_PROP_MULTI_SLICE_BYTES_COUNT, + CAP_FLAG_OUTPUT_PORT}, + + {SLICE_MAX_MB, ENC, H264 | HEVC, + 1, MAX_SLICE_MB_SIZE, 1, 1, + V4L2_CID_MPEG_VIDEO_MULTI_SLICE_MAX_MB, + HFI_PROP_MULTI_SLICE_MB_COUNT, + CAP_FLAG_OUTPUT_PORT}, + + {MB_RC, ENC, H264 | HEVC, + 0, 1, 1, 1, + V4L2_CID_MPEG_VIDEO_MB_RC_ENABLE, + 0, + CAP_FLAG_OUTPUT_PORT}, + + {TRANSFORM_8X8, ENC, H264, + 0, 1, 1, 1, + V4L2_CID_MPEG_VIDEO_H264_8X8_TRANSFORM, + HFI_PROP_8X8_TRANSFORM, + CAP_FLAG_OUTPUT_PORT}, + + {CHROMA_QP_INDEX_OFFSET, ENC, HEVC, + MIN_CHROMA_QP_OFFSET, MAX_CHROMA_QP_OFFSET, + 1, MAX_CHROMA_QP_OFFSET, + V4L2_CID_MPEG_VIDEO_H264_CHROMA_QP_INDEX_OFFSET, + HFI_PROP_CHROMA_QP_OFFSET, + CAP_FLAG_OUTPUT_PORT}, + + {DISPLAY_DELAY_ENABLE, DEC, H264 | HEVC | VP9, + 0, 1, 1, 0, + V4L2_CID_MPEG_VIDEO_DEC_DISPLAY_DELAY_ENABLE, + HFI_PROP_DECODE_ORDER_OUTPUT, + CAP_FLAG_INPUT_PORT}, + + {DISPLAY_DELAY, DEC, H264 | HEVC | VP9, + 0, 1, 1, 0, + V4L2_CID_MPEG_VIDEO_DEC_DISPLAY_DELAY, + HFI_PROP_DECODE_ORDER_OUTPUT, + CAP_FLAG_INPUT_PORT}, + + {OUTPUT_ORDER, DEC, H264 | HEVC | VP9, + 0, 1, 1, 0, + 0, + HFI_PROP_DECODE_ORDER_OUTPUT, + CAP_FLAG_INPUT_PORT}, + + {INPUT_BUF_HOST_MAX_COUNT, ENC | DEC, CODECS_ALL, + DEFAULT_MAX_HOST_BUF_COUNT, DEFAULT_MAX_HOST_BURST_BUF_COUNT, + 1, DEFAULT_MAX_HOST_BUF_COUNT, + 0, + HFI_PROP_BUFFER_HOST_MAX_COUNT, + CAP_FLAG_INPUT_PORT}, + + {OUTPUT_BUF_HOST_MAX_COUNT, ENC | DEC, CODECS_ALL, + DEFAULT_MAX_HOST_BUF_COUNT, DEFAULT_MAX_HOST_BURST_BUF_COUNT, + 1, DEFAULT_MAX_HOST_BUF_COUNT, + 0, + HFI_PROP_BUFFER_HOST_MAX_COUNT, + CAP_FLAG_OUTPUT_PORT}, + + {CONCEAL_COLOR_8BIT, DEC, CODECS_ALL, 0x0, 0xff3fcff, 1, + DEFAULT_VIDEO_CONCEAL_COLOR_BLACK, + V4L2_CID_MPEG_VIDEO_MUTE_YUV, + HFI_PROP_CONCEAL_COLOR_8BIT, + CAP_FLAG_INPUT_PORT}, + + {CONCEAL_COLOR_10BIT, DEC, CODECS_ALL, 0x0, 0x3fffffff, 1, + DEFAULT_VIDEO_CONCEAL_COLOR_BLACK, + V4L2_CID_MPEG_VIDEO_MUTE_YUV, + HFI_PROP_CONCEAL_COLOR_10BIT, + CAP_FLAG_INPUT_PORT}, + + {STAGE, DEC | ENC, CODECS_ALL, + MSM_VIDC_STAGE_1, + MSM_VIDC_STAGE_2, 1, + MSM_VIDC_STAGE_2, + 0, + HFI_PROP_STAGE}, + + {PIPE, DEC | ENC, CODECS_ALL, + MSM_VIDC_PIPE_1, + MSM_VIDC_PIPE_4, 1, + MSM_VIDC_PIPE_4, + 0, + HFI_PROP_PIPE}, + + {POC, DEC, H264, 0, 2, 1, 1, + 0, + HFI_PROP_PIC_ORDER_CNT_TYPE}, + + {QUALITY_MODE, ENC, CODECS_ALL, + MSM_VIDC_MAX_QUALITY_MODE, + MSM_VIDC_POWER_SAVE_MODE, 1, + MSM_VIDC_POWER_SAVE_MODE}, + + {CODED_FRAMES, DEC, H264 | HEVC, + CODED_FRAMES_PROGRESSIVE, CODED_FRAMES_INTERLACE, + 1, CODED_FRAMES_PROGRESSIVE, + 0, + HFI_PROP_CODED_FRAMES}, + + {BIT_DEPTH, DEC, CODECS_ALL, BIT_DEPTH_8, BIT_DEPTH_10, 1, BIT_DEPTH_8, + 0, + HFI_PROP_LUMA_CHROMA_BIT_DEPTH}, + + {BITSTREAM_SIZE_OVERWRITE, DEC, CODECS_ALL, 0, INT_MAX, 1, 0, + 0}, + + {DEFAULT_HEADER, DEC, CODECS_ALL, + 0, 1, 1, 0, + 0, + HFI_PROP_DEC_DEFAULT_HEADER}, + + {RAP_FRAME, DEC, CODECS_ALL, + 0, 1, 1, 1, + 0, + HFI_PROP_DEC_START_FROM_RAP_FRAME, + CAP_FLAG_INPUT_PORT}, + + {SEQ_CHANGE_AT_SYNC_FRAME, DEC, CODECS_ALL, + 0, 1, 1, 1, + 0, + HFI_PROP_SEQ_CHANGE_AT_SYNC_FRAME, + CAP_FLAG_INPUT_PORT | CAP_FLAG_DYNAMIC_ALLOWED}, + + {ALL_INTRA, ENC, H264 | HEVC, + 0, 1, 1, 0, + 0, + 0, + CAP_FLAG_OUTPUT_PORT}, +}; + +static struct msm_platform_inst_cap_dependency instance_cap_dependency_data_sm8550[] = { + /* {cap, domain, codec, + * children, + * adjust, set} + */ + + {PIX_FMTS, ENC, H264, + {IR_PERIOD}}, + + {PIX_FMTS, ENC, HEVC, + {PROFILE, MIN_FRAME_QP, MAX_FRAME_QP, I_FRAME_QP, P_FRAME_QP, + B_FRAME_QP, MIN_QUALITY, IR_PERIOD, LTR_COUNT}}, + + {PIX_FMTS, DEC, HEVC, + {PROFILE}}, + + {FRAME_RATE, ENC, CODECS_ALL, + {0}, + NULL, + msm_vidc_set_q16}, + + {HFLIP, ENC, CODECS_ALL, + {0}, + NULL, + msm_vidc_set_flip}, + + {VFLIP, ENC, CODECS_ALL, + {0}, + NULL, + msm_vidc_set_flip}, + + {ROTATION, ENC, CODECS_ALL, + {0}, + NULL, + msm_vidc_set_rotation}, + + {HEADER_MODE, ENC, CODECS_ALL, + {0}, + NULL, + msm_vidc_set_header_mode}, + + {WITHOUT_STARTCODE, ENC, CODECS_ALL, + {0}, + NULL, + msm_vidc_set_nal_length}, + + {REQUEST_I_FRAME, ENC, H264 | HEVC, + {0}, + NULL, + msm_vidc_set_req_sync_frame}, + + {BIT_RATE, ENC, H264, + {PEAK_BITRATE, L0_BR}, + msm_vidc_adjust_bitrate, + msm_vidc_set_bitrate}, + + {BIT_RATE, ENC, HEVC, + {PEAK_BITRATE, L0_BR}, + msm_vidc_adjust_bitrate, + msm_vidc_set_bitrate}, + + {BITRATE_MODE, ENC, H264, + {LTR_COUNT, IR_PERIOD, I_FRAME_QP, P_FRAME_QP, + B_FRAME_QP, ENH_LAYER_COUNT, BIT_RATE, + MIN_QUALITY, VBV_DELAY, + PEAK_BITRATE, SLICE_MODE}, + msm_vidc_adjust_bitrate_mode, + msm_vidc_set_u32_enum}, + + {BITRATE_MODE, ENC, HEVC, + {LTR_COUNT, IR_PERIOD, I_FRAME_QP, P_FRAME_QP, + B_FRAME_QP, CONSTANT_QUALITY, ENH_LAYER_COUNT, + BIT_RATE, MIN_QUALITY, VBV_DELAY, + PEAK_BITRATE, SLICE_MODE}, + msm_vidc_adjust_bitrate_mode, + msm_vidc_set_u32_enum}, + + {CONSTANT_QUALITY, ENC, HEVC, + {0}, + NULL, + msm_vidc_set_constant_quality}, + + {GOP_SIZE, ENC, CODECS_ALL, + {ALL_INTRA}, + msm_vidc_adjust_gop_size, + msm_vidc_set_gop_size}, + + {B_FRAME, ENC, H264 | HEVC, + {ALL_INTRA}, + msm_vidc_adjust_b_frame, + msm_vidc_set_u32}, + + {LTR_COUNT, ENC, H264 | HEVC, + {0}, + msm_vidc_adjust_ltr_count, + msm_vidc_set_u32}, + + {USE_LTR, ENC, H264 | HEVC, + {0}, + msm_vidc_adjust_use_ltr, + msm_vidc_set_use_and_mark_ltr}, + + {MARK_LTR, ENC, H264 | HEVC, + {0}, + msm_vidc_adjust_mark_ltr, + msm_vidc_set_use_and_mark_ltr}, + + {IR_PERIOD, ENC, H264 | HEVC, + {0}, + msm_vidc_adjust_ir_period, + msm_vidc_set_ir_period}, + + {AU_DELIMITER, ENC, H264 | HEVC, + {0}, + NULL, + msm_vidc_set_u32}, + + {MIN_QUALITY, ENC, H264, + {0}, + msm_vidc_adjust_min_quality, + msm_vidc_set_u32}, + + {MIN_QUALITY, ENC, HEVC, + {0}, + msm_vidc_adjust_min_quality, + msm_vidc_set_u32}, + + {VBV_DELAY, ENC, H264 | HEVC, + {0}, + NULL, + msm_vidc_set_cbr_related_properties}, + + {PEAK_BITRATE, ENC, H264 | HEVC, + {0}, + msm_vidc_adjust_peak_bitrate, + msm_vidc_set_cbr_related_properties}, + + {MIN_FRAME_QP, ENC, H264, + {0}, + NULL, + msm_vidc_set_min_qp}, + + {MIN_FRAME_QP, ENC, HEVC, + {0}, + msm_vidc_adjust_hevc_min_qp, + msm_vidc_set_min_qp}, + + {MAX_FRAME_QP, ENC, H264, + {0}, + NULL, + msm_vidc_set_max_qp}, + + {MAX_FRAME_QP, ENC, HEVC, + {0}, + msm_vidc_adjust_hevc_max_qp, + msm_vidc_set_max_qp}, + + {I_FRAME_QP, ENC, HEVC, + {0}, + msm_vidc_adjust_hevc_i_frame_qp, + msm_vidc_set_frame_qp}, + + {I_FRAME_QP, ENC, H264, + {0}, + NULL, + msm_vidc_set_frame_qp}, + + {P_FRAME_QP, ENC, HEVC, + {0}, + msm_vidc_adjust_hevc_p_frame_qp, + msm_vidc_set_frame_qp}, + + {P_FRAME_QP, ENC, H264, + {0}, + NULL, + msm_vidc_set_frame_qp}, + + {B_FRAME_QP, ENC, HEVC, + {0}, + msm_vidc_adjust_hevc_b_frame_qp, + msm_vidc_set_frame_qp}, + + {B_FRAME_QP, ENC, H264, + {0}, + NULL, + msm_vidc_set_frame_qp}, + + {LAYER_TYPE, ENC, H264 | HEVC, + {LTR_COUNT}}, + + {LAYER_ENABLE, ENC, H264 | HEVC, + {0}}, + + {ENH_LAYER_COUNT, ENC, H264 | HEVC, + {GOP_SIZE, B_FRAME, BIT_RATE, MIN_QUALITY, SLICE_MODE, + LTR_COUNT}, + msm_vidc_adjust_layer_count, + msm_vidc_set_layer_count_and_type}, + + {L0_BR, ENC, H264 | HEVC, + {L1_BR}, + msm_vidc_adjust_layer_bitrate, + msm_vidc_set_layer_bitrate}, + + {L1_BR, ENC, H264 | HEVC, + {L2_BR}, + msm_vidc_adjust_layer_bitrate, + msm_vidc_set_layer_bitrate}, + + {L2_BR, ENC, H264 | HEVC, + {L3_BR}, + msm_vidc_adjust_layer_bitrate, + msm_vidc_set_layer_bitrate}, + + {L3_BR, ENC, H264 | HEVC, + {L4_BR}, + msm_vidc_adjust_layer_bitrate, + msm_vidc_set_layer_bitrate}, + + {L4_BR, ENC, H264 | HEVC, + {L5_BR}, + msm_vidc_adjust_layer_bitrate, + msm_vidc_set_layer_bitrate}, + + {L5_BR, ENC, H264 | HEVC, + {0}, + msm_vidc_adjust_layer_bitrate, + msm_vidc_set_layer_bitrate}, + + {ENTROPY_MODE, ENC, H264, + {BIT_RATE}, + msm_vidc_adjust_entropy_mode, + msm_vidc_set_u32}, + + {PROFILE, ENC, H264, + {ENTROPY_MODE, TRANSFORM_8X8}, + NULL, + msm_vidc_set_u32_enum}, + + {PROFILE, DEC, H264, + {ENTROPY_MODE}, + NULL, + msm_vidc_set_u32_enum}, + + {PROFILE, ENC | DEC, HEVC, + {0}, + msm_vidc_adjust_profile, + msm_vidc_set_u32_enum}, + + {PROFILE, DEC, VP9, + {0}, + NULL, + msm_vidc_set_u32_enum}, + + {LEVEL, DEC, CODECS_ALL, + {0}, + NULL, + msm_vidc_set_u32_enum}, + + {LEVEL, ENC, CODECS_ALL, + {0}, + NULL, + msm_vidc_set_level}, + + {HEVC_TIER, ENC | DEC, HEVC, + {0}, + NULL, + msm_vidc_set_u32_enum}, + + {LF_MODE, ENC, CODECS_ALL, + {0}, + NULL, + msm_vidc_set_deblock_mode}, + + {SLICE_MODE, ENC, H264 | HEVC, + {STAGE}, + msm_vidc_adjust_slice_count, + msm_vidc_set_slice_count}, + + {TRANSFORM_8X8, ENC, H264, + {0}, + msm_vidc_adjust_transform_8x8, + msm_vidc_set_u32}, + + {CHROMA_QP_INDEX_OFFSET, ENC, HEVC, + {0}, + msm_vidc_adjust_chroma_qp_index_offset, + msm_vidc_set_chroma_qp_index_offset}, + + {DISPLAY_DELAY_ENABLE, DEC, H264 | HEVC | VP9, + {OUTPUT_ORDER}, + NULL, + NULL}, + + {DISPLAY_DELAY, DEC, H264 | HEVC | VP9, + {OUTPUT_ORDER}, + NULL, + NULL}, + + {OUTPUT_ORDER, DEC, H264 | HEVC | VP9, + {0}, + msm_vidc_adjust_output_order, + msm_vidc_set_u32}, + + {INPUT_BUF_HOST_MAX_COUNT, ENC | DEC, CODECS_ALL, + {0}, + msm_vidc_adjust_input_buf_host_max_count, + msm_vidc_set_u32}, + + {INPUT_BUF_HOST_MAX_COUNT, ENC, H264 | HEVC, + {0}, + msm_vidc_adjust_input_buf_host_max_count, + msm_vidc_set_u32}, + + {OUTPUT_BUF_HOST_MAX_COUNT, ENC | DEC, CODECS_ALL, + {0}, + msm_vidc_adjust_output_buf_host_max_count, + msm_vidc_set_u32}, + + {OUTPUT_BUF_HOST_MAX_COUNT, ENC, H264 | HEVC, + {0}, + msm_vidc_adjust_output_buf_host_max_count, + msm_vidc_set_u32}, + + {CONCEAL_COLOR_8BIT, DEC, CODECS_ALL, + {0}, + NULL, + msm_vidc_set_u32_packed}, + + {CONCEAL_COLOR_10BIT, DEC, CODECS_ALL, + {0}, + NULL, + msm_vidc_set_u32_packed}, + + {STAGE, ENC | DEC, CODECS_ALL, + {0}, + NULL, + msm_vidc_set_stage}, + + {STAGE, ENC, H264 | HEVC, + {0}, + NULL, + msm_vidc_set_stage}, + + {STAGE, DEC, H264 | HEVC | VP9, + {0}, + NULL, + msm_vidc_set_stage}, + + {PIPE, DEC | ENC, CODECS_ALL, + {0}, + NULL, + msm_vidc_set_pipe}, + + {RAP_FRAME, DEC, CODECS_ALL, + {0}, + NULL, + msm_vidc_set_u32}, + + {ALL_INTRA, ENC, H264 | HEVC, + {LTR_COUNT, IR_PERIOD, SLICE_MODE, BIT_RATE}, + msm_vidc_adjust_all_intra, + NULL}, +}; + +/* Default UBWC config for LPDDR5 */ +static struct msm_vidc_ubwc_config_data ubwc_config_sm8550[] = { + UBWC_CONFIG(8, 32, 16, 0, 1, 1, 1), +}; + +static struct msm_vidc_format_capability format_data_sm8550 = { + .codec_info = codec_data_sm8550, + .codec_info_size = ARRAY_SIZE(codec_data_sm8550), + .color_format_info = color_format_data_sm8550, + .color_format_info_size = ARRAY_SIZE(color_format_data_sm8550), + .color_prim_info = color_primaries_data_sm8550, + .color_prim_info_size = ARRAY_SIZE(color_primaries_data_sm8550), + .transfer_char_info = transfer_char_data_sm8550, + .transfer_char_info_size = ARRAY_SIZE(transfer_char_data_sm8550), + .matrix_coeff_info = matrix_coeff_data_sm8550, + .matrix_coeff_info_size = ARRAY_SIZE(matrix_coeff_data_sm8550), +}; + +/* name, min_kbps, max_kbps */ +static const struct bw_table sm8550_bw_table[] = { + { "venus-cnoc", 1000, 1000 }, + { "venus-ddr", 1000, 15000000 }, +}; + +/* name */ +static const struct pd_table sm8550_pd_table[] = { + { "iris-ctl" }, + { "vcodec" }, +}; + +/* name */ +static const char * const sm8550_opp_table[] = { "mx", "mmcx", NULL }; + +/* name, clock id, scaling */ +static const struct clk_table sm8550_clk_table[] = { + { "gcc_video_axi0", GCC_VIDEO_AXI0_CLK, 0 }, + { "core_clk", VIDEO_CC_MVS0C_CLK, 0 }, + { "vcodec_clk", VIDEO_CC_MVS0_CLK, 1 }, +}; + +/* name, exclusive_release */ +static const struct clk_rst_table sm8550_clk_reset_table[] = { + { "video_axi_reset", 0 }, +}; + +/* name, start, size, secure, dma_coherant, region, dma_mask */ +const struct context_bank_table sm8550_context_bank_table[] = { + {"qcom,vidc,cb-ns", 0x25800000, 0xba800000, 0, 1, MSM_VIDC_NON_SECURE, 0xe0000000 - 1}, + {"qcom,vidc,cb-sec-non-pxl", 0x01000000, 0x24800000, 1, 0, MSM_VIDC_SECURE_NONPIXEL, 0 }, +}; + +/* freq */ +static struct freq_table sm8550_freq_table[] = { + {533333333}, {444000000}, {366000000}, {338000000}, {240000000} +}; + +/* register, value, mask */ +static const struct reg_preset_table sm8550_reg_preset_table[] = { + { 0xB0088, 0x0, 0x11 }, +}; + +/* decoder properties */ +static const u32 sm8550_vdec_psc_avc[] = { + HFI_PROP_BITSTREAM_RESOLUTION, + HFI_PROP_CROP_OFFSETS, + HFI_PROP_CODED_FRAMES, + HFI_PROP_BUFFER_FW_MIN_OUTPUT_COUNT, + HFI_PROP_PIC_ORDER_CNT_TYPE, + HFI_PROP_PROFILE, + HFI_PROP_LEVEL, + HFI_PROP_SIGNAL_COLOR_INFO, +}; + +static const u32 sm8550_vdec_psc_hevc[] = { + HFI_PROP_BITSTREAM_RESOLUTION, + HFI_PROP_CROP_OFFSETS, + HFI_PROP_LUMA_CHROMA_BIT_DEPTH, + HFI_PROP_BUFFER_FW_MIN_OUTPUT_COUNT, + HFI_PROP_PROFILE, + HFI_PROP_LEVEL, + HFI_PROP_TIER, + HFI_PROP_SIGNAL_COLOR_INFO, +}; + +static const u32 sm8550_vdec_psc_vp9[] = { + HFI_PROP_BITSTREAM_RESOLUTION, + HFI_PROP_CROP_OFFSETS, + HFI_PROP_LUMA_CHROMA_BIT_DEPTH, + HFI_PROP_BUFFER_FW_MIN_OUTPUT_COUNT, + HFI_PROP_PROFILE, + HFI_PROP_LEVEL, +}; + +static const u32 sm8550_vdec_input_properties_avc[] = { + HFI_PROP_NO_OUTPUT, + HFI_PROP_SUBFRAME_INPUT, +}; + +static const u32 sm8550_vdec_input_properties_hevc[] = { + HFI_PROP_NO_OUTPUT, + HFI_PROP_SUBFRAME_INPUT, +}; + +static const u32 sm8550_vdec_input_properties_vp9[] = { + HFI_PROP_NO_OUTPUT, + HFI_PROP_SUBFRAME_INPUT, +}; + +static const u32 sm8550_vdec_output_properties_avc[] = { + HFI_PROP_WORST_COMPRESSION_RATIO, + HFI_PROP_WORST_COMPLEXITY_FACTOR, + HFI_PROP_PICTURE_TYPE, + HFI_PROP_DPB_LIST, + HFI_PROP_CABAC_SESSION, +}; + +static const u32 sm8550_vdec_output_properties_hevc[] = { + HFI_PROP_WORST_COMPRESSION_RATIO, + HFI_PROP_WORST_COMPLEXITY_FACTOR, + HFI_PROP_PICTURE_TYPE, + HFI_PROP_DPB_LIST, +}; + +static const u32 sm8550_vdec_output_properties_vp9[] = { + HFI_PROP_WORST_COMPRESSION_RATIO, + HFI_PROP_WORST_COMPLEXITY_FACTOR, + HFI_PROP_PICTURE_TYPE, + HFI_PROP_DPB_LIST, +}; + +static const struct msm_vidc_platform_data sm8550_data = { + /* resources dependent on other module */ + .bw_tbl = sm8550_bw_table, + .bw_tbl_size = ARRAY_SIZE(sm8550_bw_table), + .clk_tbl = sm8550_clk_table, + .clk_tbl_size = ARRAY_SIZE(sm8550_clk_table), + .clk_rst_tbl = sm8550_clk_reset_table, + .clk_rst_tbl_size = ARRAY_SIZE(sm8550_clk_reset_table), + .subcache_tbl = NULL, + .subcache_tbl_size = 0, + + /* populate context bank */ + .context_bank_tbl = sm8550_context_bank_table, + .context_bank_tbl_size = ARRAY_SIZE(sm8550_context_bank_table), + + /* populate power domain and opp table */ + .pd_tbl = sm8550_pd_table, + .pd_tbl_size = ARRAY_SIZE(sm8550_pd_table), + .opp_tbl = sm8550_opp_table, + .opp_tbl_size = ARRAY_SIZE(sm8550_opp_table), + + /* platform specific resources */ + .freq_tbl = sm8550_freq_table, + .freq_tbl_size = ARRAY_SIZE(sm8550_freq_table), + .reg_prst_tbl = sm8550_reg_preset_table, + .reg_prst_tbl_size = ARRAY_SIZE(sm8550_reg_preset_table), + .fwname = "vpu30_4v", + .pas_id = 9, + + /* caps related resorces */ + .core_data = core_data_sm8550, + .core_data_size = ARRAY_SIZE(core_data_sm8550), + .inst_cap_data = instance_cap_data_sm8550, + .inst_cap_data_size = ARRAY_SIZE(instance_cap_data_sm8550), + .inst_cap_dependency_data = instance_cap_dependency_data_sm8550, + .inst_cap_dependency_data_size = ARRAY_SIZE(instance_cap_dependency_data_sm8550), + .ubwc_config = ubwc_config_sm8550, + .format_data = &format_data_sm8550, + + /* decoder properties related*/ + .psc_avc_tbl = sm8550_vdec_psc_avc, + .psc_avc_tbl_size = ARRAY_SIZE(sm8550_vdec_psc_avc), + .psc_hevc_tbl = sm8550_vdec_psc_hevc, + .psc_hevc_tbl_size = ARRAY_SIZE(sm8550_vdec_psc_hevc), + .psc_vp9_tbl = sm8550_vdec_psc_vp9, + .psc_vp9_tbl_size = ARRAY_SIZE(sm8550_vdec_psc_vp9), + .dec_input_prop_avc = sm8550_vdec_input_properties_avc, + .dec_input_prop_hevc = sm8550_vdec_input_properties_hevc, + .dec_input_prop_vp9 = sm8550_vdec_input_properties_vp9, + .dec_input_prop_size_avc = ARRAY_SIZE(sm8550_vdec_input_properties_avc), + .dec_input_prop_size_hevc = ARRAY_SIZE(sm8550_vdec_input_properties_hevc), + .dec_input_prop_size_vp9 = ARRAY_SIZE(sm8550_vdec_input_properties_vp9), + .dec_output_prop_avc = sm8550_vdec_output_properties_avc, + .dec_output_prop_hevc = sm8550_vdec_output_properties_hevc, + .dec_output_prop_vp9 = sm8550_vdec_output_properties_vp9, + .dec_output_prop_size_avc = ARRAY_SIZE(sm8550_vdec_output_properties_avc), + .dec_output_prop_size_hevc = ARRAY_SIZE(sm8550_vdec_output_properties_hevc), + .dec_output_prop_size_vp9 = ARRAY_SIZE(sm8550_vdec_output_properties_vp9), +}; + +static int msm_vidc_init_data(struct msm_vidc_core *core) +{ + d_vpr_h("%s: initialize sm8550 data\n", __func__); + + core->platform->data = sm8550_data; + + return 0; +} + +int msm_vidc_init_platform_sm8550(struct msm_vidc_core *core) +{ + return msm_vidc_init_data(core); +}