media: coda: Add control for h.264 chroma qp index offset
authorPhilipp Zabel <p.zabel@pengutronix.de>
Thu, 10 Jan 2019 16:56:12 +0000 (11:56 -0500)
committerMauro Carvalho Chehab <mchehab+samsung@kernel.org>
Wed, 16 Jan 2019 19:09:45 +0000 (14:09 -0500)
Allow to set a fixed quantization parameter offset between luma and
chroma in the h.264 encoder.

Signed-off-by: Philipp Zabel <p.zabel@pengutronix.de>
Signed-off-by: Hans Verkuil <hverkuil-cisco@xs4all.nl>
Signed-off-by: Mauro Carvalho Chehab <mchehab+samsung@kernel.org>
drivers/media/platform/coda/coda-bit.c
drivers/media/platform/coda/coda-common.c
drivers/media/platform/coda/coda.h

index 2998c869f79fc76f7cb7b2cc497e58c167613b8d..88065b07149c5f95fe45d4f38643aa3df088304b 100644 (file)
@@ -1012,7 +1012,9 @@ static int coda_start_encoding(struct coda_ctx *ctx)
                          CODA_264PARAM_DEBLKFILTEROFFSETBETA_MASK) <<
                         CODA_264PARAM_DEBLKFILTEROFFSETBETA_OFFSET) |
                        (ctx->params.h264_constrained_intra_pred_flag <<
-                        CODA_264PARAM_CONSTRAINEDINTRAPREDFLAG_OFFSET);
+                        CODA_264PARAM_CONSTRAINEDINTRAPREDFLAG_OFFSET) |
+                       (ctx->params.h264_chroma_qp_index_offset &
+                        CODA_264PARAM_CHROMAQPOFFSET_MASK);
                coda_write(dev, value, CODA_CMD_ENC_SEQ_264_PARA);
                break;
        case V4L2_PIX_FMT_JPEG:
index f6c9273805bb3dac1dfdafc17e863f27d71a583f..390d1ce6ab32b0b295bc6f9361d3f90c08a25400 100644 (file)
@@ -1842,6 +1842,9 @@ static int coda_s_ctrl(struct v4l2_ctrl *ctrl)
        case V4L2_CID_MPEG_VIDEO_H264_CONSTRAINED_INTRA_PREDICTION:
                ctx->params.h264_constrained_intra_pred_flag = ctrl->val;
                break;
+       case V4L2_CID_MPEG_VIDEO_H264_CHROMA_QP_INDEX_OFFSET:
+               ctx->params.h264_chroma_qp_index_offset = ctrl->val;
+               break;
        case V4L2_CID_MPEG_VIDEO_H264_PROFILE:
                /* TODO: switch between baseline and constrained baseline */
                if (ctx->inst_type == CODA_INST_ENCODER)
@@ -1931,6 +1934,8 @@ static void coda_encode_ctrls(struct coda_ctx *ctx)
        v4l2_ctrl_new_std(&ctx->ctrls, &coda_ctrl_ops,
                V4L2_CID_MPEG_VIDEO_H264_CONSTRAINED_INTRA_PREDICTION, 0, 1, 1,
                0);
+       v4l2_ctrl_new_std(&ctx->ctrls, &coda_ctrl_ops,
+               V4L2_CID_MPEG_VIDEO_H264_CHROMA_QP_INDEX_OFFSET, -12, 12, 1, 0);
        v4l2_ctrl_new_std_menu(&ctx->ctrls, &coda_ctrl_ops,
                V4L2_CID_MPEG_VIDEO_H264_PROFILE,
                V4L2_MPEG_VIDEO_H264_PROFILE_BASELINE, 0x0,
index f3d0cff4ef3a3252f3e669bd1f36e0d31511ac03..31c80bda2c0bea96fb0c9e0cf7a98f381719559c 100644 (file)
@@ -119,6 +119,7 @@ struct coda_params {
        s8                      h264_slice_alpha_c0_offset_div2;
        s8                      h264_slice_beta_offset_div2;
        bool                    h264_constrained_intra_pred_flag;
+       s8                      h264_chroma_qp_index_offset;
        u8                      h264_profile_idc;
        u8                      h264_level_idc;
        u8                      mpeg4_intra_qp;