Fixes list management bug in the ksched
[akaros.git] / tests / msr_get_cores.c
index 9934891..0a92563 100644 (file)
 #include <ros/mman.h>
 #include <ros/resource.h>
 #include <ros/procdata.h>
-#include <ros/notification.h>
 #include <ros/bcq.h>
 #include <arch/arch.h>
-#include <rstdio.h>
+#include <stdio.h>
 #include <vcore.h>
 #include <mcs.h>
 #include <timing.h>
 #include <rassert.h>
+#include <uthread.h>
 
 #ifdef __sparc_v8__
-# define udelay(x) udelay((x)/500)
+# define udelay(x) udelay((x)/2000)
 #endif
 
 mcs_barrier_t b;
@@ -43,6 +43,7 @@ int main(int argc, char** argv)
 /* begin: stuff userspace needs to do before switching to multi-mode */
        if (vcore_init())
                printf("vcore_init() failed, we're fucked!\n");
+       #if 0
        /* tell the kernel where and how we want to receive notifications */
        struct notif_method *nm;
        for (int i = 0; i < MAX_NR_NOTIF; i++) {
@@ -50,15 +51,12 @@ int main(int argc, char** argv)
                nm->flags |= NOTIF_WANTED | NOTIF_MSG | NOTIF_IPI;
                nm->vcoreid = i % 2; // vcore0 or 1, keepin' it fresh.
        }
+       #endif
        /* Need to save this somewhere that you can find it again when restarting
         * core0 */
        core0_tls = get_tls_desc(0);
        /* Need to save our floating point state somewhere (like in the
         * user_thread_tcb so it can be restarted too */
-       /* don't forget to enable notifs on vcore0 at some point */
-       struct preempt_data *vcpd;
-       vcpd = &__procdata.vcore_preempt_data[0];
-       vcpd->notif_enabled = TRUE;
 /* end: stuff userspace needs to do before switching to multi-mode */
 
        begin = read_tsc();
@@ -100,7 +98,7 @@ void vcore_entry(void)
         * set the appropriate TLS.  On x86, this will involve changing the LDT
         * entry for this vcore to point to the TCB of the new user-thread. */
        if (vcoreid == 0) {
-               vcpd->notif_pending = 0;
+               clear_notif_pending(vcoreid);
                set_tls_desc(core0_tls, 0);
                /* Load silly state (Floating point) too */
                pop_ros_tf(&vcpd->notif_tf, vcoreid);