/* SPDX-License-Identifier: GPL-2.0-only */ /* * Copyright (c) 2022-2025 Qualcomm Innovation Center, Inc. All rights reserved. */ #define BITRATE_MAX 245000000 static struct platform_inst_fw_cap inst_fw_cap_qcs8300_dec[] = { { .cap_id = PROFILE_H264, .min = V4L2_MPEG_VIDEO_H264_PROFILE_BASELINE, .max = V4L2_MPEG_VIDEO_H264_PROFILE_CONSTRAINED_HIGH, .step_or_mask = BIT(V4L2_MPEG_VIDEO_H264_PROFILE_BASELINE) | BIT(V4L2_MPEG_VIDEO_H264_PROFILE_CONSTRAINED_BASELINE) | BIT(V4L2_MPEG_VIDEO_H264_PROFILE_MAIN) | BIT(V4L2_MPEG_VIDEO_H264_PROFILE_HIGH) | BIT(V4L2_MPEG_VIDEO_H264_PROFILE_CONSTRAINED_HIGH), .value = V4L2_MPEG_VIDEO_H264_PROFILE_HIGH, .hfi_id = HFI_PROP_PROFILE, .flags = CAP_FLAG_OUTPUT_PORT | CAP_FLAG_MENU, .set = iris_set_u32_enum, }, { .cap_id = PROFILE_HEVC, .min = V4L2_MPEG_VIDEO_HEVC_PROFILE_MAIN, .max = V4L2_MPEG_VIDEO_HEVC_PROFILE_MAIN_STILL_PICTURE, .step_or_mask = BIT(V4L2_MPEG_VIDEO_HEVC_PROFILE_MAIN) | BIT(V4L2_MPEG_VIDEO_HEVC_PROFILE_MAIN_STILL_PICTURE), .value = V4L2_MPEG_VIDEO_HEVC_PROFILE_MAIN, .hfi_id = HFI_PROP_PROFILE, .flags = CAP_FLAG_OUTPUT_PORT | CAP_FLAG_MENU, .set = iris_set_u32_enum, }, { .cap_id = PROFILE_VP9, .min = V4L2_MPEG_VIDEO_VP9_PROFILE_0, .max = V4L2_MPEG_VIDEO_VP9_PROFILE_2, .step_or_mask = BIT(V4L2_MPEG_VIDEO_VP9_PROFILE_0) | BIT(V4L2_MPEG_VIDEO_VP9_PROFILE_2), .value = V4L2_MPEG_VIDEO_VP9_PROFILE_0, .hfi_id = HFI_PROP_PROFILE, .flags = CAP_FLAG_OUTPUT_PORT | CAP_FLAG_MENU, .set = iris_set_u32_enum, }, { .cap_id = LEVEL_H264, .min = V4L2_MPEG_VIDEO_H264_LEVEL_1_0, .max = V4L2_MPEG_VIDEO_H264_LEVEL_6_2, .step_or_mask = 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), .value = V4L2_MPEG_VIDEO_H264_LEVEL_6_1, .hfi_id = HFI_PROP_LEVEL, .flags = CAP_FLAG_OUTPUT_PORT | CAP_FLAG_MENU, .set = iris_set_u32_enum, }, { .cap_id = LEVEL_HEVC, .min = V4L2_MPEG_VIDEO_HEVC_LEVEL_1, .max = V4L2_MPEG_VIDEO_HEVC_LEVEL_6_2, .step_or_mask = 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), .value = V4L2_MPEG_VIDEO_HEVC_LEVEL_6_1, .hfi_id = HFI_PROP_LEVEL, .flags = CAP_FLAG_OUTPUT_PORT | CAP_FLAG_MENU, .set = iris_set_u32_enum, }, { .cap_id = LEVEL_VP9, .min = V4L2_MPEG_VIDEO_VP9_LEVEL_1_0, .max = V4L2_MPEG_VIDEO_VP9_LEVEL_6_0, .step_or_mask = 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), .value = V4L2_MPEG_VIDEO_VP9_LEVEL_6_0, .hfi_id = HFI_PROP_LEVEL, .flags = CAP_FLAG_OUTPUT_PORT | CAP_FLAG_MENU, .set = iris_set_u32_enum, }, { .cap_id = TIER, .min = V4L2_MPEG_VIDEO_HEVC_TIER_MAIN, .max = V4L2_MPEG_VIDEO_HEVC_TIER_HIGH, .step_or_mask = BIT(V4L2_MPEG_VIDEO_HEVC_TIER_MAIN) | BIT(V4L2_MPEG_VIDEO_HEVC_TIER_HIGH), .value = V4L2_MPEG_VIDEO_HEVC_TIER_HIGH, .hfi_id = HFI_PROP_TIER, .flags = CAP_FLAG_OUTPUT_PORT | CAP_FLAG_MENU, .set = iris_set_u32_enum, }, { .cap_id = INPUT_BUF_HOST_MAX_COUNT, .min = DEFAULT_MAX_HOST_BUF_COUNT, .max = DEFAULT_MAX_HOST_BURST_BUF_COUNT, .step_or_mask = 1, .value = DEFAULT_MAX_HOST_BUF_COUNT, .hfi_id = HFI_PROP_BUFFER_HOST_MAX_COUNT, .flags = CAP_FLAG_INPUT_PORT, .set = iris_set_u32, }, { .cap_id = STAGE, .min = STAGE_1, .max = STAGE_2, .step_or_mask = 1, .value = STAGE_2, .hfi_id = HFI_PROP_STAGE, .set = iris_set_stage, }, { .cap_id = PIPE, .min = PIPE_1, .max = PIPE_2, .step_or_mask = 1, .value = PIPE_2, .hfi_id = HFI_PROP_PIPE, .set = iris_set_pipe, }, { .cap_id = POC, .min = 0, .max = 2, .step_or_mask = 1, .value = 1, .hfi_id = HFI_PROP_PIC_ORDER_CNT_TYPE, }, { .cap_id = CODED_FRAMES, .min = CODED_FRAMES_PROGRESSIVE, .max = CODED_FRAMES_PROGRESSIVE, .step_or_mask = 0, .value = CODED_FRAMES_PROGRESSIVE, .hfi_id = HFI_PROP_CODED_FRAMES, }, { .cap_id = BIT_DEPTH, .min = BIT_DEPTH_8, .max = BIT_DEPTH_8, .step_or_mask = 1, .value = BIT_DEPTH_8, .hfi_id = HFI_PROP_LUMA_CHROMA_BIT_DEPTH, }, { .cap_id = RAP_FRAME, .min = 0, .max = 1, .step_or_mask = 1, .value = 1, .hfi_id = HFI_PROP_DEC_START_FROM_RAP_FRAME, .flags = CAP_FLAG_INPUT_PORT, .set = iris_set_u32, }, }; static struct platform_inst_fw_cap inst_fw_cap_qcs8300_enc[] = { { .cap_id = PROFILE_H264, .min = V4L2_MPEG_VIDEO_H264_PROFILE_BASELINE, .max = V4L2_MPEG_VIDEO_H264_PROFILE_CONSTRAINED_HIGH, .step_or_mask = 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), .value = V4L2_MPEG_VIDEO_H264_PROFILE_HIGH, .hfi_id = HFI_PROP_PROFILE, .flags = CAP_FLAG_OUTPUT_PORT | CAP_FLAG_MENU, }, { .cap_id = PROFILE_HEVC, .min = V4L2_MPEG_VIDEO_HEVC_PROFILE_MAIN, .max = V4L2_MPEG_VIDEO_HEVC_PROFILE_MAIN_10, .step_or_mask = BIT(V4L2_MPEG_VIDEO_HEVC_PROFILE_MAIN) | BIT(V4L2_MPEG_VIDEO_HEVC_PROFILE_MAIN_STILL_PICTURE) | BIT(V4L2_MPEG_VIDEO_HEVC_PROFILE_MAIN_10), .value = V4L2_MPEG_VIDEO_HEVC_PROFILE_MAIN, .hfi_id = HFI_PROP_PROFILE, .flags = CAP_FLAG_OUTPUT_PORT | CAP_FLAG_MENU, }, { .cap_id = LEVEL_H264, .min = V4L2_MPEG_VIDEO_H264_LEVEL_1_0, .max = V4L2_MPEG_VIDEO_H264_LEVEL_6_0, .step_or_mask = 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), .value = V4L2_MPEG_VIDEO_H264_LEVEL_5_0, .hfi_id = HFI_PROP_LEVEL, .flags = CAP_FLAG_OUTPUT_PORT | CAP_FLAG_MENU, }, { .cap_id = LEVEL_HEVC, .min = V4L2_MPEG_VIDEO_HEVC_LEVEL_1, .max = V4L2_MPEG_VIDEO_HEVC_LEVEL_6_2, .step_or_mask = 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), .value = V4L2_MPEG_VIDEO_HEVC_LEVEL_5, .hfi_id = HFI_PROP_LEVEL, .flags = CAP_FLAG_OUTPUT_PORT | CAP_FLAG_MENU, }, { .cap_id = STAGE, .min = STAGE_1, .max = STAGE_2, .step_or_mask = 1, .value = STAGE_2, .hfi_id = HFI_PROP_STAGE, }, { .cap_id = HEADER_MODE, .min = V4L2_MPEG_VIDEO_HEADER_MODE_SEPARATE, .max = V4L2_MPEG_VIDEO_HEADER_MODE_JOINED_WITH_1ST_FRAME, .step_or_mask = BIT(V4L2_MPEG_VIDEO_HEADER_MODE_SEPARATE) | BIT(V4L2_MPEG_VIDEO_HEADER_MODE_JOINED_WITH_1ST_FRAME), .value = V4L2_MPEG_VIDEO_HEADER_MODE_JOINED_WITH_1ST_FRAME, .hfi_id = HFI_PROP_SEQ_HEADER_MODE, .flags = CAP_FLAG_OUTPUT_PORT | CAP_FLAG_MENU, }, { .cap_id = PREPEND_SPSPPS_TO_IDR, .min = 0, .max = 1, .step_or_mask = 1, .value = 0, }, { .cap_id = BITRATE, .min = 1, .max = BITRATE_MAX, .step_or_mask = 1, .value = BITRATE_DEFAULT, .hfi_id = HFI_PROP_TOTAL_BITRATE, .flags = CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT | CAP_FLAG_DYNAMIC_ALLOWED, }, { .cap_id = BITRATE_PEAK, .min = 1, .max = BITRATE_MAX, .step_or_mask = 1, .value = BITRATE_DEFAULT, .hfi_id = HFI_PROP_TOTAL_PEAK_BITRATE, .flags = CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT | CAP_FLAG_DYNAMIC_ALLOWED, }, { .cap_id = BITRATE_MODE, .min = V4L2_MPEG_VIDEO_BITRATE_MODE_VBR, .max = V4L2_MPEG_VIDEO_BITRATE_MODE_CBR, .step_or_mask = BIT(V4L2_MPEG_VIDEO_BITRATE_MODE_VBR) | BIT(V4L2_MPEG_VIDEO_BITRATE_MODE_CBR), .value = V4L2_MPEG_VIDEO_BITRATE_MODE_VBR, .hfi_id = HFI_PROP_RATE_CONTROL, .flags = CAP_FLAG_OUTPUT_PORT | CAP_FLAG_MENU, }, { .cap_id = FRAME_SKIP_MODE, .min = V4L2_MPEG_VIDEO_FRAME_SKIP_MODE_DISABLED, .max = V4L2_MPEG_VIDEO_FRAME_SKIP_MODE_BUF_LIMIT, .step_or_mask = 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), .value = V4L2_MPEG_VIDEO_FRAME_SKIP_MODE_DISABLED, .flags = CAP_FLAG_OUTPUT_PORT | CAP_FLAG_MENU, }, { .cap_id = FRAME_RC_ENABLE, .min = 0, .max = 1, .step_or_mask = 1, .value = 1, }, { .cap_id = GOP_SIZE, .min = 0, .max = INT_MAX, .step_or_mask = 1, .value = 2 * DEFAULT_FPS - 1, .hfi_id = HFI_PROP_MAX_GOP_FRAMES, .flags = CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT | CAP_FLAG_DYNAMIC_ALLOWED, }, { .cap_id = ENTROPY_MODE, .min = V4L2_MPEG_VIDEO_H264_ENTROPY_MODE_CAVLC, .max = V4L2_MPEG_VIDEO_H264_ENTROPY_MODE_CABAC, .step_or_mask = BIT(V4L2_MPEG_VIDEO_H264_ENTROPY_MODE_CAVLC) | BIT(V4L2_MPEG_VIDEO_H264_ENTROPY_MODE_CABAC), .value = V4L2_MPEG_VIDEO_H264_ENTROPY_MODE_CABAC, .hfi_id = HFI_PROP_CABAC_SESSION, .flags = CAP_FLAG_OUTPUT_PORT | CAP_FLAG_MENU, }, { .cap_id = MIN_FRAME_QP_H264, .min = MIN_QP_8BIT, .max = MAX_QP, .step_or_mask = 1, .value = MIN_QP_8BIT, .hfi_id = HFI_PROP_MIN_QP_PACKED, .flags = CAP_FLAG_OUTPUT_PORT, }, { .cap_id = MIN_FRAME_QP_HEVC, .min = MIN_QP_8BIT, .max = MAX_QP, .step_or_mask = 1, .value = MIN_QP_8BIT, .hfi_id = HFI_PROP_MIN_QP_PACKED, .flags = CAP_FLAG_OUTPUT_PORT, }, { .cap_id = MAX_FRAME_QP_H264, .min = MIN_QP_8BIT, .max = MAX_QP, .step_or_mask = 1, .value = MAX_QP, .hfi_id = HFI_PROP_MAX_QP_PACKED, .flags = CAP_FLAG_OUTPUT_PORT, }, { .cap_id = MAX_FRAME_QP_HEVC, .min = MIN_QP_8BIT, .max = MAX_QP, .step_or_mask = 1, .value = MAX_QP, .hfi_id = HFI_PROP_MAX_QP_PACKED, .flags = CAP_FLAG_OUTPUT_PORT, }, { .cap_id = I_FRAME_MIN_QP_H264, .min = MIN_QP_8BIT, .max = MAX_QP, .step_or_mask = 1, .value = MIN_QP_8BIT, }, { .cap_id = I_FRAME_MIN_QP_HEVC, .min = MIN_QP_8BIT, .max = MAX_QP, .step_or_mask = 1, .value = MIN_QP_8BIT, }, { .cap_id = P_FRAME_MIN_QP_H264, .min = MIN_QP_8BIT, .max = MAX_QP, .step_or_mask = 1, .value = MIN_QP_8BIT, }, { .cap_id = P_FRAME_MIN_QP_HEVC, .min = MIN_QP_8BIT, .max = MAX_QP, .step_or_mask = 1, .value = MIN_QP_8BIT, }, { .cap_id = B_FRAME_MIN_QP_H264, .min = MIN_QP_8BIT, .max = MAX_QP, .step_or_mask = 1, .value = MIN_QP_8BIT, }, { .cap_id = B_FRAME_MIN_QP_HEVC, .min = MIN_QP_8BIT, .max = MAX_QP, .step_or_mask = 1, .value = MIN_QP_8BIT, }, { .cap_id = I_FRAME_MAX_QP_H264, .min = MIN_QP_8BIT, .max = MAX_QP, .step_or_mask = 1, .value = MAX_QP, }, { .cap_id = I_FRAME_MAX_QP_HEVC, .min = MIN_QP_8BIT, .max = MAX_QP, .step_or_mask = 1, .value = MAX_QP, }, { .cap_id = P_FRAME_MAX_QP_H264, .min = MIN_QP_8BIT, .max = MAX_QP, .step_or_mask = 1, .value = MAX_QP, }, { .cap_id = P_FRAME_MAX_QP_HEVC, .min = MIN_QP_8BIT, .max = MAX_QP, .step_or_mask = 1, .value = MAX_QP, }, { .cap_id = B_FRAME_MAX_QP_H264, .min = MIN_QP_8BIT, .max = MAX_QP, .step_or_mask = 1, .value = MAX_QP, }, { .cap_id = B_FRAME_MAX_QP_HEVC, .min = MIN_QP_8BIT, .max = MAX_QP, .step_or_mask = 1, .value = MAX_QP, }, { .cap_id = I_FRAME_QP_H264, .min = MIN_QP_8BIT, .max = MAX_QP, .step_or_mask = 1, .value = DEFAULT_QP, .hfi_id = HFI_PROP_QP_PACKED, .flags = CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT | CAP_FLAG_DYNAMIC_ALLOWED, }, { .cap_id = I_FRAME_QP_HEVC, .min = MIN_QP_8BIT, .max = MAX_QP, .step_or_mask = 1, .value = DEFAULT_QP, .hfi_id = HFI_PROP_QP_PACKED, .flags = CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT | CAP_FLAG_DYNAMIC_ALLOWED, }, { .cap_id = P_FRAME_QP_H264, .min = MIN_QP_8BIT, .max = MAX_QP, .step_or_mask = 1, .value = DEFAULT_QP, .hfi_id = HFI_PROP_QP_PACKED, .flags = CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT | CAP_FLAG_DYNAMIC_ALLOWED, }, { .cap_id = P_FRAME_QP_HEVC, .min = MIN_QP_8BIT, .max = MAX_QP, .step_or_mask = 1, .value = DEFAULT_QP, .hfi_id = HFI_PROP_QP_PACKED, .flags = CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT | CAP_FLAG_DYNAMIC_ALLOWED, }, { .cap_id = B_FRAME_QP_H264, .min = MIN_QP_8BIT, .max = MAX_QP, .step_or_mask = 1, .value = DEFAULT_QP, .hfi_id = HFI_PROP_QP_PACKED, .flags = CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT | CAP_FLAG_DYNAMIC_ALLOWED, }, { .cap_id = B_FRAME_QP_HEVC, .min = MIN_QP_8BIT, .max = MAX_QP, .step_or_mask = 1, .value = DEFAULT_QP, .hfi_id = HFI_PROP_QP_PACKED, .flags = CAP_FLAG_OUTPUT_PORT | CAP_FLAG_INPUT_PORT | CAP_FLAG_DYNAMIC_ALLOWED, }, }; static struct platform_inst_caps platform_inst_cap_qcs8300 = { .min_frame_width = 96, .max_frame_width = 4096, .min_frame_height = 96, .max_frame_height = 4096, .max_mbpf = (4096 * 2176) / 256, .mb_cycles_vpp = 200, .mb_cycles_fw = 326389, .mb_cycles_fw_vpp = 44156, .num_comv = 0, .max_frame_rate = MAXIMUM_FPS, .max_operating_rate = MAXIMUM_FPS, };