summaryrefslogtreecommitdiff
path: root/libtrivfs/startup.c
diff options
context:
space:
mode:
authorMichael I. Bushnell <mib@gnu.org>1995-06-27 15:17:28 +0000
committerMichael I. Bushnell <mib@gnu.org>1995-06-27 15:17:28 +0000
commit54ad72d3d4dfe87176a6ebfa61ffdd57f48cf5d7 (patch)
treef4a86cf696ab213e96867d67d3ab1d2560dbbcbe /libtrivfs/startup.c
parent3310d5e315b0b789a1323b719cebee675b4bfe6b (diff)
(trivfs_startup): New parms CONTROL_BUCKET and PROTID_BUCKET; pass
them to trivfs_handle_port. Use new ports interface.
Diffstat (limited to 'libtrivfs/startup.c')
-rw-r--r--libtrivfs/startup.c13
1 files changed, 8 insertions, 5 deletions
diff --git a/libtrivfs/startup.c b/libtrivfs/startup.c
index 31312f9f..28bfb1a8 100644
--- a/libtrivfs/startup.c
+++ b/libtrivfs/startup.c
@@ -31,14 +31,18 @@
any error occurs sending fsys_startup, it is returned, otherwise 0. */
error_t
trivfs_startup(mach_port_t bootstrap,
- int control_type, int protid_type,
+ struct port_class *control_class,
+ struct port_bucket *control_bucket,
+ struct port_class *protid_class,
+ struct port_bucket *protid_bucket,
struct trivfs_control **control)
{
error_t err;
mach_port_t realnode;
struct trivfs_control *tcntl;
mach_port_t mcntl =
- trivfs_handle_port (MACH_PORT_NULL, control_type, protid_type);
+ trivfs_handle_port (MACH_PORT_NULL, control_class, control_bucket,
+ protid_class, protid_bucket);
assert(mcntl != MACH_PORT_NULL);
@@ -46,14 +50,13 @@ trivfs_startup(mach_port_t bootstrap,
err = fsys_startup (bootstrap, mcntl, MACH_MSG_TYPE_MAKE_SEND, &realnode);
/* Install the returned realnode for trivfs's use */
- tcntl = ports_check_port_type (mcntl, control_type);
+ tcntl = ports_lookup_port (control_bucket, mcntl, control_class);
assert (tcntl);
- ports_change_hardsoft (tcntl, 1);
if (!err)
tcntl->underlying = realnode;
- ports_done_with_port (tcntl);
+ ports_port_deref (tcntl);
if (control)
*control = tcntl;