From nobody Mon Feb 9 08:28:58 2026 Received: from mail-wm1-f45.google.com (mail-wm1-f45.google.com [209.85.128.45]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id E137831B80A for ; Fri, 26 Dec 2025 11:31:54 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=209.85.128.45 ARC-Seal: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1766748716; cv=none; b=LpyauWR/tB34dXCjRH1Tim7OmKNDxaFAeogdXmDkm+lNUtYdct1wAgnQqm2G1Rg+CqOI5BKw68huaZCB1fYk6bxRz4HR7gh0FrE02OHVAlXib2/sMaYlYi8TTWrJN9/vSK/mmrCxx8baqlt5/KhekJDNvaUTVtW+JwZ4d2avEzo= ARC-Message-Signature: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1766748716; c=relaxed/simple; bh=N170/wcwZcC6UGcnBD4mfpj8N8jv2FwKTbOrfG/2glU=; h=From:To:Cc:Subject:Date:Message-Id:In-Reply-To:References: MIME-Version; b=WN9pRRhSvo5JS3D3CItFv9XkN6PQfE69aFuXGH4vidDr/3mHKxAyf/DKLmydpinSN73eni3c8uBmTOvQrTOwZMaAYMHJB0l4DppqLmX7AZrknz+cnevOl+5u6TxiE1unsGugF1hdDQhCP+HNraOfd/EbUzgei2m0rOChom8nZx0= ARC-Authentication-Results: i=1; smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=gmail.com; spf=pass smtp.mailfrom=gmail.com; dkim=pass (2048-bit key) header.d=gmail.com header.i=@gmail.com header.b=Rj0YS5hV; arc=none smtp.client-ip=209.85.128.45 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=gmail.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=gmail.com Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=gmail.com header.i=@gmail.com header.b="Rj0YS5hV" Received: by mail-wm1-f45.google.com with SMTP id 5b1f17b1804b1-47d3ba3a4deso10925165e9.2 for ; Fri, 26 Dec 2025 03:31:54 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20230601; t=1766748713; x=1767353513; darn=vger.kernel.org; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:from:to:cc:subject:date :message-id:reply-to; bh=Rhf0TH4eJNjuHSmbRZBfmqwPKHrm+PMdGGpE2aA2ePg=; b=Rj0YS5hV7ckfTKZHIfCLDLCXZAF+njrMoxCRCSlmoZok7NCm8XzGHBMsbo0kn+v0of c2zThAl9muSHwuiiI/dGBxk4pZIaCpuCyNtdb32XfPTuRuDrAjRre+gW2C0Eq9Cq7I6k 8naaZwqj/N20zBq4T3u3EZqVJerueaN1iinmFRDKXtS3o4CW+Q9qsuB+QETRag4nzJm1 3/evY0NpIeh+bL1upDCtp4grhgO6CAzTvQ0VMZLLqgk9ENWiQNLvHkhhAAHjTmuarLuE 47TgGhg8GHbc0xjMVrNkbK//x+yP2Z1Ba0NpepoFBEMnrieMrcaugyGiprUWDKCRepXh Nmkg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1766748713; x=1767353513; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:x-gm-gg:x-gm-message-state:from :to:cc:subject:date:message-id:reply-to; bh=Rhf0TH4eJNjuHSmbRZBfmqwPKHrm+PMdGGpE2aA2ePg=; b=c0CgE15naE58vNdnFyI4YzBzpXxc+X0A5cJoqg0PGoLhJe6tULYSBG/ZvTVl9z/YEu o8GnRX/2t4fd9+q7/EjPfOtzRKGSs7+t7zSOFFSfwpHPvaRbbYvnluQ4qpdooh7D/dMr 1CV48yThjVvkvf2f7dk+s3p5jpohm1VLtx5tirfmg+RmYYZnZmeQ6ANUd1jRhb5UtSPV Ql51TKWdyud1UnTr5LPY2yMWArE0csFzF2hFUjDgDE7cfTPWaFj3LyXrlWVzPMXs3LaR muNi0/R1pHbbhgwdt/lQszs0lpd/unfe3JoeGYnBQb7gHTXS7/AiND81CqB3vPEQV7Tn 1v+Q== X-Forwarded-Encrypted: i=1; AJvYcCUUsT0GO0Zw0TRt2OcYkBtkzM3q3nzW19XmBp9rcVmUy8zaJ5hMjw4SheG3nlCGw27LXyKwGpw/YNCgiVE=@vger.kernel.org X-Gm-Message-State: AOJu0YzqDpPyKN9eyRWuxEAKcEZ8vzfnA42NBlj/WQWQof4AntQKpz0z hoWRgJo6xrL2Pe8MVz43Q96cbEAFDwBY39F0Tmh/OqF10dUlVEM/FFZd X-Gm-Gg: AY/fxX4Slh45dxtDVSsRwrOVj1re0qbCxD6+FbmS/LhOc9RGPdGJiL3oZLRqnwx0ksf VbRHGMKnaIPP5PEhWO1TGh+A8UxE26fCyC4FBfrRPfiNHAoDfON/+a3dY1uQ7HxJWhBkWTXkwYs hyjmxFDjsMysOVU6msGW2tCW3c4cJ+YjLu96KDV1B5VkMcuowhtvoRwDZ3YHfNXz4o2eu7xwyoa LVgqKQyEuMLogLI6c56TbE2AleNQCgbcOpVJmlfZN011Iqf1LOb3KBd0Wsd8sNgjZY02VNoMgcl tnD/1Tu7aRtHvdOge+19rTi8FHUdHNLec+WusWOXKqY1A8o9PWDO5BogIcN76BpwCHvwgXBzNyV 82VD+F83JdxZQSwL47dUnZJzj+1F1E+JZjjZzAHczMO4aJEDyCUU/U3o4LWihuS44QojEwg44o7 Rj8V4ZfsE02wtkmZY= X-Google-Smtp-Source: AGHT+IEdX/opTeKmbf9vs+IfU8RNLfI0e1Jx0FbC8ZOgZmZVG+BhcxQJNX7MD2OXkK7u+x0+7A8c8A== X-Received: by 2002:a05:600c:3506:b0:477:63a4:88fe with SMTP id 5b1f17b1804b1-47d195499e5mr211765625e9.2.1766748712900; Fri, 26 Dec 2025 03:31:52 -0800 (PST) Received: from toolbox.. ([87.200.95.144]) by smtp.gmail.com with ESMTPSA id ffacd0b85a97d-4324ea1b1bdsm44182107f8f.8.2025.12.26.03.31.49 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Fri, 26 Dec 2025 03:31:52 -0800 (PST) From: Christian Hewitt To: Detlev Casanova , =?UTF-8?q?Olivier=20Cr=C3=AAte?= , Ezequiel Garcia , Mauro Carvalho Chehab , Rob Herring , Krzysztof Kozlowski , Conor Dooley , Heiko Stuebner , Diederik de Haas , Dmitry Osipenko , Thomas Gleixner , Dragan Simic , Chukun Pan , linux-media@vger.kernel.org, linux-rockchip@lists.infradead.org, devicetree@vger.kernel.org, linux-arm-kernel@lists.infradead.org, linux-kernel@vger.kernel.org Cc: Nicolas Dufresne Subject: [PATCH v2 2/3] media: rkvdec: Add support for the VDPU346 variant Date: Fri, 26 Dec 2025 11:31:39 +0000 Message-Id: <20251226113140.573759-3-christianshewitt@gmail.com> X-Mailer: git-send-email 2.34.1 In-Reply-To: <20251226113140.573759-1-christianshewitt@gmail.com> References: <20251226113140.573759-1-christianshewitt@gmail.com> Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 Content-Transfer-Encoding: quoted-printable Content-Type: text/plain; charset="utf-8" VDPU346 is similar to VDPU381 but with a single core and limited to 4K60 media. It is also limited to H264 L5.1 and omits AV1 and AVS2 capabilities. VDPU346 is used with RK3566 and RK3568. Signed-off-by: Christian Hewitt Reviewed-by: Nicolas Dufresne --- .../media/platform/rockchip/rkvdec/rkvdec.c | 103 ++++++++++++++++++ 1 file changed, 103 insertions(+) diff --git a/drivers/media/platform/rockchip/rkvdec/rkvdec.c b/drivers/medi= a/platform/rockchip/rkvdec/rkvdec.c index e547057dc75f..6b39e99d8a8b 100644 --- a/drivers/media/platform/rockchip/rkvdec/rkvdec.c +++ b/drivers/media/platform/rockchip/rkvdec/rkvdec.c @@ -236,6 +236,62 @@ static const struct rkvdec_ctrls rkvdec_hevc_ctrls =3D= { .num_ctrls =3D ARRAY_SIZE(rkvdec_hevc_ctrl_descs), }; =20 +static const struct rkvdec_ctrl_desc vdpu346_hevc_ctrl_descs[] =3D { + { + .cfg.id =3D V4L2_CID_STATELESS_HEVC_DECODE_PARAMS, + }, + { + .cfg.id =3D V4L2_CID_STATELESS_HEVC_SPS, + .cfg.ops =3D &rkvdec_ctrl_ops, + }, + { + .cfg.id =3D V4L2_CID_STATELESS_HEVC_PPS, + }, + { + .cfg.id =3D V4L2_CID_STATELESS_HEVC_SCALING_MATRIX, + }, + { + .cfg.id =3D V4L2_CID_STATELESS_HEVC_DECODE_MODE, + .cfg.min =3D V4L2_STATELESS_HEVC_DECODE_MODE_FRAME_BASED, + .cfg.max =3D V4L2_STATELESS_HEVC_DECODE_MODE_FRAME_BASED, + .cfg.def =3D V4L2_STATELESS_HEVC_DECODE_MODE_FRAME_BASED, + }, + { + .cfg.id =3D V4L2_CID_STATELESS_HEVC_START_CODE, + .cfg.min =3D V4L2_STATELESS_HEVC_START_CODE_ANNEX_B, + .cfg.def =3D V4L2_STATELESS_HEVC_START_CODE_ANNEX_B, + .cfg.max =3D V4L2_STATELESS_HEVC_START_CODE_ANNEX_B, + }, + { + .cfg.id =3D V4L2_CID_MPEG_VIDEO_HEVC_PROFILE, + .cfg.min =3D V4L2_MPEG_VIDEO_HEVC_PROFILE_MAIN, + .cfg.max =3D V4L2_MPEG_VIDEO_HEVC_PROFILE_MAIN_10, + .cfg.menu_skip_mask =3D + BIT(V4L2_MPEG_VIDEO_HEVC_PROFILE_MAIN_STILL_PICTURE), + .cfg.def =3D V4L2_MPEG_VIDEO_HEVC_PROFILE_MAIN, + }, + { + .cfg.id =3D V4L2_CID_MPEG_VIDEO_HEVC_LEVEL, + .cfg.min =3D V4L2_MPEG_VIDEO_HEVC_LEVEL_1, + .cfg.max =3D V4L2_MPEG_VIDEO_HEVC_LEVEL_5_1, + }, + { + .cfg.id =3D V4L2_CID_STATELESS_HEVC_EXT_SPS_ST_RPS, + .cfg.ops =3D &rkvdec_ctrl_ops, + .cfg.dims =3D { 65 }, + }, + { + .cfg.id =3D V4L2_CID_STATELESS_HEVC_EXT_SPS_LT_RPS, + .cfg.ops =3D &rkvdec_ctrl_ops, + .cfg.dims =3D { 65 }, + }, +}; + +static const struct rkvdec_ctrls vdpu346_hevc_ctrls =3D { + .ctrls =3D vdpu346_hevc_ctrl_descs, + .num_ctrls =3D ARRAY_SIZE(vdpu346_hevc_ctrl_descs), +}; + static const struct rkvdec_ctrl_desc vdpu38x_hevc_ctrl_descs[] =3D { { .cfg.id =3D V4L2_CID_STATELESS_HEVC_DECODE_PARAMS, @@ -463,6 +519,41 @@ static const struct rkvdec_coded_fmt_desc rk3288_coded= _fmts[] =3D { } }; =20 +static const struct rkvdec_coded_fmt_desc vdpu346_coded_fmts[] =3D { + { + .fourcc =3D V4L2_PIX_FMT_HEVC_SLICE, + .frmsize =3D { + .min_width =3D 64, + .max_width =3D 65472, + .step_width =3D 64, + .min_height =3D 64, + .max_height =3D 65472, + .step_height =3D 16, + }, + .ctrls =3D &vdpu346_hevc_ctrls, + .ops =3D &rkvdec_vdpu381_hevc_fmt_ops, + .num_decoded_fmts =3D ARRAY_SIZE(rkvdec_hevc_decoded_fmts), + .decoded_fmts =3D rkvdec_hevc_decoded_fmts, + .subsystem_flags =3D VB2_V4L2_FL_SUPPORTS_M2M_HOLD_CAPTURE_BUF, + }, + { + .fourcc =3D V4L2_PIX_FMT_H264_SLICE, + .frmsize =3D { + .min_width =3D 64, + .max_width =3D 65520, + .step_width =3D 64, + .min_height =3D 64, + .max_height =3D 65520, + .step_height =3D 16, + }, + .ctrls =3D &rkvdec_h264_ctrls, + .ops =3D &rkvdec_vdpu381_h264_fmt_ops, + .num_decoded_fmts =3D ARRAY_SIZE(rkvdec_h264_decoded_fmts), + .decoded_fmts =3D rkvdec_h264_decoded_fmts, + .subsystem_flags =3D VB2_V4L2_FL_SUPPORTS_M2M_HOLD_CAPTURE_BUF, + }, +}; + static const struct rkvdec_coded_fmt_desc vdpu381_coded_fmts[] =3D { { .fourcc =3D V4L2_PIX_FMT_HEVC_SLICE, @@ -1643,6 +1734,14 @@ static const struct rkvdec_variant_ops vdpu381_varia= nt_ops =3D { .flatten_matrices =3D transpose_and_flatten_matrices, }; =20 +static const struct rkvdec_variant vdpu346_variant =3D { + .coded_fmts =3D vdpu346_coded_fmts, + .num_coded_fmts =3D ARRAY_SIZE(vdpu346_coded_fmts), + .rcb_sizes =3D vdpu381_rcb_sizes, + .num_rcb_sizes =3D ARRAY_SIZE(vdpu381_rcb_sizes), + .ops =3D &vdpu381_variant_ops, +}; + static const struct rkvdec_variant vdpu381_variant =3D { .coded_fmts =3D vdpu381_coded_fmts, .num_coded_fmts =3D ARRAY_SIZE(vdpu381_coded_fmts), @@ -1691,6 +1790,10 @@ static const struct of_device_id of_rkvdec_match[] = =3D { .compatible =3D "rockchip,rk3399-vdec", .data =3D &rk3399_rkvdec_variant, }, + { + .compatible =3D "rockchip,rk3568-vdec", + .data =3D &vdpu346_variant, + }, { .compatible =3D "rockchip,rk3588-vdec", .data =3D &vdpu381_variant, --=20 2.34.1