mirror of
https://github.com/Evolution-X-Devices/hardware_samsung_slsi-linaro_openmax
synced 2026-01-27 11:13:30 +00:00
Change-Id: I79380bc91acf57ca5f3e56fb64af76f4c45f6566 Signed-off-by: Sam Protsenko <joe.skb7@gmail.com>
202 lines
5.2 KiB
C
202 lines
5.2 KiB
C
/*
|
|
*
|
|
* Copyright 2012 Samsung 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.
|
|
*/
|
|
|
|
/*
|
|
* @file Exynos_OSAL_Queue.c
|
|
* @brief
|
|
* @author SeungBeom Kim (sbcrux.kim@samsung.com)
|
|
* @version 2.0.0
|
|
* @history
|
|
* 2012.02.20 : Create
|
|
*/
|
|
|
|
|
|
#include <stdio.h>
|
|
#include <stdlib.h>
|
|
#include <string.h>
|
|
|
|
#include "Exynos_OSAL_Memory.h"
|
|
#include "Exynos_OSAL_Mutex.h"
|
|
#include "Exynos_OSAL_Queue.h"
|
|
|
|
|
|
OMX_ERRORTYPE Exynos_OSAL_QueueCreate(EXYNOS_QUEUE *queueHandle, int maxNumElem)
|
|
{
|
|
int i = 0;
|
|
EXYNOS_QElem *newqelem = NULL;
|
|
EXYNOS_QElem *currentqelem = NULL;
|
|
EXYNOS_QUEUE *queue = (EXYNOS_QUEUE *)queueHandle;
|
|
|
|
OMX_ERRORTYPE ret = OMX_ErrorNone;
|
|
|
|
if (!queue)
|
|
return OMX_ErrorBadParameter;
|
|
|
|
ret = Exynos_OSAL_MutexCreate(&queue->qMutex);
|
|
if (ret != OMX_ErrorNone)
|
|
return ret;
|
|
|
|
queue->first = (EXYNOS_QElem *)Exynos_OSAL_Malloc(sizeof(EXYNOS_QElem));
|
|
if (queue->first == NULL)
|
|
return OMX_ErrorInsufficientResources;
|
|
|
|
Exynos_OSAL_Memset(queue->first, 0, sizeof(EXYNOS_QElem));
|
|
currentqelem = queue->last = queue->first;
|
|
queue->numElem = 0;
|
|
queue->maxNumElem = maxNumElem;
|
|
for (i = 0; i < (queue->maxNumElem - 2); i++) {
|
|
newqelem = (EXYNOS_QElem *)Exynos_OSAL_Malloc(sizeof(EXYNOS_QElem));
|
|
if (newqelem == NULL) {
|
|
while (queue->first != NULL) {
|
|
currentqelem = queue->first->qNext;
|
|
Exynos_OSAL_Free((OMX_PTR)queue->first);
|
|
queue->first = currentqelem;
|
|
}
|
|
return OMX_ErrorInsufficientResources;
|
|
} else {
|
|
Exynos_OSAL_Memset(newqelem, 0, sizeof(EXYNOS_QElem));
|
|
currentqelem->qNext = newqelem;
|
|
currentqelem = newqelem;
|
|
}
|
|
}
|
|
|
|
currentqelem->qNext = queue->first;
|
|
|
|
return OMX_ErrorNone;
|
|
}
|
|
|
|
OMX_ERRORTYPE Exynos_OSAL_QueueTerminate(EXYNOS_QUEUE *queueHandle)
|
|
{
|
|
int i = 0;
|
|
EXYNOS_QElem *currentqelem = NULL;
|
|
EXYNOS_QUEUE *queue = (EXYNOS_QUEUE *)queueHandle;
|
|
OMX_ERRORTYPE ret = OMX_ErrorNone;
|
|
|
|
if (!queue)
|
|
return OMX_ErrorBadParameter;
|
|
|
|
for ( i = 0; i < (queue->maxNumElem - 2); i++) {
|
|
if (queue->first == NULL)
|
|
goto EXIT;
|
|
currentqelem = queue->first->qNext;
|
|
Exynos_OSAL_Free(queue->first);
|
|
queue->first = currentqelem;
|
|
}
|
|
|
|
if(queue->first) {
|
|
Exynos_OSAL_Free(queue->first);
|
|
queue->first = NULL;
|
|
}
|
|
|
|
EXIT:
|
|
ret = Exynos_OSAL_MutexTerminate(queue->qMutex);
|
|
queue->qMutex = NULL;
|
|
|
|
return ret;
|
|
}
|
|
|
|
int Exynos_OSAL_Queue(EXYNOS_QUEUE *queueHandle, void *data)
|
|
{
|
|
EXYNOS_QUEUE *queue = (EXYNOS_QUEUE *)queueHandle;
|
|
if (queue == NULL)
|
|
return -1;
|
|
|
|
Exynos_OSAL_MutexLock(queue->qMutex);
|
|
|
|
if ((queue->last == NULL) ||
|
|
(queue->last->data != NULL) ||
|
|
(queue->numElem >= queue->maxNumElem)) {
|
|
Exynos_OSAL_MutexUnlock(queue->qMutex);
|
|
return -1;
|
|
}
|
|
queue->last->data = data;
|
|
queue->last = queue->last->qNext;
|
|
queue->numElem++;
|
|
|
|
Exynos_OSAL_MutexUnlock(queue->qMutex);
|
|
return 0;
|
|
}
|
|
|
|
void *Exynos_OSAL_Dequeue(EXYNOS_QUEUE *queueHandle)
|
|
{
|
|
void *data = NULL;
|
|
EXYNOS_QUEUE *queue = (EXYNOS_QUEUE *)queueHandle;
|
|
if (queue == NULL)
|
|
return NULL;
|
|
|
|
Exynos_OSAL_MutexLock(queue->qMutex);
|
|
|
|
if ((queue->first->data == NULL) || (queue->numElem <= 0)) {
|
|
Exynos_OSAL_MutexUnlock(queue->qMutex);
|
|
return NULL;
|
|
}
|
|
data = queue->first->data;
|
|
queue->first->data = NULL;
|
|
queue->first = queue->first->qNext;
|
|
queue->numElem--;
|
|
|
|
Exynos_OSAL_MutexUnlock(queue->qMutex);
|
|
return data;
|
|
}
|
|
|
|
int Exynos_OSAL_GetElemNum(EXYNOS_QUEUE *queueHandle)
|
|
{
|
|
int ElemNum = 0;
|
|
EXYNOS_QUEUE *queue = (EXYNOS_QUEUE *)queueHandle;
|
|
if (queue == NULL)
|
|
return -1;
|
|
|
|
Exynos_OSAL_MutexLock(queue->qMutex);
|
|
ElemNum = queue->numElem;
|
|
Exynos_OSAL_MutexUnlock(queue->qMutex);
|
|
return ElemNum;
|
|
}
|
|
|
|
int Exynos_OSAL_SetElemNum(EXYNOS_QUEUE *queueHandle, int ElemNum)
|
|
{
|
|
EXYNOS_QUEUE *queue = (EXYNOS_QUEUE *)queueHandle;
|
|
if (queue == NULL)
|
|
return -1;
|
|
|
|
Exynos_OSAL_MutexLock(queue->qMutex);
|
|
queue->numElem = ElemNum;
|
|
Exynos_OSAL_MutexUnlock(queue->qMutex);
|
|
return ElemNum;
|
|
}
|
|
|
|
int Exynos_OSAL_ResetQueue(EXYNOS_QUEUE *queueHandle)
|
|
{
|
|
EXYNOS_QUEUE *queue = (EXYNOS_QUEUE *)queueHandle;
|
|
EXYNOS_QElem *currentqelem = NULL;
|
|
|
|
if (queue == NULL)
|
|
return -1;
|
|
|
|
Exynos_OSAL_MutexLock(queue->qMutex);
|
|
queue->first->data = NULL;
|
|
currentqelem = queue->first->qNext;
|
|
while (currentqelem != queue->first) {
|
|
currentqelem->data = NULL;
|
|
currentqelem = currentqelem->qNext;
|
|
}
|
|
queue->last = queue->first;
|
|
queue->numElem = 0x00;
|
|
Exynos_OSAL_MutexUnlock(queue->qMutex);
|
|
|
|
return 0;
|
|
}
|