/* * Copyright (C) 2011 Philippe Gerum . * * This library is free software; you can redistribute it and/or * modify it under the terms of the GNU Lesser General Public * License as published by the Free Software Foundation; either * version 2 of the License, or (at your option) any later version. * * This library 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 * Lesser General Public License for more details. * You should have received a copy of the GNU Lesser General Public * License along with this library; if not, write to the Free Software * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA. */ #ifndef _XENOMAI_ALCHEMY_SEM_H #define _XENOMAI_ALCHEMY_SEM_H #include #include /** * @addtogroup alchemy_sem * @{ */ /** Creation flags. */ #define S_PRIO 0x1 /* Pend by task priority order. */ #define S_FIFO 0x0 /* Pend by FIFO order. */ #define S_PULSE 0x2 /* Enable pulse mode. */ struct RT_SEM { uintptr_t handle; }; typedef struct RT_SEM RT_SEM; /** * @brief Semaphore status descriptor * @anchor RT_SEM_INFO * * This structure reports various static and runtime information about * a semaphore, returned by a call to rt_sem_inquire(). */ struct RT_SEM_INFO { /** * Current semaphore value. */ unsigned long count; /** * Number of tasks waiting on the semaphore. */ int nwaiters; /** * Name of semaphore. */ char name[XNOBJECT_NAME_LEN]; }; typedef struct RT_SEM_INFO RT_SEM_INFO; #ifdef __cplusplus extern "C" { #endif int rt_sem_create(RT_SEM *sem, const char *name, unsigned long icount, int mode); int rt_sem_delete(RT_SEM *sem); int rt_sem_p_timed(RT_SEM *sem, const struct timespec *abs_timeout); static inline int rt_sem_p_until(RT_SEM *sem, RTIME timeout) { struct timespec ts; return rt_sem_p_timed(sem, alchemy_abs_timeout(timeout, &ts)); } static inline int rt_sem_p(RT_SEM *sem, RTIME timeout) { struct timespec ts; return rt_sem_p_timed(sem, alchemy_rel_timeout(timeout, &ts)); } int rt_sem_v(RT_SEM *sem); int rt_sem_broadcast(RT_SEM *sem); int rt_sem_inquire(RT_SEM *sem, RT_SEM_INFO *info); int rt_sem_bind(RT_SEM *sem, const char *name, RTIME timeout); int rt_sem_unbind(RT_SEM *sem); #ifdef __cplusplus } #endif /** @} */ #endif /* _XENOMAI_ALCHEMY_SEM_H */