summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--trans/null.c23
1 files changed, 5 insertions, 18 deletions
diff --git a/trans/null.c b/trans/null.c
index 9982481c..02b7a9c0 100644
--- a/trans/null.c
+++ b/trans/null.c
@@ -24,8 +24,8 @@
#include <hurd/fsys.h>
#include <stdio.h>
+#include <unistd.h>
#include <error.h>
-#include <assert.h>
#include <string.h>
#include <fcntl.h>
#include <limits.h>
@@ -44,8 +44,7 @@ void
main (int argc, char **argv)
{
error_t err;
- mach_port_t bootstrap, control, realnode;
- struct trivfs_control *trivfs_control;
+ mach_port_t bootstrap;
if (argc == 2 &&
(strcmp(argv[1], "-z") == 0 || strcmp(argv[1], "--zero") == 0))
@@ -60,20 +59,10 @@ main (int argc, char **argv)
if (bootstrap == MACH_PORT_NULL)
error(1, 0, "must be started as a translator");
- _libports_initialize();
-
/* Reply to our parent */
- control = trivfs_handle_port (MACH_PORT_NULL, PT_CTL, PT_NODE);
- err = fsys_startup (bootstrap, control, MACH_MSG_TYPE_MAKE_SEND, &realnode);
+ err = trivfs_startup(bootstrap, PT_CTL, PT_NODE, NULL);
if (err)
- error(1, err, "starting translator");
-
- /* Install the returned realnode for trivfs's use */
- trivfs_control = ports_check_port_type (control, PT_CTL);
- assert (trivfs_control);
- ports_change_hardsoft (trivfs_control, 1);
- trivfs_control->underlying = realnode;
- ports_done_with_port (trivfs_control);
+ error(3, err, "Contacting parent");
/* Launch. */
ports_manage_port_operations_onethread ();
@@ -85,7 +74,7 @@ main (int argc, char **argv)
/* Trivfs hooks */
int trivfs_fstype = FSTYPE_DEV;
-int trivfs_fsid = 0; /* ??? */
+int trivfs_fsid = 0;
int trivfs_support_read = 1;
int trivfs_support_write = 1;
@@ -103,8 +92,6 @@ trivfs_modify_stat (struct stat *st)
{
st->st_blksize = vm_page_size;
- st->st_fstype = FSTYPE_DEV;
-
st->st_size = 0;
st->st_blocks = 0;