diff options
-rw-r--r-- | libpager/ChangeLog | 8 | ||||
-rw-r--r-- | libpager/demuxer.c | 25 |
2 files changed, 29 insertions, 4 deletions
diff --git a/libpager/ChangeLog b/libpager/ChangeLog index a66014e8..1d0308a1 100644 --- a/libpager/ChangeLog +++ b/libpager/ChangeLog @@ -1,3 +1,11 @@ +2001-01-16 Marcus Brinkmann <marcus@gnu.org> + + * demuxer.c (pager_demuxer): If the message was not accepted by + one of the servers, acquire a reference to the pager and its lock, + and wait until all previous messages have been processed. This + makes sure that the next message that arrives can proceed. + Reported by Neal H Walfield <neal@cs.uml.edu> + 2001-12-29 Roland McGrath <roland@frob.com> * data-init.c, object-create.c: Removed obsolete files. diff --git a/libpager/demuxer.c b/libpager/demuxer.c index f233d1c0..0bd56b4e 100644 --- a/libpager/demuxer.c +++ b/libpager/demuxer.c @@ -1,5 +1,5 @@ /* Demuxer for pager library - Copyright (C) 1994, 1995 Free Software Foundation + Copyright (C) 1994, 1995, 2002 Free Software Foundation This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as @@ -20,7 +20,7 @@ #include "notify_S.h" /* Demultiplex a single message directed at a pager port; INP is the - message received; fille OUTP with the reply. */ + message received; fill OUTP with the reply. */ int pager_demuxer (mach_msg_header_t *inp, mach_msg_header_t *outp) @@ -30,7 +30,24 @@ pager_demuxer (mach_msg_header_t *inp, extern int _pager_seqnos_notify_server (mach_msg_header_t *inp, mach_msg_header_t *outp); - return (_pager_seqnos_memory_object_server (inp, outp) - || _pager_seqnos_notify_server (inp, outp)); + int result = _pager_seqnos_memory_object_server (inp, outp) + || _pager_seqnos_notify_server (inp, outp); + if (!result) + { + struct pager *p; + + p = ports_lookup_port (0, inp->msgh_remote_port, _pager_class); + if (p) + { + mutex_lock (&p->interlock); + _pager_wait_for_seqno (p, seqno); + _pager_release_seqno (p, seqno); + mutex_unlock (&p->interlock); + ports_port_deref (p); + } + } + return result; } + + |