Adds devalarm (#A)
[akaros.git] / tests / eth_audio.c
index 0c5fae3..2c0fc23 100644 (file)
@@ -1,6 +1,6 @@
 #include <ros/resource.h>
 #include <ros/procdata.h>
-#include <ros/notification.h>
+#include <ros/event.h>
 #include <ros/bcq.h>
 #include <parlib.h>
 #include <vcore.h>
@@ -17,6 +17,8 @@
 #include <sys/mman.h>
 #include <timing.h>
 #include <assert.h>
+#include <event.h>
+#include <uthread.h>
 
 void *core0_tls = 0;
 void *in_buf, *out_buf;
@@ -49,20 +51,10 @@ int main()
        //strncpy(out_buf, "Nanwan loves you!\n", 19);
 
 /* begin: stuff userspace needs to do before switching to multi-mode */
-       if (vcore_init())
-               printf("vcore_init() failed, we're fucked!\n");
+       vcore_init();
 
-       /* tell the kernel where and how we want to receive notifications */
-       struct notif_method *nm;
-       /* ETHAUD Turn off all notifs */
-       for (int i = 0; i < MAX_NR_NOTIF; i++) {
-               nm = &__procdata.notif_methods[i];
-               nm->flags = 0;
-       }
        /* ETHAUD Turn on Free apple pie (which is the network packet) */
-       nm = &__procdata.notif_methods[NE_FREE_APPLE_PIE];
-       nm->flags |= NOTIF_WANTED | NOTIF_MSG | NOTIF_IPI;
-       nm->vcoreid = 0;        /* get it on vcore 0 */
+       enable_kevent(EV_FREE_APPLE_PIE, 0, EVENT_IPI);
 
        /* Need to save this somewhere that you can find it again when restarting
         * core0 */
@@ -70,11 +62,6 @@ int main()
        /* 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 */
        /* ETHAUD */
        /* Switch into _M mode */
@@ -106,23 +93,18 @@ void vcore_entry(void)
        uint32_t vcoreid = vcore_id();
        static bool first_time = TRUE;
 
-/* begin: stuff userspace needs to do to handle notifications */
+       printf("GIANT WARNING: this is ancient shit\n");
+/* begin: stuff userspace needs to do to handle events/notifications */
 
        struct vcore *vc = &__procinfo.vcoremap[vcoreid];
        struct preempt_data *vcpd;
        vcpd = &__procdata.vcore_preempt_data[vcoreid];
        
-       /* here is how you receive a notif_event */
-       struct notif_event ne = {0};
-       bcq_dequeue(&vcpd->notif_evts, &ne, NR_PERCORE_EVENTS);
-       /* it might be in bitmask form too: */
-       //printf("and the bitmask looks like: ");
-       //PRINT_BITMASK(__procdata.vcore_preempt_data[vcoreid].notif_bmask, MAX_NR_NOTIF);
-       /* can see how many messages had to be sent as bits */
-       //printf("Number of event overflows: %d\n", vcpd->event_overflows);
+       /* Ghetto way to get just an event number */
+       unsigned int ev_type = get_event_type(&vcpd->ev_mbox_public);
 
        /* ETHAUD app: process the packet if we got a notif */
-       if (ne.ne_type == NE_FREE_APPLE_PIE)
+       if (ev_type == EV_FREE_APPLE_PIE)
                process_packet();
 
        if (vc->preempt_pending) {
@@ -135,18 +117,18 @@ 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;
-               /* Do one last check for notifs after clearing pending */
+               handle_events(vcoreid);
                set_tls_desc(core0_tls, 0);
+               assert(__vcoreid == 0); /* in case anyone uses this */
                /* Load silly state (Floating point) too */
-               pop_ros_tf(&vcpd->notif_tf, vcoreid);
+               pop_user_ctx(&vcpd->uthread_ctx, vcoreid);
                printf("should never see me!");
        }       
-       /* unmask notifications once you can let go of the notif_tf and it is okay
-        * to clobber the transition stack.
+       /* unmask notifications once you can let go of the uthread_ctx and it is
+        * okay to clobber the transition stack.
         * Check Documentation/processes.txt: 4.2.4.  In real code, you should be
         * popping the tf of whatever user process you want (get off the x-stack) */
-       vcpd->notif_enabled = TRUE;
+       vcpd->notif_disabled = FALSE;
        
 /* end: stuff userspace needs to do to handle notifications */
        /* The other vcores will hit here. */