public inbox for stable@vger.kernel.org
 help / color / mirror / Atom feed
* [PATCH 6.1.y] media: mediatek: vcodec: Fix H264 multi stateless decoder smatch warning
@ 2025-02-21  8:49 jetlan9
  2025-02-22 15:53 ` Sasha Levin
  0 siblings, 1 reply; 2+ messages in thread
From: jetlan9 @ 2025-02-21  8:49 UTC (permalink / raw)
  To: gregkh, stable
  Cc: Yunfei Dong, AngeloGioacchino Del Regno, Sebastian Fricke,
	Hans Verkuil, Wenshan Lan

From: Yunfei Dong <yunfei.dong@mediatek.com>

[ Upstream commit 9be85491619f1953b8a29590ca630be571941ffa ]

Fix a smatch static checker warning on vdec_h264_req_multi_if.c.
Which leads to a kernel crash when fb is NULL.

Fixes: 397edc703a10 ("media: mediatek: vcodec: add h264 decoder driver for mt8186")
Signed-off-by: Yunfei Dong <yunfei.dong@mediatek.com>
Reviewed-by: AngeloGioacchino Del Regno <angelogioacchino.delregno@collabora.com>
Signed-off-by: Sebastian Fricke <sebastian.fricke@collabora.com>
Signed-off-by: Hans Verkuil <hverkuil-cisco@xs4all.nl>
[ drivers/media/platform/mediatek/vcodec/decoder/vdec/vdec_h264_req_multi_if.c
is renamed from drivers/media/platform/mediatek/vcodec/vdec/vdec_h264_req_multi_if.c
since 0934d3759615 ("media: mediatek: vcodec: separate decoder and encoder").
The path is changed accordingly to apply the patch on 6.1.y. ]
Signed-off-by: Wenshan Lan <jetlan9@163.com>
---
 .../mediatek/vcodec/vdec/vdec_h264_req_multi_if.c        | 9 +++++++--
 1 file changed, 7 insertions(+), 2 deletions(-)

diff --git a/drivers/media/platform/mediatek/vcodec/vdec/vdec_h264_req_multi_if.c b/drivers/media/platform/mediatek/vcodec/vdec/vdec_h264_req_multi_if.c
index 999ce7ee5fdc..6952875ca183 100644
--- a/drivers/media/platform/mediatek/vcodec/vdec/vdec_h264_req_multi_if.c
+++ b/drivers/media/platform/mediatek/vcodec/vdec/vdec_h264_req_multi_if.c
@@ -729,11 +729,16 @@ static int vdec_h264_slice_single_decode(void *h_vdec, struct mtk_vcodec_mem *bs
 		return vpu_dec_reset(vpu);
 
 	fb = inst->ctx->dev->vdec_pdata->get_cap_buffer(inst->ctx);
+	if (!fb) {
+		mtk_vcodec_err(inst, "fb buffer is NULL");
+		return -ENOMEM;
+	}
+
 	src_buf_info = container_of(bs, struct mtk_video_dec_buf, bs_buffer);
 	dst_buf_info = container_of(fb, struct mtk_video_dec_buf, frame_buffer);
 
-	y_fb_dma = fb ? (u64)fb->base_y.dma_addr : 0;
-	c_fb_dma = fb ? (u64)fb->base_c.dma_addr : 0;
+	y_fb_dma = fb->base_y.dma_addr;
+	c_fb_dma = fb->base_c.dma_addr;
 	mtk_vcodec_debug(inst, "[h264-dec] [%d] y_dma=%llx c_dma=%llx",
 			 inst->ctx->decoded_frame_cnt, y_fb_dma, c_fb_dma);
 
-- 
2.34.1


^ permalink raw reply related	[flat|nested] 2+ messages in thread

* Re: [PATCH 6.1.y] media: mediatek: vcodec: Fix H264 multi stateless decoder smatch warning
  2025-02-21  8:49 [PATCH 6.1.y] media: mediatek: vcodec: Fix H264 multi stateless decoder smatch warning jetlan9
@ 2025-02-22 15:53 ` Sasha Levin
  0 siblings, 0 replies; 2+ messages in thread
From: Sasha Levin @ 2025-02-22 15:53 UTC (permalink / raw)
  To: stable; +Cc: jetlan9, Sasha Levin

