Hi Vikash, On 10/7/20 10:53 PM, vgarodia@xxxxxxxxxxxxxx wrote: > Hi Stan, > > On 2020-09-28 22:14, Stanimir Varbanov wrote: >> This makes the decoder to behaives equally for sufficient and > behaves > >> insufficient events. After this change the LAST buffer flag will be set >> when the new resolution (in dynamic-resolution-change state) is smaller >> then the old bitstream resolution. >> >> Signed-off-by: Stanimir Varbanov <stanimir.varbanov@xxxxxxxxxx> >> --- >> drivers/media/platform/qcom/venus/vdec.c | 41 ++++++++++++++++-------- >> 1 file changed, 27 insertions(+), 14 deletions(-) >> >> diff --git a/drivers/media/platform/qcom/venus/vdec.c >> b/drivers/media/platform/qcom/venus/vdec.c >> index c11bdf3ca21b..c006401255dc 100644 >> --- a/drivers/media/platform/qcom/venus/vdec.c >> +++ b/drivers/media/platform/qcom/venus/vdec.c >> @@ -634,6 +634,7 @@ static int vdec_output_conf(struct venus_inst *inst) >> { >> struct venus_core *core = inst->core; >> struct hfi_enable en = { .enable = 1 }; >> + struct hfi_buffer_requirements bufreq; >> u32 width = inst->out_width; >> u32 height = inst->out_height; >> u32 out_fmt, out2_fmt; >> @@ -709,6 +710,22 @@ static int vdec_output_conf(struct venus_inst *inst) >> } >> >> if (IS_V3(core) || IS_V4(core)) { >> + ret = venus_helper_get_bufreq(inst, HFI_BUFFER_OUTPUT, &bufreq); >> + if (ret) >> + return ret; >> + >> + if (bufreq.size > inst->output_buf_size) >> + return -EINVAL; >> + >> + if (inst->dpb_fmt) { >> + ret = venus_helper_get_bufreq(inst, HFI_BUFFER_OUTPUT2, >> &bufreq); >> + if (ret) >> + return ret; >> + >> + if (bufreq.size > inst->output2_buf_size) >> + return -EINVAL; >> + } >> + >> if (inst->output2_buf_size) { >> ret = venus_helper_set_bufsize(inst, >> inst->output2_buf_size, >> @@ -1327,19 +1344,15 @@ static void vdec_event_change(struct >> venus_inst *inst, >> dev_dbg(dev, VDBGM "event %s sufficient resources (%ux%u)\n", >> sufficient ? "" : "not", ev_data->width, ev_data->height); >> >> - if (sufficient) { >> - hfi_session_continue(inst); >> - } else { >> - switch (inst->codec_state) { >> - case VENUS_DEC_STATE_INIT: >> - inst->codec_state = VENUS_DEC_STATE_CAPTURE_SETUP; >> - break; >> - case VENUS_DEC_STATE_DECODING: >> - inst->codec_state = VENUS_DEC_STATE_DRC; >> - break; >> - default: >> - break; >> - } >> + switch (inst->codec_state) { >> + case VENUS_DEC_STATE_INIT: >> + inst->codec_state = VENUS_DEC_STATE_CAPTURE_SETUP; >> + break; >> + case VENUS_DEC_STATE_DECODING: >> + inst->codec_state = VENUS_DEC_STATE_DRC; > > Video firmware would raise reconfig event to driver even for cases like > interlace detection, color space change in the bitstream. If not with > this patch, > we can optimize by sending reconfig event only for resolution and > bitdepth update, > in a followup patch. Good point. Sure, I can do that in this series as separate patch. > >> + break; >> + default: >> + break; >> } >> >> /* >> @@ -1348,7 +1361,7 @@ static void vdec_event_change(struct venus_inst >> *inst, >> * itself doesn't mark the last decoder output buffer with HFI >> EOS flag. >> */ >> >> - if (!sufficient && inst->codec_state == VENUS_DEC_STATE_DRC) { >> + if (inst->codec_state == VENUS_DEC_STATE_DRC) { >> struct vb2_v4l2_buffer *last; >> int ret; -- regards, Stan