xref: /freebsd/share/man/man8/rc.subr.8 (revision b2c76c41be32f904179efed29c0ca04d53f3996c)
1.\" 	$NetBSD: rc.subr.8,v 1.12 2004/01/06 00:52:24 lukem Exp $
2.\"
3.\" Copyright (c) 2002-2004 The NetBSD Foundation, Inc.
4.\" All rights reserved.
5.\"
6.\" This code is derived from software contributed to The NetBSD Foundation
7.\" by Luke Mewburn.
8.\"
9.\" Redistribution and use in source and binary forms, with or without
10.\" modification, are permitted provided that the following conditions
11.\" are met:
12.\" 1. Redistributions of source code must retain the above copyright
13.\"    notice, this list of conditions and the following disclaimer.
14.\" 2. Redistributions in binary form must reproduce the above copyright
15.\"    notice, this list of conditions and the following disclaimer in the
16.\"    documentation and/or other materials provided with the distribution.
17.\"
18.\" THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
19.\" ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
20.\" TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
21.\" PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
22.\" BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
23.\" CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
24.\" SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
25.\" INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
26.\" CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
27.\" ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
28.\" POSSIBILITY OF SUCH DAMAGE.
29.\"
30.Dd August 16, 2022
31.Dt RC.SUBR 8
32.Os
33.Sh NAME
34.Nm rc.subr
35.Nd functions used by system shell scripts
36.Sh SYNOPSIS
37.Bl -item -compact
38.It
39.Ic .\& Pa /etc/rc.subr
40.Pp
41.It
42.Ic backup_file Ar action Ar file Ar current Ar backup
43.It
44.Ic checkyesno Ar var
45.It
46.Ic check_pidfile Ar pidfile Ar procname Op Ar interpreter
47.It
48.Ic check_process Ar procname Op Ar interpreter
49.It
50.Ic debug Ar message
51.It
52.Ic err Ar exitval Ar message
53.It
54.Ic force_depend Ar name
55.It
56.Ic info Ar message
57.It
58.Ic load_kld Oo Fl e Ar regex Oc Oo Fl m Ar module Oc Ar file
59.It
60.Ic load_rc_config Op Ar service
61.It
62.Ic load_rc_config_var Ar name Ar var
63.It
64.Ic mount_critical_filesystems Ar type
65.It
66.Ic rc_usage Ar command ...
67.It
68.Ic reverse_list Ar item ...
69.It
70.Ic run_rc_command Ar argument
71.It
72.Ic run_rc_script Ar file Ar argument
73.It
74.Ic startmsg Oo Fl n Oc Ar message
75.It
76.Ic wait_for_pids Op Ar pid ...
77.It
78.Ic warn Ar message
79.El
80.Sh DESCRIPTION
81The
82.Nm
83script
84contains commonly used shell script functions and variable
85definitions which are used by various scripts such as
86.Xr rc 8 .
87Scripts required by ports in
88.Pa /usr/local/etc/rc.d
89will also eventually
90be rewritten to make use of it.
91.Pp
92The
93.Nm
94functions were mostly imported from
95.Nx .
96.Pp
97They are accessed by sourcing
98.Pa /etc/rc.subr
99into the current shell.
100.Pp
101The following shell functions are available:
102.Bl -tag -width 4n
103.It Ic backup_file Ar action file current backup
104Make a backup copy of
105.Ar file
106into
107.Ar current .
108Save the previous version of
109.Ar current
110as
111.Ar backup .
112.Pp
113The
114.Ar action
115argument
116may be one of the following:
117.Bl -tag -width ".Cm remove"
118.It Cm add
119.Ar file
120is now being backed up by or possibly re-entered into this backup mechanism.
121.Ar current
122is created.
123.It Cm update
124.Ar file
125has changed and needs to be backed up.
126If
127.Ar current
128exists, it is copied to
129.Ar backup
130and then
131.Ar file
132is copied to
133.Ar current .
134.It Cm remove
135.Ar file
136is no longer being tracked by this backup mechanism.
137.Ar current
138is moved to
139.Ar backup .
140.El
141.It Ic checkyesno Ar var
142Return 0 if
143.Ar var
144is defined to
145.Dq Li YES ,
146.Dq Li TRUE ,
147.Dq Li ON ,
148or
149.Ql 1 .
150Return 1 if
151.Ar var
152is defined to
153.Dq Li NO ,
154.Dq Li FALSE ,
155.Dq Li OFF ,
156or
157.Ql 0 .
158Otherwise, warn that
159.Ar var
160is not set correctly.
161The values are case insensitive.
162.Em Note :
163.Ar var
164should be a variable name, not its value;
165.Ic checkyesno
166will expand the variable by itself.
167.It Ic check_pidfile Ar pidfile procname Op Ar interpreter
168Parses the first word of the first line of
169.Ar pidfile
170for a PID, and ensures that the process with that PID
171is running and its first argument matches
172.Ar procname .
173Prints the matching PID if successful, otherwise nothing.
174If
175.Ar interpreter
176is provided, parse the first line of
177.Ar procname ,
178ensure that the line is of the form:
179.Pp
180.Dl "#! interpreter [...]"
181.Pp
182and use
183.Ar interpreter
184with its optional arguments and
185.Ar procname
186appended as the process string to search for.
187.It Ic check_process Ar procname Op Ar interpreter
188Prints the PIDs of any processes that are running with a first
189argument that matches
190.Ar procname .
191.Ar interpreter
192is handled as per
193.Ic check_pidfile .
194.It Ic debug Ar message
195Display a debugging message to
196.Va stderr ,
197log it to the system log using
198.Xr logger 1 ,
199and
200return to the caller.
201The error message consists of the script name
202(from
203.Va $0 ) ,
204followed by
205.Dq Li ": DEBUG: " ,
206and then
207.Ar message .
208This function is intended to be used by developers
209as an aid to debugging scripts.
210It can be turned on or off
211by the
212.Xr rc.conf 5
213variable
214.Va rc_debug .
215.It Ic err Ar exitval message
216Display an error message to
217.Va stderr ,
218log it to the system log
219using
220.Xr logger 1 ,
221and
222.Ic exit
223with an exit value of
224.Ar exitval .
225The error message consists of the script name
226(from
227.Va $0 ) ,
228followed by
229.Dq Li ": ERROR: " ,
230and then
231.Ar message .
232.It Ic force_depend Ar name
233Output an advisory message and force the
234.Ar name
235service to start.
236The
237.Ar name
238argument is the
239.Xr basename 1
240component of the path to the script located at
241.Pa /etc/rc.d
242(scripts stored in other locations such as
243.Pa /usr/local/etc/rc.d
244cannot be controlled with
245.Ic force_depend
246currently).
247If the script fails for any reason it will output a warning
248and return with a return value of 1.
249If it was successful
250it will return 0.
251.It Ic info Ar message
252Display an informational message to
253.Va stdout ,
254and log it to the system log using
255.Xr logger 1 .
256The message consists of the script name
257(from
258.Va $0 ) ,
259followed by
260.Dq Li ": INFO: " ,
261and then
262.Ar message .
263The display of this informational output can be
264turned on or off by the
265.Xr rc.conf 5
266variable
267.Va rc_info .
268.It Ic load_kld Oo Fl e Ar regex Oc Oo Fl m Ar module Oc Ar file
269Load
270.Ar file
271as a kernel module unless it is already loaded.
272For the purpose of checking the module status,
273either the exact module name can be specified using
274.Fl m ,
275or an
276.Xr egrep 1
277regular expression matching the module name can be supplied via
278.Fl e .
279By default, the module is assumed to have the same name as
280.Ar file ,
281which is not always the case.
282.It Ic load_rc_config Op Ar service
283Source in the configuration file(s) for
284.Ar service .
285If no
286.Ar service
287is specified,
288only the global configuration file(s) will be loaded.
289First,
290.Pa /etc/rc.conf
291is sourced if it has not yet been read in.
292Then,
293.Pa /etc/rc.conf.d/ Ns Ar service
294is sourced if it is an existing file.
295The latter may also contain other variable assignments to override
296.Ic run_rc_command
297arguments defined by the calling script, to provide an easy
298mechanism for an administrator to override the behaviour of a given
299.Xr rc.d 8
300script without requiring the editing of that script.
301.It Ic load_rc_config_var Ar name Ar var
302Read the
303.Xr rc.conf 5
304variable
305.Ar var
306for
307.Ar name
308and set in the current shell, using
309.Ic load_rc_config
310in a sub-shell to prevent unwanted side effects from other variable
311assignments.
312.It Ic mount_critical_filesystems Ar type
313Go through a list of critical file systems,
314as found in the
315.Xr rc.conf 5
316variable
317.Va critical_filesystems_ Ns Ar type ,
318mounting each one that
319is not currently mounted.
320.It Ic rc_usage Ar command ...
321Print a usage message for
322.Va $0 ,
323with
324.Ar commands
325being the list of valid arguments
326prefixed by
327.Sm off
328.Dq Bq Li fast | force | one | quiet .
329.Sm on
330.It Ic reverse_list Ar item ...
331Print the list of
332.Ar items
333in reverse order.
334.It Ic run_rc_command Ar argument
335Run the
336.Ar argument
337method for the current
338.Xr rc.d 8
339script, based on the settings of various shell variables.
340.Ic run_rc_command
341is extremely flexible, and allows fully functional
342.Xr rc.d 8
343scripts to be implemented in a small amount of shell code.
344.Pp
345.Ar argument
346is searched for in the list of supported commands, which may be one
347of:
348.Bl -tag -width ".Cm restart" -offset indent
349.It Cm start
350Start the service.
351This should check that the service is to be started as specified by
352.Xr rc.conf 5 .
353Also checks if the service is already running and refuses to start if
354it is.
355This latter check is not performed by standard
356.Fx
357scripts if the system is starting directly to multi-user mode, to
358speed up the boot process.
359.It Cm stop
360If the service is to be started as specified by
361.Xr rc.conf 5 ,
362stop the service.
363This should check that the service is running and complain if it is not.
364.It Cm restart
365Perform a
366.Cm stop
367then a
368.Cm start .
369Defaults to displaying the process ID of the program (if running).
370.It Cm enabled
371Return 0 if the service is enabled and 1 if it is not.
372This command does not print anything.
373.It Cm rcvar
374Display which
375.Xr rc.conf 5
376variables are used to control the startup of the service (if any).
377.El
378.Pp
379If
380.Va pidfile
381or
382.Va procname
383is set, also support:
384.Bl -tag -width ".Cm restart" -offset indent
385.It Cm poll
386Wait for the command to exit.
387.It Cm status
388Show the status of the process.
389.El
390.Pp
391Other supported commands are listed in the optional variable
392.Va extra_commands .
393.Pp
394.Ar argument
395may have one of the following prefixes which alters its operation:
396.Bl -tag -width ".Li force" -offset indent
397.It Li fast
398Skip the check for an existing running process,
399and sets
400.Va rc_fast Ns = Ns Li YES .
401.It Li force
402Skip the checks for
403.Va rcvar
404being set to
405.Dq Li YES ,
406and sets
407.Va rc_force Ns = Ns Li YES .
408This ignores
409.Ar argument Ns Va _precmd
410returning non-zero, and ignores any of the
411.Va required_*
412tests failing, and always returns a zero exit status.
413.It Li one
414Skip the checks for
415.Va rcvar
416being set to
417.Dq Li YES ,
418but performs all the other prerequisite tests.
419.It Li quiet
420Inhibits some verbose diagnostics.
421Currently, this includes messages
422.Qq Starting ${name}
423(as checked by
424.Ic check_startmsgs
425inside
426.Nm )
427and errors about usage of services that are not enabled in
428.Xr rc.conf 5 .
429This prefix also sets
430.Va rc_quiet Ns = Ns Li YES .
431.Em Note :
432.Va rc_quiet
433is not intended to completely mask all debug and warning messages,
434but only certain small classes of them.
435.El
436.Pp
437.Ic run_rc_command
438uses the following shell variables to control its behaviour.
439Unless otherwise stated, these are optional.
440.Bl -tag -width ".Va procname" -offset indent
441.It Va name
442The name of this script.
443This is not optional.
444.It Va rcvar
445The value of
446.Va rcvar
447is checked with
448.Ic checkyesno
449to determine if this method should be run.
450.It Va command
451Full path to the command.
452Not required if
453.Ar argument Ns Va _cmd
454is defined for each supported keyword.
455Can be overridden by
456.Va ${name}_program .
457.It Va command_args
458Optional arguments and/or shell directives for
459.Va command .
460.It Va command_interpreter
461.Va command
462is started with:
463.Pp
464.Dl "#! command_interpreter [...]"
465.Pp
466which results in its
467.Xr ps 1
468command being:
469.Pp
470.Dl "command_interpreter [...] command"
471.Pp
472so use that string to find the PID(s) of the running command
473rather than
474.Va command .
475.It Va extra_commands
476Extra commands/keywords/arguments supported.
477.It Va pidfile
478Path to PID file.
479Used to determine the PID(s) of the running command.
480If
481.Va pidfile
482is set, use:
483.Pp
484.Dl "check_pidfile $pidfile $procname"
485.Pp
486to find the PID.
487Otherwise, if
488.Va command
489is set, use:
490.Pp
491.Dl "check_process $procname"
492.Pp
493to find the PID.
494.It Va procname
495Process name to check for.
496Defaults to the value of
497.Va command .
498.It Va required_dirs
499Check for the existence of the listed directories
500before running the
501.Cm start
502method.
503The list is checked before running
504.Va start_precmd .
505.It Va required_files
506Check for the readability of the listed files
507before running the
508.Cm start
509method.
510The list is checked before running
511.Va start_precmd .
512.It Va required_modules
513Ensure that the listed kernel modules are loaded
514before running the
515.Cm start
516method.
517The list is checked after running
518.Va start_precmd .
519This is done after invoking the commands from
520.Va start_precmd
521so that the missing modules are not loaded in vain
522if the preliminary commands indicate a error condition.
523A word in the list can have an optional
524.Dq Li \&: Ns Ar modname
525or
526.Dq Li ~ Ns Ar pattern
527suffix.
528The
529.Ar modname
530or
531.Ar pattern
532parameter is passed to
533.Ic load_kld
534through a
535.Fl m
536or
537.Fl e
538option, respectively.
539See the description of
540.Ic load_kld
541in this document for details.
542.It Va required_vars
543Perform
544.Ic checkyesno
545on each of the list variables
546before running the
547.Cm start
548method.
549The list is checked after running
550.Va start_precmd .
551.It Va ${name}_chdir
552Directory to
553.Ic cd
554to before running
555.Va command ,
556if
557.Va ${name}_chroot
558is not provided.
559.It Va ${name}_chroot
560Directory to
561.Xr chroot 8
562to before running
563.Va command .
564Only supported after
565.Pa /usr
566is mounted.
567.It Va ${name}_env
568A list of environment variables to run
569.Va command
570with.
571Those variables will be passed as arguments to the
572.Xr env 1
573utility unless
574.Ar argument Ns Va _cmd
575is defined.
576In that case the contents of
577.Va ${name}_env
578will be exported via the
579.Xr export 1
580builtin of
581.Xr sh 1 ,
582which puts some limitations on the names of variables
583(e.g., a variable name may not start with a digit).
584.It Va ${name}_env_file
585A file to source for environmental variables to run
586.Va command
587with.
588.Em Note :
589all the variables which are being assigned in this file are going
590to be exported into the environment of
591.Va command .
592.It Va ${name}_fib
593FIB
594.Pa Routing Table
595number to run
596.Va command
597with.
598See
599.Xr setfib 1
600for more details.
601.It Va ${name}_flags
602Arguments to call
603.Va command
604with.
605This is usually set in
606.Xr rc.conf 5 ,
607and not in the
608.Xr rc.d 8
609script.
610The environment variable
611.Sq Ev flags
612can be used to override this.
613.It Va ${name}_nice
614.Xr nice 1
615level to run
616.Va command
617as.
618Only supported after
619.Pa /usr
620is mounted.
621.It Va ${name}_limits
622Resource limits to apply to
623.Va command .
624This will be passed as arguments to the
625.Xr limits 1
626utility.
627By default, the resource limits are based on the login class defined in
628.Va ${name}_login_class .
629.It Va ${name}_login_class
630Login class to use with
631.Va ${name}_limits .
632Defaults to
633.Dq Li daemon .
634.It Va ${name}_oomprotect
635.Xr protect 1
636.Va command
637from being killed when swap space is exhausted.
638If
639.Dq Li YES
640is used, no child processes are protected.
641If
642.Dq Li ALL ,
643protect all child processes.
644.It Va ${name}_program
645Full path to the command.
646Overrides
647.Va command
648if both are set, but has no effect if
649.Va command
650is unset.
651As a rule,
652.Va command
653should be set in the script while
654.Va ${name}_program
655should be set in
656.Xr rc.conf 5 .
657.It Va ${name}_user
658User to run
659.Va command
660as, using
661.Xr chroot 8
662if
663.Va ${name}_chroot
664is set, otherwise
665uses
666.Xr su 1 .
667Only supported after
668.Pa /usr
669is mounted.
670.It Va ${name}_group
671Group to run the chrooted
672.Va command
673as.
674.It Va ${name}_groups
675Comma separated list of supplementary groups to run the chrooted
676.Va command
677with.
678.It Va ${name}_prepend
679Commands to be prepended to
680.Va command .
681This is a generic version of
682.Va ${name}_env ,
683.Va ${name}_fib ,
684or
685.Va ${name}_nice .
686.It Va ${name}_setup
687Command to be run prior to
688.Va command .
689.It Ar argument Ns Va _cmd
690Shell commands which override the default method for
691.Ar argument .
692.It Ar argument Ns Va _precmd
693Shell commands to run just before running
694.Ar argument Ns Va _cmd
695or the default method for
696.Ar argument .
697If this returns a non-zero exit code, the main method is not performed.
698If the default method is being executed, this check is performed after
699the
700.Va required_*
701checks and process (non-)existence checks.
702.It Ar argument Ns Va _postcmd
703Shell commands to run if running
704.Ar argument Ns Va _cmd
705or the default method for
706.Ar argument
707returned a zero exit code.
708.It Va sig_stop
709Signal to send the processes to stop in the default
710.Cm stop
711method.
712Defaults to
713.Dv SIGTERM .
714.It Va sig_reload
715Signal to send the processes to reload in the default
716.Cm reload
717method.
718Defaults to
719.Dv SIGHUP .
720.El
721.Pp
722For a given method
723.Ar argument ,
724if
725.Ar argument Ns Va _cmd
726is not defined, then a default method is provided by
727.Ic run_rc_command :
728.Bl -tag -width ".Sy Argument" -offset indent
729.It Sy Argument
730.Sy Default method
731.It Cm start
732If
733.Va command
734is not running and
735.Ic checkyesno Va rcvar
736succeeds, start
737.Va command .
738.It Cm stop
739Determine the PIDs of
740.Va command
741with
742.Ic check_pidfile
743or
744.Ic check_process
745(as appropriate),
746.Ic kill Va sig_stop
747those PIDs, and run
748.Ic wait_for_pids
749on those PIDs.
750.It Cm reload
751Similar to
752.Cm stop ,
753except that it uses
754.Va sig_reload
755instead, and does not run
756.Ic wait_for_pids .
757Another difference from
758.Cm stop
759is that
760.Cm reload
761is not provided by default.
762It can be enabled via
763.Va extra_commands
764if appropriate:
765.Pp
766.Dl "extra_commands=reload"
767.It Cm restart
768Runs the
769.Cm stop
770method, then the
771.Cm start
772method.
773.It Cm status
774Show the PID of
775.Va command ,
776or some other script specific status operation.
777.It Cm poll
778Wait for
779.Va command
780to exit.
781.It Cm rcvar
782Display which
783.Xr rc.conf 5
784variable is used (if any).
785This method always works, even if the appropriate
786.Xr rc.conf 5
787variable is set to
788.Dq Li NO .
789.El
790.Pp
791The following variables are available to the methods
792(such as
793.Ar argument Ns Va _cmd )
794as well as after
795.Ic run_rc_command
796has completed:
797.Bl -tag -width ".Va rc_service" -offset indent
798.It Va rc_arg
799Argument provided to
800.Ic run_rc_command ,
801after fast and force processing has been performed.
802.It Va rc_flags
803Flags to start the default command with.
804Defaults to
805.Va ${name}_flags ,
806unless overridden by the environment variable
807.Sq Ev flags .
808This variable may be changed by the
809.Ar argument Ns Va _precmd
810method.
811.It Va rc_service
812Path to the service script being executed, in case it needs to re-invoke itself.
813.It Va rc_pid
814PID of
815.Va command
816(if appropriate).
817.It Va rc_fast
818Not empty if
819.Dq Li fast
820prefix was used.
821.It Va rc_force
822Not empty if
823.Dq Li force
824prefix was used.
825.El
826.It Ic run_rc_script Ar file argument
827Start the script
828.Ar file
829with an argument of
830.Ar argument ,
831and handle the return value from the script.
832.Pp
833Various shell variables are unset before
834.Ar file
835is started:
836.Bd -ragged -offset indent
837.Va name ,
838.Va command ,
839.Va command_args ,
840.Va command_interpreter ,
841.Va extra_commands ,
842.Va pidfile ,
843.Va rcvar ,
844.Va required_dirs ,
845.Va required_files ,
846.Va required_vars ,
847.Ar argument Ns Va _cmd ,
848.Ar argument Ns Va _precmd .
849.Ar argument Ns Va _postcmd .
850.Ed
851.Pp
852The startup behaviour of
853.Ar file
854depends upon the following checks:
855.Bl -enum
856.It
857If
858.Ar file
859ends in
860.Pa .sh ,
861it is sourced into the current shell.
862.It
863If
864.Ar file
865appears to be a backup or scratch file
866(e.g., with a suffix of
867.Pa ~ , # , .OLD ,
868or
869.Pa .orig ) ,
870ignore it.
871.It
872If
873.Ar file
874is not executable, ignore it.
875.It
876If the
877.Xr rc.conf 5
878variable
879.Va rc_fast_and_loose
880is empty,
881source
882.Ar file
883in a sub shell,
884otherwise source
885.Ar file
886into the current shell.
887.El
888.It Ic startmsg Oo Fl n Oc Ar message
889Display a start message to
890.Va stdout .
891It should be used instead of
892.Xr echo 1 .
893The display of this output can be turned off if the
894.Xr rc.conf 5
895variable
896.Va rc_startmsgs
897is set to
898.Dq Li NO .
899.It Ic stop_boot Op Ar always
900Prevent booting to multiuser mode.
901If the
902.Va autoboot
903variable is set to
904.Ql yes
905(see
906.Xr rc 8
907to learn more about
908.Va autoboot ) ,
909or
910.Ic checkyesno Ar always
911indicates a truth value, then a
912.Dv SIGTERM
913signal is sent to the parent
914process, which is assumed to be
915.Xr rc 8 .
916Otherwise, the shell exits with a non-zero status.
917.It Ic wait_for_pids Op Ar pid ...
918Wait until all of the provided
919.Ar pids
920do not exist any more, printing the list of outstanding
921.Ar pids
922every two seconds.
923.It Ic warn Ar message
924Display a warning message to
925.Va stderr
926and log it to the system log
927using
928.Xr logger 1 .
929The warning message consists of the script name
930(from
931.Va $0 ) ,
932followed by
933.Dq Li ": WARNING: " ,
934and then
935.Ar message .
936.El
937.Sh FILES
938.Bl -tag -width ".Pa /etc/rc.subr" -compact
939.It Pa /etc/rc.subr
940The
941.Nm
942file resides in
943.Pa /etc .
944.El
945.Sh SEE ALSO
946.Xr rc.conf 5 ,
947.Xr rc 8
948.Sh HISTORY
949The
950.Nm
951script
952appeared in
953.Nx 1.3 .
954The
955.Xr rc.d 8
956support functions appeared in
957.Nx 1.5 .
958The
959.Nm
960script
961first appeared in
962.Fx 5.0 .
963