There's also an Appendix, which may be useful if you're new to Unix installation.
Why do you need a helper machine? The simple answer is, you need a helper to write a bootable NetBSD system onto a hard drive, because that's the only guaranteed way to boot NetBSD on a DECstation.
Pmaxes don't have floppy disk drives for the most part. Even those that do, don't support booting from them. Booting from tape, and making tape distributions, is too painful. And since NetBSD does not yet boot diskless on all DECstations, you may have no option but to construct a bootable disk using a miniroot and a helper machine.
Clearly, for installation on your first NetBSD/pmax machine, you can't use a NetBSD/pmax system to build that boot disk. You need to use some other system. Let's call this other system the "helper". You also need a disk drive onto which you'll end up installing NetBSD: the target disk.
There are three slightly different paths. Using another NetBSD system as a helper; or using Ultrix on a second machine as a helper; and using Ultrix on the target machine as a helper. Which path you choose depends on which is most convenient in your environment. However, keep in mind the fact that you're going to have to move the target disk from the helper to the target machine at some point -- and possibly several times, if you have trouble during the installation.
The bad news is, even when you get a miniroot filesystem installed, labelled, and booted, it's still far too small to hold a real root filesystem. You will almost certainly want to label a second target disk whilst running the NetBSD miniroot, use tar to copy the miniroot environment to the a patition of the second disk. This is a pain, but currently unavoidable.
Also, binary snapshots are regularly made for NetBSD/pmax of NetBSD-current. Those are available at ftp://ftp.NetBSD.org/pub/NetBSD/arch/pmax/snapshot/
Whichever set you choose, there are files called "miniroot", "bootrz" and "rzboot". Grab these now.
You also need a disklabel program, that can write NetBSD disk labels, for your helper machine. If your helper is a NetBSD system, you have it already. If your helper is an Ultrix system, then you can find the source code for a version of the NetBSD disklabel program that runs on Ultrix at ftp://ftp.NetBSD.org/pub/NetBSD/arch/pmax/tools/disklabel.tar.gz
If you can't find a helper machine, or more correctly you can't find a suitable disklabel program for it, there's still a dirty hack you can use.
It's worth stressing the following point: Since the disklabel tells NetBSD how the disk is divided into partition, it obviouly is going to tell NetBSD where to look for the miniroot, and a real root, when you eventually get around to booting it. But you need to put at least a miniroot onto a disk and boot, before you can use NetBSD to read the disklabel. So you need to access the NetBSD partitions, somehow, from whatever your helper system is. But you need to use the helper's disk drivers (and some kind of disk label) to do this.
The pmax kernel distributed on miniroots hardwires SCSI ids 0, 1, 2, 3, and 4 to be disk devices. You need to make sure that the SCSI ID of your target disks are in that range, or that you can them to be in that range before you boot them on a DECstation. The miniroot kernel also hardwires units 5 and 6 to be tapes; the CPU's SCSI adapter is SCSI 7. This very likely will not be the same numbering convention your helper machine uses.
Numbering will get much more flexible when we move to using the "standard" NetBSD SCSI drivers.
Once you have disklabel for your helper get bootrz and rzboot and put them in /usr/mdec. Then, decide how big you want your partitions to be and write a disk label to the target disk. This automagically put NetBSD/pmax bootblocks on the target disk.
To label a disk, on Ultrix, at unit number 3, using the NetBSD disklabel program compiled under Ultrix:
disklabel /dev/rz3c -b rzboot -s bootrz
NOTE: if you use a non-PMAX NetBSD machine it will assume you want to write the native bootblocks. You'll need to specify -b rzboot -s bootrz. It's not known that this really works. You may need to cross-compile a disklabel specially configured for pmaxes.
Note: The precompiled binary is an ECOFF version 3.0 binary. It should run on Ultrix systems from 4.2a through 4.4. If you have problems with core-dumps, read the README file that comes with the cross-disklabel tools. Also note that the /etc/disktab format the cross-disklabel needs is the NetBSD format, not the Ultrix format.
Most other systems use sd instead of rz.
To do this, use a command like
dd if=miniroot of=/dev/rD#P seek=16 skip=16
where D is a disk name, # is a unit number, and P is the partition for the whole disk. For example, with the target disk on an Ultrix system, at unit 1, that would be
dd if=miniroot of=/dev/rrz1c seek=16 skip=16
and on a Sun, with the target disk at unit 2, the corresponding command would be
dd if=miniroot of=/dev/rsd2c seek=16 skip=16
Note that earlier versions of these instructions omitted the skip=16 step. A workaround for that bug was to use an offset of 16 in the disklabel of the "A" partition. This should not be necessary if the skip=16 is specified.
The boot command you need to give the boot PROM depends on what model of DECstation your target is, the unit number of your SCSI disk, and which SCSI bus it's connected to.
In the examples below, # indicates the SCSI ID of your target disk, when it's on your target machine.
On a 3100, type:
setenv bootpath rz(0,#,0)netbsd boot
On a 5000/200, type:
boot 5/rz#a/netbsd
On a 5000/2x, 5000/1xx, or 5000/240, type:
boot 3/rz#a/netbsd
(If your target disk is attached to a TURBOchannel PMAZ-AA optional SCSI adapter, you should replace the 3 or 5 with the slot number of your SCSI adapter.)
This will boot the miniroot. You should then see output something like:
NetBSD 1.0A (INSTALL) #40: Tue Sep 12 15:01:05 PDT 1995 jonathan@Reno.Stanford.EDU:/greyhawk/n1/src/NetBSD/src/sys/arch/pmax/compile/INSTALL real mem = 67108864 avail mem = 57528320 using 1638 buffers containing 6709248 bytes of memory mainbus0 (root) tc0 at mainbus0 asic0 at tc0 slot 3 offset 0x0 le0 at asic0 offset 0xc0000 priority 4: address 08:00:2b:2b:06:43, 32 receive buffers, 8 transmit buffers scc0 at asic0 offset 0x100000 priority 6 scc1 at asic0 offset 0x180000 priority 5 clock0 at asic0 offset 0x200000 priority 0 asc0 at asic0 offset 0x300000 priority 3: target 7 le1 at tc0 slot 1 offset 0x0: address 08:00:2b:24:41:58, 32 receive buffers, 8 transmit buffers cfb0 at tc0 slot 0 offset 0x0 (1024x864x8) (console) autconfiguration done, spl back to 0x0 Beginning old-style SCSI device autoconfiguration rz0 at asc0 drive 0 slave 0 FUJITSU M2624F-512 rev 0304, 1015812 512 byte blocks root device?
The miniroot is now prompting you for a disk to use as the root filesystem. It's impossible to tell, when compiling a miniroot, what disk drives any given installer will choose to put NetBSD on. So the miniroot kernel asks which disk drive it should use as its root filesystem. You need to answer with the disk drive on which you put the miniroot (e.g., rz0 for drive 0, rz1 for drive 1, and so on). If you have more than one disk drive, the list of disk drives and unit numbers the kernel printed out should help you figure out the right response.
If you install the full distribution on a root disk and do not run MAKEDEV, you will not be able to boot from that disk -- not even in single-user mode.
The next thing to do is to unpack a full set of binaries and configuration files. Newfs the partitions you want to use for NetBSD. Then mount a disk that has a copy of base.tar.gz, and unpack it. (You can either mount an Ultrix disk read-only, or configure the network and NFS-mount from another machine). After that, unpack base.tar.gz with the obvious commands. And then you're done!
Of course, you'll want a full-size root partition first. If you have a disk with an empty 'A' partition, you newfs it, mount it, and can copy the contents of the miniroot to it with a command like:
( cd / ; tar cpf - . ) | (cd /newroot ; tar xpf - )
In the DOS world, a bootblock is something like the Master Boot Record, or MBR.
The traditional way to install 4.3BSD UNIX on a VAX-11 was to enter a small bootstrap program, in hex, from the console, and start the machine. The boot program would load a standalone monitor from a half-inch tape drive. Then, one used the standalone copy program to copy a miniroot -- the first file on the tape after the standalone utilities -- to what was going to be the swap partition of the 4.3BSD system. The miniroot has a special kernel that asks the device name to use as a root filesystem. If the root filesysstem ends in *, then the miniroot knew it was running out of a swap partition, and didn't swap on itself. This leaves the a partition of the target drive free. You then use the miniroot to newfs and unpack a root filesystem onto that a partition.
For example, one would use dd to write a miniroot onto NetBSD's b partition, booting it via boot 3/rz1b/netbsd, the miniroot to run on rz1*. Then use the miniroot shell to newfs /dev/rz1a and a /usr partition, and unpack a distribution onto the full root and /usr
It may help if you think of a miniroot as simply being an binary image of a boot floppy. Since 5 Mbyte floppies are hard to come by, we just write it to a hard disk instead. The easiest place to put it the miniroot is in the front of what will become the swap partition of the target disk, being careful not to swap there in the meantime.
NetBSD/pmax installation is much more complicated than this, because for a, variety of reasons, booting miniroots from swap partitions just doesn't work.
cat miniroot | dd of=/dev/r#c
but that's strongly dis-recommended, because it doesn't let you customize the disk label. In fact, you end up with no diskabel, so the kernel defaults to a compiled-in disk label that was suitable for a particular machine at Stanford. In addition, newer miniroots are prepared using the vnd driver instead of a real disk. vnd doesn't support writing disklabels, so newer miniroots may contain zeros instead of a pre-installed bootblock and disklabel. Attempt this at your own risk!
If you try this, you'll probably need two target disks: one for this dirty hack, and a second which you label after booting the miniroot set up with that dirty hack. It's also probably safer to use boot.dd instead of bootrz and rzboot.
boot.dd is the first 8 Kbytes -- the boot blocks and disk label -- dd'ed off a 'C' partition of a machine at Stanford, so the bootblocks and disk label can be dd'ed into the first 8 Kbytes of a disk, if there is absolutely no other way to construct a disklabel.
However, NetBSD/pmax doesn't yet boot diskless on all machines, so this isn't a generally-available option. If you wish to pursue it, see the NetBSD diskless 8 manual page and the pmax diskless boot configuration instructions.
Many DECstations will boot diskless using bootp and tftp. Whether or not yours will depends on the specific PROM revision you have. On those systems that can boot diskless, setting up a diskless-boot configuration may be the simplest way to label a local disk and install install NetBSD on it. (In effect, you use a diskless-booted NetBSD setup on the target machine as your helper machine.) Alternatively, you may wish to configure a NetBSD/pmax machine for production use as a diskless client. This section is an overview of how to set up a Decstation to boot NetBSD diskless, for either installation or permanent diskless boot.
boot 3/tftpwill attempt to netboot an ECOFF-format binary using the builtin Ethernet interface. On a 5000/200,
boot 6/tftp
does the same thing. On a 2100 or 3100, (boot -f tftp() is reported to work, but I am unable to verify it. If that fails on a 2100 or 3100, you need to do
setenv bootpath tftp()kernelname boot
Note that on the 3100, this clobbers any previous PROM bootpath. Write down the previous value of bootpath and keep it safe!
NetBSD/pmax kernels are compiled as ELF, and then converted to a.out so that the standard NetBSD tools (e.g., libkvm and (nlist) can read them. To build a net-bootable kernel, first configure and compile a kernel, say nfsnetbsd. Then convert the elf image (netbsd.elf) to ECOFF using the elf2ecoff tool.
Luckily, the kernel Makefiles already do something very similar, to convert the ELF-format kernel produced by the linker to a.out. You can almost cut-and-paste the commands. Just remember to change elf2aout to elf2ecoff. Be careful not overwrite the a.out kernel, if you'll want it later for a diskful boot!
.ris.dec:hn:vm=rfc1048 newbie:ht=ethernet:ha=08002b1e39cc:ip=10.0.0.84:bf=/some/path/we/can/tftp/to//nfsnetbsd
The 'ha' field is the hardware address of the machine requesting the diskless boot, and the 'bf' is a path that should be accessible for tftp. You can find the hardware address by examiing the PROM startup message on a 3100, or using the PROM cnfg command on a TURBOchannel machine.
A suitable kernel to use for diskless booting is the nfsnetbsd file from the NetBSD/pmax distribution. If you obtained nfsnetbsd.gz, remember to gunzip it before booting!
In section 8, make sure that you add the '-alldirs' flag to /etc/exports, if you're using a NetBSD system as the server. Also, if you get the client's root partition from the binary distribution, don't forget to populate its /dev directory.
Assuming all this works, you'll be running NetBSD with a root shell on the console. You can proceed to label your disk, newfs root and /usr partitions, and install the fulll binary distribution. There is no need to install a miniroot: if you can netboot NetBSD, you have all the tools necessary to label a disk and install a full-sized root and /usr partition.
The pmax boot PROMs use (dhcp-compliant) bootp requests to obtain an IP address and TFTP server from which to load a kernel; but once the NetBSD kernel itself is booted, it uses the rpc.bootparam protocol to find the IP address and other information. Ultrix does not include an rpc.bootparamd server.
Andrew Gallatin (gallatin@cs.Duke.EDU) has an rpc.bootparamd server that works under Ultrix, and will supply it on request. We are interested in hearing from anyone who tries this. We are also interested in building a list of which PROM versions and systems can boot successfully using tftp and/or MOP.
|
|