1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2025-01-18 12:52:44 +01:00
RIOT/sys/posix/include/semaphore.h
2014-12-06 02:05:51 +01:00

123 lines
2.4 KiB
C

/*
* Copyright (C) 2013 Freie Universität Berlin
*
* This file is subject to the terms and conditions of the GNU Lesser
* General Public License v2.1. See the file LICENSE in the top level
* directory for more details.
*/
#ifndef _SEMAPHORE_H
#define _SEMAPHORE_H 1
#include <time.h>
#include "priority_queue.h"
#ifdef __cplusplus
extern "C" {
#endif
/** Value returned if `sem_open' failed. */
#define SEM_FAILED ((sem_t *) 0)
/**
* @brief Semaphore struct
*/
typedef struct sem {
/** the value of the semaphore */
volatile unsigned int value;
/** list of threads waiting for the semaphore */
priority_queue_t queue;
} sem_t;
/**
* @brief Initialize semaphore object SEM to VALUE.
*
* @param sem Semaphore to initialize
* @param pshared unused
* @param value Value to set
*/
int sem_init(sem_t *sem, int pshared, unsigned int value);
/**
* @brief Free resources associated with semaphore object SEM.
*
* @param sem Semaphore to destroy
*/
int sem_destroy(sem_t *sem);
/*
* @brief Open a named semaphore NAME with open flags OFLAG.
*
* @brief WARNING: named semaphore are currently not supported
*
* @param name Name to set
* @param oflag Flags to set
*/
sem_t *sem_open(const char *name, int oflag, ...);
/**
* @brief Close descriptor for named semaphore SEM.
*
* @brief WARNING: named semaphore are currently not supported
*
* @param sem Semaphore to close
*/
int sem_close(sem_t *sem);
/**
* @brief Remove named semaphore NAME.
*
* @brief WARNING: named semaphore are currently not supported
*
* @param name Name to unlink
*/
int sem_unlink(const char *name);
/**
* @brief Wait for SEM being posted.
*
* @param sem Semaphore to wait
*/
int sem_wait(sem_t *sem);
/**
* @brief Similar to `sem_wait' but wait only until ABSTIME.
*
* @brief WARNING: currently not supported
*
* @param sem Semaphore to wait on
* @param abstime Max time to wait for a post
*
*/
int sem_timedwait(sem_t *sem, const struct timespec *abstime);
/**
* @brief Test whether SEM is posted.
*
* @param sem Semaphore to trywait on
*
*/
int sem_trywait(sem_t *sem);
/**
* @brief Post SEM.
*
* @param sem Semaphore to post on
*/
int sem_post(sem_t *sem);
/**
* @brief Get current value of SEM and store it in *SVAL.
*
* @param sem Semaphore to get value from
* @param sval place whre value goes to
*/
int sem_getvalue(sem_t *sem, int *sval);
#ifdef __cplusplus
}
#endif
#endif /* semaphore.h */