blob: c09bd8f66813f2ae5941f6044fa9da30a4c8f6cf (
plain) (
tree)
|
|
/*
* Barrier Manager
*
* DESCRIPTION:
*
* This package is the implementation of the Barrier Manager.
*
* Directives provided are:
*
* + create a barrier
* + get an ID of a barrier
* + delete a barrier
* + acquire a barrier
* + release a barrier
*
* COPYRIGHT (c) 1989-2006.
* 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.
*
* $Id$
*/
#if HAVE_CONFIG_H
#include "config.h"
#endif
#include <limits.h>
#include <rtems/system.h>
#include <rtems/posix/barrier.h>
/**
* @brief _POSIX_Barrier_Manager_initialization
*
* Input parameters:
* maximum_barriers - maximum configured barriers
*
* Output parameters: NONE
*/
void _POSIX_Barrier_Manager_initialization(
uint32_t maximum_barriers
)
{
_Objects_Initialize_information(
&_POSIX_Barrier_Information, /* object information table */
OBJECTS_POSIX_API, /* object API */
OBJECTS_POSIX_BARRIERS, /* object class */
maximum_barriers, /* maximum objects of this class */
sizeof( POSIX_Barrier_Control ),/* size of this object's control block */
TRUE, /* TRUE if the name is a string */
_POSIX_PATH_MAX /* maximum length of each object's name */
#if defined(RTEMS_MULTIPROCESSING)
,
FALSE, /* TRUE if this is a global object class */
NULL /* Proxy extraction support callout */
#endif
);
}
|