README.altboot revision 1.6
1/// notes about altboot ///
2
3$NetBSD: README.altboot,v 1.6 2011/11/13 16:22:18 phx Exp $
4
5Altboot is a functional bridge to fill the gap between a NAS product
6custom bootloader and the NetBSD kernel startup environment.  Altboot
7irons out and rectifies erroneously configured HW by product
8bootloaders and prepares a sane runtime, better suited for booting
9NetBSD kernels.
10
11- provides the foundation of a fast NetBSD porting cycle with functionalities
12  product bootloaders don't have.
13- facilitates a flexible and clean NetBSD implementation tailoured
14  to target HW in detail, minimizing bumpy adjustments and hacks in
15  locore asm and machdeps in very early kernel startup stage.
16- levels out differences among similar-but-not-the-same porting
17  targets to make it possible having common NetBSD kernels for them.
18- builds and hands a bootinfo list to the NetBSD kernel.
19
20Altboot is known working on at least these models:
21
22- KuroBox or LinkStation with a popular U-Boot as the replacement of
23  vendor proprietary
24
25   U-Boot 1.1.4 LiSt 2.1.0 (Sep 21 2006 - 00:22:56) LinkStation / KuroBox
26
27- Synology 101g+ with vendor custom PPCboot
28
29   PPCBoot 2.0.0 (Mar  1 2005 - 15:31:41)
30
31- Synology 106j, 207, 407e with vendor custom PPCboot
32
33   PPCBoot 2.0.0 (Jan 30 2007 - xx:xx:xx)
34
35- D-Link DSM-G600 with heavily restricted vendor custom U-Boot
36
37   U-Boot 0.2.0 (May 26 2005 - 19:38:32)
38
39- QNAP TS-101 (V200) with vendor custom U-Boot
40
41   U-Boot 1.1.2 (Aug 28 2005 - 13:37:25) QNAP System, Inc.
42
43The standard use of altboot is to invoke it with a short script from
44U-Boot/PPCboot, where the altboot.bin image is stored in an unoccupied 128KB
45section of the target's HW NOR flash.  Combined with standard
46U-Boot/PPCboot functions, it is possible to boot a NetBSD kernel off
47it right after power-on, without the help of manual intervention.  Note
48that the original U-Boot/PPCboot still remains useful and altboot works
49as a functional extension for them.
50
51In case the firmware was crippled by the vendor so that it only boots
52Linux U-Boot images (D-Link), you can still use altboot by uploading
53altboot.img instead of the Linux kernel.
54
55Altboot hands the following bootinfo records to the NetBSD/sandpoint
56kernel.
57- processor clock tick value driving MPC8241/8245.
58- serial console selection.
59- booted kernel filename and which device it was fetched from.
60- Ethernet MAC address, if target HW lacks SEEPROM to store a unit unique
61  value.
62- product family indication.
63- preloaded kernel module names (under development).
64
65When no arguments are given, altboot defaults to boot a kernel called
66"netbsd" from the root partition of the first disk in multiuser mode.
67
68Boot arguments may be passed in three ways:
69- On the command line, directly after the "go 0x1000000" command.
70- From the U-Boot "bootargs" environment variable, when started by "bootm".
71- By entering the interactive mode.
72
73The following boot arguments are recognized:
74- multi			boot into multiuser
75- auto			boot into multiuser
76- single		boot into singleuser
77- ask			ask for boot device
78- ddb			drop into the kernel debugger
79- userconf		change configured devices
80
81The following boot flags are recognized:
82- norm			boot normally
83- quiet			boot quietly
84- verb			boot verbosely
85- silent		boot silently
86- debug			boot with debug output
87
88Additionally the special argument "altboot" is recognized, which replaces
89the actually running altboot program with the loaded binary file and
90restarts itself. Mainly useful for altboot testing.
91
92Multiple arguments may be specified at once, although not all combinations
93make sense. The format of an altboot command line is:
94
95  [[<bootargs> ...] <devicename>:[<bootfile>]]
96
97The following device names are supported:
98- tftp			boot from TFTP (address retrieved by DHCP)
99- nfs			boot from NFS (address retrieved by DHCP)
100- wd[N[P]]		boot from disk N, partition P, defaults to wd0a
101- mem			boot from memory
102
103For tftp and nfs the bootfile is determined by DHCP, when missing.
104For wd it defaults to "netbsd".
105For mem the bootfile is actually a hexadecimal address to load from and
106is mandatory.
107
108                             ### ### ###
109