/* * 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. */ /** * @addtogroup posix * @{ */ /** * @file unistd.h * @brief standard symbolic constants and types * @see * The Open Group Base Specifications Issue 7, * * * @author Martin Lenders */ #ifndef _UNISTD_H #define _UNISTD_H #include #include "timex.h" #include "vtimer.h" #ifdef __cplusplus extern "C" { #endif #define STDIN_FILENO 0 ///< stdin file descriptor #define STDOUT_FILENO 1 ///< stdout file descriptor #define STDERR_FILENO 2 ///< stderr file descriptor /** * @brief Close a file descriptor. * @details shall deallocate the file descriptor indicated by *fildes*. To * deallocate means to make the file descriptor available for return * by subsequent calls to open() or other functions that allocate file * descriptors. All outstanding record locks owned by the process on * the file associated with the file descriptor shall be removed (that * is, unlocked). * * @see * The Open Group Base Specification Issue 7, close * * * @param[in] fildes The file descriptor to the file which is to close. * @return Upon successful completion, 0 shall be returned; otherwise, -1 * shall be returned and errno set to indicate the error. */ int close(int fildes); /** * @name Microseconds data type * @{ */ #ifndef __USECONDS_T_TYPE #if !(defined(__MACH__) || defined(__FreeBSD__)) typedef unsigned long __USECONDS_T_TYPE; typedef __USECONDS_T_TYPE __useconds_t; #else #ifdef __MACH__ typedef __darwin_useconds_t __useconds_t; #endif #endif #endif typedef __useconds_t useconds_t; /** @} */ /** * @brief the caller will sleep for given amount of micro seconds * @details The usleep() function will cause the calling thread to be * suspended from execution until either the number of real-time microseconds * specified by the argument useconds has elapsed or a signal is delivered to * the calling thread and its action is to invoke a signal-catching function * or to terminate the process. The suspension time may be longer than * requested due to the scheduling of other activity by the system. * * @see * The Open Group Base Specification Issue 2, usleep * * * @param useconds time to sleep in micro seconds * @return 0 on success */ int usleep(useconds_t useconds); /** * @brief the caller will sleep for given amount of seconds * @details The sleep() function shall cause the calling thread to be suspended * from execution until either the number of realtime seconds * specified by the argument seconds has elapsed or a signal is * delivered to the calling thread and its action is to invoke a * signal-catching function or to terminate the process. The * suspension time may be longer than requested due to the scheduling * of other activity by the system. * * @see * The Open Group Base Specification Issue 6, sleep * * * @param seconds time to sleep in seconds * @return 0 on success */ unsigned int sleep(unsigned int seconds); #ifdef __cplusplus } #endif /** * @} */ #endif /* _UNISTD_H */