summaryrefslogtreecommitdiff
path: root/proc/msg.c
diff options
context:
space:
mode:
authorRoland McGrath <roland@gnu.org>1994-05-12 06:46:22 +0000
committerRoland McGrath <roland@gnu.org>1994-05-12 06:46:22 +0000
commite1a85cecc45b7ca88f25d21a5418e4d3813ca204 (patch)
treeeb4fed61deb9c798b6e94c6e9e615c3477c44f59 /proc/msg.c
parentbc72ba4f490c36e0c5e31ab14b5cba85f42c85eb (diff)
Formerly msg.c.~6~
Diffstat (limited to 'proc/msg.c')
-rw-r--r--proc/msg.c12
1 files changed, 9 insertions, 3 deletions
diff --git a/proc/msg.c b/proc/msg.c
index 63be1e12..7d6c7006 100644
--- a/proc/msg.c
+++ b/proc/msg.c
@@ -19,6 +19,7 @@
#include <hurd.h>
#include "proc.h"
#include "process_reply.h"
+#include <hurd/startup.h>
#include <assert.h>
#include <stdlib.h>
@@ -41,8 +42,9 @@ check_message_return (struct proc *p, void *availpaddr)
error_t
S_proc_setmsgport (struct proc *p,
- mach_port_t msgport,
- mach_port_t *oldmsgport)
+ mach_port_t reply, mach_msg_type_name_t replytype,
+ mach_port_t msgport,
+ mach_port_t *oldmsgport)
{
*oldmsgport = p->p_msgport;
p->p_msgport = msgport;
@@ -51,11 +53,15 @@ S_proc_setmsgport (struct proc *p,
prociterate (check_message_return, p);
p->p_checkmsghangs = 0;
+ /* init is single-threaded. Reply to it before we expect it
+ to service requests. */
+ proc_setmsgport_reply (reply, replytype, 0, p->p_msgport);
+
if (p == startup_proc)
startup_essential_task (msgport, mach_task_self (), MACH_PORT_NULL,
"proc", master_host_port);
- return 0;
+ return MIG_NO_REPLY;
}
/* Check to see if process P is blocked trying to get the message port of