From nobody Mon Feb 9 16:18:33 2026 Received: from mx0b-0031df01.pphosted.com (mx0b-0031df01.pphosted.com [205.220.180.131]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id DDBFF37996D for ; Thu, 29 Jan 2026 07:48:47 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=205.220.180.131 ARC-Seal: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1769672929; cv=none; b=klNZjW2qyn/M9zu8pwHq8CAVz+JICsWTJ8gdofTfPL7uOKeJknLu1WtnDsjzUJkTPSoFcK2M6JAb31NXV6He3q1qxB4VnYCQQwJoTKfHNdkGjf77RMepf1Z6ng6B4lByDgDRRuXAocSVyAdOpDgizhXv0KHDyf1N+09a/bDc1ic= ARC-Message-Signature: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1769672929; c=relaxed/simple; bh=vu0FF/0EWxRRRdI+Ueke/qWAx0AFTRqdB2hGPgQ0ldo=; h=From:Date:Subject:MIME-Version:Content-Type:Message-Id:References: In-Reply-To:To:Cc; b=mDjJtex8R9tWNGG0A5OleaHUjHl4VtLTLp2SNK179asJZva9TfoKiC2+0LGQDQz92Ex/tDRTLtT20fSYboinHxdZ6cJsc5JtBUoT7Vwx5zLOkQKr3kEqA5f1FWMA+7r3J63bSk9eR1jgedWfPFH75RON/zNZWMrA0hc5VUJZLoI= ARC-Authentication-Results: i=1; smtp.subspace.kernel.org; dmarc=pass (p=reject dis=none) header.from=oss.qualcomm.com; spf=pass smtp.mailfrom=oss.qualcomm.com; dkim=pass (2048-bit key) header.d=qualcomm.com header.i=@qualcomm.com header.b=nF7sqw2B; dkim=pass (2048-bit key) header.d=oss.qualcomm.com header.i=@oss.qualcomm.com header.b=cl7uPmb2; arc=none smtp.client-ip=205.220.180.131 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=reject dis=none) header.from=oss.qualcomm.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=oss.qualcomm.com Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=qualcomm.com header.i=@qualcomm.com header.b="nF7sqw2B"; dkim=pass (2048-bit key) header.d=oss.qualcomm.com header.i=@oss.qualcomm.com header.b="cl7uPmb2" Received: from pps.filterd (m0279872.ppops.net [127.0.0.1]) by mx0a-0031df01.pphosted.com (8.18.1.11/8.18.1.11) with ESMTP id 60T2okSv2033278 for ; Thu, 29 Jan 2026 07:48:46 GMT DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=qualcomm.com; h= cc:content-transfer-encoding:content-type:date:from:in-reply-to :message-id:mime-version:references:subject:to; s=qcppdkim1; bh= vusokcB14ISYWAIOqjpq0u21/gtzX6Vq7VTeLwjsWM4=; b=nF7sqw2BwWDt2SqG qH9w/+/UkyUrEc7ro2ni52WD49yBBIxHitx2U2b9EboRUGT805kwZ/iosprSvP+M bK1+y2TUyzuOaz9PR8UMrG0ouf1g66XIEUy7p9jCU2CBfSXcsCVZpdl+m8EUcZ3j rXgYw1lde4JrotZb37Tg3gfHdSWSJAaG4if+TYlcKZVClAe0+RvX5I4j2jUEjSQX 6A9GBrckrdd+TvGsCQQYPA+ZqQ7k2RWHTNRDdESGykvVBrBYsJZq0YSfiJB5O8F4 H45zt/1g1xZtHmzDZp4JqZGeHGvfYghIW/fEJjNRBlM4msBC2a/LxjOOdj+xJkYl e0wzZg== Received: from mail-pg1-f198.google.com (mail-pg1-f198.google.com [209.85.215.198]) by mx0a-0031df01.pphosted.com (PPS) with ESMTPS id 4bytqy1hn7-1 (version=TLSv1.3 cipher=TLS_AES_128_GCM_SHA256 bits=128 verify=NOT) for ; Thu, 29 Jan 2026 07:48:46 +0000 (GMT) Received: by mail-pg1-f198.google.com with SMTP id 41be03b00d2f7-c613929d317so502905a12.2 for ; Wed, 28 Jan 2026 23:48:46 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=oss.qualcomm.com; s=google; t=1769672925; x=1770277725; darn=vger.kernel.org; h=cc:to:in-reply-to:references:message-id:content-transfer-encoding :mime-version:subject:date:from:from:to:cc:subject:date:message-id :reply-to; bh=vusokcB14ISYWAIOqjpq0u21/gtzX6Vq7VTeLwjsWM4=; b=cl7uPmb24Hmcn0saNDMnvHzCZ8mBOTohHk83+GMWFyZMbaDZYkcMEUGWIwMvqaRGHO qIp2Lt0YuhkNeoLer269SNGr3AE0rlIr1yR9wF/crXQUfXNJKarkMriKpxtT4xWtNc6H hcayDatFNVGhUWIdoou9tMg/yOrhzxtg4mE1FihG/ciTkS+ZR45jOXw+zLP/4155qYG1 /YEaWUwImM+NSPaEIIdGVlaSrHWhARkNNp2wxYSboK6nVwqF7YYVK2LMYGzB2DfPE+eD rwpS+/s34RzaF6DirZ8EbW7PjRN9kKfyVt/X6wZlhkYgn9rgBsm0aTLWL4q0sNfJGzfp RGmw== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1769672925; x=1770277725; h=cc:to:in-reply-to:references:message-id:content-transfer-encoding :mime-version:subject:date:from:x-gm-gg:x-gm-message-state:from:to :cc:subject:date:message-id:reply-to; bh=vusokcB14ISYWAIOqjpq0u21/gtzX6Vq7VTeLwjsWM4=; b=V6AfT2/3Ogo0UBv/8qJF1y8xR+rq3h8ltm4cBTQg2yqGRgTxTPRBuG5vzXtMibMmHP 8ltMl9BRvXW/D7Do49Pq3NZ81/D0svAgd+XZ0l5bPhNXzopGYe+GeGA2AcIXxkVMFX6S 6esSNJXvWmhvslSkKT2c/JXCRxNJsktmt2deOF1SryYxPWwBpTPUeGFdqb3J63kvPk8u T253R9PlsppHTTPl890yqWnxHJDLKSONbMZ8YF/82KuLqRq2OabnoucYXI+nQCNz4nJY iDuDHzOSrQRdD75YWX9X2qNQFrAoGKFo7pYwoInOk2ZoEN0Rmmyi7gsUfB2wzdBxr6P/ WCOQ== X-Forwarded-Encrypted: i=1; AJvYcCUh/t9teQ8Ezo4XbmiHotctThiGaPUt5zXcQj69vcCgNgH7ENn1bgd3t9KUlA84cLvs1WXQ19VUMxP5/G0=@vger.kernel.org X-Gm-Message-State: AOJu0YztQNwzGJdz+C+yJ04J7si4toITsobUjpwmmKtXA6FLr6KEhu3W zhi/P7JwvelMCvjfOXOv/2mNneGe9F9oHZO1tORYZPYcFzojRmjOWKvS1yG3JaI5uV+lqLtJo86 0fHKPQJDr3P0QlpCoiBqB9G1rNeWWPr/m52OAYmX1jXWIiFhievQZRdJ4l0TJuBjXs9g= X-Gm-Gg: AZuq6aKLNQ1Q8ChKvz/zq9uXSXDIvEuLJIZIGcQ+3Vb1LIeC+bwNrf2+c1/ak4qyjoR gBeRQsxg5yjuQqdhPET2oWua1aDc8W91/S4n6jUCMMY5I769Bkr18dRr+lvxr/3Brxm5WZKVOtS 38kDaF2Ettpq3GZxHxf3t9MB/H2G4H6G0M61QXa4XXtaFLKwbCm5epFo/6D1VvsU9Rrg2mVu+fn ENn5CzYSvX7YGQR3z9H68tRRoPuI0B2DzR6MN5D1wySRDmLBRroFheTyeqcpxO1D03XUtF4L2Q7 q6aMnd0PAm7PLOZk3hg45YTRj5HE51ZYyMI4CxuGODJzxhcqDN/KO4KIr3Ho8l2KwNjOB6E8UYV 2cZxS5bHLf26S4oHYvNYirjHOKegzU8v4WwS6ChfQ72ToK+tW0rQectAX7XY5/pL5dRJXajRLQC Jj2Tcwp/YejTA= X-Received: by 2002:a05:6a00:2294:b0:7f7:6229:fbb5 with SMTP id d2e1a72fcca58-82369196317mr7631202b3a.25.1769672924502; Wed, 28 Jan 2026 23:48:44 -0800 (PST) X-Received: by 2002:a05:6a00:2294:b0:7f7:6229:fbb5 with SMTP id d2e1a72fcca58-82369196317mr7631169b3a.25.1769672923975; Wed, 28 Jan 2026 23:48:43 -0800 (PST) Received: from WANGAOW-LAB01.ap.qualcomm.com (tpe-colo-wan-fw-bordernet.qualcomm.com. [103.229.16.4]) by smtp.gmail.com with ESMTPSA id d2e1a72fcca58-82379b49fecsm4534634b3a.15.2026.01.28.23.48.40 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Wed, 28 Jan 2026 23:48:43 -0800 (PST) From: Wangao Wang Date: Thu, 29 Jan 2026 15:48:22 +0800 Subject: [PATCH v4 1/6] media: qcom: iris: Add intra refresh support for gen1 encoder Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 Content-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: quoted-printable Message-Id: <20260129-batch2_iris_encoder_enhancements-v4-1-efaac131a5f7@oss.qualcomm.com> References: <20260129-batch2_iris_encoder_enhancements-v4-0-efaac131a5f7@oss.qualcomm.com> In-Reply-To: <20260129-batch2_iris_encoder_enhancements-v4-0-efaac131a5f7@oss.qualcomm.com> To: Vikash Garodia , Dikshita Agarwal , Abhinav Kumar , Bryan O'Donoghue , Mauro Carvalho Chehab Cc: quic_qiweil@quicinc.com, Renjiang Han , Wangao Wang , linux-media@vger.kernel.org, linux-arm-msm@vger.kernel.org, linux-kernel@vger.kernel.org, Neil Armstrong X-Mailer: b4 0.14.2 X-Developer-Signature: v=1; a=ed25519-sha256; t=1769672917; l=7870; i=wangao.wang@oss.qualcomm.com; s=20251021; h=from:subject:message-id; bh=vu0FF/0EWxRRRdI+Ueke/qWAx0AFTRqdB2hGPgQ0ldo=; b=5bEjBpBWB4qctfZwZght7IWnWmiuwpvthGMmXrqYOVgo51ZJYeyJQaavYM8UXsA5KhX6xnWyY mLXyvMzF7c0CR0AHVCT90/OioLTX9ZNaZEQwu3qzlrkJq1BvDh4uMVz X-Developer-Key: i=wangao.wang@oss.qualcomm.com; a=ed25519; pk=bUPgYblBUAsoPyGfssbNR7ZXUSGF8v1VF4FJzSO6/aA= X-Proofpoint-Spam-Details-Enc: AW1haW4tMjYwMTI5MDA0NiBTYWx0ZWRfX3YubTY3phxrx 7RiI/ULYlTUTVU2ZIWpUywHT7fLnpnqmR3A3+unYE+xUvX5jO8c5YDuTDgXsegiu3p3UU/TOHSx neHJFSwpC/XWEnpi5M4UrqgReQS7lDowJmYsYQDFh9/pdFSpSUNcq8MPb+KZ5NftFeapVnjkuJX JC5zb0K4e97iIsY5d628j6Bz79gUXFm/fDgAPQDm/pR10oo/fsHJCwZkpQI4xgvYYe5wkQ1ukfj ThidYglcsaR71l1bZNEJD3iPPzxilUQiWmftVbF4nRMINsU3qEx6jwSpG71GTZI1SYpBOusdqtW ZBkn2RUSeij77RI6YeMcITxR//nRlNoBfaEFHSr7WJAEofkGmI0SDBUlMLNuVc6Vu++Tnp0NrJF FEHAMz//E3Cv3GR6A02gz13VNmQmHgIYgOLxoG9fxgLnUTO3ONAMPxkLC9VViMH3XeED+f/Bkc+ K2QgJ87UUzi/Gv0jCNw== X-Authority-Analysis: v=2.4 cv=Je2xbEKV c=1 sm=1 tr=0 ts=697b10de cx=c_pps a=Qgeoaf8Lrialg5Z894R3/Q==:117 a=nuhDOHQX5FNHPW3J6Bj6AA==:17 a=IkcTkHD0fZMA:10 a=vUbySO9Y5rIA:10 a=s4-Qcg_JpJYA:10 a=VkNPw1HP01LnGYTKEx00:22 a=EUspDBNiAAAA:8 a=KKAkSRfTAAAA:8 a=vcDqveFK9my7lXZq-ZEA:9 a=QEXdDO2ut3YA:10 a=x9snwWr2DeNwDh03kgHS:22 a=cvBusfyB2V15izCimMoJ:22 X-Proofpoint-ORIG-GUID: BGLSKrRk-XMRqWPBFFHJFIchZPrGDb5K X-Proofpoint-GUID: BGLSKrRk-XMRqWPBFFHJFIchZPrGDb5K X-Proofpoint-Virus-Version: vendor=baseguard engine=ICAP:2.0.293,Aquarius:18.0.1121,Hydra:6.1.51,FMLib:17.12.100.49 definitions=2026-01-29_01,2026-01-28_03,2025-10-01_01 X-Proofpoint-Spam-Details: rule=outbound_notspam policy=outbound score=0 malwarescore=0 adultscore=0 priorityscore=1501 phishscore=0 lowpriorityscore=0 spamscore=0 impostorscore=0 clxscore=1015 bulkscore=0 suspectscore=0 classifier=typeunknown authscore=0 authtc= authcc= route=outbound adjust=0 reason=mlx scancount=1 engine=8.22.0-2601150000 definitions=main-2601290046 Add support for intra refresh configuration on gen1 encoder by enabling V4L2_CID_MPEG_VIDEO_INTRA_REFRESH_PERIOD and V4L2_CID_MPEG_VIDEO_INTRA_REFRESH_PERIOD_TYPE controls. Reviewed-by: Dikshita Agarwal Tested-by: Neil Armstrong # on SM8650-HDK Signed-off-by: Wangao Wang --- drivers/media/platform/qcom/iris/iris_ctrls.c | 39 ++++++++++++++++++= +++- drivers/media/platform/qcom/iris/iris_ctrls.h | 3 +- .../platform/qcom/iris/iris_hfi_gen1_command.c | 8 +++++ .../platform/qcom/iris/iris_hfi_gen1_defines.h | 13 ++++++++ .../media/platform/qcom/iris/iris_platform_gen1.c | 19 +++++++++++ .../media/platform/qcom/iris/iris_platform_gen2.c | 2 +- 6 files changed, 81 insertions(+), 3 deletions(-) diff --git a/drivers/media/platform/qcom/iris/iris_ctrls.c b/drivers/media/= platform/qcom/iris/iris_ctrls.c index 3cec957580f5ebbc8d6a7a613866fd0377fe213a..5441278f80fc5d0f97367c09b2e= bd98a55c7ff1c 100644 --- a/drivers/media/platform/qcom/iris/iris_ctrls.c +++ b/drivers/media/platform/qcom/iris/iris_ctrls.c @@ -970,7 +970,44 @@ int iris_set_flip(struct iris_inst *inst, enum platfor= m_inst_fw_cap_type cap_id) &hfi_val, sizeof(u32)); } =20 -int iris_set_ir_period(struct iris_inst *inst, enum platform_inst_fw_cap_t= ype cap_id) +int iris_set_ir_period_gen1(struct iris_inst *inst, enum platform_inst_fw_= cap_type cap_id) +{ + const struct iris_hfi_command_ops *hfi_ops =3D inst->core->hfi_ops; + struct v4l2_pix_format_mplane *fmt =3D &inst->fmt_dst->fmt.pix_mp; + u32 codec_align =3D inst->codec =3D=3D V4L2_PIX_FMT_HEVC ? 32 : 16; + u32 ir_period =3D inst->fw_caps[cap_id].value; + u32 hfi_id =3D inst->fw_caps[cap_id].hfi_id; + struct hfi_intra_refresh hfi_val; + + if (!ir_period) + return -EINVAL; + + if (inst->fw_caps[IR_TYPE].value =3D=3D + V4L2_CID_MPEG_VIDEO_INTRA_REFRESH_PERIOD_TYPE_RANDOM) { + hfi_val.mode =3D HFI_INTRA_REFRESH_RANDOM; + } else if (inst->fw_caps[IR_TYPE].value =3D=3D + V4L2_CID_MPEG_VIDEO_INTRA_REFRESH_PERIOD_TYPE_CYCLIC) { + hfi_val.mode =3D HFI_INTRA_REFRESH_CYCLIC; + } else { + return -EINVAL; + } + + /* + * Calculate the number of macroblocks in a frame, + * then determine how many macroblocks need to be + * refreshed within one ir_period. + */ + hfi_val.mbs =3D (fmt->width / codec_align) * (fmt->height / codec_align); + hfi_val.mbs /=3D ir_period; + + return hfi_ops->session_set_property(inst, hfi_id, + HFI_HOST_FLAGS_NONE, + iris_get_port_info(inst, cap_id), + HFI_PAYLOAD_STRUCTURE, + &hfi_val, sizeof(hfi_val)); +} + +int iris_set_ir_period_gen2(struct iris_inst *inst, enum platform_inst_fw_= cap_type cap_id) { const struct iris_hfi_command_ops *hfi_ops =3D inst->core->hfi_ops; struct vb2_queue *q =3D v4l2_m2m_get_dst_vq(inst->m2m_ctx); diff --git a/drivers/media/platform/qcom/iris/iris_ctrls.h b/drivers/media/= platform/qcom/iris/iris_ctrls.h index 9518803577bc39f5c1339a49878dd0c3e8f510ad..a0d5338bdc910bd30407132e8b7= 00c333ad74e4c 100644 --- a/drivers/media/platform/qcom/iris/iris_ctrls.h +++ b/drivers/media/platform/qcom/iris/iris_ctrls.h @@ -34,7 +34,8 @@ int iris_set_frame_qp(struct iris_inst *inst, enum platfo= rm_inst_fw_cap_type cap int iris_set_qp_range(struct iris_inst *inst, enum platform_inst_fw_cap_ty= pe cap_id); int iris_set_rotation(struct iris_inst *inst, enum platform_inst_fw_cap_ty= pe cap_id); int iris_set_flip(struct iris_inst *inst, enum platform_inst_fw_cap_type c= ap_id); -int iris_set_ir_period(struct iris_inst *inst, enum platform_inst_fw_cap_t= ype cap_id); +int iris_set_ir_period_gen1(struct iris_inst *inst, enum platform_inst_fw_= cap_type cap_id); +int iris_set_ir_period_gen2(struct iris_inst *inst, enum platform_inst_fw_= cap_type cap_id); int iris_set_properties(struct iris_inst *inst, u32 plane); =20 #endif diff --git a/drivers/media/platform/qcom/iris/iris_hfi_gen1_command.c b/dri= vers/media/platform/qcom/iris/iris_hfi_gen1_command.c index 11815f6f5bacd4b464f6c76fd32adbd59d4167a7..f30fbb803936cea030c2b548580= 1cbb7addef34d 100644 --- a/drivers/media/platform/qcom/iris/iris_hfi_gen1_command.c +++ b/drivers/media/platform/qcom/iris/iris_hfi_gen1_command.c @@ -687,6 +687,14 @@ iris_hfi_gen1_packet_session_set_property(struct hfi_s= ession_set_property_pkt *p packet->shdr.hdr.size +=3D sizeof(u32) + sizeof(*plane_actual_info); break; } + case HFI_PROPERTY_PARAM_VENC_INTRA_REFRESH: { + struct hfi_intra_refresh *in =3D pdata, *intra_refresh =3D prop_data; + + intra_refresh->mode =3D in->mode; + intra_refresh->mbs =3D in->mbs; + packet->shdr.hdr.size +=3D sizeof(u32) + sizeof(*intra_refresh); + break; + } default: return -EINVAL; } diff --git a/drivers/media/platform/qcom/iris/iris_hfi_gen1_defines.h b/dri= vers/media/platform/qcom/iris/iris_hfi_gen1_defines.h index 42226ccee3d9b9eb5f793c3be127acd8afad2138..04c79ee0463d7f32a2042044fe4= 564718cc01561 100644 --- a/drivers/media/platform/qcom/iris/iris_hfi_gen1_defines.h +++ b/drivers/media/platform/qcom/iris/iris_hfi_gen1_defines.h @@ -139,6 +139,14 @@ #define HFI_PROPERTY_PARAM_VENC_H264_DEBLOCK_CONTROL 0x2005003 #define HFI_PROPERTY_PARAM_VENC_RATE_CONTROL 0x2005004 #define HFI_PROPERTY_PARAM_VENC_SESSION_QP_RANGE_V2 0x2005009 + +#define HFI_INTRA_REFRESH_NONE 0x1 +#define HFI_INTRA_REFRESH_CYCLIC 0x2 +#define HFI_INTRA_REFRESH_ADAPTIVE 0x3 +#define HFI_INTRA_REFRESH_CYCLIC_ADAPTIVE 0x4 +#define HFI_INTRA_REFRESH_RANDOM 0x5 + +#define HFI_PROPERTY_PARAM_VENC_INTRA_REFRESH 0x200500d #define HFI_PROPERTY_PARAM_VENC_MAX_NUM_B_FRAMES 0x2005020 #define HFI_PROPERTY_CONFIG_VENC_TARGET_BITRATE 0x2006001 #define HFI_PROPERTY_CONFIG_VENC_SYNC_FRAME_SEQUENCE_HEADER 0x2006008 @@ -447,6 +455,11 @@ struct hfi_framerate { u32 framerate; }; =20 +struct hfi_intra_refresh { + u32 mode; + u32 mbs; +}; + struct hfi_event_data { u32 error; u32 height; diff --git a/drivers/media/platform/qcom/iris/iris_platform_gen1.c b/driver= s/media/platform/qcom/iris/iris_platform_gen1.c index df8e6bf9430ed2a070e092edae9ef998d092cb5e..a7595c302162b9fe758c6170689= 5a709b3b4e852 100644 --- a/drivers/media/platform/qcom/iris/iris_platform_gen1.c +++ b/drivers/media/platform/qcom/iris/iris_platform_gen1.c @@ -246,6 +246,25 @@ static const struct platform_inst_fw_cap inst_fw_cap_s= m8250_enc[] =3D { .flags =3D CAP_FLAG_OUTPUT_PORT, .set =3D iris_set_qp_range, }, + { + .cap_id =3D IR_TYPE, + .min =3D V4L2_CID_MPEG_VIDEO_INTRA_REFRESH_PERIOD_TYPE_RANDOM, + .max =3D V4L2_CID_MPEG_VIDEO_INTRA_REFRESH_PERIOD_TYPE_CYCLIC, + .step_or_mask =3D BIT(V4L2_CID_MPEG_VIDEO_INTRA_REFRESH_PERIOD_TYPE_RAND= OM) | + BIT(V4L2_CID_MPEG_VIDEO_INTRA_REFRESH_PERIOD_TYPE_CYCLIC), + .value =3D V4L2_CID_MPEG_VIDEO_INTRA_REFRESH_PERIOD_TYPE_RANDOM, + .flags =3D CAP_FLAG_OUTPUT_PORT | CAP_FLAG_MENU, + }, + { + .cap_id =3D IR_PERIOD, + .min =3D 0, + .max =3D ((4096 * 2304) >> 8), + .step_or_mask =3D 1, + .value =3D 0, + .hfi_id =3D HFI_PROPERTY_PARAM_VENC_INTRA_REFRESH, + .flags =3D CAP_FLAG_OUTPUT_PORT, + .set =3D iris_set_ir_period_gen1, + }, }; =20 static struct platform_inst_caps platform_inst_cap_sm8250 =3D { diff --git a/drivers/media/platform/qcom/iris/iris_platform_gen2.c b/driver= s/media/platform/qcom/iris/iris_platform_gen2.c index 5da90d47f9c6eab4a7e6b17841fdc0e599397bf7..0de85c51cf745e9a121da14b1ad= 7bc761505c957 100644 --- a/drivers/media/platform/qcom/iris/iris_platform_gen2.c +++ b/drivers/media/platform/qcom/iris/iris_platform_gen2.c @@ -738,7 +738,7 @@ static const struct platform_inst_fw_cap inst_fw_cap_sm= 8550_enc[] =3D { .value =3D 0, .flags =3D CAP_FLAG_OUTPUT_PORT | CAP_FLAG_DYNAMIC_ALLOWED, - .set =3D iris_set_ir_period, + .set =3D iris_set_ir_period_gen2, }, }; =20 --=20 2.43.0