Message ID | 1539071483-1371-1-git-send-email-mgottam@codeaurora.org (mailing list archive) |
---|---|
State | Not Applicable, archived |
Delegated to: | Andy Gross |
Headers | show |
Series | media: venus: handle peak bitrate set property | expand |
Hi Malathi, Thanks for the patch! On 10/09/2018 10:51 AM, Malathi Gottam wrote: > Max bitrate property is not supported for venus version 4xx. > Add a version check for the same. I'd like to avoid version checks in this layer of the driver. Could just black-list this property in pkt_session_set_property_4xx? Hint, see HFI_PROPERTY_CONFIG_VENC_MAX_BITRATE in the same function. > > Signed-off-by: Malathi Gottam <mgottam@codeaurora.org> > --- > drivers/media/platform/qcom/venus/venc.c | 22 ++++++++++++---------- > 1 file changed, 12 insertions(+), 10 deletions(-) > > diff --git a/drivers/media/platform/qcom/venus/venc.c b/drivers/media/platform/qcom/venus/venc.c > index ef11495..3f50cd0 100644 > --- a/drivers/media/platform/qcom/venus/venc.c > +++ b/drivers/media/platform/qcom/venus/venc.c > @@ -757,18 +757,20 @@ static int venc_set_properties(struct venus_inst *inst) > if (ret) > return ret; > > - if (!ctr->bitrate_peak) > - bitrate *= 2; > - else > - bitrate = ctr->bitrate_peak; > + if (!IS_V4(inst->core)) { > + if (!ctr->bitrate_peak) > + bitrate *= 2; > + else > + bitrate = ctr->bitrate_peak; > > - ptype = HFI_PROPERTY_CONFIG_VENC_MAX_BITRATE; > - brate.bitrate = bitrate; > - brate.layer_id = 0; > + ptype = HFI_PROPERTY_CONFIG_VENC_MAX_BITRATE; > + brate.bitrate = bitrate; > + brate.layer_id = 0; > > - ret = hfi_session_set_property(inst, ptype, &brate); > - if (ret) > - return ret; > + ret = hfi_session_set_property(inst, ptype, &brate); > + if (ret) > + return ret; > + } > > if (inst->fmt_cap->pixfmt == V4L2_PIX_FMT_H264) { > profile = venc_v4l2_to_hfi(V4L2_CID_MPEG_VIDEO_H264_PROFILE, >
On 2018-10-09 20:29, Stanimir Varbanov wrote: > Hi Malathi, > > Thanks for the patch! > > On 10/09/2018 10:51 AM, Malathi Gottam wrote: >> Max bitrate property is not supported for venus version 4xx. >> Add a version check for the same. > > I'd like to avoid version checks in this layer of the driver. Could > just > black-list this property in pkt_session_set_property_4xx? Hint, see > HFI_PROPERTY_CONFIG_VENC_MAX_BITRATE in the same function. > >> >> Signed-off-by: Malathi Gottam <mgottam@codeaurora.org> >> --- >> drivers/media/platform/qcom/venus/venc.c | 22 ++++++++++++---------- >> 1 file changed, 12 insertions(+), 10 deletions(-) >> >> diff --git a/drivers/media/platform/qcom/venus/venc.c >> b/drivers/media/platform/qcom/venus/venc.c >> index ef11495..3f50cd0 100644 >> --- a/drivers/media/platform/qcom/venus/venc.c >> +++ b/drivers/media/platform/qcom/venus/venc.c >> @@ -757,18 +757,20 @@ static int venc_set_properties(struct venus_inst >> *inst) >> if (ret) >> return ret; >> >> - if (!ctr->bitrate_peak) >> - bitrate *= 2; >> - else >> - bitrate = ctr->bitrate_peak; >> + if (!IS_V4(inst->core)) { >> + if (!ctr->bitrate_peak) >> + bitrate *= 2; >> + else >> + bitrate = ctr->bitrate_peak; >> >> - ptype = HFI_PROPERTY_CONFIG_VENC_MAX_BITRATE; >> - brate.bitrate = bitrate; >> - brate.layer_id = 0; >> + ptype = HFI_PROPERTY_CONFIG_VENC_MAX_BITRATE; >> + brate.bitrate = bitrate; >> + brate.layer_id = 0; >> >> - ret = hfi_session_set_property(inst, ptype, &brate); >> - if (ret) >> - return ret; >> + ret = hfi_session_set_property(inst, ptype, &brate); >> + if (ret) >> + return ret; >> + } >> >> if (inst->fmt_cap->pixfmt == V4L2_PIX_FMT_H264) { >> profile = venc_v4l2_to_hfi(V4L2_CID_MPEG_VIDEO_H264_PROFILE, >> Hi Stan, Though this property is bypassed in the function "pkt_session_set_property_4xx", it is set to firmware in hfi_venus layer. So we can return -ENOTSUPP from packet layer. If hfi_venus layer receives error as ENOTSUPP, treat it as normal and return 0 to venc layer. I will post the updated patch, with this implementation.
diff --git a/drivers/media/platform/qcom/venus/venc.c b/drivers/media/platform/qcom/venus/venc.c index ef11495..3f50cd0 100644 --- a/drivers/media/platform/qcom/venus/venc.c +++ b/drivers/media/platform/qcom/venus/venc.c @@ -757,18 +757,20 @@ static int venc_set_properties(struct venus_inst *inst) if (ret) return ret; - if (!ctr->bitrate_peak) - bitrate *= 2; - else - bitrate = ctr->bitrate_peak; + if (!IS_V4(inst->core)) { + if (!ctr->bitrate_peak) + bitrate *= 2; + else + bitrate = ctr->bitrate_peak; - ptype = HFI_PROPERTY_CONFIG_VENC_MAX_BITRATE; - brate.bitrate = bitrate; - brate.layer_id = 0; + ptype = HFI_PROPERTY_CONFIG_VENC_MAX_BITRATE; + brate.bitrate = bitrate; + brate.layer_id = 0; - ret = hfi_session_set_property(inst, ptype, &brate); - if (ret) - return ret; + ret = hfi_session_set_property(inst, ptype, &brate); + if (ret) + return ret; + } if (inst->fmt_cap->pixfmt == V4L2_PIX_FMT_H264) { profile = venc_v4l2_to_hfi(V4L2_CID_MPEG_VIDEO_H264_PROFILE,
Max bitrate property is not supported for venus version 4xx. Add a version check for the same. Signed-off-by: Malathi Gottam <mgottam@codeaurora.org> --- drivers/media/platform/qcom/venus/venc.c | 22 ++++++++++++---------- 1 file changed, 12 insertions(+), 10 deletions(-)