]> git.ipfire.org Git - thirdparty/kernel/linux.git/commitdiff
media: venus: vdec: restrict EOS addr quirk to IRIS2 only
authorDikshita Agarwal <dikshita.agarwal@oss.qualcomm.com>
Tue, 25 Nov 2025 05:34:19 +0000 (11:04 +0530)
committerHans Verkuil <hverkuil+cisco@kernel.org>
Tue, 20 Jan 2026 12:19:32 +0000 (13:19 +0100)
On SM8250 (IRIS2) with firmware older than 1.0.087, the firmware could
not handle a dummy device address for EOS buffers, so a NULL device
address is sent instead. The existing check used IS_V6() alongside a
firmware version gate:

    if (IS_V6(core) && is_fw_rev_or_older(core, 1, 0, 87))
        fdata.device_addr = 0;
    else
fdata.device_addr = 0xdeadb000;

However, SC7280 which is also V6, uses a firmware string of the form
"1.0.<commit-hash>", which the version parser translates to 1.0.0. This
unintentionally satisfies the `is_fw_rev_or_older(..., 1, 0, 87)`
condition on SC7280. Combined with IS_V6() matching there as well, the
quirk is incorrectly applied to SC7280, causing VP9 decode failures.

Constrain the check to IRIS2 (SM8250) only, which is the only platform
that needed this quirk, by replacing IS_V6() with IS_IRIS2(). This
restores correct behavior on SC7280 (no forced NULL EOS buffer address).

Fixes: 47f867cb1b63 ("media: venus: fix EOS handling in decoder stop command")
Cc: stable@vger.kernel.org
Reported-by: Mecid <mecid@mecomediagroup.de>
Closes: https://github.com/qualcomm-linux/kernel-topics/issues/222
Co-developed-by: Renjiang Han <renjiang.han@oss.qualcomm.com>
Signed-off-by: Renjiang Han <renjiang.han@oss.qualcomm.com>
Signed-off-by: Dikshita Agarwal <dikshita.agarwal@oss.qualcomm.com>
Tested-by: Renjiang Han <renjiang.han@oss.qualcomm.com>
Signed-off-by: Bryan O'Donoghue <bod@kernel.org>
Signed-off-by: Hans Verkuil <hverkuil+cisco@kernel.org>
drivers/media/platform/qcom/venus/vdec.c

index d0bd2d86a31f9a18cb68b08ba66affdf8fc5092d..4cd69440e87532bb4f992f439a428105235de223 100644 (file)
@@ -565,7 +565,13 @@ vdec_decoder_cmd(struct file *file, void *fh, struct v4l2_decoder_cmd *cmd)
 
                fdata.buffer_type = HFI_BUFFER_INPUT;
                fdata.flags |= HFI_BUFFERFLAG_EOS;
-               if (IS_V6(inst->core) && is_fw_rev_or_older(inst->core, 1, 0, 87))
+
+               /* Send NULL EOS addr for only IRIS2 (SM8250),for firmware <= 1.0.87.
+                * SC7280 also reports "1.0.<hash>" parsed as 1.0.0; restricting to IRIS2
+                * avoids misapplying this quirk and breaking VP9 decode on SC7280.
+                */
+
+               if (IS_IRIS2(inst->core) && is_fw_rev_or_older(inst->core, 1, 0, 87))
                        fdata.device_addr = 0;
                else
                        fdata.device_addr = 0xdeadb000;