2017-07-28 08:45:05 -07:00
|
|
|
/************************************************************************************//**
|
|
|
|
* \file port/linux/critutil.c
|
|
|
|
* \brief Critical section utility source file.
|
|
|
|
* \ingroup Utility
|
|
|
|
* \internal
|
|
|
|
*----------------------------------------------------------------------------------------
|
|
|
|
* C O P Y R I G H T
|
|
|
|
*----------------------------------------------------------------------------------------
|
|
|
|
* Copyright (c) 2017 by Feaser http://www.feaser.com All rights reserved
|
|
|
|
*
|
|
|
|
*----------------------------------------------------------------------------------------
|
|
|
|
* L I C E N S E
|
|
|
|
*----------------------------------------------------------------------------------------
|
|
|
|
* This file is part of OpenBLT. OpenBLT is free software: you can redistribute it and/or
|
|
|
|
* modify it under the terms of the GNU General Public License as published by the Free
|
|
|
|
* Software Foundation, either version 3 of the License, or (at your option) any later
|
|
|
|
* version.
|
|
|
|
*
|
|
|
|
* OpenBLT is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;
|
|
|
|
* without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
|
|
|
|
* PURPOSE. See the GNU General Public License for more details.
|
|
|
|
*
|
|
|
|
* You have received a copy of the GNU General Public License along with OpenBLT. It
|
|
|
|
* should be located in ".\Doc\license.html". If not, contact Feaser to obtain a copy.
|
|
|
|
*
|
|
|
|
* \endinternal
|
|
|
|
****************************************************************************************/
|
|
|
|
|
|
|
|
/****************************************************************************************
|
|
|
|
* Include files
|
|
|
|
****************************************************************************************/
|
2017-07-28 09:04:36 -07:00
|
|
|
#include <assert.h> /* for assertions */
|
2017-07-28 08:45:05 -07:00
|
|
|
#include <stdint.h> /* for standard integer types */
|
|
|
|
#include <stdbool.h> /* for boolean type */
|
|
|
|
#include <pthread.h> /* for posix threads */
|
|
|
|
#include "util.h" /* Utility module */
|
|
|
|
|
|
|
|
|
|
|
|
/****************************************************************************************
|
|
|
|
* Local data declarations
|
|
|
|
****************************************************************************************/
|
2017-07-28 09:04:36 -07:00
|
|
|
/** \brief Flag to determine if the critical section object was already initialized. */
|
2017-08-01 04:20:00 -07:00
|
|
|
static volatile bool criticalSectionInitialized = false;
|
2017-07-28 09:04:36 -07:00
|
|
|
|
|
|
|
/** \brief Critical section object. */
|
2017-08-01 04:20:00 -07:00
|
|
|
static volatile pthread_mutex_t mtxCritSect;
|
2017-07-28 09:04:36 -07:00
|
|
|
|
|
|
|
|
|
|
|
/************************************************************************************//**
|
|
|
|
** \brief Initializes the critical section module. Should be called before the
|
|
|
|
** Enter/Exit functions are used. It is okay to call this initialization
|
|
|
|
** multiple times from different modules.
|
|
|
|
**
|
|
|
|
****************************************************************************************/
|
|
|
|
void UtilCriticalSectionInit(void)
|
|
|
|
{
|
|
|
|
/* Only initialize if not yet done so previously. */
|
|
|
|
if (!criticalSectionInitialized)
|
|
|
|
{
|
|
|
|
/* Initialize the critical section object. */
|
2017-08-01 04:20:00 -07:00
|
|
|
(void)pthread_mutex_init((pthread_mutex_t *)&mtxCritSect, NULL);
|
2017-07-28 09:04:36 -07:00
|
|
|
/* Set initialized flag. */
|
|
|
|
criticalSectionInitialized = true;
|
|
|
|
}
|
|
|
|
} /*** end of UtilCriticalSectionInit ***/
|
|
|
|
|
|
|
|
|
|
|
|
/************************************************************************************//**
|
|
|
|
** \brief Terminates the critical section module. Should be called once critical
|
|
|
|
** sections are no longer needed. Typically called from another module's
|
|
|
|
** termination function that also initialized it. It is okay to call this
|
|
|
|
** termination multiple times from different modules.
|
|
|
|
**
|
|
|
|
****************************************************************************************/
|
|
|
|
void UtilCriticalSectionTerminate(void)
|
|
|
|
{
|
|
|
|
/* Only terminate if it was initialized. */
|
|
|
|
if (criticalSectionInitialized)
|
|
|
|
{
|
|
|
|
/* Reset the initialized flag. */
|
|
|
|
criticalSectionInitialized = false;
|
|
|
|
/* Delete the critical section object. */
|
2017-08-01 04:20:00 -07:00
|
|
|
(void)pthread_mutex_destroy((pthread_mutex_t *)&mtxCritSect);
|
2017-07-28 09:04:36 -07:00
|
|
|
}
|
|
|
|
} /*** end of UtilCriticalSectionTerminate ***/
|
|
|
|
|
2017-07-28 08:45:05 -07:00
|
|
|
|
|
|
|
|
|
|
|
/************************************************************************************//**
|
|
|
|
** \brief Enters a critical section. The functions UtilCriticalSectionEnter and
|
|
|
|
** UtilCriticalSectionExit should always be used in a pair.
|
|
|
|
**
|
|
|
|
****************************************************************************************/
|
|
|
|
void UtilCriticalSectionEnter(void)
|
|
|
|
{
|
2017-07-28 09:04:36 -07:00
|
|
|
/* Check initialization. */
|
|
|
|
assert(criticalSectionInitialized);
|
|
|
|
|
|
|
|
/* Only continue if actually initialized. */
|
|
|
|
if (criticalSectionInitialized)
|
|
|
|
{
|
2017-08-01 04:20:00 -07:00
|
|
|
(void)pthread_mutex_lock((pthread_mutex_t *)&mtxCritSect);
|
2017-07-28 09:04:36 -07:00
|
|
|
}
|
2017-07-28 10:19:21 -07:00
|
|
|
} /*** end of UtilCriticalSectionEnter ***/ /*lint !e456 !e454 */
|
2017-07-28 08:45:05 -07:00
|
|
|
|
|
|
|
|
|
|
|
/************************************************************************************//**
|
|
|
|
** \brief Leaves a critical section. The functions UtilCriticalSectionEnter and
|
|
|
|
** UtilCriticalSectionExit should always be used in a pair.
|
|
|
|
**
|
|
|
|
****************************************************************************************/
|
|
|
|
void UtilCriticalSectionExit(void)
|
|
|
|
{
|
2017-07-28 09:04:36 -07:00
|
|
|
/* Check initialization. */
|
|
|
|
assert(criticalSectionInitialized);
|
|
|
|
|
|
|
|
/* Only continue if actually initialized. */
|
|
|
|
if (criticalSectionInitialized)
|
|
|
|
{
|
2017-08-01 04:20:00 -07:00
|
|
|
(void)pthread_mutex_unlock((pthread_mutex_t *)&mtxCritSect); /*lint !e455 */
|
2017-07-28 09:04:36 -07:00
|
|
|
}
|
2017-07-28 08:45:05 -07:00
|
|
|
} /*** end of UtilCriticalSectionExit ***/
|
|
|
|
|
|
|
|
|
|
|
|
/*********************************** end of critutil.c *********************************/
|
|
|
|
|