1 \ Copyright (c) 1999 Daniel C. Sobral <dcs@freebsd.org>
4 \ Redistribution and use in source and binary forms, with or without
5 \ modification, are permitted provided that the following conditions
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.
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
27 s" arch-i386" environment? [if] [if]
28 s" loader_version" environment? [if]
30 .( Loader version 1.1+ required) cr
34 .( Could not get loader version!) cr
39 256 dictthreshold ! \ 256 cells minimum free space
40 2048 dictincrease ! \ 2048 additional cells each time
42 include /boot/support.4th
43 include /boot/color.4th
45 only forth also support-functions also builtins definitions
48 \ menu-unset may not be present
49 s" beastie_disable" getenv
51 s" YES" compare-insensitive 0= if
72 0= if ( interpreted ) get_arguments then
75 ."
\e[37;44mBooting...
\e[0m" cr
80 \ Unload only if a path was passed
86 s" kernelname" getenv? if ( a kernel has been loaded )
90 load_kernel_and_modules
96 s" kernelname" getenv? if ( a kernel has been loaded )
100 load_kernel_and_modules
105 load_kernel_and_modules
106 ?dup 0= if 0 1 boot then
111 \ Prepares to boot as specified by loaded configuration files.
114 0= if ( interpreted ) get_arguments then
116 load_kernel_and_modules
117 ?dup 0= if 0 1 autoboot then
120 also forth definitions also builtins
125 only forth definitions also support-functions
127 include /boot/check-password.4th
131 \ Initializes support.4th global variables, sets loader_conf_files,
132 \ process conf files, and, if any one such file was succesfully
133 \ read to the end, load kernel and modules.
135 : start ( -- ) ( throws: abort & user-defined )
136 s" /boot/defaults/loader.conf" initialize
138 include_nextboot_file
139 \ Will *NOT* try to load kernel and modules if no configuration file
140 \ was succesfully loaded!
149 \ Overrides support.4th initialization word with one that does
150 \ everything start one does, short of loading the kernel and
151 \ modules. Returns a flag
153 : initialize ( -- flag )
154 s" /boot/defaults/loader.conf" initialize
156 include_nextboot_file
162 \ Read a configuration file, whose name was specified on the command
163 \ line, if interpreted, or given on the stack, if compiled in.
165 : (read-conf) ( addr len -- )
167 include_conf_files \ Will recurse on new loader_conf_files definitions
170 : read-conf ( <filename> | addr len -- ) ( throws: abort & user-defined )
180 \ show, enable, disable, toggle module loading. They all take module from
183 : set-module-flag ( module_addr val -- ) \ set and print flag
185 dup module.name strtype
186 module.flag @ if ." will be loaded" else ." will not be loaded" then cr
189 : enable-module find-module ?dup if true set-module-flag then ;
191 : disable-module find-module ?dup if false set-module-flag then ;
193 : toggle-module find-module ?dup if dup module.flag @ 0= set-module-flag then ;
197 \ Show loading information about a module.
199 : show-module ( <module> -- ) find-module ?dup if show-one-module then ;
201 \ Words to be used inside configuration files
203 : retry false ; \ For use in load error commands
204 : ignore true ; \ For use in load error commands
206 \ Return to strict forth vocabulary
214 : .? 2 spaces 2swap 15 #type 2 spaces type cr ;
218 s" boot-conf" s" load kernel and modules, then autoboot" .?
219 s" read-conf" s" read a configuration file" .?
220 s" enable-module" s" enable loading of a module" .?
221 s" disable-module" s" disable loading of a module" .?
222 s" toggle-module" s" toggle loading of a module" .?
223 s" show-module" s" show module load data" .?