diff options
author | Justus Winter <4winter@informatik.uni-hamburg.de> | 2015-10-29 15:43:28 +0100 |
---|---|---|
committer | Justus Winter <4winter@informatik.uni-hamburg.de> | 2015-10-29 15:43:28 +0100 |
commit | 0437af60d3bbf09003f3fd1fdb9993958fcd430d (patch) | |
tree | 98021e7403283fa3920972b7ccd0908e435bb125 /trans | |
parent | d4a2c3958c79b9582b6541585ad2a72aca7a734a (diff) | |
download | hurd-0437af60d3bbf09003f3fd1fdb9993958fcd430d.tar.gz hurd-0437af60d3bbf09003f3fd1fdb9993958fcd430d.tar.bz2 hurd-0437af60d3bbf09003f3fd1fdb9993958fcd430d.zip |
trans: improve demuxers
Handle multiple request types as recommended by the Mach Server
Writer's Guide section 4, subsection "Handling Multiple Request
Types". This avoids initializing the reply message in every X_server
function.
* trans/proxy-defpager.c (proxy_defpager_demuxer): Improve the demuxer
function.
* trans/streamio.c (demuxer): Likewise.
Diffstat (limited to 'trans')
-rw-r--r-- | trans/proxy-defpager.c | 14 | ||||
-rw-r--r-- | trans/streamio.c | 15 |
2 files changed, 21 insertions, 8 deletions
diff --git a/trans/proxy-defpager.c b/trans/proxy-defpager.c index 662f2698..4fdeb35b 100644 --- a/trans/proxy-defpager.c +++ b/trans/proxy-defpager.c @@ -236,10 +236,16 @@ int proxy_defpager_demuxer (mach_msg_header_t *inp, mach_msg_header_t *outp) { - extern int default_pager_server (mach_msg_header_t *, mach_msg_header_t *); - - return default_pager_server (inp, outp) - || trivfs_demuxer (inp, outp); + mig_routine_t routine; + if ((routine = default_pager_server_routine (inp)) || + (routine = NULL, trivfs_demuxer (inp, outp))) + { + if (routine) + (*routine) (inp, outp); + return TRUE; + } + else + return FALSE; } int diff --git a/trans/streamio.c b/trans/streamio.c index 54627b73..507250bd 100644 --- a/trans/streamio.c +++ b/trans/streamio.c @@ -36,6 +36,7 @@ #include "libtrivfs/trivfs_fs_S.h" #include "libtrivfs/trivfs_io_S.h" +#include "device_reply_S.h" /* The global lock */ pthread_mutex_t global_lock; @@ -273,10 +274,16 @@ static const struct argp argp = { options, parse_opt, args_doc, doc }; int demuxer (mach_msg_header_t *inp, mach_msg_header_t *outp) { - extern int device_reply_server (mach_msg_header_t *, mach_msg_header_t *); - - return (trivfs_demuxer (inp, outp) - || device_reply_server (inp, outp)); + mig_routine_t routine; + if ((routine = NULL, trivfs_demuxer (inp, outp)) || + (routine = device_reply_server_routine (inp))) + { + if (routine) + (*routine) (inp, outp); + return TRUE; + } + else + return FALSE; } int |