Figure out where to install-libs
[akaros.git] / user / pthread / pthread.h
index b0c835c..2613cac 100644 (file)
@@ -7,6 +7,7 @@
 #include <uthread.h>
 #include <mcs.h>
 #include <dtls.h>
 #include <uthread.h>
 #include <mcs.h>
 #include <dtls.h>
+#include <spinlock.h>
 
 #ifdef __cplusplus
   extern "C" {
 
 #ifdef __cplusplus
   extern "C" {
@@ -38,7 +39,9 @@ struct pthread_tcb {
        void *(*start_routine)(void*);
        void *arg;
        void *retval;
        void *(*start_routine)(void*);
        void *arg;
        void *retval;
-       uint64_t sigmask;
+       sigset_t sigmask;
+       sigset_t sigpending;
+       struct sigdata *sigdata;
 };
 typedef struct pthread_tcb* pthread_t;
 TAILQ_HEAD(pthread_queue, pthread_tcb);
 };
 typedef struct pthread_tcb* pthread_t;
 TAILQ_HEAD(pthread_queue, pthread_tcb);
@@ -59,6 +62,7 @@ struct sysc_mgmt {
 #define PTHREAD_BARRIER_SPINS 100 // totally arbitrary
 #define PTHREAD_COND_INITIALIZER {0,{0},{0},0}
 #define PTHREAD_PROCESS_PRIVATE 0
 #define PTHREAD_BARRIER_SPINS 100 // totally arbitrary
 #define PTHREAD_COND_INITIALIZER {0,{0},{0},0}
 #define PTHREAD_PROCESS_PRIVATE 0
+#define PTHREAD_PROCESS_SHARED 1
 
 typedef struct
 {
 
 typedef struct
 {
@@ -71,17 +75,14 @@ typedef struct
   atomic_t lock;
 } pthread_mutex_t;
 
   atomic_t lock;
 } pthread_mutex_t;
 
-/* TODO: MAX_PTHREADS is arbitrarily defined for now.
- * It indicates the maximum number of threads that can wait on  
-   the same cond var/ barrier concurrently. */
-
-#define MAX_PTHREADS 32
 typedef struct
 {
 typedef struct
 {
-  volatile int sense;
-  int count;
-  int nprocs;
-  pthread_mutex_t pmutex;
+       int                                                     total_threads;
+       volatile int                            sense;  /* state of barrier, flips btw runs */
+       atomic_t                                        count;
+       struct spin_pdr_lock            lock;
+       struct pthread_queue            waiters;
+       int                                                     nr_waiters;
 } pthread_barrier_t;
 
 #define WAITER_CLEARED 0
 } pthread_barrier_t;
 
 #define WAITER_CLEARED 0
@@ -103,19 +104,24 @@ enum
 #define PTHREAD_STACK_PAGES 4
 #define PTHREAD_STACK_SIZE (PTHREAD_STACK_PAGES*PGSIZE)
 
 #define PTHREAD_STACK_PAGES 4
 #define PTHREAD_STACK_SIZE (PTHREAD_STACK_PAGES*PGSIZE)
 
+typedef int clockid_t;
 typedef struct
 {
   int pshared;
 typedef struct
 {
   int pshared;
+  clockid_t clock;
 } pthread_condattr_t;
 
 } pthread_condattr_t;
 
-
+/* Regarding the spinlock vs MCS, I don't expect this lock to be heavily
+ * contended.  Most of the time, the caller already holds the mutex associated
+ * with the cond var. */
 typedef struct
 {
 typedef struct
 {
-  const pthread_condattr_t* attr;
-  uint32_t waiters[MAX_PTHREADS];
-  uint32_t in_use[MAX_PTHREADS];
-  uint32_t next_waiter; //start the search for an available waiter at this spot
+       struct pthread_queue            waiters;
+       struct spin_pdr_lock            spdr_lock;
+       int                                             attr_pshared;
+       int                                             attr_clock;
 } pthread_cond_t;
 } pthread_cond_t;
+
 typedef struct 
 {
        size_t stacksize;
 typedef struct 
 {
        size_t stacksize;
@@ -127,12 +133,15 @@ typedef dtls_key_t pthread_key_t;
 
 /* Akaros pthread extensions / hacks */
 void pthread_can_vcore_request(bool can);      /* default is TRUE */
 
 /* Akaros pthread extensions / hacks */
 void pthread_can_vcore_request(bool can);      /* default is TRUE */
+void pthread_need_tls(bool need);                      /* default is TRUE */
 void pthread_lib_init(void);
 void __pthread_generic_yield(struct pthread_tcb *pthread);
 
 /* The pthreads API */
 int pthread_attr_init(pthread_attr_t *);
 int pthread_attr_destroy(pthread_attr_t *);
 void pthread_lib_init(void);
 void __pthread_generic_yield(struct pthread_tcb *pthread);
 
 /* The pthreads API */
 int pthread_attr_init(pthread_attr_t *);
 int pthread_attr_destroy(pthread_attr_t *);
+int __pthread_create(pthread_t *, const pthread_attr_t *,
+                     void *(*)(void *), void *);
 int pthread_create(pthread_t *, const pthread_attr_t *,
                    void *(*)(void *), void *);
 int pthread_detach(pthread_t __th);
 int pthread_create(pthread_t *, const pthread_attr_t *,
                    void *(*)(void *), void *);
 int pthread_detach(pthread_t __th);
@@ -163,8 +172,11 @@ int pthread_cond_wait(pthread_cond_t *, pthread_mutex_t *);
 
 int pthread_condattr_init(pthread_condattr_t *);
 int pthread_condattr_destroy(pthread_condattr_t *);
 
 int pthread_condattr_init(pthread_condattr_t *);
 int pthread_condattr_destroy(pthread_condattr_t *);
-int pthread_condattr_setpshared(pthread_condattr_t *, int);
 int pthread_condattr_getpshared(pthread_condattr_t *, int *);
 int pthread_condattr_getpshared(pthread_condattr_t *, int *);
+int pthread_condattr_setpshared(pthread_condattr_t *, int);
+int pthread_condattr_getclock(const pthread_condattr_t *attr,
+                              clockid_t *clock_id);
+int pthread_condattr_setclock(pthread_condattr_t *attr, clockid_t clock_id);
 
 #define pthread_rwlock_t pthread_mutex_t
 #define pthread_rwlockattr_t pthread_mutexattr_t
 
 #define pthread_rwlock_t pthread_mutex_t
 #define pthread_rwlockattr_t pthread_mutexattr_t