NetBSD/sys/arch/i386/netboot/README

182 lines
5.7 KiB
Plaintext
Raw Normal View History

Ethernet boot prom code.
This is code that can be burned into an eprom and installed in an
ethernet card. It uses the extension facilities of the bios to to boot
a kernel via the network.
Netboot uses bootp or rarp to determine its ip address and tftps a
designated kernel from a server. You should be running a daemon for
either bootp or rarp to service requests from this client. If you are
using bootp, the boot file name and the gateway (if necessary) will
also be transmitted to the client. If you use rarpd, the boot file
name is synthesized by this boot code from the eight hexadecimal
digits that comprise the IP address of the client and an extension of
"386bsd". If you use rarp, the rarp server must also be the tftp
server.
If you have configured both bootp and rarpd into the boot prom, the
response from the first host to respond via either protocol will be
used.
This code was developed using GNU as 2.1 and GNU cc version 2.3.3,
running under 386bsd. Pre 2.0 versions of GNU as might have trouble
with some syntax. Testing was done with a SMC Elite16 and 16k eproms.
Installation instructions:
Check the configurable parameters in Makefile.
Check the configurable parameters in the ethernet driver source for
the card you are using:
- in wd80x3.c: WD_BASEREG, WD_BASEMEM (irqs not used)
Make.
If you wish, you can test the binary (boot.bin) by copying it to a
floppy with the dosload.exe program and execute the boot code from the
floppy.
Burn the resultant binary (boot.bin) into an eprom and install it in
the ethernet card.
Decide which protocol (bootp or rarp) to use on a server; set up that
server.
Setting up a bootp server entails creating a bootpd client
configuration file. The format is similar to that of printcap. An
entry looks something like:
sams-1:\
:bf=diskless_kernel.386bsd:\
:gw=139.88.30.4:\
:ht=ethernet:\
:ha=0000c025e35b:\
:ip=139.88.30.39:\
:sm=255.255.255.0:\
:to=18000:
Setting up a rarpd server entails creating an ethernet/ip address
resolution file '/etc/ethers' with a line for each netboot client in
the form:
00:00:c0:25:e3:5b sams-1.lerc.nasa.gov
If you don't know the ethernet address, boot the client with the eprom
installed; the ethernet address of the card will be displayed.
Set up tftpd on a server. Check '/etc/inetd.conf'; there should be a
line that starts something like:
tftp dgram udp wait root ...
perhaps commented out.
Build a kernel that is capable of operating via NFS. Martin Renters
released some patches and a kernel configuration program that work
nicely (comp.os.386bsd.development around March 22, 1993); they should
be around somewhere. If you can't find them, I can email you a copy.
Make the kernel available via tftp under one of the names which this
code will use to look for the kernel. If you are using bootp, you can
specify the name as a bootp client configuration parameter. If you
don't specify the name, or if you are using rarp the this code will
synthesize the name using its client's IP address. The hexadecimal
version of the client's IP address with the extension '.386bsd' is the
default choice.
Create the exportable nfs mount points for which this kernel will use
and load them with necessary files (the base distribution, ...).
Export them so they can be mounted by this kernel when it boots from
the client IP address.
Usage instructions:
At any time the escape key can be struck to gain entrance to the
interactive monitor. There is a menu of monitor commands that can be
invoked to customize a boot operation.
Notes:
When Martin Renter's patches are applied to netbsd 0.8, there will be
one failure (pmap.c). Ignore it, the relevant code has already been
fixed.
I had some small problems with getfh(2) as used in the nfs configuring
program - I suspect the problem is a bug in SunOS 4.1.1 - if you have
similar problems, I can email you my gross hack workaround.
As noted by Mr. Renters, advisory flock()ing is not supported - this
breaks some programs. The first broken utility you will likely
encounter is vipw(1). The others: passwd, dump, ar, mail, tip, lpr,
sendmail.
You should examine your rc script and make appropriate changes to the
boot up sequence.
Here are the steps I took to bring netbsd 0.8 up for the client sams-1
using the host dinah in the domain lerc.nasa.gov.
- Create the /dev/vga device.
- Create some ptys.
- Create /etc/fstab to contain:
dinah:/home/386bsd-root / nfs rw
dinah:/home/386bsd-swap none swap rw
in it for the root and swap.
- Edit /etc/rc; the line 'mount -a -t nonfs' is changed to:
mount -a -t nonfs,swap
- Edit /etc/myname to contain
sams-1
- Edit /etc/hosts to contain:
127.0.0.1 localhost loghost
139.88.30.39 sams-1
and delete the other stuff in it.
- Create /etc/resolv.conf to contain:
domain lerc.nasa.gov
nameserver 128.156.1.43
nameserver 139.88.76.3
where the two addresses are those of some name servers in my domain.
There are, of course, the two alternatives of using just the /etc/hosts
file, or using named.
- Create /etc/mygate to contain:
139.88.30.4
which is the IP address of my gateway.
- Re-symlink /etc/localtime to the correct zone.
TBD:
-linux
-ne2100
-handle small memory configuration
-USE_BIOS version
-return to bios correctly
-remove old Phys... stuff; relics of real mode prom version
-accept bootd extension items & pass as args, modify kernel to
init nfs_diskless from args. Need:
myif [local] [bootp]
mygateway [bootp]
swap_args [local]
swap_fh [bootp]
swap_saddr [local] [bootp]
swap_hostname [bootp]
root_args [local]
root_fh [bootp]
root_saddr [local] [bootp]
root_hostnam [bootp]
A tight squeeze, passing all necessary info in one bootp packet.
Please send me any improvements you make to this code. It will be
appreciated.
Jim McKim (mckim@lerc.nasa.gov)