[PATCH v7, 07/15] media: mtk-vcodec: Add irq interface for multi hardware
yunfei.dong at mediatek.com
yunfei.dong at mediatek.com
Wed Oct 27 04:36:03 PDT 2021
Hi AngeloGioacchino,
Thanks for your suggestion.
On Thu, 2021-10-14 at 12:04 +0200, AngeloGioacchino Del Regno wrote:
> > Adds irq interface for multi hardware.
> >
> > Signed-off-by: Yunfei Dong <yunfei.dong at mediatek.com>
> > ---
> > .../platform/mtk-vcodec/mtk_vcodec_dec_drv.c | 33
> > +++++++++++++++++--
> > .../platform/mtk-vcodec/mtk_vcodec_dec_hw.c | 2 +-
> > .../platform/mtk-vcodec/mtk_vcodec_drv.h | 25 ++++++++++----
> > .../platform/mtk-vcodec/mtk_vcodec_enc_drv.c | 4 +--
> > .../platform/mtk-vcodec/mtk_vcodec_intr.c | 27 +++++++-------
> > -
> > .../platform/mtk-vcodec/mtk_vcodec_intr.h | 4 +--
> > .../platform/mtk-vcodec/vdec/vdec_h264_if.c | 2 +-
> > .../mtk-vcodec/vdec/vdec_h264_req_if.c | 2 +-
> > .../platform/mtk-vcodec/vdec/vdec_vp8_if.c | 2 +-
> > .../platform/mtk-vcodec/vdec/vdec_vp9_if.c | 2 +-
> > .../platform/mtk-vcodec/venc/venc_h264_if.c | 2 +-
> > .../platform/mtk-vcodec/venc/venc_vp8_if.c | 2 +-
> > 12 files changed, 71 insertions(+), 36 deletions(-)
> >
> > diff --git a/drivers/media/platform/mtk-vcodec/mtk_vcodec_dec_drv.c
> > b/drivers/media/platform/mtk-vcodec/mtk_vcodec_dec_drv.c
> > index 17cb3e3519eb..ff70fa5b34e3 100644
> > --- a/drivers/media/platform/mtk-vcodec/mtk_vcodec_dec_drv.c
> > +++ b/drivers/media/platform/mtk-vcodec/mtk_vcodec_dec_drv.c
> > @@ -73,6 +73,20 @@ static int mtk_vcodec_comp_device_check(struct
> > mtk_vcodec_ctx *ctx)
> > return 0;
> > }
> >
> > +static int mtk_vcodec_get_hw_count(struct mtk_vcodec_dev *dev)
> > +{
> > + switch (dev->vdec_pdata->hw_arch) {
> > + case MTK_VDEC_PURE_SINGLE_CORE:
> > + return MTK_VDEC_ONE_CORE;
> > + case MTK_VDEC_LAT_SINGLE_CORE:
> > + return MTK_VDEC_ONE_LAT_ONE_CORE;
> > + default:
> > + mtk_v4l2_err("not support hw arch:%d",
> > + dev->vdec_pdata->hw_arch);
> > + return MTK_VDEC_NO_HW;
> > + }
> > +}
> > +
> > static irqreturn_t mtk_vcodec_dec_irq_handler(int irq, void
> > *priv)
> > {
> > struct mtk_vcodec_dev *dev = priv;
> > @@ -104,7 +118,7 @@ static irqreturn_t
> > mtk_vcodec_dec_irq_handler(int irq, void *priv)
> > writel((readl(vdec_misc_addr) & ~VDEC_IRQ_CLR),
> > dev->reg_base[VDEC_MISC] + VDEC_IRQ_CFG_REG);
> >
> > - wake_up_ctx(ctx, MTK_INST_IRQ_RECEIVED);
> > + wake_up_ctx(ctx, MTK_INST_IRQ_RECEIVED, 0);
> >
> > mtk_v4l2_debug(3,
> > "mtk_vcodec_dec_irq_handler :wake up ctx %d,
> > dec_done_status=%x",
> > @@ -176,7 +190,7 @@ static int fops_vcodec_open(struct file *file)
> > {
> > struct mtk_vcodec_dev *dev = video_drvdata(file);
> > struct mtk_vcodec_ctx *ctx = NULL;
> > - int ret = 0;
> > + int ret = 0, i, hw_count;
> > struct vb2_queue *src_vq;
> >
> > ctx = kzalloc(sizeof(*ctx), GFP_KERNEL);
> > @@ -190,7 +204,19 @@ static int fops_vcodec_open(struct file *file)
> > v4l2_fh_add(&ctx->fh);
> > INIT_LIST_HEAD(&ctx->list);
> > ctx->dev = dev;
> > - init_waitqueue_head(&ctx->queue);
> > +
> > + if (ctx->dev->vdec_pdata->is_comp_supported) {
>
> As pointed out in the review for patch 04/15 of this series,
> is_comp_supported
> is always false since you moved away from the component framework.
>
> That means that this code can be removed, as nothing ever hits that.
>
> Please note that other patches in this series are following
> similar/same patterns,
> so this comment applies to the entire series.
>
> > + hw_count = mtk_vcodec_get_hw_count(dev);
> > + if (!hw_count) {
> > + ret = -EINVAL;
> > + goto err_init_queue;
> > + }
> > + for (i = 0; i < hw_count; i++)
> > + init_waitqueue_head(&ctx->queue[i]);
> > + } else {
> > + init_waitqueue_head(&ctx->queue[0]);
> > + }
> > +
> > mutex_init(&ctx->lock);
> >
> > ret = mtk_vcodec_comp_device_check(ctx);
> > @@ -253,6 +279,7 @@ static int fops_vcodec_open(struct file *file)
> > err_m2m_ctx_init:
> > v4l2_ctrl_handler_free(&ctx->ctrl_hdl);
> > err_ctrls_setup:
> > +err_init_queue:
>
> ...and if that unused component code gets removed, this label can
> also be removed.
>
For add 8192 to support component, these code need to keep.
> > v4l2_fh_del(&ctx->fh);
> > v4l2_fh_exit(&ctx->fh);
> > kfree(ctx);
> > diff --git a/drivers/media/platform/mtk-vcodec/mtk_vcodec_dec_hw.c
> > b/drivers/media/platform/mtk-vcodec/mtk_vcodec_dec_hw.c
> > index 3752ccaea284..0997a5a08156 100644
> > --- a/drivers/media/platform/mtk-vcodec/mtk_vcodec_dec_hw.c
> > +++ b/drivers/media/platform/mtk-vcodec/mtk_vcodec_dec_hw.c
> > @@ -56,7 +56,7 @@ static irqreturn_t mtk_vdec_comp_irq_handler(int
> > irq, void *priv)
> > writel(dec_done_status | VDEC_IRQ_CFG, vdec_misc_addr);
> > writel(dec_done_status & ~VDEC_IRQ_CLR, vdec_misc_addr);
> >
> > - wake_up_ctx(ctx, MTK_INST_IRQ_RECEIVED);
> > + wake_up_ctx(ctx, MTK_INST_IRQ_RECEIVED, dev->comp_idx);
> >
> > mtk_v4l2_debug(3, "wake up ctx %d, dec_done_status=%x",
> > ctx->id, dec_done_status);
> > diff --git a/drivers/media/platform/mtk-vcodec/mtk_vcodec_drv.h
> > b/drivers/media/platform/mtk-vcodec/mtk_vcodec_drv.h
> > index 140f1a761942..f8e8b5ba408b 100644
> > --- a/drivers/media/platform/mtk-vcodec/mtk_vcodec_drv.h
> > +++ b/drivers/media/platform/mtk-vcodec/mtk_vcodec_drv.h
> > @@ -104,6 +104,16 @@ enum mtk_vdec_hw_id {
> > MTK_VDEC_HW_MAX,
> > };
> >
> > +/**
> > + * struct mtk_vdec_hw_count - Supported hardware count
> > + */
> > +enum mtk_vdec_hw_count {
> > + MTK_VDEC_NO_HW = 0,
> > + MTK_VDEC_ONE_CORE,
> > + MTK_VDEC_ONE_LAT_ONE_CORE,
> > + MTK_VDEC_MAX_HW_COUNT,
> > +};
> > +
> > /*
> > * struct mtk_video_fmt - Structure used to store information
> > about pixelformats
> > */
> > @@ -293,9 +303,9 @@ struct mtk_vcodec_ctx {
> > struct vdec_pic_info picinfo;
> > int dpb_size;
> >
> > - int int_cond;
> > - int int_type;
> > - wait_queue_head_t queue;
> > + int int_cond[MTK_VDEC_HW_MAX];
> > + int int_type[MTK_VDEC_HW_MAX];
> > + wait_queue_head_t queue[MTK_VDEC_HW_MAX];
> > unsigned int irq_status;
> >
> > struct v4l2_ctrl_handler ctrl_hdl;
> > @@ -505,11 +515,12 @@ static inline struct mtk_vcodec_ctx
> > *ctrl_to_ctx(struct v4l2_ctrl *ctrl)
> > }
> >
> > /* Wake up context wait_queue */
> > -static inline void wake_up_ctx(struct mtk_vcodec_ctx *ctx,
> > unsigned int reason)
> > +static inline void wake_up_ctx(struct mtk_vcodec_ctx *ctx,
> > unsigned int reason,
> > + unsigned int hw_id)
> > {
> > - ctx->int_cond = 1;
> > - ctx->int_type = reason;
> > - wake_up_interruptible(&ctx->queue);
> > + ctx->int_cond[hw_id] = 1;
> > + ctx->int_type[hw_id] = reason;
> > + wake_up_interruptible(&ctx->queue[hw_id]);
> > }
> >
> > #endif /* _MTK_VCODEC_DRV_H_ */
> > diff --git a/drivers/media/platform/mtk-vcodec/mtk_vcodec_enc_drv.c
> > b/drivers/media/platform/mtk-vcodec/mtk_vcodec_enc_drv.c
> > index 2828df77020c..c7540c0cdcea 100644
> > --- a/drivers/media/platform/mtk-vcodec/mtk_vcodec_enc_drv.c
> > +++ b/drivers/media/platform/mtk-vcodec/mtk_vcodec_enc_drv.c
> > @@ -114,7 +114,7 @@ static irqreturn_t
> > mtk_vcodec_enc_irq_handler(int irq, void *priv)
> >
> > clean_irq_status(ctx->irq_status, addr);
> >
> > - wake_up_ctx(ctx, MTK_INST_IRQ_RECEIVED);
> > + wake_up_ctx(ctx, MTK_INST_IRQ_RECEIVED, 0);
> > return IRQ_HANDLED;
> > }
> >
> > @@ -140,7 +140,7 @@ static int fops_vcodec_open(struct file *file)
> > v4l2_fh_add(&ctx->fh);
> > INIT_LIST_HEAD(&ctx->list);
> > ctx->dev = dev;
> > - init_waitqueue_head(&ctx->queue);
> > + init_waitqueue_head(&ctx->queue[0]);
> >
> > ctx->type = MTK_INST_ENCODER;
> > ret = mtk_vcodec_enc_ctrls_setup(ctx);
> > diff --git a/drivers/media/platform/mtk-vcodec/mtk_vcodec_intr.c
> > b/drivers/media/platform/mtk-vcodec/mtk_vcodec_intr.c
> > index 70580c2525ba..8147533da98b 100644
> > --- a/drivers/media/platform/mtk-vcodec/mtk_vcodec_intr.c
> > +++ b/drivers/media/platform/mtk-vcodec/mtk_vcodec_intr.c
> > @@ -11,34 +11,31 @@
> > #include "mtk_vcodec_intr.h"
> > #include "mtk_vcodec_util.h"
> >
> > -int mtk_vcodec_wait_for_done_ctx(struct mtk_vcodec_ctx *ctx, int
> > command,
> > - unsigned int timeout_ms)
> > +int mtk_vcodec_wait_for_done_ctx(struct mtk_vcodec_ctx *ctx,
> > + int command, unsigned int timeout_ms, unsigned hw_id)
> > {
> > - wait_queue_head_t *waitqueue;
> > long timeout_jiff, ret;
> > int status = 0;
> >
> > - waitqueue = (wait_queue_head_t *)&ctx->queue;
> > timeout_jiff = msecs_to_jiffies(timeout_ms);
> > -
> > - ret = wait_event_interruptible_timeout(*waitqueue,
> > - ctx->int_cond,
> > + ret = wait_event_interruptible_timeout(ctx->queue[hw_id],
> > + ctx->int_cond[hw_id],
> > timeout_jiff);
> >
> > if (!ret) {
> > status = -1; /* timeout */
> > - mtk_v4l2_err("[%d] ctx->type=%d, cmd=%d,
> > wait_event_interruptible_timeout time=%ums out %d %d!",
> > - ctx->id, ctx->type, command, timeout_ms,
> > - ctx->int_cond, ctx->int_type);
> > + mtk_v4l2_err("[%d] cmd=%d, type=%d, dec timeout=%ums
> > (%d %d)",
> > + ctx->id, command, ctx->type,
> > timeout_ms,
> > + ctx->int_cond[hw_id], ctx-
> > >int_type[hw_id]);
> > } else if (-ERESTARTSYS == ret) {
> > - mtk_v4l2_err("[%d] ctx->type=%d, cmd=%d,
> > wait_event_interruptible_timeout interrupted by a signal %d %d",
> > - ctx->id, ctx->type, command, ctx-
> > >int_cond,
> > - ctx->int_type);
> > status = -1;
> > + mtk_v4l2_err("[%d] cmd=%d, type=%d, dec inter fail (%d
> > %d)",
> > + ctx->id, command, ctx->type,
> > + ctx->int_cond[hw_id], ctx-
> > >int_type[hw_id]);
> > }
> >
> > - ctx->int_cond = 0;
> > - ctx->int_type = 0;
> > + ctx->int_cond[hw_id] = 0;
> > + ctx->int_type[hw_id] = 0;
> >
> > return status;
> > }
> > diff --git a/drivers/media/platform/mtk-vcodec/mtk_vcodec_intr.h
> > b/drivers/media/platform/mtk-vcodec/mtk_vcodec_intr.h
> > index 638cd1f3526a..2bf4cabfaa43 100644
> > --- a/drivers/media/platform/mtk-vcodec/mtk_vcodec_intr.h
> > +++ b/drivers/media/platform/mtk-vcodec/mtk_vcodec_intr.h
> > @@ -12,7 +12,7 @@
> > struct mtk_vcodec_ctx;
> >
> > /* timeout is ms */
> > -int mtk_vcodec_wait_for_done_ctx(struct mtk_vcodec_ctx *data, int
> > command,
> > - unsigned int timeout_ms);
> > +int mtk_vcodec_wait_for_done_ctx(struct mtk_vcodec_ctx *ctx,
> > + int command, unsigned int timeout_ms,
> > unsigned int hw_id);
> >
> > #endif /* _MTK_VCODEC_INTR_H_ */
> > diff --git a/drivers/media/platform/mtk-vcodec/vdec/vdec_h264_if.c
> > b/drivers/media/platform/mtk-vcodec/vdec/vdec_h264_if.c
> > index 40d6e6c5ac7a..481655bb6016 100644
> > --- a/drivers/media/platform/mtk-vcodec/vdec/vdec_h264_if.c
> > +++ b/drivers/media/platform/mtk-vcodec/vdec/vdec_h264_if.c
> > @@ -413,7 +413,7 @@ static int vdec_h264_decode(void *h_vdec,
> > struct mtk_vcodec_mem *bs,
> > /* wait decoder done interrupt */
> > err = mtk_vcodec_wait_for_done_ctx(inst->ctx,
> > MTK_INST_IRQ_RECEIVE
> > D,
> > - WAIT_INTR_TIMEOUT_MS
> > );
> > + WAIT_INTR_TIMEOUT_MS
> > , 0);
> > if (err)
> > goto err_free_fb_out;
> >
> > diff --git a/drivers/media/platform/mtk-
> > vcodec/vdec/vdec_h264_req_if.c b/drivers/media/platform/mtk-
> > vcodec/vdec/vdec_h264_req_if.c
> > index 4dde9ee786b4..d23baa364246 100644
> > --- a/drivers/media/platform/mtk-vcodec/vdec/vdec_h264_req_if.c
> > +++ b/drivers/media/platform/mtk-vcodec/vdec/vdec_h264_req_if.c
> > @@ -724,7 +724,7 @@ static int vdec_h264_slice_decode(void *h_vdec,
> > struct mtk_vcodec_mem *bs,
> > /* wait decoder done interrupt */
> > err = mtk_vcodec_wait_for_done_ctx(inst->ctx,
> > MTK_INST_IRQ_RECEIVED,
> > - WAIT_INTR_TIMEOUT_MS);
> > + WAIT_INTR_TIMEOUT_MS, 0);
> > if (err)
> > goto err_free_fb_out;
> > vpu_dec_end(vpu);
> > diff --git a/drivers/media/platform/mtk-vcodec/vdec/vdec_vp8_if.c
> > b/drivers/media/platform/mtk-vcodec/vdec/vdec_vp8_if.c
> > index e5393f841080..88c046731754 100644
> > --- a/drivers/media/platform/mtk-vcodec/vdec/vdec_vp8_if.c
> > +++ b/drivers/media/platform/mtk-vcodec/vdec/vdec_vp8_if.c
> > @@ -488,7 +488,7 @@ static int vdec_vp8_decode(void *h_vdec, struct
> > mtk_vcodec_mem *bs,
> >
> > /* wait decoder done interrupt */
> > mtk_vcodec_wait_for_done_ctx(inst->ctx, MTK_INST_IRQ_RECEIVED,
> > - WAIT_INTR_TIMEOUT_MS);
> > + WAIT_INTR_TIMEOUT_MS, 0);
> >
> > if (inst->vsi->load_data)
> > load_dec_table(inst);
> > diff --git a/drivers/media/platform/mtk-vcodec/vdec/vdec_vp9_if.c
> > b/drivers/media/platform/mtk-vcodec/vdec/vdec_vp9_if.c
> > index 71cdc3ddafcb..70b8383f7c8e 100644
> > --- a/drivers/media/platform/mtk-vcodec/vdec/vdec_vp9_if.c
> > +++ b/drivers/media/platform/mtk-vcodec/vdec/vdec_vp9_if.c
> > @@ -539,7 +539,7 @@ static bool vp9_wait_dec_end(struct
> > vdec_vp9_inst *inst)
> >
> > mtk_vcodec_wait_for_done_ctx(inst->ctx,
> > MTK_INST_IRQ_RECEIVED,
> > - WAIT_INTR_TIMEOUT_MS);
> > + WAIT_INTR_TIMEOUT_MS, 0);
> >
> > if (ctx->irq_status & MTK_VDEC_IRQ_STATUS_DEC_SUCCESS)
> > return true;
> > diff --git a/drivers/media/platform/mtk-vcodec/venc/venc_h264_if.c
> > b/drivers/media/platform/mtk-vcodec/venc/venc_h264_if.c
> > index b6a4f2074fa5..9ae1bd8dbc32 100644
> > --- a/drivers/media/platform/mtk-vcodec/venc/venc_h264_if.c
> > +++ b/drivers/media/platform/mtk-vcodec/venc/venc_h264_if.c
> > @@ -335,7 +335,7 @@ static unsigned int
> > h264_enc_wait_venc_done(struct venc_h264_inst *inst)
> > struct mtk_vcodec_ctx *ctx = (struct mtk_vcodec_ctx *)inst-
> > >ctx;
> >
> > if (!mtk_vcodec_wait_for_done_ctx(ctx, MTK_INST_IRQ_RECEIVED,
> > - WAIT_INTR_TIMEOUT_MS)) {
> > + WAIT_INTR_TIMEOUT_MS, 0)) {
> > irq_status = ctx->irq_status;
> > mtk_vcodec_debug(inst, "irq_status %x <-", irq_status);
> > }
> > diff --git a/drivers/media/platform/mtk-vcodec/venc/venc_vp8_if.c
> > b/drivers/media/platform/mtk-vcodec/venc/venc_vp8_if.c
> > index 8267a9c4fd25..f96564277577 100644
> > --- a/drivers/media/platform/mtk-vcodec/venc/venc_vp8_if.c
> > +++ b/drivers/media/platform/mtk-vcodec/venc/venc_vp8_if.c
> > @@ -222,7 +222,7 @@ static unsigned int
> > vp8_enc_wait_venc_done(struct venc_vp8_inst *inst)
> > struct mtk_vcodec_ctx *ctx = (struct mtk_vcodec_ctx *)inst-
> > >ctx;
> >
> > if (!mtk_vcodec_wait_for_done_ctx(ctx, MTK_INST_IRQ_RECEIVED,
> > - WAIT_INTR_TIMEOUT_MS)) {
> > + WAIT_INTR_TIMEOUT_MS, 0)) {
> > irq_status = ctx->irq_status;
> > mtk_vcodec_debug(inst, "isr return %x", irq_status);
> > }
> >
Thanks,
Yunfei Dong
More information about the Linux-mediatek
mailing list