kopia lustrzana https://github.com/OpenRTX/OpenRTX
Audio codec: using a single condition variable for queue wait management.
rodzic
dd118d0a87
commit
5b3e136127
|
@ -38,8 +38,7 @@ static bool running;
|
||||||
static bool reqStop;
|
static bool reqStop;
|
||||||
static pthread_t codecThread;
|
static pthread_t codecThread;
|
||||||
static pthread_mutex_t mutex;
|
static pthread_mutex_t mutex;
|
||||||
static pthread_cond_t not_empty;
|
static pthread_cond_t wakeup_cond;
|
||||||
static pthread_cond_t not_full;
|
|
||||||
|
|
||||||
static uint8_t readPos;
|
static uint8_t readPos;
|
||||||
static uint8_t writePos;
|
static uint8_t writePos;
|
||||||
|
@ -81,8 +80,7 @@ void codec_init()
|
||||||
memset(dataBuffer, 0x00, BUF_SIZE * sizeof(uint64_t));
|
memset(dataBuffer, 0x00, BUF_SIZE * sizeof(uint64_t));
|
||||||
|
|
||||||
pthread_mutex_init(&mutex, NULL);
|
pthread_mutex_init(&mutex, NULL);
|
||||||
pthread_cond_init(¬_empty, NULL);
|
pthread_cond_init(&wakeup_cond, NULL);
|
||||||
pthread_cond_init(¬_full, NULL);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void codec_terminate()
|
void codec_terminate()
|
||||||
|
@ -95,8 +93,7 @@ void codec_terminate()
|
||||||
if(running) stopThread();
|
if(running) stopThread();
|
||||||
|
|
||||||
pthread_mutex_destroy(&mutex);
|
pthread_mutex_destroy(&mutex);
|
||||||
pthread_cond_destroy(¬_empty);
|
pthread_cond_destroy(&wakeup_cond);
|
||||||
pthread_cond_destroy(¬_full);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
bool codec_startEncode(const pathId path)
|
bool codec_startEncode(const pathId path)
|
||||||
|
@ -167,7 +164,7 @@ int codec_popFrame(uint8_t *frame, const bool blocking)
|
||||||
pthread_mutex_lock(&mutex);
|
pthread_mutex_lock(&mutex);
|
||||||
while(numElements == 0)
|
while(numElements == 0)
|
||||||
{
|
{
|
||||||
pthread_cond_wait(¬_empty, &mutex);
|
pthread_cond_wait(&wakeup_cond, &mutex);
|
||||||
}
|
}
|
||||||
|
|
||||||
element = dataBuffer[readPos];
|
element = dataBuffer[readPos];
|
||||||
|
@ -201,7 +198,7 @@ int codec_pushFrame(const uint8_t *frame, const bool blocking)
|
||||||
pthread_mutex_lock(&mutex);
|
pthread_mutex_lock(&mutex);
|
||||||
while(numElements >= BUF_SIZE)
|
while(numElements >= BUF_SIZE)
|
||||||
{
|
{
|
||||||
pthread_cond_wait(¬_full, &mutex);
|
pthread_cond_wait(&wakeup_cond, &mutex);
|
||||||
}
|
}
|
||||||
|
|
||||||
// There is free space, push data into the queue
|
// There is free space, push data into the queue
|
||||||
|
@ -278,8 +275,11 @@ static void *encodeFunc(void *arg)
|
||||||
dataBuffer[writePos] = frame;
|
dataBuffer[writePos] = frame;
|
||||||
writePos = (writePos + 1) % BUF_SIZE;
|
writePos = (writePos + 1) % BUF_SIZE;
|
||||||
|
|
||||||
if(numElements == 0) pthread_cond_signal(¬_empty);
|
if(numElements == 0)
|
||||||
if(numElements < BUF_SIZE) numElements += 1;
|
pthread_cond_signal(&wakeup_cond);
|
||||||
|
|
||||||
|
if(numElements < BUF_SIZE)
|
||||||
|
numElements += 1;
|
||||||
|
|
||||||
pthread_mutex_unlock(&mutex);
|
pthread_mutex_unlock(&mutex);
|
||||||
}
|
}
|
||||||
|
@ -332,7 +332,9 @@ static void *decodeFunc(void *arg)
|
||||||
{
|
{
|
||||||
frame = dataBuffer[readPos];
|
frame = dataBuffer[readPos];
|
||||||
readPos = (readPos + 1) % BUF_SIZE;
|
readPos = (readPos + 1) % BUF_SIZE;
|
||||||
if(numElements >= BUF_SIZE) pthread_cond_signal(¬_full);
|
if(numElements >= BUF_SIZE)
|
||||||
|
pthread_cond_signal(&wakeup_cond);
|
||||||
|
|
||||||
numElements -= 1;
|
numElements -= 1;
|
||||||
newData = true;
|
newData = true;
|
||||||
}
|
}
|
||||||
|
|
Ładowanie…
Reference in New Issue