mirror of
https://github.com/nyanmisaka/mpp.git
synced 2025-10-05 17:16:50 +08:00

git-svn-id: https://10.10.10.66:8443/svn/MediaProcessPlatform/trunk/mpp@165 6e48237b-75ef-9749-8fc9-41990f28c85a
106 lines
2.7 KiB
C++
106 lines
2.7 KiB
C++
/*
|
|
* Copyright 2010 Rockchip Electronics S.LSI Co. LTD
|
|
*
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
* you may not use this file except in compliance with the License.
|
|
* You may obtain a copy of the License at
|
|
*
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
*
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
* See the License for the specific language governing permissions and
|
|
* limitations under the License.
|
|
*/
|
|
|
|
#define MODULE_TAG "mpp_thread"
|
|
|
|
#include "mpp_log.h"
|
|
#include "mpp_thread.h"
|
|
|
|
#define MPP_THREAD_DBG_FUNCTION (0x00000001)
|
|
|
|
static RK_U32 thread_debug = 0;
|
|
|
|
#define thread_dbg(flag, fmt, ...) mpp_dbg(thread_debug, flag, fmt, ## __VA_ARGS__)
|
|
|
|
MppThread::MppThread(MppThreadFunc func, void *ctx)
|
|
: mStatus(MPP_THREAD_UNINITED),
|
|
mFunction(func),
|
|
mContext(ctx)
|
|
{
|
|
pthread_mutexattr_t attr;
|
|
pthread_mutexattr_init(&attr);
|
|
pthread_mutexattr_settype(&attr, PTHREAD_MUTEX_RECURSIVE);
|
|
pthread_mutex_init(&mLock, &attr);
|
|
pthread_mutexattr_destroy(&attr);
|
|
|
|
pthread_cond_init(&mCondition, NULL);
|
|
}
|
|
|
|
MppThread::~MppThread()
|
|
{
|
|
pthread_cond_destroy(&mCondition);
|
|
pthread_mutex_destroy(&mLock);
|
|
}
|
|
|
|
MppThreadStatus MppThread::get_status()
|
|
{
|
|
return mStatus;
|
|
}
|
|
void MppThread::set_status(MppThreadStatus status)
|
|
{
|
|
mStatus = status;
|
|
}
|
|
|
|
void MppThread::start()
|
|
{
|
|
pthread_attr_t attr;
|
|
pthread_attr_init(&attr);
|
|
pthread_attr_setdetachstate(&attr, PTHREAD_CREATE_JOINABLE);
|
|
|
|
if (MPP_THREAD_UNINITED == mStatus) {
|
|
// NOTE: set status here first to avoid unexpected loop quit racing condition
|
|
mStatus = MPP_THREAD_RUNNING;
|
|
if (0 == pthread_create(&mThread, &attr, mFunction, mContext))
|
|
thread_dbg(MPP_THREAD_DBG_FUNCTION, "mThread %p mContext %p create success\n",
|
|
mFunction, mContext);
|
|
else
|
|
mStatus = MPP_THREAD_UNINITED;
|
|
}
|
|
pthread_attr_destroy(&attr);
|
|
}
|
|
|
|
void MppThread::stop()
|
|
{
|
|
mStatus = MPP_THREAD_STOPPING;
|
|
void *dummy;
|
|
pthread_join(mThread, &dummy);
|
|
thread_dbg(MPP_THREAD_DBG_FUNCTION, "mThread %p mContext %p destroy success\n",
|
|
mFunction, mContext);
|
|
|
|
mStatus = MPP_THREAD_UNINITED;
|
|
}
|
|
|
|
void MppThread::lock()
|
|
{
|
|
pthread_mutex_lock(&mLock);
|
|
}
|
|
|
|
void MppThread::unlock()
|
|
{
|
|
pthread_mutex_unlock(&mLock);
|
|
}
|
|
|
|
void MppThread::wait()
|
|
{
|
|
pthread_cond_wait(&mCondition, &mLock);
|
|
}
|
|
|
|
void MppThread::signal()
|
|
{
|
|
pthread_cond_signal(&mCondition);
|
|
}
|
|
|