Pulled code specific to all 2LS out of pthread.c
[akaros.git] / user / pthread / pthread.h
1 #ifndef _PTHREAD_H
2 #define _PTHREAD_H
3
4 #include <sys/queue.h>
5 #include <vcore.h>
6 #include <mcs.h>
7
8 #ifdef __cplusplus
9   extern "C" {
10 #endif
11
12 /* Pthread struct.  First has to be the uthread struct, which the vcore code
13  * will access directly (as if pthread_tcb is a struct uthread). */
14 struct pthread_tcb {
15         struct uthread uthread;
16         TAILQ_ENTRY(pthread_tcb) next;
17         int finished;
18         bool detached;
19         uint32_t id;
20         uint32_t stacksize;
21 };
22 typedef struct pthread_tcb* pthread_t;
23 TAILQ_HEAD(pthread_queue, pthread_tcb);
24
25 #define PTHREAD_ONCE_INIT 0
26 #define PTHREAD_BARRIER_SERIAL_THREAD 12345
27 #define PTHREAD_MUTEX_INITIALIZER {0}
28 #define PTHREAD_MUTEX_NORMAL 0
29 #define PTHREAD_MUTEX_DEFAULT PTHREAD_MUTEX_NORMAL
30 #define PTHREAD_MUTEX_SPINS 100 // totally arbitrary
31 #define PTHREAD_BARRIER_SPINS 100 // totally arbitrary
32 #define PTHREAD_COND_INITIALIZER {0}
33 #define PTHREAD_PROCESS_PRIVATE 0
34
35 typedef struct
36 {
37   int type;
38 } pthread_mutexattr_t;
39
40 typedef struct
41 {
42   const pthread_mutexattr_t* attr;
43   int lock;
44 } pthread_mutex_t;
45
46 /* TODO: MAX_PTHREADS is arbitrarily defined for now.
47  * It indicates the maximum number of threads that can wait on  
48    the same cond var/ barrier concurrently. */
49
50 #define MAX_PTHREADS 32
51 typedef struct
52 {
53   volatile int sense;
54   int count;
55   int nprocs;
56   pthread_mutex_t pmutex;
57 } pthread_barrier_t;
58
59 #define WAITER_CLEARED 0
60 #define WAITER_WAITING 1
61 #define SLOT_FREE 0
62 #define SLOT_IN_USE 1
63
64 /* Detach state.  */
65 enum
66 {
67   PTHREAD_CREATE_JOINABLE,
68 #define PTHREAD_CREATE_JOINABLE PTHREAD_CREATE_JOINABLE
69   PTHREAD_CREATE_DETACHED
70 #define PTHREAD_CREATE_DETACHED PTHREAD_CREATE_DETACHED
71 };
72
73 // TODO: how big do we want these?  ideally, we want to be able to guard and map
74 // more space if we go too far.
75 #define PTHREAD_STACK_PAGES 4
76 #define PTHREAD_STACK_SIZE (PTHREAD_STACK_PAGES*PGSIZE)
77
78 typedef struct
79 {
80   int pshared;
81 } pthread_condattr_t;
82
83
84 typedef struct
85 {
86   const pthread_condattr_t* attr;
87   int waiters[MAX_PTHREADS];
88   int in_use[MAX_PTHREADS];
89   int next_waiter; //start the search for an available waiter at this spot
90 } pthread_cond_t;
91 typedef struct 
92 {
93         size_t stacksize;
94         int detachstate;
95 } pthread_attr_t;
96 typedef int pthread_barrierattr_t;
97 typedef int pthread_once_t;
98 typedef void** pthread_key_t;
99
100 /* The pthreads API */
101 int pthread_attr_init(pthread_attr_t *);
102 int pthread_attr_destroy(pthread_attr_t *);
103 int pthread_create(pthread_t *, const pthread_attr_t *,
104                    void *(*)(void *), void *);
105 int pthread_join(pthread_t, void **);
106 int pthread_yield(void);
107
108 int pthread_attr_setdetachstate(pthread_attr_t *__attr,int __detachstate);
109
110 int pthread_mutex_destroy(pthread_mutex_t *);
111 int pthread_mutex_init(pthread_mutex_t *, const pthread_mutexattr_t *);
112 int pthread_mutex_lock(pthread_mutex_t *);
113 int pthread_mutex_trylock(pthread_mutex_t *);
114 int pthread_mutex_unlock(pthread_mutex_t *);
115 int pthread_mutex_destroy(pthread_mutex_t *);
116
117 int pthread_mutexattr_init(pthread_mutexattr_t *);
118 int pthread_mutexattr_destroy(pthread_mutexattr_t *);
119 int pthread_mutexattr_gettype(const pthread_mutexattr_t *, int *);
120 int pthread_mutexattr_settype(pthread_mutexattr_t *, int);
121
122 int pthread_cond_init(pthread_cond_t *, const pthread_condattr_t *);
123 int pthread_cond_destroy(pthread_cond_t *);
124 int pthread_cond_broadcast(pthread_cond_t *);
125 int pthread_cond_signal(pthread_cond_t *);
126 int pthread_cond_wait(pthread_cond_t *, pthread_mutex_t *);
127
128 int pthread_condattr_init(pthread_condattr_t *);
129 int pthread_condattr_destroy(pthread_condattr_t *);
130 int pthread_condattr_setpshared(pthread_condattr_t *, int);
131 int pthread_condattr_getpshared(pthread_condattr_t *, int *);
132
133 #define pthread_rwlock_t pthread_mutex_t
134 #define pthread_rwlockattr_t pthread_mutexattr_t
135 #define pthread_rwlock_destroy pthread_mutex_destroy
136 #define pthread_rwlock_init pthread_mutex_init
137 #define pthread_rwlock_unlock pthread_mutex_unlock
138 #define pthread_rwlock_rdlock pthread_mutex_lock
139 #define pthread_rwlock_wrlock pthread_mutex_lock
140 #define pthread_rwlock_tryrdlock pthread_mutex_trylock
141 #define pthread_rwlock_trywrlock pthread_mutex_trylock
142
143 pthread_t pthread_self();
144 int pthread_equal(pthread_t t1, pthread_t t2);
145 void pthread_exit(void* ret);
146 int pthread_once(pthread_once_t* once_control, void (*init_routine)(void));
147
148 int pthread_barrier_init(pthread_barrier_t* b, const pthread_barrierattr_t* a, int count);
149 int pthread_barrier_wait(pthread_barrier_t* b);
150 int pthread_barrier_destroy(pthread_barrier_t* b);
151
152 //added for redis compile
153 int pthread_detach(pthread_t __th);
154 int pthread_attr_setstacksize(pthread_attr_t *attr, size_t stacksize);
155 int pthread_attr_getstacksize(const pthread_attr_t *attr, size_t *stacksize);
156
157 #ifdef __cplusplus
158   }
159 #endif
160
161 #endif