aboutsummaryrefslogtreecommitdiff
path: root/libmachdev
diff options
context:
space:
mode:
authorSamuel Thibault <samuel.thibault@ens-lyon.org>2021-08-11 16:27:43 +0200
committerSamuel Thibault <samuel.thibault@ens-lyon.org>2021-08-11 16:29:45 +0200
commit9049b963b6023ef6d7bd3f8c81ef5ab1f3b43fd3 (patch)
treeda5c163f6e6240d9400aa36fcdf38226e5e5e023 /libmachdev
parentc654480ef67c15b2cd9e774afa65f53b32693b40 (diff)
downloadhurd-9049b963b6023ef6d7bd3f8c81ef5ab1f3b43fd3.tar.gz
hurd-9049b963b6023ef6d7bd3f8c81ef5ab1f3b43fd3.tar.bz2
hurd-9049b963b6023ef6d7bd3f8c81ef5ab1f3b43fd3.zip
libmachdev: Fix startup_dosync
We do not actually want to shut everything down. For instance, we still have to be able to start the acpi translator to perform the actual shutdown. What we however have to do is syncing the disks.
Diffstat (limited to 'libmachdev')
-rw-r--r--libmachdev/ds_routines.c6
-rw-r--r--libmachdev/machdev-device_emul.h2
-rw-r--r--libmachdev/machdev.h2
-rw-r--r--libmachdev/trivfs_server.c8
4 files changed, 9 insertions, 9 deletions
diff --git a/libmachdev/ds_routines.c b/libmachdev/ds_routines.c
index c2de4b26..ac915166 100644
--- a/libmachdev/ds_routines.c
+++ b/libmachdev/ds_routines.c
@@ -315,13 +315,13 @@ void machdev_device_init()
}
}
-void machdev_device_shutdown(mach_port_t dosync_handle)
+void machdev_device_sync()
{
int i;
for (i = 0; i < num_emul; i++)
{
- if (emulation_list[i]->shutdown)
- emulation_list[i]->shutdown(dosync_handle);
+ if (emulation_list[i]->sync)
+ emulation_list[i]->sync();
}
}
diff --git a/libmachdev/machdev-device_emul.h b/libmachdev/machdev-device_emul.h
index 7748f37f..9f7b0b21 100644
--- a/libmachdev/machdev-device_emul.h
+++ b/libmachdev/machdev-device_emul.h
@@ -64,7 +64,7 @@ struct machdev_device_emulation_ops
recnum_t, vm_offset_t, vm_size_t);
io_return_t (*writev_trap) (void *, dev_mode_t,
recnum_t, io_buf_vec_t *, vm_size_t);
- void (*shutdown) (mach_port_t);
+ void (*sync) (void);
};
#endif /* _MACHDEV_DEVICE_EMUL_H_ */
diff --git a/libmachdev/machdev.h b/libmachdev/machdev.h
index 5d0eed02..7ac42eed 100644
--- a/libmachdev/machdev.h
+++ b/libmachdev/machdev.h
@@ -30,7 +30,7 @@
void machdev_register (struct machdev_device_emulation_ops *ops);
void machdev_device_init(void);
-void machdev_device_shutdown(mach_port_t dosync_handle);
+void machdev_device_sync(void);
void * machdev_server(void *);
error_t machdev_create_device_port (size_t size, void *result);
int machdev_trivfs_init(int argc, char **argv, mach_port_t bootstrap_resume_task, const char *name, const char *path, mach_port_t *bootstrap);
diff --git a/libmachdev/trivfs_server.c b/libmachdev/trivfs_server.c
index 5d7a1300..029a8da7 100644
--- a/libmachdev/trivfs_server.c
+++ b/libmachdev/trivfs_server.c
@@ -490,7 +490,7 @@ machdev_trivfs_init(int argc, char **argv, mach_port_t bootstrap_resume_task,
return 0;
}
-/* The system is going down. Sync data, then call trivfs_goaway() */
+/* The system is going down, sync data. */
error_t
S_startup_dosync (mach_port_t handle)
{
@@ -502,10 +502,10 @@ S_startup_dosync (mach_port_t handle)
ports_port_deref (inpi);
- /* Sync and close device(s) */
- machdev_device_shutdown (handle);
+ /* Sync device(s) */
+ machdev_device_sync ();
- return trivfs_goaway (NULL, FSYS_GOAWAY_FORCE);
+ return 0;
}
error_t