From mboxrd@z Thu Jan 1 00:00:00 1970 Received: from mx0a-0031df01.pphosted.com (mx0a-0031df01.pphosted.com [205.220.168.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 DDD702E11A6 for ; Tue, 12 May 2026 08:55:22 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=205.220.168.131 ARC-Seal:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1778576131; cv=none; b=JOqWNQAo7k6RaFia7e+m4aqN+nzrpO3SrZkGgCd4YzxW/GrtOKbQjM2JndMyCDeC8bznhPAfD0NXAa6dIq514DRRzoqi1gp1afybcERbwfm9MSvFk4+j1bgb9dOivSOqxQYYw/ha//m1rSctrRDv9ESTIagrlpurVkepDrJuFqg= ARC-Message-Signature:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1778576131; c=relaxed/simple; bh=gwtNvlfUubWDaiqh/mFhnWgfbZIOj0eIrfEYWmfkJpM=; h=From:Subject:Date:Message-Id:MIME-Version:Content-Type:To:Cc; b=YUEneXSEge5z8Sc4MCvghrdVxIYEHckmGylTkJNjUYh+vYktHQyTBu34de38P/tmRMMqITIv0oqqT7WHxECgcr77U+4AtU64ntahsvOnZLjmio/5ARPKeFdQttYFVd0qCPHdNBHXE43mMlZ7FDiNx0ZcLmkgG0tgpSNT/cGVoeQ= 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=PpSIET12; dkim=pass (2048-bit key) header.d=oss.qualcomm.com header.i=@oss.qualcomm.com header.b=dmQeB1vw; arc=none smtp.client-ip=205.220.168.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="PpSIET12"; dkim=pass (2048-bit key) header.d=oss.qualcomm.com header.i=@oss.qualcomm.com header.b="dmQeB1vw" Received: from pps.filterd (m0279862.ppops.net [127.0.0.1]) by mx0a-0031df01.pphosted.com (8.18.1.11/8.18.1.11) with ESMTP id 64C5BZQw3385878 for ; Tue, 12 May 2026 08:55:20 GMT DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=qualcomm.com; h= cc:content-transfer-encoding:content-type:date:from:message-id :mime-version:subject:to; s=qcppdkim1; bh=9mJA7itZBXELD2JlCu9s+u KTEHrl+15jJgnmgnLk8A0=; b=PpSIET122qZNfTDJEDLzy/CordvUThLK3VpvHd tjPchpqVD7oiDHkVKBOJVB+iauAZBZPEVNpj4btg2MOHWVCk38+mUnr983URinKX RhMQMDo6P12VV/uLY3PG+FBykSVj7I6ql7AftGpDsNr3AW6UYG7zMLpaBOUXF6/o 8tbCEhxDgLjQJ8no/UR4iO9Jpitb3GD60m9kY+tDfAtVJDyoD/jnCJFU+WjRqVql wKoOkIpqCNjzODxJ4p/emMw0NjFkCKZOzAwwR8l0da1nMX7ER/1fQ4CWqLSGYl9f SiJz68FJorzN01vuiD+Xa52Hc7tsGPdryD6mb2681n4n5n0Q== Received: from mail-pl1-f200.google.com (mail-pl1-f200.google.com [209.85.214.200]) by mx0a-0031df01.pphosted.com (PPS) with ESMTPS id 4e3nv4j9fg-1 (version=TLSv1.3 cipher=TLS_AES_128_GCM_SHA256 bits=128 verify=NOT) for ; Tue, 12 May 2026 08:55:20 +0000 (GMT) Received: by mail-pl1-f200.google.com with SMTP id d9443c01a7336-2ba86e35aa1so80517545ad.1 for ; Tue, 12 May 2026 01:55:20 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=oss.qualcomm.com; s=google; t=1778576120; x=1779180920; darn=vger.kernel.org; h=cc:to:content-transfer-encoding:mime-version:message-id:date :subject:from:from:to:cc:subject:date:message-id:reply-to; bh=9mJA7itZBXELD2JlCu9s+uKTEHrl+15jJgnmgnLk8A0=; b=dmQeB1vwmZcJoj2jF2nX8o3OktIADH45qffKusIZaPX+KPTTkl87pY9lZkNHnmIgnb mSBdr413VXdwODC1mJEsDK0rJ5cgJGZLDoPTF5XgVwoQNs3dae+HSdYt9rEn5c3hKJQu NBPMy9mN207ZjRBUpK5WRSfRJSs95Ien61LW95ztWjt7db5qJDSCdYcItGTlOwLcC4mG 12U4oX4Qt9QpU34VosIT4s7+YcLTqLHhUnj6LvWw3zi7XAHgTZjZyiHNnIYVobORHbzD FzDSqLoaQ7yt657u9b2pvcuVKyplb0syVgQLz4uE7KAREEP+MvdJjNl+UJ+N55bKYKes JnzQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20251104; t=1778576120; x=1779180920; h=cc:to:content-transfer-encoding:mime-version:message-id:date :subject:from:x-gm-gg:x-gm-message-state:from:to:cc:subject:date :message-id:reply-to; bh=9mJA7itZBXELD2JlCu9s+uKTEHrl+15jJgnmgnLk8A0=; b=IF4LeBJMToHP8mZnD19psONkF4aahwwq/RyLQbKs4oKIR65W/y4OdcWWvuvxBVQFs9 yOxrVu0TyXJw0SNqk9BsZfF2RD+Td7arc7lOI3rienhTIQuIqLP0qjaoYHp9JLyag+dt pMqfNidGa2F2lYlydxFxF9T2o6IZjxmBKSJGs0pW61rF7Rx+jJSQ5AwftyCC4xz+6Lcx 4Vll9m3NjfAemHBsgI8LQ9WyBUs98gQo0HU6D1pk4y/c9EAywgv3QXKYA8eWSbigc0fw YacxjYpEhgGhO95jPPhMvOT4QirQFYi044E12kSM08/YTm6UBJkez1P5NYGN4pJPcmKr PGmQ== X-Forwarded-Encrypted: i=1; AFNElJ8Jk6Awx+PkEZVb6/y+MNj/Ep2dAas/k5iFXX46wDoaktSZHVtGxzK+xKSS24snq6czs/zAxpo8TC+yQq4V@vger.kernel.org X-Gm-Message-State: AOJu0Yw2hlsqspoqveZzZsD2Ig3vp0gI0Ei4JRezvUnZ0Z9K6ng7CFVj t0N1cB2JUblOoDvPEAm/rC43o90EdI2kJQ+YvTBb6VdTWnwlM+Dmzgq9+0VPTGw00Pi/MiJK9Fq 57blqnH3dlemeURHEOP9V1xLWiHdAZX3u2vG9eKd16yZuStwiepBqGQw9nuZohagkAWCT X-Gm-Gg: Acq92OEjnngszH9EwVscHZXtVm3gssKaD3Yk8e9TGDfiWpT6EY/fEAwOs86KnMzLF5x 0qyWDwHaAML2FFzN/gTdbr3KIMGaYFoK/OSrM7xWa4rCHHL6civEuR2ZOUShfLbJqm1fjSr5f5K H7QA+Aw3UVCi+8Foo7CH140wHcM1X4zaQZ+enrx50lcVd9HAhMnH6pGvk8qF2oJJxaH01M4Um2G CgMANgVEANFyumzzavrExd0vZx+AUTqGfC174aZ9LghBtLLGJdRdmYvyYiOEycWZhCZbsrjeM9n 2lp3tW/xfPeqF+Ow+ZmKf8ovw8x8DLfiq2CvdZXzdZ8WmE/nv4TIbtNos6t2C4iWIM9m8o8jqVC xvYgPw6VOijXTrJVmz532JhYkDtR+2qPHn6ed+uO8DqIxSsGjFGiZdlMSCmf/GNUhFjFBuHFr/P X+HkNqd4hN6xlRm5V3cvYP X-Received: by 2002:a17:902:f710:b0:2bd:412:21fb with SMTP id d9443c01a7336-2bd04123306mr17817335ad.8.1778576119479; Tue, 12 May 2026 01:55:19 -0700 (PDT) X-Received: by 2002:a17:902:f710:b0:2bd:412:21fb with SMTP id d9443c01a7336-2bd04123306mr17816935ad.8.1778576118832; Tue, 12 May 2026 01:55:18 -0700 (PDT) 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 d9443c01a7336-2baf1e90854sm127641405ad.66.2026.05.12.01.55.15 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 12 May 2026 01:55:18 -0700 (PDT) From: Wangao Wang Subject: [PATCH v7 0/6] media: qcom: iris: encoder feature enhancements batch2 Date: Tue, 12 May 2026 16:55:09 +0800 Message-Id: <20260512-batch2_features-v7-0-4954e3b4df84@oss.qualcomm.com> Precedence: bulk X-Mailing-List: linux-arm-msm@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 Content-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: 7bit X-B4-Tracking: v=1; b=H4sIAO7qAmoC/6tWKk4tykwtVrJSqFYqSi3LLM7MzwNyzHUUlJIzE vPSU3UzU4B8JSMDIzMDU0Mj3aTEkuQMo/i01MSS0qLUYt1kwxRzS0tjEwvLJAMloK6CotS0zAq widGxtbUAWDpZS2EAAAA= X-Change-ID: 20260512-batch2_features-c1d7993489b0 To: Vikash Garodia , Dikshita Agarwal , Abhinav Kumar , Bryan O'Donoghue , Mauro Carvalho Chehab Cc: linux-media@vger.kernel.org, linux-arm-msm@vger.kernel.org, linux-kernel@vger.kernel.org, Wangao Wang , Neil Armstrong X-Mailer: b4 0.14.2 X-Developer-Signature: v=1; a=ed25519-sha256; t=1778576115; l=17457; i=wangao.wang@oss.qualcomm.com; s=20251021; h=from:subject:message-id; bh=gwtNvlfUubWDaiqh/mFhnWgfbZIOj0eIrfEYWmfkJpM=; b=AN53hARwTpUmjABPo/g7MR5vDBTMRN9XrBa3J5J7NsiUsazlJOYmbxKuuTdURdxfh2aX1O4bG jwO2/zMJMK/DPlCmu2pWiyxR3HGn8sJcRkmHqArAGQrvMYLwySmN11x X-Developer-Key: i=wangao.wang@oss.qualcomm.com; a=ed25519; pk=bUPgYblBUAsoPyGfssbNR7ZXUSGF8v1VF4FJzSO6/aA= X-Authority-Analysis: v=2.4 cv=ZrTd7d7G c=1 sm=1 tr=0 ts=6a02eaf8 cx=c_pps a=IZJwPbhc+fLeJZngyXXI0A==:117 a=nuhDOHQX5FNHPW3J6Bj6AA==:17 a=IkcTkHD0fZMA:10 a=NGcC8JguVDcA:10 a=s4-Qcg_JpJYA:10 a=VkNPw1HP01LnGYTKEx00:22 a=u7WPNUs3qKkmUXheDGA7:22 a=_K5XuSEh1TEqbUxoQ0s3:22 a=VwQbUJbxAAAA:8 a=EUspDBNiAAAA:8 a=kI2NT6hAmfhZTMc1HBoA:9 a=QEXdDO2ut3YA:10 a=uG9DUKGECoFWVXl0Dc02:22 X-Proofpoint-Spam-Details-Enc: AW1haW4tMjYwNTEyMDA4OSBTYWx0ZWRfX43oT61Tky+7l CiK0slz8884Z7llOGXrB//a0TfM/kKcD6bHXWBn/pzPeB+rvfwx56rNrIZtOl9I3xB1jPqimw6T yZIukNR+sbi7R41hjzkHo59KmDwh2tavjzDjzGWhN+bpB4hlyeCl3kO0aFyz5L0kZYCNBWXu1VI 06oFxLe9IbhhZ5zwa5GfcxCp9LTAQfR+gnMXqnLfrG6ZirTQk0gy5VV6Dlig7fYs2nHDOd5H4tu e4pixaCTOsJczXRAR/wb/UAxs68YvZo9DN0I2acrGCvNIZNwp59XRlNTxMg/yHEKUmmalWAq4Zd zZR/CSiZO/shjHsvvIyvopg3NkAaewx642Y/lNBUrcmK9dKFGsWUOeMBfBpnU/XMpf890FFOU9h GLrtx1djTMLWG2Peoaubz7Zt0KlVToS017V0jGVn9PwhB7AzEb0v6mGh956dduOUE3iEAdCsCLV eMUQrkvlr+KcheAjHeg== X-Proofpoint-ORIG-GUID: Ytj_uGukkNVr10rdYpDIwpW3kMQXeMxt X-Proofpoint-GUID: Ytj_uGukkNVr10rdYpDIwpW3kMQXeMxt X-Proofpoint-Virus-Version: vendor=baseguard engine=ICAP:2.0.293,Aquarius:18.0.1143,Hydra:6.1.51,FMLib:17.12.100.49 definitions=2026-05-11_05,2026-05-08_02,2025-10-01_01 X-Proofpoint-Spam-Details: rule=outbound_notspam policy=outbound score=0 phishscore=0 malwarescore=0 spamscore=0 suspectscore=0 clxscore=1015 priorityscore=1501 lowpriorityscore=0 bulkscore=0 adultscore=0 impostorscore=0 classifier=typeunknown authscore=0 authtc= authcc= route=outbound adjust=0 reason=mlx scancount=1 engine=8.22.0-2605050000 definitions=main-2605120089 Hi All, This patch series introduces several enhancements to the Qualcomm Iris encoder driver, improving support for V4L2 controls and enabling more video encoding features. All patches have been tested with v4l2-compliance and v4l2-ctl on gen1:SM8250, QCS6490, gen2:QCS8300, QCS8550, QCS9100, X1E-80100. Commands used for V4l2-ctl validation: Intra Refresh: ./v4l2-ctl --verbose -d /dev/video1 \ --set-fmt-video-out=width=1920,height=1080,pixelformat=NV12 \ --set-selection-output target=crop,width=1920,height=1080 \ --set-fmt-video=pixelformat=H264 --stream-mmap --stream-out-mmap \ --stream-from=input_nv12_1080p.yuv \ --stream-to=output/ir_random.h264 \ --set-ctrl intra_refresh_period_type=0,intra_refresh_period=30 ./v4l2-ctl --verbose -d /dev/video1 \ --set-fmt-video-out=width=1920,height=1080,pixelformat=NV12 \ --set-selection-output target=crop,width=1920,height=1080 \ --set-fmt-video=pixelformat=H264 --stream-mmap --stream-out-mmap \ --stream-from=input_nv12_1080p.yuv \ --stream-to=output/ir_cyclic.h264 \ --set-ctrl intra_refresh_period_type=1,intra_refresh_period=30 ./v4l2-ctl --verbose -d /dev/video1 \ --set-fmt-video-out=width=1920,height=1080,pixelformat=NV12 \ --set-selection-output target=crop,width=1920,height=1080 \ --set-fmt-video=pixelformat=HEVC --stream-mmap --stream-out-mmap \ --stream-from=input_nv12_1080p.yuv \ --stream-to=output/ir_random.h265 \ --set-ctrl intra_refresh_period_type=0,intra_refresh_period=30 ./v4l2-ctl --verbose -d /dev/video1 \ --set-fmt-video-out=width=1920,height=1080,pixelformat=NV12 \ --set-selection-output target=crop,width=1920,height=1080 \ --set-fmt-video=pixelformat=HEVC --stream-mmap --stream-out-mmap \ --stream-from=input_nv12_1080p.yuv \ --stream-to=output/ir_cyclic.h265 \ --set-ctrl intra_refresh_period_type=1,intra_refresh_period=30 B frames: ./v4l2-ctl --verbose -d /dev/video1 \ --set-fmt-video-out=width=1920,height=1080,pixelformat=NV12 \ --set-selection-output target=crop,width=1920,height=1080 \ --set-fmt-video=pixelformat=H264 --stream-mmap --stream-out-mmap \ --stream-from=input_nv12_1080p.yuv \ --stream-to=output/b_frames.h264 \ --set-ctrl video_b_frames=1 ./v4l2-ctl --verbose -d /dev/video1 \ --set-fmt-video-out=width=1920,height=1080,pixelformat=NV12 \ --set-selection-output target=crop,width=1920,height=1080 \ --set-fmt-video=pixelformat=HEVC --stream-mmap --stream-out-mmap \ --stream-from=input_nv12_1080p.yuv \ --stream-to=output/b_frames.h265 \ --set-ctrl video_b_frames=1 LTR: ./v4l2-ctl --verbose -d /dev/video1 \ --set-fmt-video-out=width=1920,height=1080,pixelformat=NV12 \ --set-selection-output target=crop,width=1920,height=1080 \ --set-fmt-video=pixelformat=H264 --stream-mmap --stream-out-mmap \ --stream-from=input_nv12_1080p.yuv \ --stream-to=output/ltr.h264 \ --set-ctrl ltr_count=2,frame_ltr_index=1 ./v4l2-ctl --verbose -d /dev/video1 \ --set-fmt-video-out=width=1920,height=1080,pixelformat=NV12 \ --set-selection-output target=crop,width=1920,height=1080 \ --set-fmt-video=pixelformat=HEVC --stream-mmap --stream-out-mmap \ --stream-from=input_nv12_1080p.yuv \ --stream-to=output/ltr.h265 \ --set-ctrl ltr_count=2,frame_ltr_index=1 Hierarchical Coding: ./v4l2-ctl --verbose -d /dev/video1 \ --set-fmt-video-out=width=1920,height=1080,pixelformat=NV12 \ --set-selection-output target=crop,width=1920,height=1080 \ --set-fmt-video=pixelformat=H264 --stream-mmap --stream-out-mmap \ --stream-from=input_nv12_1080p.yuv \ --stream-to=output/hier_coding_p_layer1_3M.h264 \ --set-ctrl video_bitrate_mode=1,enable_h264_hierarchical_coding=1,h264_hierarchical_coding_type=1,h264_number_of_hc_layers=3,h264_hierarchical_lay_1_bitrate=3000000 ./v4l2-ctl --verbose -d /dev/video1 \ --set-fmt-video-out=width=1920,height=1080,pixelformat=NV12 \ --set-selection-output target=crop,width=1920,height=1080 \ --set-fmt-video=pixelformat=H264 --stream-mmap --stream-out-mmap \ --stream-from=input_nv12_1080p.yuv \ --stream-to=output/hier_coding_p_layer1_6M.h264 \ --set-ctrl video_bitrate_mode=1,enable_h264_hierarchical_coding=1,h264_hierarchical_coding_type=1,h264_number_of_hc_layers=3,h264_hierarchical_lay_1_bitrate=6000000 ./v4l2-ctl --verbose -d /dev/video1 \ --set-fmt-video-out=width=1920,height=1080,pixelformat=NV12 \ --set-selection-output target=crop,width=1920,height=1080 \ --set-fmt-video=pixelformat=H264 --stream-mmap --stream-out-mmap \ --stream-from=input_nv12_1080p.yuv \ --stream-to=output/hier_coding_b_layer1_3M.h264 \ --set-ctrl video_bitrate_mode=1,enable_h264_hierarchical_coding=0,h264_hierarchical_coding_type=1,h264_number_of_hc_layers=3,h264_hierarchical_lay_1_bitrate=3000000 ./v4l2-ctl --verbose -d /dev/video1 \ --set-fmt-video-out=width=1920,height=1080,pixelformat=NV12 \ --set-selection-output target=crop,width=1920,height=1080 \ --set-fmt-video=pixelformat=H264 --stream-mmap --stream-out-mmap \ --stream-from=input_nv12_1080p.yuv \ --stream-to=output/hier_coding_b_layer1_6M.h264 \ --set-ctrl video_bitrate_mode=1,enable_h264_hierarchical_coding=0,h264_hierarchical_coding_type=1,h264_number_of_hc_layers=3,h264_hierarchical_lay_1_bitrate=6000000 ./v4l2-ctl --verbose -d /dev/video1 \ --set-fmt-video-out=width=1920,height=1080,pixelformat=NV12 \ --set-selection-output target=crop,width=1920,height=1080 \ --set-fmt-video=pixelformat=HEVC --stream-mmap --stream-out-mmap \ --stream-from=input_nv12_1080p.yuv \ --stream-to=output/hier_coding_p.h265 \ --set-ctrl hevc_hierarchical_coding_type=1,hevc_hierarchical_coding_layer=5,hevc_hierarchical_lay_1_bitrate=6000000 ./v4l2-ctl --verbose -d /dev/video1 \ --set-fmt-video-out=width=1920,height=1080,pixelformat=NV12 \ --set-selection-output target=crop,width=1920,height=1080 \ --set-fmt-video=pixelformat=HEVC --stream-mmap --stream-out-mmap \ --stream-from=input_nv12_1080p.yuv \ --stream-to=output/hier_coding_b.h265 \ --set-ctrl hevc_hierarchical_coding_type=0,hevc_hierarchical_coding_layer=5,hevc_hierarchical_lay_1_bitrate=3000000 The result of v4l2-compliance on QCS8300: v4l2-compliance 1.31.0-5379, 64 bits, 64-bit time_t v4l2-compliance SHA: 14c988631ad4 2025-11-11 11:19:35 Compliance test for iris_driver device /dev/video1: Driver Info: Driver name : iris_driver Card type : Iris Encoder Bus info : platform:aa00000.video-codec Driver version : 6.18.0 Capabilities : 0x84204000 Video Memory-to-Memory Multiplanar Streaming Extended Pix Format Device Capabilities Device Caps : 0x04204000 Video Memory-to-Memory Multiplanar Streaming Extended Pix Format Detected Stateful Encoder Required ioctls: test VIDIOC_QUERYCAP: OK test invalid ioctls: OK Allow for multiple opens: test second /dev/video1 open: OK test VIDIOC_QUERYCAP: OK test VIDIOC_G/S_PRIORITY: OK test for unlimited opens: OK Debug ioctls: test VIDIOC_DBG_G/S_REGISTER: OK (Not Supported) test VIDIOC_LOG_STATUS: OK (Not Supported) Input ioctls: test VIDIOC_G/S_TUNER/ENUM_FREQ_BANDS: OK (Not Supported) test VIDIOC_G/S_FREQUENCY: OK (Not Supported) test VIDIOC_S_HW_FREQ_SEEK: OK (Not Supported) test VIDIOC_ENUMAUDIO: OK (Not Supported) test VIDIOC_G/S/ENUMINPUT: OK (Not Supported) test VIDIOC_G/S_AUDIO: OK (Not Supported) Inputs: 0 Audio Inputs: 0 Tuners: 0 Output ioctls: test VIDIOC_G/S_MODULATOR: OK (Not Supported) test VIDIOC_G/S_FREQUENCY: OK (Not Supported) test VIDIOC_ENUMAUDOUT: OK (Not Supported) test VIDIOC_G/S/ENUMOUTPUT: OK (Not Supported) test VIDIOC_G/S_AUDOUT: OK (Not Supported) Outputs: 0 Audio Outputs: 0 Modulators: 0 Input/Output configuration ioctls: test VIDIOC_ENUM/G/S/QUERY_STD: OK (Not Supported) test VIDIOC_ENUM/G/S/QUERY_DV_TIMINGS: OK (Not Supported) test VIDIOC_DV_TIMINGS_CAP: OK (Not Supported) test VIDIOC_G/S_EDID: OK (Not Supported) Control ioctls: test VIDIOC_QUERY_EXT_CTRL/QUERYMENU: OK test VIDIOC_QUERYCTRL: OK test VIDIOC_G/S_CTRL: OK test VIDIOC_G/S/TRY_EXT_CTRLS: OK test VIDIOC_(UN)SUBSCRIBE_EVENT/DQEVENT: OK test VIDIOC_G/S_JPEGCOMP: OK (Not Supported) Standard Controls: 52 Private Controls: 0 Format ioctls: test VIDIOC_ENUM_FMT/FRAMESIZES/FRAMEINTERVALS: OK test VIDIOC_G/S_PARM: OK test VIDIOC_G_FBUF: OK (Not Supported) test VIDIOC_G_FMT: OK test VIDIOC_TRY_FMT: OK test VIDIOC_S_FMT: OK test VIDIOC_G_SLICED_VBI_CAP: OK (Not Supported) test Cropping: OK test Composing: OK (Not Supported) test Scaling: OK (Not Supported) Codec ioctls: test VIDIOC_(TRY_)ENCODER_CMD: OK test VIDIOC_G_ENC_INDEX: OK (Not Supported) test VIDIOC_(TRY_)DECODER_CMD: OK (Not Supported) Buffer ioctls: test VIDIOC_REQBUFS/CREATE_BUFS/QUERYBUF: OK test CREATE_BUFS maximum buffers: OK test VIDIOC_REMOVE_BUFS: OK test VIDIOC_EXPBUF: OK test Requests: OK (Not Supported) test blocking wait: OK Test input 0: Streaming ioctls: test read/write: OK (Not Supported) Video Capture Multiplanar: Captured 61 buffers test MMAP (select, REQBUFS): OK Video Capture Multiplanar: Captured 61 buffers test MMAP (epoll, REQBUFS): OK Video Capture Multiplanar: Captured 61 buffers test MMAP (select, CREATE_BUFS): OK Video Capture Multiplanar: Captured 61 buffers test MMAP (epoll, CREATE_BUFS): OK test USERPTR (select): OK (Not Supported) test DMABUF: Cannot test, specify --expbuf-device Total for iris_driver device /dev/video1: 54, Succeeded: 54, Failed: 0, Warnings: 0 The result of v4l2-compliance on QCS6490: v4l2-compliance 1.31.0-5379, 64 bits, 64-bit time_t v4l2-compliance SHA: 14c988631ad4 2025-11-11 11:19:35 Compliance test for iris_driver device /dev/video1: Driver Info: Driver name : iris_driver Card type : Iris Encoder Bus info : platform:aa00000.video-codec Driver version : 6.18.0 Capabilities : 0x84204000 Video Memory-to-Memory Multiplanar Streaming Extended Pix Format Device Capabilities Device Caps : 0x04204000 Video Memory-to-Memory Multiplanar Streaming Extended Pix Format Detected Stateful Encoder Required ioctls: test VIDIOC_QUERYCAP: OK test invalid ioctls: OK Allow for multiple opens: test second /dev/video1 open: OK test VIDIOC_QUERYCAP: OK test VIDIOC_G/S_PRIORITY: OK test for unlimited opens: OK Debug ioctls: test VIDIOC_DBG_G/S_REGISTER: OK (Not Supported) test VIDIOC_LOG_STATUS: OK (Not Supported) Input ioctls: test VIDIOC_G/S_TUNER/ENUM_FREQ_BANDS: OK (Not Supported) test VIDIOC_G/S_FREQUENCY: OK (Not Supported) test VIDIOC_S_HW_FREQ_SEEK: OK (Not Supported) test VIDIOC_ENUMAUDIO: OK (Not Supported) test VIDIOC_G/S/ENUMINPUT: OK (Not Supported) test VIDIOC_G/S_AUDIO: OK (Not Supported) Inputs: 0 Audio Inputs: 0 Tuners: 0 Output ioctls: test VIDIOC_G/S_MODULATOR: OK (Not Supported) test VIDIOC_G/S_FREQUENCY: OK (Not Supported) test VIDIOC_ENUMAUDOUT: OK (Not Supported) test VIDIOC_G/S/ENUMOUTPUT: OK (Not Supported) test VIDIOC_G/S_AUDOUT: OK (Not Supported) Outputs: 0 Audio Outputs: 0 Modulators: 0 Input/Output configuration ioctls: test VIDIOC_ENUM/G/S/QUERY_STD: OK (Not Supported) test VIDIOC_ENUM/G/S/QUERY_DV_TIMINGS: OK (Not Supported) test VIDIOC_DV_TIMINGS_CAP: OK (Not Supported) test VIDIOC_G/S_EDID: OK (Not Supported) Control ioctls: test VIDIOC_QUERY_EXT_CTRL/QUERYMENU: OK test VIDIOC_QUERYCTRL: OK test VIDIOC_G/S_CTRL: OK test VIDIOC_G/S/TRY_EXT_CTRLS: OK test VIDIOC_(UN)SUBSCRIBE_EVENT/DQEVENT: OK test VIDIOC_G/S_JPEGCOMP: OK (Not Supported) Standard Controls: 33 Private Controls: 0 Format ioctls: test VIDIOC_ENUM_FMT/FRAMESIZES/FRAMEINTERVALS: OK test VIDIOC_G/S_PARM: OK test VIDIOC_G_FBUF: OK (Not Supported) test VIDIOC_G_FMT: OK test VIDIOC_TRY_FMT: OK test VIDIOC_S_FMT: OK test VIDIOC_G_SLICED_VBI_CAP: OK (Not Supported) test Cropping: OK test Composing: OK (Not Supported) test Scaling: OK (Not Supported) Codec ioctls: test VIDIOC_(TRY_)ENCODER_CMD: OK test VIDIOC_G_ENC_INDEX: OK (Not Supported) test VIDIOC_(TRY_)DECODER_CMD: OK (Not Supported) Buffer ioctls: test VIDIOC_REQBUFS/CREATE_BUFS/QUERYBUF: OK test CREATE_BUFS maximum buffers: OK test VIDIOC_REMOVE_BUFS: OK test VIDIOC_EXPBUF: OK test Requests: OK (Not Supported) test blocking wait: OK Test input 0: Streaming ioctls: test read/write: OK (Not Supported) Video Capture Multiplanar: Captured 61 buffers test MMAP (select, REQBUFS): OK Video Capture Multiplanar: Captured 61 buffers test MMAP (epoll, REQBUFS): OK Video Capture Multiplanar: Captured 61 buffers test MMAP (select, CREATE_BUFS): OK Video Capture Multiplanar: Captured 61 buffers test MMAP (epoll, CREATE_BUFS): OK test USERPTR (select): OK (Not Supported) test DMABUF: Cannot test, specify --expbuf-device Total for iris_driver device /dev/video1: 54, Succeeded: 54, Failed: 0, Warnings: 0 Signed-off-by: Wangao Wang --- Changes in v7: - Rebase. - Link to v6: https://lore.kernel.org/r/20260401-batch2_iris_encoder_enhancements-v6-0-7022af3401ff@oss.qualcomm.com Changes in v6: - Rebase. - Link to v5: https://lore.kernel.org/r/20260206-batch2_iris_encoder_enhancements-v5-0-fb75ed8fa375@oss.qualcomm.com Changes in v5: - Fix incorrect logic in max_bitrate assignment.(Vikash) - Fix incorrect hfi_id for LAYER5_BITRATE_HEVC.(Vikash) - Add setter for H.264 layer type and layer count.(Vikash) - Link to v4: https://lore.kernel.org/r/20260129-batch2_iris_encoder_enhancements-v4-0-efaac131a5f7@oss.qualcomm.com Changes in v4: - Fix the bug in the H.264 layer type check.(Dikshita) - Add streaming check for layer bitrate setting.(Dikshita) - Tested different hierarchical coding type values.(Dikshita) - Link to v3: https://lore.kernel.org/r/20260109-batch2_iris_encoder_enhancements-v3-0-196855ef32ba@oss.qualcomm.com Changes in v3: - Correct the maximum value of IR_PERIOD.(Dikshita) - Use 'codec' instead of 'standard' in the calculation of COMV size. (Dikshita) - Verified these patches on SM8250.(Dikshita) - Link to v2: https://lore.kernel.org/r/20251219-batch2_iris_encoder_enhancements-v2-0-371f7fe24801@oss.qualcomm.com Changes in v2: - Add comment for ir_period calculation.(bod,Dikshita) - Correct the maximum value of IR_PERIOD.(Dikshita) - Add a patch to optimize the calculation of hdr size.(bod) - Correct the num_recon calculation.(Dikshita) - Add a patch to simplify the calculation of COMV size.(Dikshita) - Catch the result code of session_set_property.(bod) - Add comment for shift operation in hfi_buffer_get_recon_count.(bod) - Add support for layer bitrate setting.(Dikshita) - Link to v1: https://lore.kernel.org/r/20251127-batch2_iris_encoder_enhancements-v1-0-5ea78e2de2ae@oss.qualcomm.com Signed-off-by: Wangao Wang --- Wangao Wang (6): media: qcom: iris: Add intra refresh support for gen1 encoder media: qcom: iris: Add Long-Term Reference support for encoder media: qcom: iris: Add B frames support for encoder media: qcom: iris: Add hierarchical coding support for encoder media: qcom: iris: Optimize iris_hfi_gen1_packet_session_set_property media: qcom: iris: Simplify COMV size calculation drivers/media/platform/qcom/iris/iris_ctrls.c | 485 ++++++++++++++++++++- drivers/media/platform/qcom/iris/iris_ctrls.h | 16 +- drivers/media/platform/qcom/iris/iris_hfi_gen1.c | 161 ++++++- .../platform/qcom/iris/iris_hfi_gen1_command.c | 98 ++++- .../platform/qcom/iris/iris_hfi_gen1_defines.h | 49 +++ drivers/media/platform/qcom/iris/iris_hfi_gen2.c | 226 +++++++++- .../platform/qcom/iris/iris_hfi_gen2_defines.h | 18 + drivers/media/platform/qcom/iris/iris_instance.h | 4 + .../platform/qcom/iris/iris_platform_common.h | 31 ++ drivers/media/platform/qcom/iris/iris_vpu_buffer.c | 65 ++- 10 files changed, 1112 insertions(+), 41 deletions(-) --- base-commit: ca546c9ed44a2c2fe9c6fb719935965c754b20fb change-id: 20260512-batch2_features-c1d7993489b0 Best regards, -- Wangao Wang