From eb448eece9305b2bba641471a428af4dad97effc Mon Sep 17 00:00:00 2001 From: Sebastian Huber Date: Fri, 19 Jul 2013 15:18:08 +0200 Subject: posix: Create spinlock implementation header Move implementation specific parts of spinlock.h and spinlock.inl into new header file spinlockimpl.h. The spinlock.h contains now only the application visible API. --- cpukit/posix/inline/rtems/posix/spinlock.inl | 96 ---------------------------- 1 file changed, 96 deletions(-) delete mode 100644 cpukit/posix/inline/rtems/posix/spinlock.inl (limited to 'cpukit/posix/inline/rtems/posix') diff --git a/cpukit/posix/inline/rtems/posix/spinlock.inl b/cpukit/posix/inline/rtems/posix/spinlock.inl deleted file mode 100644 index b8ababda02..0000000000 --- a/cpukit/posix/inline/rtems/posix/spinlock.inl +++ /dev/null @@ -1,96 +0,0 @@ -/** - * @file - * - * @brief Inlined Routines from the POSIX Spinlock Manager - * - * This file contains the static inlin implementation of the inlined - * routines from the POSIX Spinlock 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_SPINLOCK_H -# error "Never use directly; include instead." -#endif - -#ifndef _RTEMS_POSIX_SPINLOCK_INL -#define _RTEMS_POSIX_SPINLOCK_INL - -#include - -/** - * @brief Allocate a spinlock control block. - * - * This function allocates a spinlock control block from - * the inactive chain of free spinlock control blocks. - */ -RTEMS_INLINE_ROUTINE POSIX_Spinlock_Control *_POSIX_Spinlock_Allocate( void ) -{ - return (POSIX_Spinlock_Control *) - _Objects_Allocate( &_POSIX_Spinlock_Information ); -} - -/** - * @brief Free a spinlock control block. - * - * This routine frees a spinlock control block to the - * inactive chain of free spinlock control blocks. - */ -RTEMS_INLINE_ROUTINE void _POSIX_Spinlock_Free ( - POSIX_Spinlock_Control *the_spinlock -) -{ - _Objects_Free( &_POSIX_Spinlock_Information, &the_spinlock->Object ); -} - -/** - * @brief Get a spinlock control block. - * - * This function maps spinlock IDs to spinlock control blocks. - * If ID corresponds to a local spinlock, then it returns - * the_spinlock control pointer which maps to ID and location - * is set to OBJECTS_LOCAL. if the spinlock ID is global and - * resides on a remote node, then location is set to OBJECTS_REMOTE, - * and the_spinlock is undefined. Otherwise, location is set - * to OBJECTS_ERROR and the_spinlock is undefined. - */ -RTEMS_INLINE_ROUTINE POSIX_Spinlock_Control *_POSIX_Spinlock_Get ( - pthread_spinlock_t *spinlock, - Objects_Locations *location -) -{ - return (POSIX_Spinlock_Control *) _Objects_Get( - &_POSIX_Spinlock_Information, - (Objects_Id) *spinlock, - location - ); -} - -/** - * @brief Check if a spinlock control block is NULL. - * - * This function returns @c TRUE if the_spinlock is @c NULL and @c FALSE - * otherwise. - * - * @param[in] the_spinlock is the pointer to the spinlock control block - * to be checked. - * - * @retval TRUE The spinlock control block is @c NULL. - * @retval FALSE The spinlock control block is not @c NULL. - */ -RTEMS_INLINE_ROUTINE bool _POSIX_Spinlock_Is_null ( - POSIX_Spinlock_Control *the_spinlock -) -{ - return ( the_spinlock == NULL ); -} - -#endif -/* end of include file */ -- cgit v1.2.3