1 // SPDX-License-Identifier: GPL-2.0
3 * Copyright (c) 2016 MediaTek Inc.
4 * Author: PC Chen <pc.chen@mediatek.com>
5 * Tiffany Lin <tiffany.lin@mediatek.com>
8 #include <linux/interrupt.h>
9 #include <linux/kernel.h>
10 #include <linux/slab.h>
12 #include "vdec_drv_if.h"
13 #include "mtk_vcodec_dec.h"
14 #include "vdec_drv_base.h"
15 #include "mtk_vcodec_dec_pm.h"
18 int vdec_if_init(struct mtk_vcodec_ctx
*ctx
, unsigned int fourcc
)
23 case V4L2_PIX_FMT_H264
:
24 ctx
->dec_if
= &vdec_h264_if
;
26 case V4L2_PIX_FMT_VP8
:
27 ctx
->dec_if
= &vdec_vp8_if
;
29 case V4L2_PIX_FMT_VP9
:
30 ctx
->dec_if
= &vdec_vp9_if
;
37 mtk_vcodec_dec_clock_on(&ctx
->dev
->pm
);
38 ret
= ctx
->dec_if
->init(ctx
);
39 mtk_vcodec_dec_clock_off(&ctx
->dev
->pm
);
45 int vdec_if_decode(struct mtk_vcodec_ctx
*ctx
, struct mtk_vcodec_mem
*bs
,
46 struct vdec_fb
*fb
, bool *res_chg
)
51 if ((bs
->dma_addr
& 63) != 0) {
52 mtk_v4l2_err("bs dma_addr should 64 byte align");
58 if (((fb
->base_y
.dma_addr
& 511) != 0) ||
59 ((fb
->base_c
.dma_addr
& 511) != 0)) {
60 mtk_v4l2_err("frame buffer dma_addr should 512 byte align");
70 mtk_vcodec_set_curr_ctx(ctx
->dev
, ctx
);
71 mtk_vcodec_dec_clock_on(&ctx
->dev
->pm
);
72 enable_irq(ctx
->dev
->dec_irq
);
73 ret
= ctx
->dec_if
->decode(ctx
->drv_handle
, bs
, fb
, res_chg
);
74 disable_irq(ctx
->dev
->dec_irq
);
75 mtk_vcodec_dec_clock_off(&ctx
->dev
->pm
);
76 mtk_vcodec_set_curr_ctx(ctx
->dev
, NULL
);
83 int vdec_if_get_param(struct mtk_vcodec_ctx
*ctx
, enum vdec_get_param_type type
,
92 ret
= ctx
->dec_if
->get_param(ctx
->drv_handle
, type
, out
);
98 void vdec_if_deinit(struct mtk_vcodec_ctx
*ctx
)
100 if (!ctx
->drv_handle
)
104 mtk_vcodec_dec_clock_on(&ctx
->dev
->pm
);
105 ctx
->dec_if
->deinit(ctx
->drv_handle
);
106 mtk_vcodec_dec_clock_off(&ctx
->dev
->pm
);
107 mtk_vdec_unlock(ctx
);
109 ctx
->drv_handle
= NULL
;