diff options
author | kan <kan@FreeBSD.org> | 2005-03-12 21:26:53 +0000 |
---|---|---|
committer | kan <kan@FreeBSD.org> | 2005-03-12 21:26:53 +0000 |
commit | 21240a6daf5497baf0d15c2c75c104e72760a7df (patch) | |
tree | 1bea38ba12920bed826a2baf3e725779e0755901 /sys/boot | |
parent | d5c41269cf4401fe8ddb1a336604522d15a42c1c (diff) | |
download | FreeBSD-src-21240a6daf5497baf0d15c2c75c104e72760a7df.zip FreeBSD-src-21240a6daf5497baf0d15c2c75c104e72760a7df.tar.gz |
Allow kernels loaded by pxeboot, which was compiled with LOADER_TFTP_SUPPORT,
to stll be able to mount NFS root as prescribed by DCHP configuration. Since
pxeboot is using TFTP to get to the files, pxeboot can not rely on NFS to
provide it a root directory hande as a side effect. pxeboot has to make RPC
mount call itself.
Diffstat (limited to 'sys/boot')
-rw-r--r-- | sys/boot/i386/libi386/pxe.c | 24 |
1 files changed, 24 insertions, 0 deletions
diff --git a/sys/boot/i386/libi386/pxe.c b/sys/boot/i386/libi386/pxe.c index b78508a..a0f66a7 100644 --- a/sys/boot/i386/libi386/pxe.c +++ b/sys/boot/i386/libi386/pxe.c @@ -413,6 +413,22 @@ struct nfs_iodesc { /* structure truncated here */ }; extern struct nfs_iodesc nfs_root_node; +extern int rpc_port; + +static void +pxe_rpcmountcall() +{ + struct iodesc *d; + int error; + + if (!(d = socktodesc(pxe_sock))) + return; + d->myport = htons(--rpc_port); + d->destip = rootip; + if ((error = nfs_getrootfh(d, rootpath, nfs_root_node.fh)) != 0) + printf("NFS MOUNT RPC error: %d\n", error); + nfs_root_node.iodesc = d; +} static void pxe_setnfshandle(char *rootpath) @@ -421,6 +437,14 @@ pxe_setnfshandle(char *rootpath) u_char *fh; char buf[2 * NFS_FHSIZE + 3], *cp; + /* + * If NFS files were never opened, we need to do mount call + * ourselves. Use nfs_root_node.iodesc as flag indicating + * previous NFS usage. + */ + if (nfs_root_node.iodesc == NULL) + pxe_rpcmountcall(); + fh = &nfs_root_node.fh[0]; buf[0] = 'X'; cp = &buf[1]; |