Re: [PATCH 1/2] media: amphion: Support display delay for Hevc format

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Le mardi 07 janvier 2025 à 09:29 +0800, Ming Qian(OSS) a écrit :
> Hi Nicolas,
> 
> 
> On 2025/1/7 6:16, Nicolas Dufresne wrote:
> > Hi,
> > 
> > nit: use capital HEVC in the subject
> > 
> 
> I'll fix it in the v2 patch
> 
> > Le jeudi 19 décembre 2024 à 10:51 +0900, Ming Qian a écrit :
> > > The amphion decoder firmware v1.9.0 supports display delay 0 for
> > > hevc format, then driver can enable this feature.
> > 
> > nit: HEVC
> > 
> > I think this added "feature" hides a bug you haven't fixed in this patch.
> > 
> > 
> >          v4l2_ctrl_new_std(&inst->ctrl_handler, &vdec_ctrl_ops,
> >                            V4L2_CID_MPEG_VIDEO_DEC_DISPLAY_DELAY_ENABLE,
> >                            0, 1, 1, 0);
> > 
> > With the control registered this way, 0 is the default, and the range of 0-1.
> > But from your commit message, this is only supported from firmware 1.9.0 and up.
> > I think the patch should basically adjust the min and def values according to
> > the detected firmware version.
> > 
> > This might actually be more complex, aka per CODEC, and for that you may want to
> > use v4l2_ctrl_config structure.
> > 
> > Nicolas
> > 
> 
> Thanks for the tip.
> By the way, how to define different ctrl values for each CODEC format?
> Is it reasonable to new a ctrl after set capture format?
> Or can we change the min/max value after set capture format?

Very good question, I clearly didn't think through my reply. Seems fine to leave
it that way. Per-codec, would mean having multiple CID, which is not your fault
it has been combined.

Nicolas

> 
> Thanks,
> Ming
> 
> > 
> > > Signed-off-by: Ming Qian <ming.qian@xxxxxxxxxxx>
> > > ---
> > >   drivers/media/platform/amphion/vpu_malone.c | 14 +++++++++++---
> > >   1 file changed, 11 insertions(+), 3 deletions(-)
> > > 
> > > diff --git a/drivers/media/platform/amphion/vpu_malone.c b/drivers/media/platform/amphion/vpu_malone.c
> > > index 5c6b2a841b6f..8f4aa48b2d65 100644
> > > --- a/drivers/media/platform/amphion/vpu_malone.c
> > > +++ b/drivers/media/platform/amphion/vpu_malone.c
> > > @@ -332,6 +332,8 @@ struct vpu_dec_ctrl {
> > >   	u32 buf_addr[VID_API_NUM_STREAMS];
> > >   };
> > >   
> > > +static const struct malone_padding_scode *get_padding_scode(u32 type, u32 fmt);
> > > +
> > >   u32 vpu_malone_get_data_size(void)
> > >   {
> > >   	return sizeof(struct vpu_dec_ctrl);
> > > @@ -654,8 +656,10 @@ static int vpu_malone_set_params(struct vpu_shared_addr *shared,
> > >   		hc->jpg[instance].jpg_mjpeg_interlaced = 0;
> > >   	}
> > >   
> > > -	hc->codec_param[instance].disp_imm = params->display_delay_enable ? 1 : 0;
> > > -	if (malone_format != MALONE_FMT_AVC)
> > > +	if (params->display_delay_enable &&
> > > +	    get_padding_scode(SCODE_PADDING_BUFFLUSH, params->codec_format))
> > > +		hc->codec_param[instance].disp_imm = 1;
> > > +	else
> > >   		hc->codec_param[instance].disp_imm = 0;
> > >   	hc->codec_param[instance].dbglog_enable = 0;
> > >   	iface->dbglog_desc.level = 0;
> > > @@ -1024,6 +1028,7 @@ static const struct malone_padding_scode padding_scodes[] = {
> > >   	{SCODE_PADDING_EOS,      V4L2_PIX_FMT_JPEG,        {0x0, 0x0}},
> > >   	{SCODE_PADDING_BUFFLUSH, V4L2_PIX_FMT_H264,        {0x15010000, 0x0}},
> > >   	{SCODE_PADDING_BUFFLUSH, V4L2_PIX_FMT_H264_MVC,    {0x15010000, 0x0}},
> > > +	{SCODE_PADDING_BUFFLUSH, V4L2_PIX_FMT_HEVC,        {0x3e010000, 0x20}},
> > >   };
> > >   
> > >   static const struct malone_padding_scode padding_scode_dft = {0x0, 0x0};
> > > @@ -1058,8 +1063,11 @@ static int vpu_malone_add_padding_scode(struct vpu_buffer *stream_buffer,
> > >   	int ret;
> > >   
> > >   	ps = get_padding_scode(scode_type, pixelformat);
> > > -	if (!ps)
> > > +	if (!ps) {
> > > +		if (scode_type == SCODE_PADDING_BUFFLUSH)
> > > +			return 0;
> > >   		return -EINVAL;
> > > +	}
> > >   
> > >   	wptr = readl(&str_buf->wptr);
> > >   	if (wptr < stream_buffer->phys || wptr > stream_buffer->phys + stream_buffer->length)
> > 






[Index of Archives]     [Linux Input]     [Video for Linux]     [Gstreamer Embedded]     [Mplayer Users]     [Linux USB Devel]     [Linux Audio Users]     [Linux Kernel]     [Linux SCSI]     [Yosemite Backpacking]

  Powered by Linux