mirror of
https://github.com/nyanmisaka/mpp.git
synced 2025-10-06 01:26:49 +08:00
[mpp]: add hal and dec module to mpp
git-svn-id: https://10.10.10.66:8443/svn/MediaProcessPlatform/trunk/mpp@194 6e48237b-75ef-9749-8fc9-41990f28c85a
This commit is contained in:
@@ -72,7 +72,8 @@ typedef struct {
|
|||||||
typedef void* MppHalCtx;
|
typedef void* MppHalCtx;
|
||||||
|
|
||||||
typedef struct MppHalCfg_t {
|
typedef struct MppHalCfg_t {
|
||||||
RK_U32 size;
|
MppCtxType type;
|
||||||
|
MppCodingType coding;
|
||||||
} MppHalCfg;
|
} MppHalCfg;
|
||||||
|
|
||||||
|
|
||||||
@@ -109,12 +110,12 @@ extern "C" {
|
|||||||
|
|
||||||
void *mpp_hal_thread(void *data);
|
void *mpp_hal_thread(void *data);
|
||||||
|
|
||||||
MPP_RET mpp_hal_init(MppHal *ctx, MppHalCfg cfg);
|
MPP_RET mpp_hal_init(MppHal **ctx, MppHalCfg *cfg);
|
||||||
MPP_RET mpp_hal_deinit(MppHal ctx);
|
MPP_RET mpp_hal_deinit(MppHal *ctx);
|
||||||
|
|
||||||
MPP_RET mpp_hal_reg_gen(MppHal ctx, MppHalDecTask task);
|
MPP_RET mpp_hal_reg_gen(MppHal *ctx, MppHalDecTask *task);
|
||||||
MPP_RET mpp_hal_hw_start(MppHal ctx, MppHalDecTask task);
|
MPP_RET mpp_hal_hw_start(MppHal *ctx, MppHalDecTask *task);
|
||||||
MPP_RET mpp_hal_hw_wait(MppHal ctx, MppHalDecTask task);
|
MPP_RET mpp_hal_hw_wait(MppHal *ctx, MppHalDecTask *task);
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
}
|
}
|
||||||
|
@@ -16,6 +16,7 @@
|
|||||||
|
|
||||||
#define MODULE_TAG "mpp_hal"
|
#define MODULE_TAG "mpp_hal"
|
||||||
|
|
||||||
|
#include "mpp_mem.h"
|
||||||
#include "mpp_log.h"
|
#include "mpp_log.h"
|
||||||
|
|
||||||
#include "mpp.h"
|
#include "mpp.h"
|
||||||
@@ -82,3 +83,38 @@ void *mpp_hal_thread(void *data)
|
|||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
MPP_RET mpp_hal_init(MppHal **ctx, MppHalCfg *cfg)
|
||||||
|
{
|
||||||
|
*ctx = mpp_malloc(MppHal, 1);
|
||||||
|
(void)cfg;
|
||||||
|
return MPP_OK;
|
||||||
|
}
|
||||||
|
|
||||||
|
MPP_RET mpp_hal_deinit(MppHal *ctx)
|
||||||
|
{
|
||||||
|
mpp_free(ctx);
|
||||||
|
return MPP_OK;
|
||||||
|
}
|
||||||
|
|
||||||
|
MPP_RET mpp_hal_reg_gen(MppHal *ctx, MppHalDecTask *task)
|
||||||
|
{
|
||||||
|
(void)ctx;
|
||||||
|
(void)task;
|
||||||
|
return MPP_OK;
|
||||||
|
}
|
||||||
|
|
||||||
|
MPP_RET mpp_hal_hw_start(MppHal *ctx, MppHalDecTask *task)
|
||||||
|
{
|
||||||
|
(void)ctx;
|
||||||
|
(void)task;
|
||||||
|
return MPP_OK;
|
||||||
|
}
|
||||||
|
|
||||||
|
MPP_RET mpp_hal_hw_wait(MppHal *ctx, MppHalDecTask *task)
|
||||||
|
{
|
||||||
|
(void)ctx;
|
||||||
|
(void)task;
|
||||||
|
return MPP_OK;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
30
mpp/mpp.cpp
30
mpp/mpp.cpp
@@ -46,6 +46,8 @@ Mpp::Mpp(MppCtxType type, MppCodingType coding)
|
|||||||
mInternalGroup(NULL),
|
mInternalGroup(NULL),
|
||||||
mPacketGroup(NULL),
|
mPacketGroup(NULL),
|
||||||
mFrameGroup(NULL),
|
mFrameGroup(NULL),
|
||||||
|
mDec(NULL),
|
||||||
|
mHal(NULL),
|
||||||
mTheadCodec(NULL),
|
mTheadCodec(NULL),
|
||||||
mThreadHal(NULL),
|
mThreadHal(NULL),
|
||||||
mType(type),
|
mType(type),
|
||||||
@@ -60,8 +62,16 @@ Mpp::Mpp(MppCtxType type, MppCodingType coding)
|
|||||||
mPackets = new mpp_list((node_destructor)NULL);
|
mPackets = new mpp_list((node_destructor)NULL);
|
||||||
mFrames = new mpp_list((node_destructor)mpp_frame_deinit);
|
mFrames = new mpp_list((node_destructor)mpp_frame_deinit);
|
||||||
mTasks = new mpp_list((node_destructor)NULL);
|
mTasks = new mpp_list((node_destructor)NULL);
|
||||||
|
|
||||||
|
mpp_dec_init(&mDec, coding);
|
||||||
|
MppHalCfg cfg = {
|
||||||
|
type,
|
||||||
|
coding,
|
||||||
|
};
|
||||||
|
mpp_hal_init(&mHal, &cfg);
|
||||||
mTheadCodec = new MppThread(mpp_dec_thread, this);
|
mTheadCodec = new MppThread(mpp_dec_thread, this);
|
||||||
mThreadHal = new MppThread(mpp_hal_thread, this);
|
mThreadHal = new MppThread(mpp_hal_thread, this);
|
||||||
|
|
||||||
mTask = mpp_malloc(MppHalDecTask*, mTaskNum);
|
mTask = mpp_malloc(MppHalDecTask*, mTaskNum);
|
||||||
mpp_buffer_group_normal_get(&mInternalGroup, MPP_BUFFER_TYPE_ION);
|
mpp_buffer_group_normal_get(&mInternalGroup, MPP_BUFFER_TYPE_ION);
|
||||||
mpp_buffer_group_normal_get(&mPacketGroup, MPP_BUFFER_TYPE_NORMAL);
|
mpp_buffer_group_normal_get(&mPacketGroup, MPP_BUFFER_TYPE_NORMAL);
|
||||||
@@ -72,8 +82,16 @@ Mpp::Mpp(MppCtxType type, MppCodingType coding)
|
|||||||
mFrames = new mpp_list((node_destructor)NULL);
|
mFrames = new mpp_list((node_destructor)NULL);
|
||||||
mPackets = new mpp_list((node_destructor)mpp_packet_deinit);
|
mPackets = new mpp_list((node_destructor)mpp_packet_deinit);
|
||||||
mTasks = new mpp_list((node_destructor)NULL);
|
mTasks = new mpp_list((node_destructor)NULL);
|
||||||
|
|
||||||
|
mpp_dec_init(&mDec, coding);
|
||||||
|
MppHalCfg cfg = {
|
||||||
|
type,
|
||||||
|
coding,
|
||||||
|
};
|
||||||
|
mpp_hal_init(&mHal, &cfg);
|
||||||
mTheadCodec = new MppThread(mpp_enc_thread, this);
|
mTheadCodec = new MppThread(mpp_enc_thread, this);
|
||||||
mThreadHal = new MppThread(mpp_hal_thread, this);
|
mThreadHal = new MppThread(mpp_hal_thread, this);
|
||||||
|
|
||||||
mTask = mpp_malloc(MppHalDecTask*, mTaskNum);
|
mTask = mpp_malloc(MppHalDecTask*, mTaskNum);
|
||||||
mpp_buffer_group_normal_get(&mInternalGroup, MPP_BUFFER_TYPE_ION);
|
mpp_buffer_group_normal_get(&mInternalGroup, MPP_BUFFER_TYPE_ION);
|
||||||
mpp_buffer_group_normal_get(&mPacketGroup, MPP_BUFFER_TYPE_NORMAL);
|
mpp_buffer_group_normal_get(&mPacketGroup, MPP_BUFFER_TYPE_NORMAL);
|
||||||
@@ -85,6 +103,7 @@ Mpp::Mpp(MppCtxType type, MppCodingType coding)
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (mFrames && mPackets && mTask &&
|
if (mFrames && mPackets && mTask &&
|
||||||
|
mDec && mHal &&
|
||||||
mTheadCodec && mThreadHal &&
|
mTheadCodec && mThreadHal &&
|
||||||
mPacketGroup && mFrameGroup) {
|
mPacketGroup && mFrameGroup) {
|
||||||
mTheadCodec->start();
|
mTheadCodec->start();
|
||||||
@@ -115,6 +134,17 @@ void Mpp::clear()
|
|||||||
delete mThreadHal;
|
delete mThreadHal;
|
||||||
mThreadHal = NULL;
|
mThreadHal = NULL;
|
||||||
}
|
}
|
||||||
|
if (mDec) {
|
||||||
|
if (mType == MPP_CTX_DEC)
|
||||||
|
mpp_dec_deinit(mDec);
|
||||||
|
else
|
||||||
|
mpp_dec_deinit(mDec);
|
||||||
|
mDec = NULL;
|
||||||
|
}
|
||||||
|
if (mHal) {
|
||||||
|
mpp_hal_deinit(mHal);
|
||||||
|
mHal = NULL;
|
||||||
|
}
|
||||||
if (mPackets) {
|
if (mPackets) {
|
||||||
delete mPackets;
|
delete mPackets;
|
||||||
mPackets = NULL;
|
mPackets = NULL;
|
||||||
|
@@ -77,7 +77,9 @@ public:
|
|||||||
|
|
||||||
RK_U32 mStatus;
|
RK_U32 mStatus;
|
||||||
|
|
||||||
void *mCodec;
|
union {
|
||||||
|
MppDecCtx *mDec;
|
||||||
|
};
|
||||||
MppHal *mHal;
|
MppHal *mHal;
|
||||||
|
|
||||||
// decoder context
|
// decoder context
|
||||||
|
@@ -415,5 +415,5 @@ typedef struct h264d_syntax_t {
|
|||||||
DXVA2_DecodeBufferDesc *buf;
|
DXVA2_DecodeBufferDesc *buf;
|
||||||
} H264D_Syntax_t;
|
} H264D_Syntax_t;
|
||||||
|
|
||||||
#endif /* end of __H264D_SYNTAX_H__ */
|
#endif /*__H264D_SYNTAX_H__*/
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user