x86_64: user space TF handlers
[akaros.git] / user / pthread / pthread.c
index b1062df..508cf8f 100644 (file)
@@ -1,4 +1,4 @@
-#include <ros/arch/trapframe.h>
+#include <ros/trapframe.h>
 #include <pthread.h>
 #include <vcore.h>
 #include <mcs.h>
@@ -327,6 +327,8 @@ int pthread_attr_getstacksize(const pthread_attr_t *attr, size_t *stacksize)
 void pthread_lib_init(void)
 {
        uintptr_t mmap_block;
+       struct pthread_tcb *t;
+       int ret;
        /* Some testing code might call this more than once (once for a slimmed down
         * pth 2LS, and another from pthread_create().  Also, this is racy, but the
         * first time through we are an SCP. */
@@ -334,8 +336,10 @@ void pthread_lib_init(void)
        assert(!in_multi_mode());
        mcs_pdr_init(&queue_lock);
        /* Create a pthread_tcb for the main thread */
-       pthread_t t = (pthread_t)calloc(1, sizeof(struct pthread_tcb));
-       assert(t);
+       ret = posix_memalign((void**)&t, __alignof__(struct pthread_tcb),
+                            sizeof(struct pthread_tcb));
+       assert(!ret);
+       memset(t, 0, sizeof(struct pthread_tcb));       /* aggressively 0 for bugs */
        t->id = get_next_pid();
        t->stacksize = USTACK_NUM_PAGES * PGSIZE;
        t->stacktop = (void*)USTACKTOP;
@@ -344,7 +348,7 @@ void pthread_lib_init(void)
        t->joiner = 0;
        assert(t->id == 0);
        /* Put the new pthread (thread0) on the active queue */
-       mcs_pdr_lock(&queue_lock);      /* arguably, we don't need these (_S mode) */
+       mcs_pdr_lock(&queue_lock);
        threads_active++;
        TAILQ_INSERT_TAIL(&active_queue, t, next);
        mcs_pdr_unlock(&queue_lock);
@@ -412,8 +416,10 @@ int pthread_create(pthread_t *thread, const pthread_attr_t *attr,
        run_once(pthread_lib_init());
        /* Create the actual thread */
        struct pthread_tcb *pthread;
-       pthread = (pthread_t)calloc(1, sizeof(struct pthread_tcb));
-       assert(pthread);
+       int ret = posix_memalign((void**)&pthread, __alignof__(struct pthread_tcb),
+                                sizeof(struct pthread_tcb));
+       assert(!ret);
+       memset(pthread, 0, sizeof(struct pthread_tcb)); /* aggressively 0 for bugs*/
        pthread->stacksize = PTHREAD_STACK_SIZE;        /* default */
        pthread->state = PTH_CREATED;
        pthread->id = get_next_pid();
@@ -432,8 +438,8 @@ int pthread_create(pthread_t *thread, const pthread_attr_t *attr,
        /* Set the u_tf to start up in __pthread_run, which will call the real
         * start_routine and pass it the arg.  Note those aren't set until later in
         * pthread_create(). */
-       init_user_tf(&pthread->uthread.utf, (long)&__pthread_run,
-                    (long)(pthread->stacktop));
+       init_user_ctx(&pthread->uthread.u_ctx, (uintptr_t)&__pthread_run,
+                     (uintptr_t)(pthread->stacktop));
        pthread->start_routine = start_routine;
        pthread->arg = arg;
        /* Initialize the uthread */