diff options
-rw-r--r-- | libdiskfs/boot-start.c | 153 |
1 files changed, 48 insertions, 105 deletions
diff --git a/libdiskfs/boot-start.c b/libdiskfs/boot-start.c index b94fcf71..63454e9f 100644 --- a/libdiskfs/boot-start.c +++ b/libdiskfs/boot-start.c @@ -8,7 +8,7 @@ it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 2, or (at your option) any later version. -The GNU Hurd is distributed in the hope that it will be useful, +The GNU Hurd is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. @@ -20,15 +20,16 @@ the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA. */ /* Written by Michael I. Bushnell. */ #include "priv.h" -#include <hurd/fsys.h> #include <stdio.h> +#include <hurd.h> +#include <hurd/fsys.h> #include <hurd/exec.h> +#include <hurd/startup.h> #include <hurd/paths.h> #include <fcntl.h> #include <device/device.h> #include <sys/reboot.h> #include <string.h> -#include <hurd.h> #include "fsys_S.h" #include "fsys_reply_U.h" @@ -102,10 +103,10 @@ diskfs_start_bootstrap () MACH_MSG_TYPE_MAKE_SEND); ports_port_deref (rootpi); - + /* Contact the exec server. */ err = fsys_getroot (diskfs_exec_ctl, root_pt, MACH_MSG_TYPE_COPY_SEND, - idlist, 3, idlist, 3, 0, + idlist, 3, idlist, 3, 0, &retry, retry_name, &diskfs_exec); assert_perror (err); assert (retry == FS_RETRY_NORMAL); @@ -141,29 +142,29 @@ diskfs_start_bootstrap () } else initname = default_init; - + err = dir_lookup (root_pt, initname, O_READ, 0, &retry, pathbuf, &startup_pt); - + assert_perror (err); assert (retry == FS_RETRY_NORMAL); assert (pathbuf[0] == '\0'); bootinfo = ports_allocate_port (diskfs_port_bucket, sizeof (struct port_info), - diskfs_initboot_class); + diskfs_initboot_class); bootpt = ports_get_right (bootinfo); mach_port_insert_right (mach_task_self (), bootpt, bootpt, MACH_MSG_TYPE_MAKE_SEND); ports_port_deref (bootinfo); - + portarray[INIT_PORT_CRDIR] = root_pt; portarray[INIT_PORT_CWDIR] = root_pt; portarray[INIT_PORT_AUTH] = MACH_PORT_NULL; portarray[INIT_PORT_PROC] = MACH_PORT_NULL; portarray[INIT_PORT_CTTYID] = MACH_PORT_NULL; portarray[INIT_PORT_BOOTSTRAP] = bootpt; - + fdarray[0] = fdarray[1] = fdarray[2] = get_console (); /* XXX */ exec_argvlen = @@ -179,9 +180,9 @@ diskfs_start_bootstrap () printf (" init"); fflush (stdout); err = exec_exec (diskfs_exec, startup_pt, MACH_MSG_TYPE_COPY_SEND, - newt, 0, exec_argv, exec_argvlen, 0, 0, + newt, 0, exec_argv, exec_argvlen, 0, 0, fdarray, MACH_MSG_TYPE_COPY_SEND, 3, - portarray, MACH_MSG_TYPE_COPY_SEND, INIT_PORT_MAX, + portarray, MACH_MSG_TYPE_COPY_SEND, INIT_PORT_MAX, /* Supply no intarray, since we have no info for it. With none supplied, it will use the defaults. */ NULL, 0, 0, 0, 0, 0); @@ -198,34 +199,38 @@ diskfs_start_bootstrap () call (as does any task) to get its state. We can't give it all of its ports (we'll provide those with a later call to exec_init). */ kern_return_t -diskfs_S_exec_startup (mach_port_t port, - vm_address_t *base_addr, - vm_size_t *stack_size, - int *flags, - char **argvP, - u_int *argvlen, - char **envpP __attribute__ ((unused)), - u_int *envplen, - mach_port_t **dtableP, - mach_msg_type_name_t *dtablepoly, - u_int *dtablelen, - mach_port_t **portarrayP, - mach_msg_type_name_t *portarraypoly, - u_int *portarraylen, - int **intarrayP, - u_int *intarraylen) +diskfs_S_exec_startup_get_info (mach_port_t port, + vm_address_t *user_entry, + vm_address_t *phdr_data, + vm_size_t *phdr_size, + vm_address_t *base_addr, + vm_size_t *stack_size, + int *flags, + char **argvP, + mach_msg_type_number_t *argvlen, + char **envpP __attribute__ ((unused)), + mach_msg_type_number_t *envplen, + mach_port_t **dtableP, + mach_msg_type_name_t *dtablepoly, + mach_msg_type_number_t *dtablelen, + mach_port_t **portarrayP, + mach_msg_type_name_t *portarraypoly, + mach_msg_type_number_t *portarraylen, + int **intarrayP, + mach_msg_type_number_t *intarraylen) { mach_port_t *portarray, *dtable; mach_port_t rootport; struct ufsport *upt; struct protid *rootpi; - - if (!(upt = ports_lookup_port (diskfs_port_bucket, port, + + if (!(upt = ports_lookup_port (diskfs_port_bucket, port, diskfs_execboot_class))) return EOPNOTSUPP; - *base_addr = 0; - *stack_size = 0; + *user_entry = 0; + *phdr_data = *base_addr = 0; + *phdr_size = *stack_size = 0; /* We have no args for it. Tell it to look on its stack for the args placed there by the boot loader. */ @@ -233,18 +238,18 @@ diskfs_S_exec_startup (mach_port_t port, *flags = EXEC_STACK_ARGS; if (*portarraylen < INIT_PORT_MAX) - vm_allocate (mach_task_self (), (u_int *)portarrayP, + vm_allocate (mach_task_self (), (vm_address_t *) portarrayP, (INIT_PORT_MAX * sizeof (mach_port_t)), 1); portarray = *portarrayP; *portarraylen = INIT_PORT_MAX; if (*dtablelen < 3) - vm_allocate (mach_task_self (), (u_int *)dtableP, + vm_allocate (mach_task_self (), (vm_address_t *) dtableP, (3 * sizeof (mach_port_t)), 1); dtable = *dtableP; *dtablelen = 3; dtable[0] = dtable[1] = dtable[2] = get_console (); /* XXX */ - + *intarrayP = NULL; *intarraylen = 0; @@ -284,10 +289,10 @@ diskfs_execboot_fsys_startup (mach_port_t port, int flags, struct protid *rootpi; mach_port_t rootport; - if (!(pt = ports_lookup_port (diskfs_port_bucket, port, + if (!(pt = ports_lookup_port (diskfs_port_bucket, port, diskfs_execboot_class))) return EOPNOTSUPP; - + rootpi = diskfs_make_protid (diskfs_make_peropen (diskfs_root_node, flags, MACH_PORT_NULL), 0,0,0,0); @@ -313,7 +318,7 @@ diskfs_execboot_fsys_startup (mach_port_t port, int flags, ports_port_deref (pt); return 0; } - + /* Called by init to get the privileged ports as described in <hurd/fsys.defs>. */ kern_return_t @@ -329,7 +334,7 @@ diskfs_S_fsys_getpriv (mach_port_t port, if (!init_bootstrap_port) return EOPNOTSUPP; - + err = get_privileged_ports (host_priv, dev_master); if (!err) { @@ -359,7 +364,7 @@ diskfs_S_fsys_init (mach_port_t port, error_t err; mach_port_t root_pt; struct protid *rootpi; - + pt = ports_lookup_port (diskfs_port_bucket, port, diskfs_initboot_class); if (!pt) return EOPNOTSUPP; @@ -367,7 +372,7 @@ diskfs_S_fsys_init (mach_port_t port, if (initdone) return EOPNOTSUPP; initdone = 1; - + /* init is single-threaded, so we must reply to its RPC before doing anything which might attempt to send an RPC to init. */ fsys_init_reply (reply, replytype, 0); @@ -389,7 +394,7 @@ diskfs_S_fsys_init (mach_port_t port, /* Declare that the exec server is our child. */ proc_child (procserver, diskfs_exec_server_task); - /* Don't start this until now so that exec is fully authenticated + /* Don't start this until now so that exec is fully authenticated with proc. */ exec_init (diskfs_exec, authhandle, execprocess, MACH_MSG_TYPE_MOVE_SEND); @@ -470,70 +475,8 @@ diskfs_S_fsys_init (mach_port_t port, return MIG_NO_REPLY; /* Already replied above. */ } -/* Unused */ -error_t -diskfs_S_exec_init (mach_port_t a __attribute__ ((unused)), - auth_t b __attribute__ ((unused)), - process_t c __attribute__ ((unused))) -{ - return EOPNOTSUPP; -} - -/* Unused */ -error_t -diskfs_S_exec_setexecdata (mach_port_t a __attribute__ ((unused)), - mach_port_t *b __attribute__ ((unused)), - u_int c __attribute__ ((unused)), - int bcopy __attribute__ ((unused)), - int *d __attribute__ ((unused)), - u_int e __attribute__ ((unused)), - int ecopy __attribute__ ((unused))) -{ - return EOPNOTSUPP; -} - -/* Unused. */ -error_t -diskfs_S_exec_exec (mach_port_t execserver __attribute__ ((unused)), - mach_port_t file __attribute__ ((unused)), - mach_port_t oldtask __attribute__ ((unused)), - int flags __attribute__ ((unused)), - data_t argv __attribute__ ((unused)), - mach_msg_type_number_t argvCnt __attribute__ ((unused)), - boolean_t argvSCopy __attribute__ ((unused)), - data_t envp __attribute__ ((unused)), - mach_msg_type_number_t envpCnt __attribute__ ((unused)), - boolean_t envpSCopy __attribute__ ((unused)), - portarray_t dtable __attribute__ ((unused)), - mach_msg_type_number_t dtableCnt __attribute__ ((unused)), - boolean_t dtableSCopy __attribute__ ((unused)), - portarray_t portarray __attribute__ ((unused)), - mach_msg_type_number_t portarrayCnt - __attribute__ ((unused)), - boolean_t portarraySCopy __attribute__ ((unused)), - intarray_t intarray __attribute__ ((unused)), - mach_msg_type_number_t intarrayCnt - __attribute__ ((unused)), - boolean_t intarraySCopy __attribute__ ((unused)), - mach_port_t *deallocnames __attribute__ ((unused)), - u_int deallocnamescnt __attribute__ ((unused)), - mach_port_t *destroynames __attribute__ ((unused)), - u_int destroynamescnt __attribute__ ((unused)) - ) -{ - return EOPNOTSUPP; -} - -/* Unused. */ -error_t -diskfs_S_exec_boot_init (mach_port_t execserver __attribute__ ((unused)), - startup_t init __attribute__ ((unused))) -{ - return EOPNOTSUPP; -} - /* Start the execserver running (when we are a bootstrap filesystem). */ -static void +static void start_execserver (void) { mach_port_t right; |