riscv vmm: implement SBI RFNC extension.
[freebsd/src.git] / stand / forth / menu.4th.8
blob2421fe03be0c26c0e006ef435b4f37ff1cff60bd
1 .\" Copyright (c) 2011-2013 Devin Teske
2 .\" All rights reserved.
3 .\"
4 .\" Redistribution and use in source and binary forms, with or without
5 .\" modification, are permitted provided that the following conditions
6 .\" are met:
7 .\" 1. Redistributions of source code must retain the above copyright
8 .\"    notice, this list of conditions and the following disclaimer.
9 .\" 2. Redistributions in binary form must reproduce the above copyright
10 .\"    notice, this list of conditions and the following disclaimer in the
11 .\"    documentation and/or other materials provided with the distribution.
12 .\"
13 .\" THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
14 .\" ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
15 .\" IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
16 .\" ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
17 .\" FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
18 .\" DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
19 .\" OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
20 .\" HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
21 .\" LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
22 .\" OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
23 .\" SUCH DAMAGE.
24 .\"
25 .Dd October 4, 2024
26 .Dt MENU.4TH 8
27 .Os
28 .Sh NAME
29 .Nm menu.4th
30 .Nd FreeBSD dynamic menu boot module
31 .Sh DESCRIPTION
32 The file that goes by the name of
33 .Nm
34 is a set of commands designed to display a dynamic menu system managed through
35 a system of carefully named environment variables.
36 The commands of
37 .Nm
38 by themselves are not enough for most uses.
39 Please refer to the
40 examples below for the most common situations, and to
41 .Xr loader 8
42 for additional commands.
43 .Pp
44 Before using any of the commands provided in
45 .Nm ,
46 it must be included
47 through the command:
48 .Pp
49 .Dl include menu.4th
50 .Pp
51 This line is present in the default
52 .Pa /boot/menu.rc
53 file, so it is not needed (and should not be re-issued) in a normal setup.
54 .Pp
55 The commands provided by it are:
56 .Pp
57 .Bl -tag -width disable-module_module -compact -offset indent
58 .It Ic menu-init
59 Draws the menu bounding box and initializes some internal state variables.
60 This should be called before any other menu-related functions.
61 .It Ic menu-display
62 Displays the menu (configured via the below documented environment variables)
63 and blocks on keyboard input, awaiting user action.
64 .It Ic menu-erase
65 Clears the screen area within the menu bounding box.
66 .It Ic menu-redraw
67 Calls
68 .Ic menu-erase
69 and then redraws the menu.
70 .It Ic menu-unset
71 Unsets the environment variables associated with individual menu items,
72 clearing the way for a new menu.
73 .It Ic menu-clear
74 Calls
75 .Ic menu-unset
76 and then
77 .Ic menu-erase .
78 .El
79 .Pp
80 The environment variables that effect its behavior are:
81 .Bl -tag -width bootfile -offset indent
82 .It Va loader_color
83 If set to
84 .Dq Li NO
85 (case-insensitive) or
86 .Dq Li 0 ,
87 causes the menu to be displayed without color.
88 The default is to use ANSI coloring whenever possible.
89 If serial boot is enabled, color is disabled by default.
90 Color features include the use of ANSI bold for numbers appearing to the left
91 of menuitems and the use of special
92 .Dq Li ansi
93 variables described below.
94 .It Va autoboot_delay
95 Number of seconds
96 .Ic menu-display
97 will wait before executing
98 .Va menu_timeout_command
99 .Ic ( boot
100 by default) unless a key is pressed.
101 If set to
102 .Dq Li NO
103 (case-insensitive)
104 .Ic menu-display
105 will wait for user input and never execute
106 .Ic menu_timeout_command .
107 If set to
108 .Dq Li -1 ,
109 .Ic menu-display
110 will boot immediately, preventing both interruption of the
111 .Ic autoboot
112 process and escaping to the loader prompt.
113 Default is
114 .Dq Li 10 .
116 .Xr loader 8
117 for additional information.
118 .It Va menu_timeout_command
119 The command to be executed after
120 .Va autoboot_delay
121 seconds if a key is not pressed.
122 The default is
123 .Ic boot .
124 .It Va loader_menu_frame
125 Sets the desired box style to draw around the boot menu.
126 Possible values are:
127 .Dq Li single
128 .Pq the default ,
129 .Dq Li double ,
131 .Dq Li none .
132 .It Va loader_menu_timeout_x
133 Sets the desired column position of the timeout countdown text.
134 Default is 4.
135 .It Va loader_menu_timeout_y
136 Sets the desired row position of the timeout countdown text.
137 Default is 23.
138 .It Va loader_menu_title
139 The text to display above the menu.
140 Default is
141 .Dq Li "Welcome to FreeBSD" .
142 .It Va loader_menu_title_align
143 Default is to align
144 .Ic loader_menu_title
145 centered above the menu. This can be set to
146 .Dq Li left
148 .Dq Li right
149 to instead display the title left-or-right justified
150 .Pq respectively .
151 .It Va loader_menu_x
152 Sets the desired column position of the boot menu.
153 Default is 5.
154 .It Va loader_menu_y
155 Sets the desired row position of the boot menu.
156 Default is 10.
157 .It Va menu_caption[x]
158 The text to be displayed for the numbered menuitem
159 .Dq Li x .
160 .It Va menu_command[x]
161 The command to be executed when the number associated with menuitem
162 .Dq Li x
163 is pressed.
164 See the list of included FICL words below for some ideas.
165 .It Va menu_keycode[x]
166 An optional decimal ASCII keycode to be associated with menuitem
167 .Dq Li x .
168 When pressed, will cause the execution of
169 .Va menu_command[x] .
170 .It Va ansi_caption[x]
172 .Va loader_color
173 is set
174 .Pq enabled by default ,
175 use this caption for menuitem
176 .Dq Li x
177 instead of
178 .Va menu_caption[x] .
179 .It Va toggled_text[x]
180 For menuitems where
181 .Va menu_command[x]
182 is set to
183 .Dq Li toggle_menuitem
184 (or a derivative thereof), the text displayed
185 will toggle between this and
186 .Va menu_caption[x] .
187 .It Va toggled_ansi[x]
188 Like
189 .Va toggled_text[x]
190 except used when
191 .Va loader_color
192 is enabled
193 .Pq default .
194 .It Va menu_caption[x][y]
195 For menuitems where
196 .Va menu_command[x]
197 is set to
198 .Dq Li cycle_menuitem
199 (or a derivative thereof), the text displayed will cycle between this and other
200 .Va menu_caption[x][y]
201 entries.
202 .It Va ansi_caption[x][y]
203 Like
204 .Va menu_caption[x][y]
205 except used when
206 .Va loader_color
207 is enabled
208 .Pq default .
209 .It Va menu_acpi
210 When set to a number
211 .Dq Li x
212 associated with a given menuitem, that menuitem will only appear when
213 running on ACPI-compatible hardware,
214 .Va acpi.rsdp
215 is set (indicating the presence of hardware ACPI support as detected by
216 .Xr loader 8 ) ,
218 .Va hint.acpi.0.disabled
219 is not set.
220 On non-i386 hardware, menuitems configured after the
221 .Dq Li menu_acpi
222 menuitem will use a lower number (to compensate for the missing ACPI menuitem)
223 but continue to function as expected.
224 On i386-compatible hardware lacking ACPI support (as detected by
225 .Xr loader 8 ) ,
226 subsequent menuitems will retain their associated numbers.
227 .It Va acpi.rsdp
228 Set automatically by
229 .Xr loader 8
230 on ACPI-compatible hardware when ACPI support is detected at boot time.
231 Effects the display of the
232 .Dq Li menu_acpi
233 menuitem (if configured).
234 .It Va hint.acpi.0.disabled
235 Effects the display of the
236 .Va menu_acpi
237 menuitem.
238 If set, the menuitem will display
239 .Va toggled_text[x]
240 .Va ( toggled_ansi[x]
242 .Va loader_color
243 is set), otherwise
244 .Va menu_caption[x]
245 .Va ( ansi_caption[x]
247 .Va loader_color
248 is set).
249 .It Va menu_options
250 When set to a number
251 .Dq Li x ,
252 a single blank-line and an
253 .Dq Li Options
254 header are inserted between
255 .Va menu_caption[x-1]
257 .Va menu_caption[x]
258 (if configured).
259 .It Va menu_reboot
260 If set, adds a built-in
261 .Dq Li Reboot
262 menuitem to the end of the last configured menuitem.
264 .Va menu_options
265 is configured, the
266 .Dq Li Reboot
267 menuitem will be inserted before the
268 .Dq Options
269 separator.
272 In addition, it provides the following FICL words:
274 .Bl -tag -width disable-module_module -compact -offset indent
275 .It Ic arch-i386? ( -- BOOL )
276 Returns true (-1) on i386 and false (0) otherwise.
277 .It Ic acpipresent? ( -- BOOL )
278 Returns true (-1) if ACPI is present and false (0) otherwise.
279 .It Ic acpienabled? ( -- BOOL )
280 Returns true (-1) if ACPI is enabled and false (0) otherwise.
281 .It Ic toggle_menuitem ( N -- N )
282 Toggles menuitem
283 .Dq Li N
284 between
285 .Va menu_caption[x]
287 .Va toggled_text[x]
288 (where
289 .Dq Li N
290 represents the ASCII decimal value for
291 .Dq Li x ) .
292 .It Ic cycle_menuitem ( N -- N )
293 Cycles menuitem
294 .Dq Li N
295 between
296 .Va menu_caption[x][y]
297 entries (where
298 .Va N
299 represents the ASCII decimal value for
300 .Va x ) .
303 For all values of
304 .Dq Li x
305 above, use any number between 1 through 9. Sorry, double-digits are not
306 currently supported.
307 .Sh FILES
308 .Bl -tag -width /boot/loader.4th -compact
309 .It Pa /boot/loader
311 .Xr loader 8 .
312 .It Pa /boot/menu.4th
314 itself.
315 .It Pa /boot/loader.rc
316 .Xr loader 8
317 bootstrapping script.
319 .Sh EXAMPLES
320 A simple boot menu:
322 .Bd -literal -offset indent -compact
323 include /boot/menu.4th
324 menu-init
325 set menu_caption[1]="Boot"
326 set menu_command[1]="boot"
327 set menu_options=2
328 set menu_caption[2]="Option: NO"
329 set toggled_text[2]="Option: YES"
330 set menu_command[2]="toggle_menuitem"
331 set menu_timeout_command="boot"
332 set menu_reboot
333 menu-display
335 .Sh SEE ALSO
336 .Xr loader.conf 5 ,
337 .Xr beastie.4th 8 ,
338 .Xr loader 8 ,
339 .Xr loader.4th 8
340 .Sh HISTORY
343 set of commands first appeared in
344 .Fx 9.0 .
345 .Sh AUTHORS
348 set of commands was written by
349 .An -nosplit
350 .An Devin Teske Aq dteske@FreeBSD.org .