install.md revision 1.8 1 # $NetBSD: install.md,v 1.8 2021/06/26 00:25:41 tsutsui Exp $
2 #
3 #
4 # Copyright (c) 1996 The NetBSD Foundation, Inc.
5 # All rights reserved.
6 #
7 # This code is derived from software contributed to The NetBSD Foundation
8 # by Jason R. Thorpe.
9 #
10 # Redistribution and use in source and binary forms, with or without
11 # modification, are permitted provided that the following conditions
12 # are met:
13 # 1. Redistributions of source code must retain the above copyright
14 # notice, this list of conditions and the following disclaimer.
15 # 2. Redistributions in binary form must reproduce the above copyright
16 # notice, this list of conditions and the following disclaimer in the
17 # documentation and/or other materials provided with the distribution.
18 #
19 # THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
20 # ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
21 # TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
22 # PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
23 # BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
24 # CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
25 # SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
26 # INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
27 # CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
28 # ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
29 # POSSIBILITY OF SUCH DAMAGE.
30 #
31
32 #
33 # machine dependent section of installation/upgrade script.
34 #
35
36 # Machine-dependent install sets
37 # MDSETS="xbin xman xinc xcon" XXX
38 MDSETS="kern-GENERIC"
39
40 md_set_term() {
41 if [ ! -z "$TERM" ]; then
42 return
43 fi
44 echo -n "Specify terminal type [sun]: "
45 getresp "sun"
46 TERM="$resp"
47 export TERM
48 }
49
50 md_makerootwritable() {
51 # Just remount the root device read-write.
52 if [ ! -e /tmp/root_writable ]; then
53 echo "Remounting root read-write..."
54 mi_mount_kernfs
55 mount -u -t ffs /kern/rootdev /
56 cp /dev/null /tmp/root_writable
57 fi
58 }
59
60 md_get_diskdevs() {
61 # return available disk devices
62 mi_mount_kernfs
63 mi_filter_msgbuf | sed -ne '/^[xs]d[0-9] /s/ .*//p' \
64 -e '/^xy[0-9] /s/ .*//p'
65 }
66
67 md_get_cddevs() {
68 # return available CDROM devices
69 mi_mount_kernfs
70 mi_filter_msgbuf | sed -ne '/^cd[0-9] /s/ .*//p'
71 }
72
73 md_get_ifdevs() {
74 # return available network devices
75 mi_mount_kernfs
76 mi_filter_msgbuf | sed -ne '/^[il]e[0-9] /s/ .*//p'
77 }
78
79 md_get_partition_range() {
80 # return an expression describing the valid partition id's
81 echo '[a-h]'
82 }
83
84 md_installboot() {
85 # install the boot block on disk $1
86 echo "Installing boot block..."
87 ( cd /usr/mdec ;\
88 cp -p ./ufsboot /mnt/ufsboot ;\
89 sync ; sleep 1 ; sync ;\
90 /usr/sbin/installboot -v /dev/r${1}a bootxx ufsboot )
91 echo "done."
92 }
93
94 md_native_fstype() {
95 }
96
97 md_native_fsopts() {
98 }
99
100 md_prep_disklabel() {
101 # $1 is the root disk
102 echo -n "Do you wish to edit the disklabel on ${1}? [y]"
103 getresp "y"
104 case "$resp" in
105 y*|Y*) ;;
106 *) return ;;
107 esac
108
109 # display example
110 cat << \__md_prep_disklabel_1
111 Here is an example of what the partition information will look like once
112 you have entered the disklabel editor. Disk partition sizes and offsets
113 are in sector (most likely 512 bytes) units. Make sure all partitions
114 start on a cylinder boundary (c/t/s == XXX/0/0).
115
116 [Example]
117 partition start (c/t/s) nblks (c/t/s) type
118
119 a (root) 0 (0/00/00) 31392 (109/00/00) 4.2BSD
120 b (swap) 31392 (109/00/00) 73440 (255/00/00) swap
121 c (disk) 0 (0/00/00) 1070496 (3717/00/00) unused
122 d (user) 104832 (364/00/00) 30528 (106/00/00) 4.2BSD
123 e (user) 135360 (470/00/00) 40896 (142/00/00) 4.2BSD
124 f (user) 176256 (612/00/00) 92160 (320/00/00) 4.2BSD
125 g (user) 268416 (932/00/00) 802080 (2785/00/00) 4.2BSD
126
127 [End of example]
128
129 Hit the <return> key when you have read this...
130
131 __md_prep_disklabel_1
132 getresp ""
133 edlabel /dev/r${1}c
134 }
135
136 md_copy_kernel() {
137 if [ ! -f /mnt/netbsd ]; then
138 echo -n "No kernel set extracted. Copying miniroot kernel..."
139 cp -p /netbsd /mnt/netbsd
140 echo "done."
141 fi
142 ln /mnt/netbsd /mnt/vmunix
143 }
144
145 md_welcome_banner() {
146 if [ "$MODE" = "install" ]; then
147 echo ""
148 echo "Welcome to the NetBSD/${MACHINE} ${RELEASE} installation program."
149 cat << \__welcome_banner_1
150
151 This program is designed to help you put NetBSD on your disk,
152 in a simple and rational way. You'll be asked several questions,
153 and it would probably be useful to have your disk's hardware
154 manual, the installation notes, and a calculator handy.
155 __welcome_banner_1
156
157 else
158 echo ""
159 echo "Welcome to the NetBSD/${MACHINE} ${VERSION} upgrade program."
160 cat << \__welcome_banner_2
161
162 This program is designed to help you upgrade your NetBSD system in a
163 simple and rational way.
164
165 As a reminder, installing the 'etc' binary set is NOT recommended.
166 Once the rest of your system has been upgraded, you should manually
167 merge any changes to files in the 'etc' set into those files which
168 already exist on your system.
169 __welcome_banner_2
170 fi
171
172 cat << \__welcome_banner_3
173
174 As with anything which modifies your disk's contents, this
175 program can cause SIGNIFICANT data loss, and you are advised
176 to make sure your data is backed up before beginning the
177 installation process.
178
179 Default answers are displayed in brackets after the questions.
180 You can hit Control-C at any time to quit, but if you do so at a
181 prompt, you may have to hit return. Also, quitting in the middle of
182 installation may leave your system in an inconsistent state.
183
184 __welcome_banner_3
185 }
186
187 md_not_going_to_install() {
188 cat << \__not_going_to_install_1
189
190 OK, then. Enter 'halt' at the prompt to halt the machine. Once the
191 machine has halted, power-cycle the system to load new boot code.
192
193 __not_going_to_install_1
194 }
195
196 md_congrats() {
197 local what;
198 if [ "$MODE" = "install" ]; then
199 what="installed";
200 else
201 what="upgraded";
202 fi
203 cat << __congratulations_1
204
205 CONGRATULATIONS! You have successfully $what NetBSD!
206 To boot the installed system, enter halt at the command prompt. Once the
207 system has halted, reset the machine and boot from the disk.
208
209 __congratulations_1
210 }
211