[ Sasha's backport helper bot ]

Hi,

✅ All tests passed successfully. No issues detected.
No action required from the submitter.

The upstream commit SHA1 provided is correct: 9be85491619f1953b8a29590ca630be571941ffa

WARNING: Author mismatch between patch and upstream commit:
Backport author: jetlan9@163.com
Commit author: Yunfei Dong<yunfei.dong@mediatek.com>


Status in newer kernel trees:
6.13.y | Present (exact SHA1)
6.12.y | Present (exact SHA1)
6.6.y | Present (different SHA1: 588bcce9e64c)

Note: The patch differs from the upstream commit:
---
1:  9be85491619f1 ! 1:  dffd0505449e8 media: mediatek: vcodec: Fix H264 multi stateless decoder smatch warning
    @@ Metadata
      ## Commit message ##
         media: mediatek: vcodec: Fix H264 multi stateless decoder smatch warning
     
    +    [ Upstream commit 9be85491619f1953b8a29590ca630be571941ffa ]
    +
         Fix a smatch static checker warning on vdec_h264_req_multi_if.c.
         Which leads to a kernel crash when fb is NULL.
     
    @@ Commit message
         Reviewed-by: AngeloGioacchino Del Regno <angelogioacchino.delregno@collabora.com>
         Signed-off-by: Sebastian Fricke <sebastian.fricke@collabora.com>
         Signed-off-by: Hans Verkuil <hverkuil-cisco@xs4all.nl>
    +    [ drivers/media/platform/mediatek/vcodec/decoder/vdec/vdec_h264_req_multi_if.c
    +    is renamed from drivers/media/platform/mediatek/vcodec/vdec/vdec_h264_req_multi_if.c
    +    since 0934d3759615 ("media: mediatek: vcodec: separate decoder and encoder").
    +    The path is changed accordingly to apply the patch on 6.1.y. ]
    +    Signed-off-by: Wenshan Lan <jetlan9@163.com>
     
    - ## drivers/media/platform/mediatek/vcodec/decoder/vdec/vdec_h264_req_multi_if.c ##
    -@@ drivers/media/platform/mediatek/vcodec/decoder/vdec/vdec_h264_req_multi_if.c: static int vdec_h264_slice_single_decode(void *h_vdec, struct mtk_vcodec_mem *bs
    + ## drivers/media/platform/mediatek/vcodec/vdec/vdec_h264_req_multi_if.c ##
    +@@ drivers/media/platform/mediatek/vcodec/vdec/vdec_h264_req_multi_if.c: static int vdec_h264_slice_single_decode(void *h_vdec, struct mtk_vcodec_mem *bs
      		return vpu_dec_reset(vpu);
      
      	fb = inst->ctx->dev->vdec_pdata->get_cap_buffer(inst->ctx);
     +	if (!fb) {
    -+		mtk_vdec_err(inst->ctx, "fb buffer is NULL");
    ++		mtk_vcodec_err(inst, "fb buffer is NULL");
     +		return -ENOMEM;
     +	}
     +
    @@ drivers/media/platform/mediatek/vcodec/decoder/vdec/vdec_h264_req_multi_if.c: st
     -	c_fb_dma = fb ? (u64)fb->base_c.dma_addr : 0;
     +	y_fb_dma = fb->base_y.dma_addr;
     +	c_fb_dma = fb->base_c.dma_addr;
    - 	mtk_vdec_debug(inst->ctx, "[h264-dec] [%d] y_dma=%llx c_dma=%llx",
    - 		       inst->ctx->decoded_frame_cnt, y_fb_dma, c_fb_dma);
    + 	mtk_vcodec_debug(inst, "[h264-dec] [%d] y_dma=%llx c_dma=%llx",
    + 			 inst->ctx->decoded_frame_cnt, y_fb_dma, c_fb_dma);
      
---

Results of testing on various branches:

| Branch                    | Patch Apply | Build Test |
|---------------------------|-------------|------------|
| stable/linux-6.1.y        |  Success    |  Success   |

^ permalink raw reply	[flat|nested] 2+ messages in thread

end of thread, other threads:[~2025-02-22 15:53 UTC | newest]

Thread overview: 2+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2025-02-21  8:49 [PATCH 6.1.y] media: mediatek: vcodec: Fix H264 multi stateless decoder smatch warning jetlan9
2025-02-22 15:53 ` Sasha Levin

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox