summaryrefslogtreecommitdiff
path: root/libdiskfs/init-startup.c
diff options
context:
space:
mode:
authorThomas Bushnell <thomas@gnu.org>2000-03-17 17:21:02 +0000
committerThomas Bushnell <thomas@gnu.org>2000-03-17 17:21:02 +0000
commited1d3f38812f06fcc85ff3fc60785b2193fa08a5 (patch)
tree04b5b9afee694f2aa16f15d5693c6b452acd0a19 /libdiskfs/init-startup.c
parentbde9c6f42327e37103f1fdd5381438536005b701 (diff)
2000-03-17 Thomas Bushnell, BSG <tb@mit.edu>
* boot-start.c (diskfs_S_fsys_init, diskfs_start_bootstrap): Don't use MOVE_SEND in Hurd RPC. * file-exec.c (diskfs_S_file_exec): Don't use MAKE_SEND in Hurd RPC. * init-startup.c (diskfs_startup_diskfs, _diskfs_init_completed): Likewise.
Diffstat (limited to 'libdiskfs/init-startup.c')
-rw-r--r--libdiskfs/init-startup.c15
1 files changed, 9 insertions, 6 deletions
diff --git a/libdiskfs/init-startup.c b/libdiskfs/init-startup.c
index 0b0b8d5f..98e39ea1 100644
--- a/libdiskfs/init-startup.c
+++ b/libdiskfs/init-startup.c
@@ -1,5 +1,5 @@
/* diskfs_startup_diskfs -- advertise our fsys control port to our parent FS.
- Copyright (C) 1994, 1995, 1996, 1998, 1999 Free Software Foundation
+ Copyright (C) 1994, 1995, 1996, 1998, 1999, 2000 Free Software Foundation
This file is part of the GNU Hurd.
@@ -32,7 +32,7 @@ char *_diskfs_chroot_directory;
mach_port_t
diskfs_startup_diskfs (mach_port_t bootstrap, int flags)
{
- mach_port_t realnode;
+ mach_port_t realnode, right;
struct port_info *newpi;
if (_diskfs_chroot_directory != NULL)
@@ -89,8 +89,10 @@ diskfs_startup_diskfs (mach_port_t bootstrap, int flags)
sizeof (struct port_info), &newpi);
if (! errno)
{
- errno = fsys_startup (bootstrap, flags, ports_get_right (newpi),
- MACH_MSG_TYPE_MAKE_SEND, &realnode);
+ right = ports_get_send_right (newpi);
+ errno = fsys_startup (bootstrap, flags, right,
+ MACH_MSG_TYPE_COPY_SEND, &realnode);
+ mach_port_deallocate (mach_task_self (), newpi);
ports_port_deref (newpi);
}
if (errno)
@@ -186,12 +188,13 @@ _diskfs_init_completed ()
if (err)
goto errout;
- notify = ports_get_right (pi);
+ notify = ports_get_send_right (pi);
ports_port_deref (pi);
asprintf (&name,
"%s %s", program_invocation_short_name, diskfs_disk_name ?: "-");
err = startup_request_notification (init, notify,
- MACH_MSG_TYPE_MAKE_SEND, name);
+ MACH_MSG_TYPE_COPY_SEND, name);
+ mach_port_deallocate (mach_task_self (), notify);
free (name);
if (err)
goto errout;