summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--init/init.c26
1 files changed, 15 insertions, 11 deletions
diff --git a/init/init.c b/init/init.c
index 389c5c9e..9e9db6ec 100644
--- a/init/init.c
+++ b/init/init.c
@@ -444,26 +444,30 @@ launch_system (void)
proc_register_version (procserver, host_priv, "init", HURD_RELEASE,
init_version);
- /* Give the bootstrap FS its proc and auth ports. */
+ /* Get the bootstrap filesystem's proc server port.
+ We must do this before calling proc_setmsgport below. */
proc_task2proc (procserver, fstask, &fsproc);
- /* Tell the proc server our msgport. Be sure to do this after we
- are all done making requests of proc. Once we have done this
- RPC, proc assumes it can send us requests, so we cannot block on
- proc again before accepting more RPC requests! However, we must
- do this befory calling fsys_init, because fsys_init causes the
- exec server to block waiting on our message yort.*/
+ /* Run the shell. We must do this before calling proc_setmsgport below,
+ because run_for_real does proc server operations. */
+ run_for_real ("/bin/sh");
+ printf ("Init has completed.\n");
+ fflush (stdout);
+
+ /* Tell the proc server our msgport. Be sure to do this after we are all
+ done making requests of proc. Once we have done this RPC, proc
+ assumes it can send us requests, so we cannot block on proc again
+ before accepting more RPC requests! However, we must do this before
+ calling fsys_init, because fsys_init blocks on exec_init, and
+ exec_init to block waiting on our message port. */
proc_setmsgport (procserver, startup, &old);
if (old)
mach_port_deallocate (mach_task_self (), old);
+ /* Give the bootstrap FS its proc and auth ports. */
if (errno = fsys_init (bootport, fsproc, MACH_MSG_TYPE_MOVE_SEND,
authserver))
perror ("fsys_init");
-
- run_for_real ("/bin/sh");
- printf ("Init has completed.\n");
- fflush (stdout);
}