Commit e45cf927 authored by Philipp Zabel's avatar Philipp Zabel Committed by Mauro Carvalho Chehab

media: coda: update profile and level controls after sequence initialization

The header report return value from decoder sequence initialization is
available on CodaHx4 and CODA7541 already. Use the profile and level
identification values reported by the firmware to update codec specific
profile and level controls after sequence initialization has succeeded.
Signed-off-by: default avatarPhilipp Zabel <p.zabel@pengutronix.de>
Signed-off-by: default avatarHans Verkuil <hverkuil-cisco@xs4all.nl>
Signed-off-by: default avatarMauro Carvalho Chehab <mchehab+samsung@kernel.org>
parent 8a618957
...@@ -1814,6 +1814,17 @@ static int __coda_start_decoding(struct coda_ctx *ctx) ...@@ -1814,6 +1814,17 @@ static int __coda_start_decoding(struct coda_ctx *ctx)
(top_bottom & 0x3ff); (top_bottom & 0x3ff);
} }
if (dev->devtype->product != CODA_DX6) {
u8 profile, level;
val = coda_read(dev, CODA7_RET_DEC_SEQ_HEADER_REPORT);
profile = val & 0xff;
level = (val >> 8) & 0x7f;
if (profile || level)
coda_update_profile_level_ctrls(ctx, profile, level);
}
ret = coda_alloc_framebuffers(ctx, q_data_dst, src_fourcc); ret = coda_alloc_framebuffers(ctx, q_data_dst, src_fourcc);
if (ret < 0) { if (ret < 0) {
v4l2_err(&dev->v4l2_dev, "failed to allocate framebuffers\n"); v4l2_err(&dev->v4l2_dev, "failed to allocate framebuffers\n");
......
...@@ -1567,42 +1567,53 @@ static void coda_update_menu_ctrl(struct v4l2_ctrl *ctrl, int value) ...@@ -1567,42 +1567,53 @@ static void coda_update_menu_ctrl(struct v4l2_ctrl *ctrl, int value)
v4l2_ctrl_unlock(ctrl); v4l2_ctrl_unlock(ctrl);
} }
static void coda_update_h264_profile_ctrl(struct coda_ctx *ctx) void coda_update_profile_level_ctrls(struct coda_ctx *ctx, u8 profile_idc,
u8 level_idc)
{ {
const char * const *profile_names; const char * const *profile_names;
const char * const *level_names;
struct v4l2_ctrl *profile_ctrl;
struct v4l2_ctrl *level_ctrl;
const char *codec_name;
u32 profile_cid;
u32 level_cid;
int profile; int profile;
int level;
profile = coda_h264_profile(ctx->params.h264_profile_idc); switch (ctx->codec->src_fourcc) {
if (profile < 0) { case V4L2_PIX_FMT_H264:
v4l2_warn(&ctx->dev->v4l2_dev, "Invalid H264 Profile: %u\n", codec_name = "H264";
ctx->params.h264_profile_idc); profile_cid = V4L2_CID_MPEG_VIDEO_H264_PROFILE;
level_cid = V4L2_CID_MPEG_VIDEO_H264_LEVEL;
profile_ctrl = ctx->h264_profile_ctrl;
level_ctrl = ctx->h264_level_ctrl;
profile = coda_h264_profile(profile_idc);
level = coda_h264_level(level_idc);
break;
default:
return; return;
} }
coda_update_menu_ctrl(ctx->h264_profile_ctrl, profile); profile_names = v4l2_ctrl_get_menu(profile_cid);
level_names = v4l2_ctrl_get_menu(level_cid);
profile_names = v4l2_ctrl_get_menu(V4L2_CID_MPEG_VIDEO_H264_PROFILE);
coda_dbg(1, ctx, "Parsed H264 Profile: %s\n", profile_names[profile]); if (profile < 0) {
} v4l2_warn(&ctx->dev->v4l2_dev, "Invalid %s profile: %u\n",
codec_name, profile_idc);
static void coda_update_h264_level_ctrl(struct coda_ctx *ctx) } else {
{ coda_dbg(1, ctx, "Parsed %s profile: %s\n", codec_name,
const char * const *level_names; profile_names[profile]);
int level; coda_update_menu_ctrl(profile_ctrl, profile);
}
level = coda_h264_level(ctx->params.h264_level_idc);
if (level < 0) { if (level < 0) {
v4l2_warn(&ctx->dev->v4l2_dev, "Invalid H264 Level: %u\n", v4l2_warn(&ctx->dev->v4l2_dev, "Invalid %s level: %u\n",
ctx->params.h264_level_idc); codec_name, level_idc);
return; } else {
coda_dbg(1, ctx, "Parsed %s level: %s\n", codec_name,
level_names[level]);
coda_update_menu_ctrl(level_ctrl, level);
} }
coda_update_menu_ctrl(ctx->h264_level_ctrl, level);
level_names = v4l2_ctrl_get_menu(V4L2_CID_MPEG_VIDEO_H264_LEVEL);
coda_dbg(1, ctx, "Parsed H264 Level: %s\n", level_names[level]);
} }
static void coda_buf_queue(struct vb2_buffer *vb) static void coda_buf_queue(struct vb2_buffer *vb)
...@@ -1635,8 +1646,9 @@ static void coda_buf_queue(struct vb2_buffer *vb) ...@@ -1635,8 +1646,9 @@ static void coda_buf_queue(struct vb2_buffer *vb)
*/ */
if (!ctx->params.h264_profile_idc) { if (!ctx->params.h264_profile_idc) {
coda_sps_parse_profile(ctx, vb); coda_sps_parse_profile(ctx, vb);
coda_update_h264_profile_ctrl(ctx); coda_update_profile_level_ctrls(ctx,
coda_update_h264_level_ctrl(ctx); ctx->params.h264_profile_idc,
ctx->params.h264_level_idc);
} }
} }
......
...@@ -328,6 +328,9 @@ int coda_sps_parse_profile(struct coda_ctx *ctx, struct vb2_buffer *vb); ...@@ -328,6 +328,9 @@ int coda_sps_parse_profile(struct coda_ctx *ctx, struct vb2_buffer *vb);
int coda_h264_sps_fixup(struct coda_ctx *ctx, int width, int height, char *buf, int coda_h264_sps_fixup(struct coda_ctx *ctx, int width, int height, char *buf,
int *size, int max_size); int *size, int max_size);
void coda_update_profile_level_ctrls(struct coda_ctx *ctx, u8 profile_idc,
u8 level_idc);
bool coda_jpeg_check_buffer(struct coda_ctx *ctx, struct vb2_buffer *vb); bool coda_jpeg_check_buffer(struct coda_ctx *ctx, struct vb2_buffer *vb);
int coda_jpeg_write_tables(struct coda_ctx *ctx); int coda_jpeg_write_tables(struct coda_ctx *ctx);
void coda_set_jpeg_compression_quality(struct coda_ctx *ctx, int quality); void coda_set_jpeg_compression_quality(struct coda_ctx *ctx, int quality);
......
...@@ -181,7 +181,7 @@ ...@@ -181,7 +181,7 @@
#define CODA_RET_DEC_SEQ_FRATE_DR 0x1e8 #define CODA_RET_DEC_SEQ_FRATE_DR 0x1e8
#define CODA_RET_DEC_SEQ_JPG_PARA 0x1e4 #define CODA_RET_DEC_SEQ_JPG_PARA 0x1e4
#define CODA_RET_DEC_SEQ_JPG_THUMB_IND 0x1e8 #define CODA_RET_DEC_SEQ_JPG_THUMB_IND 0x1e8
#define CODA9_RET_DEC_SEQ_HEADER_REPORT 0x1ec #define CODA7_RET_DEC_SEQ_HEADER_REPORT 0x1ec
/* Decoder Picture Run */ /* Decoder Picture Run */
#define CODA_CMD_DEC_PIC_ROT_MODE 0x180 #define CODA_CMD_DEC_PIC_ROT_MODE 0x180
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment