Allows calls to pthread_sigmask before init
[akaros.git] / user / pthread / pthread.h
index 0f14fb2..aaada32 100644 (file)
@@ -1,5 +1,5 @@
-#ifndef _PTHREAD_H
-#define _PTHREAD_H
+#ifndef PTHREAD_PTHREAD_H
+#define PTHREAD_PTHREAD_H
 
 #include <sys/queue.h>
 #include <signal.h>
@@ -8,10 +8,10 @@
 #include <mcs.h>
 #include <dtls.h>
 #include <spinlock.h>
+/* GNU / POSIX scheduling crap */
+#include <sched.h>
 
-#ifdef __cplusplus
-  extern "C" {
-#endif
+__BEGIN_DECLS
 
 /* Pthread states.  These are mostly examples for other 2LSs */
 #define PTH_CREATED                    1
 struct pthread_tcb;
 struct pthread_tcb {
        struct uthread uthread;
-       TAILQ_ENTRY(pthread_tcb) next;
+       union {
+               /* Only on one list at a time */
+               TAILQ_ENTRY(pthread_tcb) tq_next;
+               SLIST_ENTRY(pthread_tcb) sl_next;
+       };
        int state;
        bool detached;
        struct pthread_tcb *joiner;                     /* raced on by exit and join */
@@ -42,8 +46,11 @@ struct pthread_tcb {
        sigset_t sigmask;
        sigset_t sigpending;
        struct sigdata *sigdata;
+       int sched_policy;
+       int sched_priority;             /* careful, GNU #defines this to __sched_priority */
 };
 typedef struct pthread_tcb* pthread_t;
+SLIST_HEAD(pthread_list, pthread_tcb);
 TAILQ_HEAD(pthread_queue, pthread_tcb);
 
 /* Per-vcore data structures to manage syscalls.  The ev_q is where we tell the
@@ -60,7 +67,8 @@ struct sysc_mgmt {
 #define PTHREAD_MUTEX_DEFAULT PTHREAD_MUTEX_NORMAL
 #define PTHREAD_MUTEX_SPINS 100 // totally arbitrary
 #define PTHREAD_BARRIER_SPINS 100 // totally arbitrary
-#define PTHREAD_COND_INITIALIZER {0,{0},{0},0}
+#define PTHREAD_COND_INITIALIZER {/* SLIST_HEAD_INITIALIZER */ {NULL},         \
+                                  SPINPDR_INITIALIZER, 0, 0}
 #define PTHREAD_PROCESS_PRIVATE 0
 #define PTHREAD_PROCESS_SHARED 1
 
@@ -81,7 +89,7 @@ typedef struct
        volatile int                            sense;  /* state of barrier, flips btw runs */
        atomic_t                                        count;
        struct spin_pdr_lock            lock;
-       struct pthread_queue            waiters;
+       struct pthread_list                     waiters;
        int                                                     nr_waiters;
 } pthread_barrier_t;
 
@@ -103,6 +111,7 @@ enum
 // more space if we go too far.
 #define PTHREAD_STACK_PAGES 4
 #define PTHREAD_STACK_SIZE (PTHREAD_STACK_PAGES*PGSIZE)
+#define PTHREAD_STACK_MIN PTHREAD_STACK_SIZE
 
 typedef int clockid_t;
 typedef struct
@@ -116,7 +125,7 @@ typedef struct
  * with the cond var. */
 typedef struct
 {
-       struct pthread_queue            waiters;
+       struct pthread_list                     waiters;
        struct spin_pdr_lock            spdr_lock;
        int                                             attr_pshared;
        int                                             attr_clock;
@@ -126,7 +135,11 @@ typedef struct
 {
        void *stackaddr;
        size_t stacksize;
+       size_t guardsize;
        int detachstate;
+       int sched_priority;
+       int sched_policy;
+       int sched_inherit;
 } pthread_attr_t;
 typedef int pthread_barrierattr_t;
 typedef int pthread_once_t;
@@ -152,6 +165,8 @@ int pthread_yield(void);
 int pthread_attr_setdetachstate(pthread_attr_t *__attr,int __detachstate);
 int pthread_attr_setstacksize(pthread_attr_t *attr, size_t stacksize);
 int pthread_attr_getstacksize(const pthread_attr_t *attr, size_t *stacksize);
+int pthread_attr_setguardsize(pthread_attr_t *attr, size_t guardsize);
+int pthread_attr_getguardsize(pthread_attr_t *attr, size_t *guardsize);
 
 int pthread_mutex_destroy(pthread_mutex_t *);
 int pthread_mutex_init(pthread_mutex_t *, const pthread_mutexattr_t *);
@@ -215,6 +230,32 @@ int pthread_getattr_np(pthread_t __th, pthread_attr_t *__attr);
 int pthread_attr_getstack(const pthread_attr_t *__attr,
                            void **__stackaddr, size_t *__stacksize);
 
+/* Scheduling Stuff, mostly ignored by the actual 2LS */
+int pthread_attr_setschedparam(pthread_attr_t *attr,
+                               const struct sched_param *param);
+int pthread_attr_getschedparam(pthread_attr_t *attr,
+                               struct sched_param *param);
+/* Policies are from sched.h. */
+int pthread_attr_setschedpolicy(pthread_attr_t *attr, int policy);
+int pthread_attr_getschedpolicy(pthread_attr_t *attr, int *policy);
+
+#define PTHREAD_SCOPE_SYSTEM   1
+#define PTHREAD_SCOPE_PROCESS  2
+int pthread_attr_setscope(pthread_attr_t *attr, int scope);
+int pthread_attr_getscope(pthread_attr_t *attr, int *scope);
+
+#define PTHREAD_INHERIT_SCHED  1
+#define PTHREAD_EXPLICIT_SCHED 2
+int pthread_attr_setinheritsched(pthread_attr_t *attr,
+                                 int inheritsched);
+int pthread_attr_getinheritsched(const pthread_attr_t *attr,
+                                 int *inheritsched);
+
+int pthread_setschedparam(pthread_t thread, int policy,
+                          const struct sched_param *param);
+int pthread_getschedparam(pthread_t thread, int *policy,
+                          struct sched_param *param);
+
 /* Unsupported Stuff */
 typedef void *upthread_once_t;
 extern int pthread_mutex_timedlock (pthread_mutex_t *__restrict __mutex,
@@ -227,9 +268,9 @@ extern int pthread_cond_timedwait (pthread_cond_t *__restrict __cond,
 extern int pthread_once (pthread_once_t *__once_control,
              void (*__init_routine) (void)) __nonnull ((1, 2));
 extern int pthread_cancel (pthread_t __th);
+void pthread_cleanup_push(void (*routine)(void *), void *arg);
+void pthread_cleanup_pop(int execute);
 
-#ifdef __cplusplus
-  }
-#endif
+__END_DECLS
 
-#endif
+#endif /* PTHREAD_PTHREAD_H */