summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--init/init.c48
1 files changed, 27 insertions, 21 deletions
diff --git a/init/init.c b/init/init.c
index 8e79d3be..14cea39e 100644
--- a/init/init.c
+++ b/init/init.c
@@ -200,29 +200,35 @@ run_for_real (char *filename)
{
file_t file;
error_t err;
-
- file = path_lookup (filename, O_EXEC, 0);
- if (file == MACH_PORT_NULL)
- perror (filename);
- else
+ char buf[512];
+ task_t task;
+
+ do
{
- task_t task;
- task_create (mach_task_self (), 0, &task);
- proc_child (procserver, task);
- proc_task2proc (procserver, task, &default_ports[INIT_PORT_PROC]);
- printf ("Pausing for %s\n", filename);
- getchar ();
- err = file_exec (file, task, 0,
- NULL, 0, /* No args. */
- NULL, 0, /* No env. */
- default_dtable, MACH_MSG_TYPE_COPY_SEND, 3,
- default_ports, MACH_MSG_TYPE_COPY_SEND,
- INIT_PORT_MAX,
- NULL, 0, /* No info in init ints. */
- NULL, 0, NULL, 0);
- mach_port_deallocate (mach_task_self (), default_ports[INIT_PORT_PROC]);
- mach_port_deallocate (mach_task_self (), task);
+ printf ("File name [%s]: ", filename);
+ if (getstring (buf, sizeof (buf)) && *buf)
+ filename = buf;
+ file = path_lookup (filename, O_EXEC, 0);
+ if (!file)
+ perror (filename);
}
+ while (!file);
+
+ task_create (mach_task_self (), 0, &task);
+ proc_child (procserver, task);
+ proc_task2proc (procserver, task, &default_ports[INIT_PORT_PROC]);
+ printf ("Pausing for %s\n", filename);
+ getchar ();
+ err = file_exec (file, task, 0,
+ NULL, 0, /* No args. */
+ NULL, 0, /* No env. */
+ default_dtable, MACH_MSG_TYPE_COPY_SEND, 3,
+ default_ports, MACH_MSG_TYPE_COPY_SEND,
+ INIT_PORT_MAX,
+ NULL, 0, /* No info in init ints. */
+ NULL, 0, NULL, 0);
+ mach_port_deallocate (mach_task_self (), default_ports[INIT_PORT_PROC]);
+ mach_port_deallocate (mach_task_self (), task);
mach_port_deallocate (mach_task_self (), file);
}