68 lines
1.7 KiB
C
68 lines
1.7 KiB
C
// SPDX-License-Identifier: GPL-2.0
|
|
|
|
#include "mtk_vcodec_fw.h"
|
|
#include "mtk_vcodec_fw_priv.h"
|
|
#include "mtk_vcodec_util.h"
|
|
#include "mtk_vcodec_drv.h"
|
|
|
|
struct mtk_vcodec_fw *mtk_vcodec_fw_select(struct mtk_vcodec_dev *dev,
|
|
enum mtk_vcodec_fw_type type,
|
|
enum mtk_vcodec_fw_use fw_use)
|
|
{
|
|
switch (type) {
|
|
case VPU:
|
|
return mtk_vcodec_fw_vpu_init(dev, fw_use);
|
|
case SCP:
|
|
return mtk_vcodec_fw_scp_init(dev);
|
|
default:
|
|
mtk_v4l2_err("invalid vcodec fw type");
|
|
return ERR_PTR(-EINVAL);
|
|
}
|
|
}
|
|
EXPORT_SYMBOL_GPL(mtk_vcodec_fw_select);
|
|
|
|
void mtk_vcodec_fw_release(struct mtk_vcodec_fw *fw)
|
|
{
|
|
fw->ops->release(fw);
|
|
}
|
|
EXPORT_SYMBOL_GPL(mtk_vcodec_fw_release);
|
|
|
|
int mtk_vcodec_fw_load_firmware(struct mtk_vcodec_fw *fw)
|
|
{
|
|
return fw->ops->load_firmware(fw);
|
|
}
|
|
EXPORT_SYMBOL_GPL(mtk_vcodec_fw_load_firmware);
|
|
|
|
unsigned int mtk_vcodec_fw_get_vdec_capa(struct mtk_vcodec_fw *fw)
|
|
{
|
|
return fw->ops->get_vdec_capa(fw);
|
|
}
|
|
EXPORT_SYMBOL_GPL(mtk_vcodec_fw_get_vdec_capa);
|
|
|
|
unsigned int mtk_vcodec_fw_get_venc_capa(struct mtk_vcodec_fw *fw)
|
|
{
|
|
return fw->ops->get_venc_capa(fw);
|
|
}
|
|
EXPORT_SYMBOL_GPL(mtk_vcodec_fw_get_venc_capa);
|
|
|
|
void *mtk_vcodec_fw_map_dm_addr(struct mtk_vcodec_fw *fw, u32 mem_addr)
|
|
{
|
|
return fw->ops->map_dm_addr(fw, mem_addr);
|
|
}
|
|
EXPORT_SYMBOL_GPL(mtk_vcodec_fw_map_dm_addr);
|
|
|
|
int mtk_vcodec_fw_ipi_register(struct mtk_vcodec_fw *fw, int id,
|
|
mtk_vcodec_ipi_handler handler,
|
|
const char *name, void *priv)
|
|
{
|
|
return fw->ops->ipi_register(fw, id, handler, name, priv);
|
|
}
|
|
EXPORT_SYMBOL_GPL(mtk_vcodec_fw_ipi_register);
|
|
|
|
int mtk_vcodec_fw_ipi_send(struct mtk_vcodec_fw *fw, int id, void *buf,
|
|
unsigned int len, unsigned int wait)
|
|
{
|
|
return fw->ops->ipi_send(fw, id, buf, len, wait);
|
|
}
|
|
EXPORT_SYMBOL_GPL(mtk_vcodec_fw_ipi_send);
|