2014-02-13 14:18:30 +01:00
|
|
|
#ifndef RIOT_PTHREAD_H
|
|
|
|
#define RIOT_PTHREAD_H 1
|
|
|
|
|
|
|
|
#include <time.h>
|
|
|
|
|
|
|
|
#include "kernel.h"
|
|
|
|
#include "mutex.h"
|
|
|
|
#include "sched.h"
|
|
|
|
|
|
|
|
#include "pthreadtypes.h"
|
|
|
|
|
|
|
|
/* Create a new thread, starting with execution of START-ROUTINE
|
|
|
|
getting passed ARG. Creation attributed come from ATTR. The new
|
|
|
|
handle is stored in *NEWTHREAD. */
|
|
|
|
int pthread_create(pthread_t *newthread, const pthread_attr_t *attr,
|
|
|
|
void *(*start_routine)(void *), void *arg);
|
|
|
|
|
|
|
|
/* Terminate calling thread.
|
|
|
|
|
|
|
|
The registered cleanup handlers are called via exception handling .*/
|
|
|
|
void pthread_exit(void *retval);
|
|
|
|
|
|
|
|
/* Make calling thread wait for termination of the thread TH. The
|
|
|
|
exit status of the thread is stored in *THREAD_RETURN, if THREAD_RETURN
|
|
|
|
is not NULL.
|
|
|
|
|
|
|
|
This function is a cancellation point and therefore not marked with
|
|
|
|
. */
|
|
|
|
int pthread_join(pthread_t th, void **thread_return);
|
|
|
|
|
|
|
|
/* Indicate that the thread TH is never to be joined with PTHREAD_JOIN.
|
|
|
|
The resources of TH will therefore be freed immediately when it
|
|
|
|
terminates, instead of waiting for another thread to perform PTHREAD_JOIN
|
|
|
|
on it. */
|
|
|
|
int pthread_detach(pthread_t th);
|
|
|
|
|
|
|
|
/* Obtain the identifier of the current thread. */
|
|
|
|
pthread_t pthread_self(void);
|
|
|
|
|
|
|
|
/* Compare two thread identifiers. */
|
|
|
|
int pthread_equal(pthread_t thread1, pthread_t thread2);
|
|
|
|
|
|
|
|
#include "pthread_attr.h"
|
|
|
|
|
|
|
|
/* Functions for scheduling control. */
|
|
|
|
|
|
|
|
/* Set the scheduling parameters for TARGET_THREAD according to POLICY
|
|
|
|
and *PARAM. */
|
|
|
|
int pthread_setschedparam(pthread_t target_thread, int policy,
|
|
|
|
const struct sched_param *param);
|
|
|
|
|
|
|
|
/* Return in *POLICY and *PARAM the scheduling parameters for TARGET_THREAD. */
|
|
|
|
int pthread_getschedparam(pthread_t target_thread, int *policy,
|
|
|
|
struct sched_param *param);
|
|
|
|
|
|
|
|
/* Set the scheduling priority for TARGET_THREAD. */
|
|
|
|
int pthread_setschedprio(pthread_t target_thread, int prio);
|
|
|
|
|
|
|
|
/* Functions for handling initialization. */
|
|
|
|
|
|
|
|
/* Guarantee that the initialization function INIT_ROUTINE will be called
|
|
|
|
only once, even if pthread_once is executed several times with the
|
|
|
|
same ONCE_CONTROL argument. ONCE_CONTROL must point to a static or
|
|
|
|
variable initialized to PTHREAD_ONCE_INIT.
|
|
|
|
|
|
|
|
The initialization functions might throw exception */
|
|
|
|
int pthread_once(pthread_once_t *once_control, void (*init_routine)(void));
|
|
|
|
|
|
|
|
/* Functions for handling cancellation.
|
|
|
|
|
|
|
|
Note that these functions are explicitly not marked to not throw an
|
|
|
|
exception in C++ code. If cancellation is implemented by unwinding
|
|
|
|
this is necessary to have the compiler generate the unwind information. */
|
|
|
|
|
|
|
|
/* Set cancelability state of current thread to STATE, returning old
|
|
|
|
state in *OLDSTATE if OLDSTATE is not NULL. */
|
|
|
|
int pthread_setcancelstate(int state, int *oldstate);
|
|
|
|
|
|
|
|
/* Set cancellation state of current thread to TYPE, returning the old
|
|
|
|
type in *OLDTYPE if OLDTYPE is not NULL. */
|
|
|
|
int pthread_setcanceltype(int type, int *oldtype);
|
|
|
|
|
|
|
|
/* Cancel THREAD immediately or at the next possibility. */
|
|
|
|
int pthread_cancel(pthread_t th);
|
|
|
|
|
|
|
|
/* Test for pending cancellation for the current thread and terminate
|
|
|
|
the thread as per pthread_exit(PTHREAD_CANCELED) if it has been
|
|
|
|
cancelled. */
|
|
|
|
void pthread_testcancel(void);
|
|
|
|
|
2014-03-01 00:03:56 +01:00
|
|
|
void __pthread_cleanup_push(__pthread_cleanup_datum_t *datum);
|
|
|
|
void __pthread_cleanup_pop(__pthread_cleanup_datum_t *datum, int execute);
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Notice: `pthread_cleanup_*` has to be defined as a macro, because the cleanup
|
|
|
|
* stack needs extra data. The standard explicitly allows defining these
|
|
|
|
* functions as macros. The alternative would be malloc.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/* The pthread_cleanup_push() function shall push the specified cancellation
|
|
|
|
* cleanup handler routine onto the calling thread's cancellation cleanup stack.
|
|
|
|
* The cancellation cleanup handler shall be popped from the cancellation
|
|
|
|
* cleanup stack and invoked with the argument arg when:
|
|
|
|
* The thread exits (that is, calls pthread_exit()).
|
|
|
|
* The thread acts upon a cancellation request.
|
|
|
|
* The thread calls pthread_cleanup_pop() with a non-zero execute argument. */
|
|
|
|
#define pthread_cleanup_push(ROUTINE, ARG) \
|
|
|
|
do { \
|
|
|
|
__extension__ __pthread_cleanup_datum_t ____datum__ = { \
|
|
|
|
.__routine = (ROUTINE), \
|
|
|
|
.__arg = (ARG), \
|
|
|
|
}; \
|
|
|
|
__extension__ int ____execute__ = 1; \
|
|
|
|
__pthread_cleanup_push(&____datum__); \
|
|
|
|
do { \
|
|
|
|
do { } while (0)
|
|
|
|
|
|
|
|
/* The pthread_cleanup_pop() function shall remove the routine at the top of the
|
|
|
|
* calling thread's cancellation cleanup stack and optionally invoke it
|
|
|
|
* (if execute is non-zero). */
|
|
|
|
#define pthread_cleanup_pop(EXECUTE) \
|
|
|
|
____execute__ = (EXECUTE); \
|
|
|
|
} while (0); \
|
|
|
|
__pthread_cleanup_pop(&____datum__, ____execute__); \
|
|
|
|
} while (0)
|
|
|
|
|
2014-02-13 14:18:30 +01:00
|
|
|
#include "pthread_mutex.h"
|
|
|
|
|
|
|
|
#include "pthread_rwlock.h"
|
|
|
|
|
|
|
|
#include "pthread_spin.h"
|
|
|
|
|
|
|
|
#include "pthread_barrier.h"
|
|
|
|
|
|
|
|
#endif /* pthread.h */
|