/* * 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_MUTEX_H #define _XENOMAI_ALCHEMY_MUTEX_H #include #include #include /** * @addtogroup alchemy_mutex * @{ */ struct RT_MUTEX { uintptr_t handle; }; typedef struct RT_MUTEX RT_MUTEX; /** * @brief Mutex status descriptor * @anchor RT_MUTEX_INFO * * This structure reports various static and runtime information about * a mutex, returned by a call to rt_mutex_inquire(). */ struct RT_MUTEX_INFO { /** * Current mutex owner, or NO_ALCHEMY_TASK if unlocked. This * information is in essence transient, and may not be valid * anymore once used by the caller. */ RT_TASK owner; /** * Name of mutex. */ char name[XNOBJECT_NAME_LEN]; }; typedef struct RT_MUTEX_INFO RT_MUTEX_INFO; #ifdef __cplusplus extern "C" { #endif int rt_mutex_create(RT_MUTEX *mutex, const char *name); int rt_mutex_delete(RT_MUTEX *mutex); int rt_mutex_acquire_timed(RT_MUTEX *mutex, const struct timespec *abs_timeout); static inline int rt_mutex_acquire_until(RT_MUTEX *mutex, RTIME timeout) { struct timespec ts; return rt_mutex_acquire_timed(mutex, alchemy_abs_timeout(timeout, &ts)); } static inline int rt_mutex_acquire(RT_MUTEX *mutex, RTIME timeout) { struct timespec ts; return rt_mutex_acquire_timed(mutex, alchemy_rel_timeout(timeout, &ts)); } int rt_mutex_release(RT_MUTEX *mutex); int rt_mutex_inquire(RT_MUTEX *mutex, RT_MUTEX_INFO *info); int rt_mutex_bind(RT_MUTEX *mutex, const char *name, RTIME timeout); int rt_mutex_unbind(RT_MUTEX *mutex); #ifdef __cplusplus } #endif /** @} */ #endif /* _XENOMAI_ALCHEMY_MUTEX_H */