From 6b4a3770cd0749bfeb593a8c6213805fb6df65a0 Mon Sep 17 00:00:00 2001 From: Sebastian Huber Date: Fri, 19 Jul 2013 10:51:44 +0200 Subject: posix: Create barrier implementation header Move implementation specific parts of barrier.h and barrier.inl into new header file barrierimpl.h. The barrier.h contains now only the application visible API. --- cpukit/posix/inline/rtems/posix/barrier.inl | 96 ----------------------------- 1 file changed, 96 deletions(-) delete mode 100644 cpukit/posix/inline/rtems/posix/barrier.inl (limited to 'cpukit/posix/inline/rtems/posix') diff --git a/cpukit/posix/inline/rtems/posix/barrier.inl b/cpukit/posix/inline/rtems/posix/barrier.inl deleted file mode 100644 index 6e439d8c66..0000000000 --- a/cpukit/posix/inline/rtems/posix/barrier.inl +++ /dev/null @@ -1,96 +0,0 @@ -/** - * @file - * - * @brief Inlined Routines from the POSIX Barrier Manager - * - * This file contains the static inlin implementation of the inlined - * routines from the POSIX Barrier Manager. - */ - -/* - * COPYRIGHT (c) 1989-2011. - * On-Line Applications Research Corporation (OAR). - * - * The license and distribution terms for this file may be - * found in the file LICENSE in this distribution or at - * http://www.rtems.com/license/LICENSE. - */ - -#ifndef _RTEMS_POSIX_BARRIER_H -# error "Never use directly; include instead." -#endif - -#ifndef _RTEMS_POSIX_BARRIER_INL -#define _RTEMS_POSIX_BARRIER_INL - -#include - -/** - * @brief Allocate a barrier control block. - * - * This function allocates a barrier control block from - * the inactive chain of free barrier control blocks. - */ -RTEMS_INLINE_ROUTINE POSIX_Barrier_Control *_POSIX_Barrier_Allocate( void ) -{ - return (POSIX_Barrier_Control *) - _Objects_Allocate( &_POSIX_Barrier_Information ); -} - -/** - * @brief Free a barrier control block. - * - * This routine frees a barrier control block to the - * inactive chain of free barrier control blocks. - */ -RTEMS_INLINE_ROUTINE void _POSIX_Barrier_Free ( - POSIX_Barrier_Control *the_barrier -) -{ - _Objects_Free( &_POSIX_Barrier_Information, &the_barrier->Object ); -} - -/** - * @brief Get a barrier control block. - * - * This function maps barrier IDs to barrier control blocks. - * If ID corresponds to a local barrier, then it returns - * the_barrier control pointer which maps to ID and location - * is set to OBJECTS_LOCAL. if the barrier ID is global and - * resides on a remote node, then location is set to OBJECTS_REMOTE, - * and the_barrier is undefined. Otherwise, location is set - * to OBJECTS_ERROR and the_barrier is undefined. - */ -RTEMS_INLINE_ROUTINE POSIX_Barrier_Control *_POSIX_Barrier_Get ( - pthread_barrier_t *barrier, - Objects_Locations *location -) -{ - return (POSIX_Barrier_Control *) _Objects_Get( - &_POSIX_Barrier_Information, - (Objects_Id) *barrier, - location - ); -} - -/** - * @brief Check if a barrier control block is NULL. - * - * This function returns @c TRUE if the_barrier is @c NULL and @c FALSE - * otherwise. - * - * @param[in] the_barrier is the pointer to the barrier control block - * to be checked. - * - * @retval TRUE The barrier control block is @c NULL. - * @retval FALSE The barrier control block is not @c NULL. - */ -RTEMS_INLINE_ROUTINE bool _POSIX_Barrier_Is_null ( - POSIX_Barrier_Control *the_barrier -) -{ - return ( the_barrier == NULL ); -} - -#endif -/* end of include file */ -- cgit v1.2.3