]> asedeno.scripts.mit.edu Git - linux.git/commitdiff
media: hantro: Fix motion vectors usage condition
authorFrancois Buergisser <fbuergisser@chromium.org>
Tue, 29 Oct 2019 01:24:47 +0000 (02:24 +0100)
committerMauro Carvalho Chehab <mchehab@kernel.org>
Sat, 9 Nov 2019 08:05:40 +0000 (09:05 +0100)
The setting of the motion vectors usage and the setting of motion
vectors address are currently done under different conditions.

When decoding pre-recorded videos, this results of leaving the motion
vectors address unset, resulting in faulty memory accesses. Fix it
by using the same condition everywhere, which matches the profiles
that support motion vectors.

Fixes: dea0a82f3d22 ("media: hantro: Add support for H264 decoding on G1")
Signed-off-by: Francois Buergisser <fbuergisser@chromium.org>
Signed-off-by: Ezequiel Garcia <ezequiel@collabora.com>
Signed-off-by: Jonas Karlman <jonas@kwiboo.se>
Reviewed-by: Boris Brezillon <boris.brezillon@collabora.com>
Tested-by: Boris Brezillon <boris.brezillon@collabora.com>
Cc: <stable@vger.kernel.org> # for v5.4 and up
Signed-off-by: Hans Verkuil <hverkuil-cisco@xs4all.nl>
Signed-off-by: Mauro Carvalho Chehab <mchehab@kernel.org>
drivers/staging/media/hantro/hantro_g1_h264_dec.c

index 29130946dea4ca8d656d7c7b43a1f4b782e8e69c..a1cb186802009a172c95b1a3ab86f12c776d48f0 100644 (file)
@@ -35,7 +35,7 @@ static void set_params(struct hantro_ctx *ctx)
        if (sps->flags & V4L2_H264_SPS_FLAG_MB_ADAPTIVE_FRAME_FIELD)
                reg |= G1_REG_DEC_CTRL0_SEQ_MBAFF_E;
        reg |= G1_REG_DEC_CTRL0_PICORD_COUNT_E;
-       if (dec_param->nal_ref_idc)
+       if (sps->profile_idc > 66 && dec_param->nal_ref_idc)
                reg |= G1_REG_DEC_CTRL0_WRITE_MVS_E;
 
        if (!(sps->flags & V4L2_H264_SPS_FLAG_FRAME_MBS_ONLY) &&
@@ -245,7 +245,7 @@ static void set_buffers(struct hantro_ctx *ctx)
        vdpu_write_relaxed(vpu, dst_dma, G1_REG_ADDR_DST);
 
        /* Higher profiles require DMV buffer appended to reference frames. */
-       if (ctrls->sps->profile_idc > 66) {
+       if (ctrls->sps->profile_idc > 66 && ctrls->decode->nal_ref_idc) {
                size_t pic_size = ctx->h264_dec.pic_size;
                size_t mv_offset = round_up(pic_size, 8);