From nobody Fri Dec 19 15:06:21 2025 Received: from mail-lf1-f50.google.com (mail-lf1-f50.google.com [209.85.167.50]) (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 318E6226CFE for ; Sat, 6 Dec 2025 11:49:50 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=209.85.167.50 ARC-Seal: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1765021793; cv=none; b=ZS+kx8P9QkVMD9ohPPhC6CNLW4ImWRFlMyCaz9iqQt4HtoFdcDaiv2v4m9NggH5HzLCzZdwSeDPHVhHPczbx1qHQXbDLkHQ1qwayaWD5l0r1Iz1QeONoHGlaK+PRm1RmiBJl5ChsImwqS8Ylek+bh9LzZnK3pVxU/n2ulpbgjng= ARC-Message-Signature: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1765021793; c=relaxed/simple; bh=m5XQ03NkmU7Dyvrl3uNqx25v8w2wEU616h/uh5i28kk=; h=From:To:Subject:Date:Message-Id:In-Reply-To:References: MIME-Version; b=qsAAZK90xhi86mAXmIlwPK1behvhOdyaDYSvfGZU50fhDJVp6hNWqUoDGn+WAkpFK9rducKV2M8e50SmrkLOg3j0CBegiC6bfxXe+vGugHuqShmtEqT6XiK/O7d4defIs2H0Hl8yU57S3eWwF7W2BFaEBYCwlEK+8B5jCdrOTjA= 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=DMPFyhAK; arc=none smtp.client-ip=209.85.167.50 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="DMPFyhAK" Received: by mail-lf1-f50.google.com with SMTP id 2adb3069b0e04-595910c9178so2315158e87.1 for ; Sat, 06 Dec 2025 03:49:50 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20230601; t=1765021789; x=1765626589; darn=vger.kernel.org; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:to:from:from:to:cc:subject:date:message-id :reply-to; bh=HePzOK2YwREM++8Zxr7PF7Xhi3Zuwv6TtIklSs2K0TA=; b=DMPFyhAKiMd4RFDstDFjqrb/gUngtDT2RZEpfhAypotloi/C/yOMVUehGCWMPyq8k8 nt52b8j+e+OJgu11/ebHD5rgwXKh6MQ2DtTHb1b4DlLEXUOdWEeU5x+CnS8Qb6fX8TWu 0Td5YVExayYnDq2H5IfkRK+T6GgwJhZ4rrY40WLKip8fSwXDPl9NmkWRHRObwd+2hLYR Lbsmz19t58LM8AYLtt2CxS7uKDXll/A3Y0UPTjLuEf7/Q22h9XYtozkmxkh2EQ3Lu9Iy WMY414GoMa83iHZqmgq5Zn/l+8tME+FSgak4TGYIpihnTCBKbb545vGpvHvAU9pqpSMY RQgQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1765021789; x=1765626589; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:to:from:x-gm-gg:x-gm-message-state:from:to :cc:subject:date:message-id:reply-to; bh=HePzOK2YwREM++8Zxr7PF7Xhi3Zuwv6TtIklSs2K0TA=; b=Yy2V3CZv3dvtn2AzV9wb14iVJa76603QUKt1zflLNo7hQPIsKzKwLHbfR2xyjhD+iE gqXrEXK/YHXdTlmNrf+pC4VUl8aDMiM/Rabk3V9WDiykcTexc2kOW9keUpoiarD32svx xkfirBsfDzQwoUHd8KTcTgyeOvGAtTVSiR0du40vRf4uz3+Fr8AW+DuZEBWeZnljNkO+ saFCT2I47D9QYy6ngJ7/hn4gNvGy0NrwH2TJGOqst2sHtAolQpbamz/3piNKMRMvPE7N j3yLakeIOrWbfGaIS0rDl12FNo8oAfWW+JedkyFhKDiOVJhY1x3GODuSsAN8Zdlk7y6D 8R1Q== X-Forwarded-Encrypted: i=1; AJvYcCW1clRQ5IWburdJE3nDY/1uHdSm8iZEo43TSLu4sa6Kr9Q4A+HVwoVOKrGUW2iSD3MRPu+mP+w9U7C1l2c=@vger.kernel.org X-Gm-Message-State: AOJu0Yx3SbAAxtuBXxu4Pi4Pgsd1MbbaFHTJZzhVZabozPpe+iLZx2i5 Q/LDlDOc0+6a0flPinAXb55H234r2kq3BAdMAoUsfxEmeIZvd0FNzbDkSGHyneHx2m8= X-Gm-Gg: ASbGnctGsuLXsBoxYpYETdPAoH6BQPuJ1O298cAhrpoPnee8JFgWTY1jnz10G4A/Kdm h65+ZN8IFJ7jw4fBTfkWwzNv5kEbt/wU5vQgHSSi9Ei2Uj0KZ0pil7kMGKvJxiBukyz/4/TEsBc dswm5bhQP5uQxuHL11HLMYIhu2cl7wZHO/638ncKrh2I9xUA2N4gKbAhahGYX7YGbQLBqM6kVEz qiKSRDPUwpozBVjwVb4YsYReqk68JnRcEDs6+d4OF0g2Eq0gnPJL7h7AizttlkjKl65MFx0QQ3N A901EKywM7kx1okT8BWS4l39XnfABP0kGK2KoCJFEqFUEUIRkwoIPglqGhkO51Uq65or3cUbzsO 8hx5mIWc0j2ai69/PUo9tmLowrvbYTcMl0bQaUCOvMda7C+0LUQ7GKov9cTmlhDLVewewxkFWGi /CN/WUXh/CIz76aOs= X-Google-Smtp-Source: AGHT+IHLtSSBaH5vwkicDwq4VHYkBOA2QyJRB3rOh/XN2E2xH2ybmyHraxYc+LAfhlTKju/XpBChLA== X-Received: by 2002:a05:600c:828d:b0:477:7b16:5fb1 with SMTP id 5b1f17b1804b1-47939df0045mr23564235e9.7.1765015327245; Sat, 06 Dec 2025 02:02:07 -0800 (PST) Received: from toolbox.. ([87.200.95.144]) by smtp.gmail.com with ESMTPSA id 5b1f17b1804b1-479310c802bsm126055205e9.6.2025.12.06.02.02.04 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Sat, 06 Dec 2025 02:02:06 -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 Subject: [PATCH 3/4] media: rkvdec: Add support for the VDPU346 variant Date: Sat, 6 Dec 2025 10:01:58 +0000 Message-Id: <20251206100158.2041439-2-christianshewitt@gmail.com> X-Mailer: git-send-email 2.34.1 In-Reply-To: <20251206100158.2041439-1-christianshewitt@gmail.com> References: <20251206100158.2041439-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 derived from 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. It is used with RK3566 and RK3568. Signed-off-by: Christian Hewitt --- .../media/platform/rockchip/rkvdec/rkvdec.c | 110 ++++++++++++++++++ 1 file changed, 110 insertions(+) diff --git a/drivers/media/platform/rockchip/rkvdec/rkvdec.c b/drivers/medi= a/platform/rockchip/rkvdec/rkvdec.c index a1c02ef3a97c..cf68454b2217 100644 --- a/drivers/media/platform/rockchip/rkvdec/rkvdec.c +++ b/drivers/media/platform/rockchip/rkvdec/rkvdec.c @@ -295,6 +295,62 @@ static const struct rkvdec_ctrls rkvdec_h264_ctrls =3D= { .num_ctrls =3D ARRAY_SIZE(rkvdec_h264_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, @@ -449,6 +505,43 @@ static const struct rkvdec_coded_fmt_desc rkvdec_coded= _fmts[] =3D { } }; =20 +static const struct rkvdec_coded_fmt_desc vdpu346_coded_fmts[] =3D { + { + .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, + .capability =3D RKVDEC_CAPABILITY_H264, + }, + { + .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, + .capability =3D RKVDEC_CAPABILITY_HEVC, + }, +}; + static const struct rkvdec_coded_fmt_desc vdpu381_coded_fmts[] =3D { { .fourcc =3D V4L2_PIX_FMT_H264_SLICE, @@ -1654,6 +1747,19 @@ static const struct rkvdec_variant rk3399_rkvdec_var= iant =3D { RKVDEC_CAPABILITY_VP9, }; =20 +static const struct rkvdec_variant rk3568_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), + .irq_handler =3D vdpu381_irq_handler, + .colmv_size =3D rkvdec_colmv_size, + .flatten_matrices =3D transpose_and_flatten_matrices, + .named_regs =3D true, + .capabilities =3D RKVDEC_CAPABILITY_H264 | + RKVDEC_CAPABILITY_HEVC, +}; + static const struct rkvdec_variant rk3588_vdpu381_variant =3D { .coded_fmts =3D vdpu381_coded_fmts, .num_coded_fmts =3D ARRAY_SIZE(vdpu381_coded_fmts), @@ -1693,6 +1799,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 &rk3568_vdpu346_variant, + }, { .compatible =3D "rockchip,rk3588-vdec", .data =3D &rk3588_vdpu381_variant, --=20 2.34.1