[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:
ChenHengming
2008-01-25 15:26:32 +00:00
parent ef5a60731c
commit b6e93ab257
5 changed files with 77 additions and 8 deletions

View File

@@ -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
} }

View File

@@ -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;
}

View File

@@ -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;

View File

@@ -77,7 +77,9 @@ public:
RK_U32 mStatus; RK_U32 mStatus;
void *mCodec; union {
MppDecCtx *mDec;
};
MppHal *mHal; MppHal *mHal;
// decoder context // decoder context

View File

@@ -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__*/