Files
MiniGUI/include/ose_semaphore.h
2017-10-26 13:34:57 +08:00

95 lines
2.3 KiB
C

/*
* \file ose_semaphore.h
* \author Wei Yongming <ymwei@minigui.org>
* \date 2006/05/19
*
* Description:
*
* This header contains all the definitions needed to support
* POSIX semaphore under OSE. The reader is referred to the POSIX
* standard or equivalent documentation for details of the
* functionality contained herein.
*
\verbatim
Copyright (C) 2005-2012 FMSoft.
All rights reserved by FMSoft (http://www.fmsoft.cn).
This file is part of MiniGUI, a compact cross-platform Graphics
User Interface (GUI) support system for real-time embedded systems.
This header contains all the definitions needed to support
POSIX semaphore under OSE. The reader is referred to the POSIX
standard or equivalent documentation for details of the
functionality contained herein.
We do this work in order to run MiniGUI on OSE.
\endverbatim
*/
/*
* $Id: ose_semaphore.h 11349 2009-03-02 05:00:43Z weiym $
*
* This is the Semaphore implementation in order to run MiniGUI on OSE.
*
* MiniGUI for Linux/uClinux, eCos, uC/OS-II, VxWorks,
* pSOS, ThreadX, NuCleus, OSE, and Win32.
*
* Copyright (C) 2005-2012 FMSoft.
*/
#ifndef FMOSE_SEMAPHORE_H
#define FMOSE_SEMAPHORE_H
#include <stddef.h>
#ifdef __cplusplus
extern "C" {
#endif /* __cplusplus */
#define OSEPTH_LEN_NAME 256
/**
* @\type SEMAPHORE
*
* @\declaration typedef struct semaphore SEMAPHORE;
*
* @\brief The SEMAPHORE type as used in system call interface.
*/
typedef struct _sem_t
{
SEMAPHORE *ose_sem;
char name [OSEPTH_LEN_NAME];
} sem_t;
#define SEM_VALUE_MAX UINT_MAX
/*-----------------------------------------------------------------------------
** Semaphore functions
*/
/* Initialize semaphore to value. */
int sem_init (sem_t *sem, int pshared, unsigned int value);
/* Destroy the semaphore. */
int sem_destroy (sem_t *sem);
/* Decrement value if >0 or wait for a post. */
int sem_wait (sem_t *sem);
/* Decrement value if >0, return -1 if not. */
int sem_trywait (sem_t *sem);
/* Increment value and wake a waiter if one is present. */
int sem_post (sem_t *sem);
/* Get current value */
int sem_getvalue (sem_t *sem, int *sval);
#endif /* FMOSE_SEMAPHORE_H */
/* End of ose_semaphore.h */