diff options
Diffstat (limited to 'device')
-rw-r--r-- | device/ds_routines.c | 31 | ||||
-rw-r--r-- | device/interrupt.h | 1 | ||||
-rw-r--r-- | device/intr.c | 116 |
3 files changed, 10 insertions, 138 deletions
diff --git a/device/ds_routines.c b/device/ds_routines.c index a54bb0e..d866acc 100644 --- a/device/ds_routines.c +++ b/device/ds_routines.c @@ -340,36 +340,7 @@ experimental_device_intr_register (ipc_port_t master_port, int line, if (line < 0 || line >= 16) return D_INVALID_OPERATION; - ret = insert_intr_entry (line, receive_port, FALSE, &entry); - if (ret) - return ret; - - return install_user_intr_handler (line, flags, entry); -#endif /* MACH_XEN */ -} - -io_return_t -experimental_device_intr_register2 (ipc_port_t master_port, int line, - int flags, ipc_port_t notification_port) -{ -#ifdef MACH_XEN - return D_INVALID_OPERATION; -#else /* MACH_XEN */ - struct intr_entry *entry; - io_return_t ret; - - /* Open must be called on the master device port. */ - if (master_port != master_device_port) - return D_INVALID_OPERATION; - - if (notification_port == IP_NULL) - return D_INVALID_OPERATION; - - /* XXX: move to arch-specific */ - if (line < 0 || line >= 16) - return D_INVALID_OPERATION; - - ret = insert_intr_entry (line, notification_port, TRUE, &entry); + ret = insert_intr_entry (line, receive_port, &entry); if (ret) return ret; diff --git a/device/interrupt.h b/device/interrupt.h index 7a00456..1987ffc 100644 --- a/device/interrupt.h +++ b/device/interrupt.h @@ -21,7 +21,6 @@ struct intr_entry; boolean_t queue_intr (struct intr_entry *e); kern_return_t insert_intr_entry (int line, ipc_port_t dest, - int new_style, /* version2 notifications? */ struct intr_entry **entry); boolean_t intr_entry_notify (mach_msg_header_t *msg); diff --git a/device/intr.c b/device/intr.c index 5033d93..20a888c 100644 --- a/device/intr.c +++ b/device/intr.c @@ -36,7 +36,6 @@ struct intr_entry ipc_port_t port; /* We receive notifications on this port. */ queue_chain_t chain; ipc_port_t dest; - int new_style; /* version2 notifications?. */ int line; /* The number of interrupts occur since last run of intr_thread. */ int interrupts; @@ -65,7 +64,6 @@ queue_intr (struct intr_entry *e) kern_return_t insert_intr_entry (int line, ipc_port_t dest, - int new_style, /* version2 notifications? */ struct intr_entry **entry) { kern_return_t err = 0; @@ -92,7 +90,6 @@ insert_intr_entry (int line, new->line = line; new->dest = dest; - new->new_style = new_style; new->interrupts = 0; /* Register a dead-name notification so that we are notified if the @@ -209,6 +206,7 @@ intr_entry_notify (mach_msg_header_t *msg) ipc_port_release_send (entry->dest); kmem_cache_free (&intr_entry_cache, (vm_offset_t) entry); + /* XXX cancel no-senders notification here */ printf ("irq handler %d: userspace handler died\n", line); return TRUE; } @@ -225,7 +223,7 @@ static void init_mach_intr_notification (mach_intr_notification_t *n) { mach_msg_header_t *m = &n->intr_header; - mach_msg_type_t *t = &n->intr_type; + mach_msg_type_t *t = &n->line_type; m->msgh_bits = MACH_MSGH_BITS (MACH_MSG_TYPE_PORT_SEND, MACH_MSG_TYPE_PORT_SEND); @@ -282,89 +280,6 @@ deliver_intr (int line, ipc_port_t dest_port, ipc_port_t interrupt_port) return TRUE; } -mach_intr_notification2_t mach_intr_notification2_template; - -static void -init_mach_intr_notification2 (mach_intr_notification2_t *n) -{ - mach_msg_header_t *m = &n->intr_header; - mach_msg_type_t *t = &n->line_type; - - m->msgh_bits = - MACH_MSGH_BITS_COMPLEX | MACH_MSGH_BITS(MACH_MSG_TYPE_PORT_SEND, 0); - m->msgh_size = sizeof *n; - m->msgh_seqno = INTR_NOTIFY_MSGH_SEQNO; - m->msgh_local_port = MACH_PORT_NULL; - m->msgh_remote_port = MACH_PORT_NULL; - m->msgh_id = MACH_INTR_NOTIFY2; - - t->msgt_name = MACH_MSG_TYPE_INTEGER_32; - t->msgt_size = 32; - t->msgt_number = 1; - t->msgt_inline = TRUE; - t->msgt_longform = FALSE; - t->msgt_deallocate = FALSE; - t->msgt_unused = 0; - - t = &n->count_type; - t->msgt_name = MACH_MSG_TYPE_INTEGER_32; - t->msgt_size = 32; - t->msgt_number = 1; - t->msgt_inline = TRUE; - t->msgt_longform = FALSE; - t->msgt_deallocate = FALSE; - t->msgt_unused = 0; - - t = &n->port_type; - t->msgt_name = MACH_MSG_TYPE_MOVE_SEND; - t->msgt_size = 32; - t->msgt_number = 1; - t->msgt_inline = TRUE; - t->msgt_longform = FALSE; - t->msgt_deallocate = FALSE; - t->msgt_unused = 0; -} - -static boolean_t -deliver_intr_notification2 (ipc_port_t notification_port, - int line, int count, - ipc_port_t interrupt_port) -{ - ipc_kmsg_t kmsg; - ipc_port_t sright, sonce, old; - mach_intr_notification2_t *n; - - assert (notification_port); - assert (interrupt_port); - - kmsg = ikm_alloc(sizeof *n); - if (kmsg == IKM_NULL) - return FALSE; - - ikm_init(kmsg, sizeof *n); - n = (mach_intr_notification2_t *) &kmsg->ikm_header; - *n = mach_intr_notification2_template; - - /* Arrange no-senders notification. */ - sright = ipc_port_make_send (interrupt_port); - sonce = ipc_port_make_sonce (interrupt_port); - ip_lock (interrupt_port); - ipc_port_nsrequest (interrupt_port, interrupt_port->ip_mscount, - sonce, &old); - if (old != IP_NULL) - ipc_port_release_sonce (old); - - n->intr_header.msgh_remote_port = (mach_port_t) notification_port; - n->line = line; - n->count = count; - n->interrupt_port = (mach_port_t) sright; - - ipc_port_copy_send (notification_port); - ipc_mqueue_send_always(kmsg); - - return TRUE; -} - void intr_thread () { @@ -373,7 +288,6 @@ intr_thread () ipc_port_t dest; queue_init (&intr_queue); init_mach_intr_notification (&mach_intr_notification_template); - init_mach_intr_notification2 (&mach_intr_notification2_template); kmem_cache_init (&intr_entry_cache, "intr_entry", sizeof (struct intr_entry), 0, NULL, 0); @@ -393,25 +307,13 @@ intr_thread () int count = e->interrupts; line = e->line; dest = e->dest; - if (e->new_style) - { - e->interrupts = 0; - - cpu_intr_restore (flags); - ok = deliver_intr_notification2 (dest, line, count, interrupt_port); - printf ("new: count? %d ok? %d\n", count, ok); - cpu_intr_save (&flags); - } - else - { - e->interrupts--; - - cpu_intr_restore (flags); - deliver_intr (line, dest, interrupt_port); - cpu_intr_save (&flags); - - assert (e->interrupts == 0); - } + assert (e->interrupts == 1); + e->interrupts--; + + cpu_intr_restore (flags); + deliver_intr (line, dest, interrupt_port); + cpu_intr_save (&flags); + /* We cannot assume that e still exists at this point because we released the lock. Hence we restart the |