Git properly ignores the symlink u/parlib/inc/arch
[akaros.git] / tests / eth_audio.c
index 57f1ca0..b290d9e 100644 (file)
@@ -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;
@@ -53,12 +55,7 @@ int main()
                printf("vcore_init() failed, we're fucked!\n");
 
        /* ETHAUD Turn on Free apple pie (which is the network packet) */
-       struct event_queue *ev_q = malloc(sizeof(struct event_queue));
-       ev_q->ev_mbox = &__procdata.vcore_preempt_data[0].ev_mbox;
-       ev_q->ev_flags = EVENT_IPI;
-       ev_q->ev_vcore = 0;     
-       ev_q->ev_handler = 0;
-       __procdata.kernel_evts[EV_FREE_APPLE_PIE] = ev_q;
+       enable_kevent(EV_FREE_APPLE_PIE, 0, EVENT_IPI);
 
        /* Need to save this somewhere that you can find it again when restarting
         * core0 */
@@ -102,18 +99,18 @@ void vcore_entry(void)
        uint32_t vcoreid = vcore_id();
        static bool first_time = TRUE;
 
+       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 an event message (ought to check overflow) */
-       struct event_msg ev_msg = {0};
-       bcq_dequeue(&vcpd->ev_mbox.ev_msgs, &ev_msg, NR_BCQ_EVENTS);
+       /* Ghetto way to get just an event number */
+       unsigned int ev_type = get_event_type(&vcpd->ev_mbox);
 
        /* ETHAUD app: process the packet if we got a notif */
-       if (ev_msg.ev_type == EV_FREE_APPLE_PIE)
+       if (ev_type == EV_FREE_APPLE_PIE)
                process_packet();
 
        if (vc->preempt_pending) {
@@ -126,8 +123,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;
-               /* Do one last check for notifs after clearing pending */
+               clear_notif_pending(vcoreid);
                set_tls_desc(core0_tls, 0);
                /* Load silly state (Floating point) too */
                pop_ros_tf(&vcpd->notif_tf, vcoreid);