[<prev] [next>] [<thread-prev] [day] [month] [year] [list]
Message-ID: <6f9be486-364f-cfa8-0a3b-ccc3967bbd5d@oss.qualcomm.com>
Date: Tue, 18 Nov 2025 10:49:45 +0530
From: Dikshita Agarwal <dikshita.agarwal@....qualcomm.com>
To: Bryan O'Donoghue <bryan.odonoghue@...aro.org>,
Vishnu Reddy <quic_bvisredd@...cinc.com>,
vikash.garodia@....qualcomm.com, abhinav.kumar@...ux.dev,
mchehab@...nel.org, hverkuil@...nel.org, stefan.schmidt@...aro.org
Cc: linux-media@...r.kernel.org, linux-arm-msm@...r.kernel.org,
linux-kernel@...r.kernel.org, stable@...r.kernel.org
Subject: Re: [PATCH] media: iris: Fix ffmpeg corrupted frame error
Hi Bryan,
On 10/7/2025 5:02 PM, Bryan O'Donoghue wrote:
> On 06/10/2025 10:18, Vishnu Reddy wrote:
>> When the ffmpeg decoder is running, the driver receives the
>> V4L2_BUF_FLAG_KEYFRAME flag in the input buffer. The driver then forwards
>> this flag information to the firmware. The firmware, in turn, copies the
>> input buffer flags directly into the output buffer flags. Upon receiving
>> the output buffer from the firmware, the driver observes that the buffer
>> contains the HFI_BUFFERFLAG_DATACORRUPT flag. The root cause is that both
>> V4L2_BUF_FLAG_KEYFRAME and HFI_BUFFERFLAG_DATACORRUPT are the same value.
>> As a result, the driver incorrectly interprets the output frame as
>> corrupted, even though the frame is actually valid. This misinterpretation
>> causes the driver to report an error and skip good frames, leading to
>> missing frames in the final video output and triggering ffmpeg's "corrupt
>> decoded frame" error.
>>
>> To resolve this issue, the input buffer flags should not be sent to the
>> firmware during decoding, since the firmware does not require this
>> information.
>>
>> Fixes: 17f2a485ca67 ("media: iris: implement vb2 ops for buf_queue and
>> firmware response")
>> Cc: stable@...r.kernel.org
>> Signed-off-by: Vishnu Reddy <quic_bvisredd@...cinc.com>
>> ---
>> drivers/media/platform/qcom/iris/iris_hfi_gen1_command.c | 2 +-
>> 1 file changed, 1 insertion(+), 1 deletion(-)
>>
>> diff --git a/drivers/media/platform/qcom/iris/iris_hfi_gen1_command.c
>> b/drivers/media/platform/qcom/iris/iris_hfi_gen1_command.c
>> index e1788c266bb1..4de03f31eaf3 100644
>> --- a/drivers/media/platform/qcom/iris/iris_hfi_gen1_command.c
>> +++ b/drivers/media/platform/qcom/iris/iris_hfi_gen1_command.c
>> @@ -282,7 +282,7 @@ static int iris_hfi_gen1_queue_input_buffer(struct
>> iris_inst *inst, struct iris_
>> com_ip_pkt.shdr.session_id = inst->session_id;
>> com_ip_pkt.time_stamp_hi = upper_32_bits(buf->timestamp);
>> com_ip_pkt.time_stamp_lo = lower_32_bits(buf->timestamp);
>> - com_ip_pkt.flags = buf->flags;
>> + com_ip_pkt.flags = 0;
>> com_ip_pkt.mark_target = 0;
>> com_ip_pkt.mark_data = 0;
>> com_ip_pkt.offset = buf->data_offset;
>> --
>> 2.34.1
>>
>
> Reviewed-by: Bryan O'Donoghue <bryan.odonoghue@...aro.org>
Can you please pull this fix for 6.19.
Thanks,
Dikshita
Powered by blists - more mailing lists