1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2025-01-18 12:52:44 +01:00
RIOT/sys/posix/pthread/include/pthread_spin.h
René Kijewski e135bdc266 documentation: fix doxygen for pthread_*.h
The pthread header files aren't in the doxygen page anymore after #1137,
because I `@file`'d the `.c` files, not the `.h` files.

This change moves doxygen boilerplate.

Closes #1199.
2014-05-18 17:33:49 +02:00

81 lines
2.6 KiB
C

/**
* @ingroup pthread
* @{
* @file
* @brief Spin locks.
* @note Do not include this header file directly, but pthread.h.
* @warning Spinlocks should be avoided.
* They will burn away the battery needlessly, and may not work because RIOT is tickless.
* Use disableIRQ() and restoreIRQ() for shortterm locks instead.
*/
#ifndef __SYS__POSIX__PTHREAD_SPIN__H
#define __SYS__POSIX__PTHREAD_SPIN__H
#include <errno.h>
/**
* @brief A spinlock.
* @warning Spinlocks should be avoided.
* They will burn away the battery needlessly, and may not work because RIOT is tickless.
* Use disableIRQ() and restoreIRQ() for shortterm locks instead.
*/
typedef volatile unsigned pthread_spinlock_t;
/**
* @brief Intializes a spinlock.
* @warning See the warning in pthread_spinlock_t.
* @details A zeroed out datum is initialized.
* @param[in,out] lock Datum to initialize.
* @param[in] pshared Unused.
* @returns `0` on success.
* `EINVAL` if `lock == NULL`.
*/
int pthread_spin_init(pthread_spinlock_t *lock, int pshared);
/**
* @brief Destroys a spinlock.
* @warning See the warning in pthread_spinlock_t.
* @details Destroying a spinlock while a thread is waiting for it causes undefined behavior.
* This is a no-op.
* @param[in,out] lock Datum to destroy.
* @returns `0` on success.
* `EINVAL` if `lock == NULL`.
*/
int pthread_spin_destroy(pthread_spinlock_t *lock);
/**
* @brief Lock a spinlock.
* @warning See the warning in pthread_spinlock_t.
* @param[in,out] lock Lock to acquire.
* @return `0` on success.
* `EINVAL` if `lock == NULL`.
*/
int pthread_spin_lock(pthread_spinlock_t *lock);
/**
* @brief Tries to lock a spinlock, returns immediately if already locked.
* @warning See the warning in pthread_spinlock_t.
* @param[in,out] lock Lock to acquire.
* @return `0` on success.
* `EBUSY` if the lock was already locked.
* `EINVAL` if `lock == NULL`.
*/
int pthread_spin_trylock(pthread_spinlock_t *lock);
/**
* @brief Releases a spinlock.
* @warning See the warning in pthread_spinlock_t.
* @param[in,out] lock Lock to release
* @return `0` on success.
* `EPERM` if the lock was not locked.
* `EINVAL` if `lock == NULL`.
*/
int pthread_spin_unlock(pthread_spinlock_t *lock);
#endif
/**
* @}
*/