mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2025-01-18 12:52:44 +01:00
123 lines
2.4 KiB
C
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 */
|