aboutsummaryrefslogtreecommitdiff
path: root/rumpdisk
diff options
context:
space:
mode:
authorDamien Zammit <damien@zamaudio.com>2021-03-16 16:47:15 +1100
committerSamuel Thibault <samuel.thibault@ens-lyon.org>2021-03-16 19:36:11 +0100
commitac1e123e56a2757cb3332e464fff6b23c36fdec1 (patch)
treeac9d54a57ac9feb2acc47bcfff9201fbe0e3bc53 /rumpdisk
parentb901dab073de26f9052a0c69872c1f3d4f15eea7 (diff)
downloadhurd-ac1e123e56a2757cb3332e464fff6b23c36fdec1.tar.gz
hurd-ac1e123e56a2757cb3332e464fff6b23c36fdec1.tar.bz2
hurd-ac1e123e56a2757cb3332e464fff6b23c36fdec1.zip
machdev,rump,pci: Rework bootstrap
* libmachdev/trivfs_server.c (bootstrapped): Rename to bootstrapping. (trivfs_S_fsys_startup): Call fsys_startup on the bootstrap port. (essential_task): New function. (trivfs_S_fsys_init): Call fsys_init on the bootstrap port. Configure proc. Mark us as essential when bootstrapping even without a devnode. (arrange_shutdown_notification): Do not configure proc. (machdev_trivfs_init): Always get the bootstrap port from the kernel, leave it MACH_PORT_NULL if unavailable. Call fsys_getpriv on it if it is. * pci-arbiter/Makefile (SRCS): Remove startup.c. * pci-arbiter/startup.c: Delete file. * pci-arbiter/startup.h: Delete file. * pci-arbiter/main.c: Do not include "startup.h" (pci_device_shutdown): Do not try to lokup the dosync_handle. (pcifs_startup): Always create the pci_control_port right on the control port. (main): Call machdev_device_init after machdev_trivfs_init. Do not call arrange_shutdown_notification. * rumpdisk/main.c (netfs_server_name): Don't pretend to be the arbiter anymore (main): Call machdev_device_init after machdev_trivfs_init. Message-Id: <20210316054715.788725-1-damien@zamaudio.com>
Diffstat (limited to 'rumpdisk')
-rw-r--r--rumpdisk/main.c7
1 files changed, 1 insertions, 6 deletions
diff --git a/rumpdisk/main.c b/rumpdisk/main.c
index a26e17cb..87bc5573 100644
--- a/rumpdisk/main.c
+++ b/rumpdisk/main.c
@@ -31,11 +31,6 @@
#include <pthread.h>
#include <mach.h>
-/* TODO: Add api to pciaccess to allow selecting backend.
- * For now we pretend to be the arbiter and claim x86 method.
- */
-char *netfs_server_name = "pci-arbiter";
-
mach_port_t bootstrap_resume_task = MACH_PORT_NULL;
static const struct argp_option options[] = {
@@ -117,8 +112,8 @@ main (int argc, char **argv)
}
rump_register_block ();
- machdev_device_init ();
machdev_trivfs_init (bootstrap_resume_task, "rumpdisk", "/dev/rumpdisk", &bootstrap);
+ machdev_device_init ();
err = pthread_create (&t, NULL, machdev_server, NULL);
if (err)
return err;