Compare commits

..

401 Commits

Author SHA1 Message Date
Roy Marples
79fe5af027 Release openrc-0.5.0 2009-06-05 09:18:47 +01:00
Roy Marples
401def2b8f Ignore more foo 2009-06-05 09:17:18 +01:00
Roy Marples
be3dd0b8e4 Update copyright 2009-06-05 09:15:55 +01:00
Roy Marples
e689f17933 Support NetBSD envstat for working out if on AC power. 2009-05-29 21:19:31 +01:00
Roy Marples
fa9e482a31 If not running on AC power don't run fsck to preserve battery life. 2009-05-29 21:06:59 +01:00
Roy Marples
60134ddec5 Only delete addresses for interfaces that exist. 2009-05-29 15:23:23 +01:00
Roy Marples
83e82c452e Merge branch 'master' of ssh://roy.marples.name/var/git/openrc 2009-05-29 14:15:12 +01:00
Roy Marples
a518d34549 Ignore more foo 2009-05-28 20:16:35 +01:00
Roy Marples
5acf0e9464 We need to use eval so we can pass "*" as an argument. 2009-05-26 22:36:53 +01:00
Roy Marples
c0fd1b49e4 Move non compiled libraries from /lib/rc to /libexec/rc
OpenRC version is now stored as plaintext in /libexec/rc/version

Plugins (cursplash, splashutils) will have to be re-compiled to pickup
the new directories. State data needs to be moved from /lib/rc/init.d
to /libexec/rc/init.d as well.
2009-05-23 20:38:12 +01:00
Roy Marples
5294abe617 If already started or stopped, abort. 2009-05-17 12:29:46 +01:00
Charlie
9c5faf231c procfs should use modules. 2009-05-11 15:31:52 +01:00
Roy Marples
701813b5ff procfs should use modules. 2009-05-11 15:31:52 +01:00
Roy Marples
b2eb9f8a83 Unset PAM environment variables if not set 2009-05-07 12:20:59 +01:00
Roy Marples
cc5e43922e Supply a working default inittab 2009-05-07 10:44:50 +01:00
Roy Marples
0aabe32375 Enable wpa_supplicant for >1 wireless interface if found. 2009-05-06 16:47:37 +01:00
Roy Marples
7c81f74b60 Fix compile on NetBSD 2009-05-05 16:39:59 +01:00
Roy Marples
d441bf1585 Ignore more foo for the BSDs 2009-05-05 10:29:52 +01:00
Roy Marples
43063ae7c2 Fix compile on NetBSD and FreeBSD 2009-05-05 10:24:21 +01:00
Roy Marples
e575b33047 We shouldn't use -L/lib 2009-05-02 18:29:00 +01:00
Roy Marples
c09e6b3e6d Typo 2009-05-02 12:31:13 +01:00
Roy Marples
6615eb4b68 Add runlevel stacking, #88
This implementation has the limitation that you cannot have a stacked
runlevel and service of the same name in a runlevel.
2009-05-02 12:26:45 +01:00
Roy Marples
e040bd77e9 Ignore test results 2009-05-02 12:18:34 +01:00
Roy Marples
658a220638 Add (c) to Copyright 2009-05-01 15:11:40 +01:00
Roy Marples
b32c9c1139 Ensure that rc.d services are not started twice if PKG_DIR is blank.
Fixes #170
2009-05-01 09:37:51 +01:00
Roy Marples
fb051bf81a Add -i, --ifexists so that we can do this
rc-sercice -i foo -- restart
instead of this
  rc-service -e foo && rc-service foo -- restart
2009-05-01 08:38:57 +01:00
Roy Marples
caf29a6480 Fix git versioning 2009-05-01 00:15:20 +01:00
Roy Marples
f689187966 Add -Z, --dry-run option to show which services we would start/stop
without actually doing so.
Fixes #151.
2009-04-30 23:42:01 +01:00
Roy Marples
3d0e5175d8 Avoid more gcc warning about not checking return values ... 2009-04-30 19:56:43 +01:00
Roy Marples
21e45e895c Brand with git version instead of svn 2009-04-30 19:16:31 +01:00
Juan RP
a1e40e9beb Fix parens 2009-04-30 16:45:18 +01:00
Roy Marples
b70501ef45 Go back to git 2009-04-30 15:05:39 +01:00
Roy Marples
e0f0fc8046 Don't start services when their need dependency is broken 2009-04-28 08:29:02 +00:00
Roy Marples
48f477f851 Fix a brain fart 2009-04-27 13:58:26 +00:00
Roy Marples
3d43fb6f22 Although the noshutdown keyword is nice, we shouldn't use it for network or dhcpcd. Instead fake network shutdown so it comes back up correctly at boot and KILL dhcpcd to preserve network. 2009-04-27 13:33:37 +00:00
Roy Marples
824bb3aee3 Allow templates to define a stop signal 2009-04-27 13:32:13 +00:00
Roy Marples
0f70279f89 Set correct prefix 2009-04-27 12:12:42 +00:00
Roy Marples
71062f479a Add noshutdown to dhcpcd and wpa_supplicant. Tweak for style. 2009-04-27 12:06:54 +00:00
Roy Marples
94b3057571 Add the noshutdown keyword to special case the shutdown. 2009-04-27 12:04:33 +00:00
Roy Marples
338c93733d Fix the nstop keyword. 2009-04-27 09:06:30 +00:00
Roy Marples
e70a142956 Style. 2009-04-27 07:51:18 +00:00
Roy Marples
eaa32c75c9 Add the nostop keyword so that we don't stop the network init script by default. 2009-04-26 21:16:05 +00:00
Roy Marples
2b866f264f Stop using needless {} in vars 2009-04-26 21:13:26 +00:00
Roy Marples
59574780da Document tap interface creation. 2009-04-26 18:53:24 +00:00
Roy Marples
77c8f8abbb Use /bin/bash or user shell in /etc/passwd if none set before /bin/sh. 2009-04-26 17:57:06 +00:00
Roy Marples
1d48183646 Try and set a keymap as early as possible, #169 2009-04-26 11:19:22 +00:00
Roy Marples
0feddbd815 Use kill for the pid check as it's fast. 2009-04-25 20:44:13 +00:00
Roy Marples
bd6bb932df Don't report final eends for interfaces as they make no sense. 2009-04-25 18:02:28 +00:00
Roy Marples
f51d8d0b7d Document interfaces variable useage a bit better. 2009-04-25 13:44:41 +00:00
Roy Marples
42580d67b8 Verbosely report vars correctly. 2009-04-25 11:39:18 +00:00
Roy Marples
c07b384d82 Don't drop to sulogin by default, but make this configurable. 2009-04-24 11:49:55 +00:00
Roy Marples
bd211d534b We should match the full variable name. 2009-04-24 11:45:48 +00:00
Roy Marples
b0ac71fe2a Add missing show levels switch. 2009-04-24 10:23:49 +00:00
Roy Marples
9966a902ab rc-status -c now lists services that have crashed.
It returns 0 if there are crashed services, otherwise 1.
This it easy to restart crashed services automatically.
More for #120.
2009-04-24 10:17:53 +00:00
Roy Marples
e2629b0a3b Remove .depend before creating it. 2009-04-24 08:33:11 +00:00
Roy Marples
5276b13926 Cast to int 2009-04-24 08:32:44 +00:00
Roy Marples
e7b35a8f15 Allow rc to start (optionally stop) crashed services, #120 2009-04-24 07:03:08 +00:00
Roy Marples
e643a7fdd5 Describe interval units 2009-04-24 06:37:29 +00:00
Roy Marples
ade85d4bd8 Improve style for KNF 2009-04-23 21:31:22 +00:00
Roy Marples
6953474655 Style 2009-04-23 20:53:24 +00:00
Roy Marples
d231a2f0d9 Fix logic, thanks to Maryasin Semen 2009-04-23 20:44:17 +00:00
Roy Marples
7086df5664 Don't include hotplugged services in manual. 2009-04-23 20:27:40 +00:00
Roy Marples
7dc9c39503 Improve the service timeout code and reduce the timeout to 60 seconds.
Don't process any dependencies when changing runlevels and called 
outside of RC otherwise we can deadlock.
2009-04-23 20:20:17 +00:00
Roy Marples
953b0b7435 Document -i, --interpreted flag. 2009-04-22 10:49:07 +00:00
Roy Marples
f326f688f6 Add the -i, --interpreted option.
This enables the code to include the daemons interpreter when matching
process name which fixes bug #164.
Existing init scripts that rely on the old behaviour will need to be 
fixed.
2009-04-22 10:45:01 +00:00
Roy Marples
588c9da0ab Document DHCP and iwconfig. 2009-04-19 21:45:09 +00:00
Roy Marples
7e9cdbd16e Document \$int and how to create bridge and vlan interfaces. 2009-04-19 21:35:26 +00:00
Roy Marples
a2856fe192 Use shell_var for shell variables. 2009-04-19 21:10:06 +00:00
Roy Marples
8e5a601087 Style 2009-04-19 21:02:31 +00:00
Roy Marples
a01f9be6f2 We should use $int for compat with NetBSD 2009-04-19 20:59:46 +00:00
Roy Marples
371506be48 Default to not building the old net scripts. 2009-04-19 20:54:11 +00:00
Roy Marples
4febf00c06 Allow family on routes, #152 2009-04-19 20:05:40 +00:00
Roy Marples
73f6d1c39e Document defaultroute 2009-04-19 18:36:06 +00:00
Roy Marples
ee53e6ad29 -w, --wait seconds
New option so you can set the number of seconds to wait for and
check the daemon is still running.
The old code that periodically polled wasn't that reliable - in this 
case simpler == better.
Fixes #160
2009-04-19 18:20:49 +00:00
Roy Marples
e2942e34af Use a bashism for a minor speedup in gendepends.sh 2009-04-19 16:47:09 +00:00
Roy Marples
bbd810425b Move special umount of tmpfs to the swap init script where it belongs, #149. 2009-04-19 11:15:37 +00:00
Roy Marples
bb6614f4e1 Document rc_nostop, #118 2009-04-19 10:25:38 +00:00
Roy Marples
170547010f Pull /etc/ifconfig.eth0 into interfaces
Reverse list of interfaces when stopping
Improve build for conf.d/network
2009-04-19 08:52:00 +00:00
Roy Marples
3579663173 Don't leak the lock fd. 2009-04-18 19:54:04 +00:00
Roy Marples
802fe9709e Allow user to provide custom status function and still hook into the system one 2009-04-18 10:39:53 +00:00
Roy Marples
657cb3a6eb Fix compile on FreeBSD. 2009-04-18 00:57:17 +00:00
Roy Marples
9225c6cefb Not all systems have the utmp group 2009-04-18 00:56:48 +00:00
Roy Marples
1a2d81751d Support BSDs 2009-04-18 00:56:26 +00:00
Roy Marples
c9e24a0494 Move status to runscript.sh so init scripts can override it, #159
Return 32 if crashed, #163
2009-04-18 00:09:03 +00:00
Roy Marples
d4c71415a9 Add MKOLDNET=yes/no toggle 2009-04-17 23:23:31 +00:00
Roy Marples
ee54bb9372 Using fifos for locking can be error prone.
flocks are safer, as we only use tmpfs for our lock files.

I don't know how this works for inactive just yet though ...
2009-04-17 22:55:11 +00:00
Roy Marples
7138c1532c Typo, thanks to Matthias Schwarzott, #166. 2009-04-17 09:48:34 +00:00
Roy Marples
6027b0ed7d Add a new init script - network
This simply assigns static addresses and an optional default route.
It's possible to add external commands as well, so to create a bonded interface.

Hopefully we can add a few examples to satisfy most of the old net.lo, which
is no longer installed into boot by default.
2009-04-16 23:47:23 +00:00
Roy Marples
95d954e7b5 Improve utmp handling 2009-04-16 23:39:37 +00:00
Roy Marples
744a8bbb4a Don't unmount /bin,/sbin,/lib,/libexec in the very silly cases where they are not on / 2009-04-16 23:34:38 +00:00
Roy Marples
ace0b9653b Avoid needless forking, #165
Thanks to Natanael Copa.
2009-04-16 23:23:21 +00:00
Roy Marples
966ecb24da Add net dependency 2009-04-16 21:02:46 +00:00
Roy Marples
cba9f12715 Simplfy rm matching pattern, thanks to cypherpunks@mailinator.com 2009-04-12 12:59:00 +00:00
Roy Marples
dea9e11a69 When logging, stdout isn't always a tty, which is the case for VPS
systems, Thanks to mwrobel - fixes #106.
2009-04-02 23:55:19 +00:00
Roy Marples
0b12faed7f We should abort boot on some errors. 2009-03-16 21:41:23 +00:00
Roy Marples
34fbf3db2f Add scripts for dhcpcd and wpa_supplicant. 2009-03-05 20:41:07 +00:00
Roy Marples
132dfd7b1e Typo, thanks to Polynomial-C 2009-03-05 00:41:44 +00:00
Roy Marples
077b2d3ba8 Report if service is not executable. 2009-02-28 14:12:19 +00:00
Roy Marples
907ca8a89f Set errno when service does not exist better. 2009-02-28 14:12:03 +00:00
Roy Marples
f38ef00939 Fix unit test. 2009-02-23 10:43:24 +00:00
Roy Marples
66cd081301 Change wipe_tmp_dirs to clean_tmp_dirs so user understands meaning better, #153 2009-02-23 09:36:48 +00:00
Roy Marples
749938d439 Style. 2009-02-23 09:35:57 +00:00
Roy Marples
70d8c5beda Typo, #150
Thanks to betelgeuse
2009-02-13 12:52:29 +00:00
Roy Marples
b60f437b52 Fix the number of terminals to operate on.
Thanks to Dimitrios Christidis <chrjim@gmail.com>
2009-02-13 12:24:32 +00:00
Roy Marples
d6d2635c51 root should respect inittab, #148. 2009-02-12 18:12:57 +00:00
Roy Marples
6cc68e21cf Fix return value for tests. 2009-02-12 10:43:30 +00:00
Roy Marples
9f3cf59818 hostid does not need root to run 2009-02-11 17:42:14 +00:00
Roy Marples
7a628e1db7 Release 0.4.3 2009-02-11 06:54:58 +00:00
Roy Marples
069590d97f Fix unmask option, thanks to douglas@openplans.org, #146 2009-02-10 23:11:17 +00:00
Roy Marples
3fc17f5966 Store the file skewed against. 2009-02-10 15:25:28 +00:00
Roy Marples
522ab21fbf Only create the reboot file if rebooting. 2009-02-10 15:16:25 +00:00
Roy Marples
3d7b56f2e2 Create /reboot if running inside OpenVZ, #138.
This should be fine as vpsreboot should only restart a stopped container.
2009-02-10 15:06:48 +00:00
Roy Marples
6bb44be2a3 We should always mount $RC_SVCDIR unless in a vserver or it's already mounted. 2009-01-29 13:38:15 +00:00
Roy Marples
415fe87d8c Clean up some compiler warnings. 2009-01-29 13:29:04 +00:00
Roy Marples
4f163f9b9a Allow wpa_cli_$IFACE to too send args to wpa_cli. 2009-01-21 09:25:34 +00:00
Roy Marples
417a817d25 noinit makes more sense than noinitd 2009-01-18 20:02:50 +00:00
Roy Marples
30a7a3a9bf Fix locale with svnversion, #140 thanks to Matthias Schwarzott. 2009-01-14 14:32:56 +00:00
Roy Marples
5208a1de29 yes should be YES 2009-01-13 11:04:37 +00:00
Roy Marples
abcc4c5c72 Don't allow SYSVINIT parameters through anymore.
RC_REBOOT is now yes when rebooting.
Document the special reboot runlevel.
2009-01-13 11:02:00 +00:00
Roy Marples
fcf1cce549 rc_newer/older_than only report file if time_t is a pointer, so it
should take precedence in the argument list.
2009-01-13 09:11:31 +00:00
Roy Marples
3d37005a3d We now warn about clock skews
rc-update -u will force a regen of the dep tree
rc_newer_than and rc_olderthan now take another two parameters for newest/oldest file and mtime
2009-01-12 23:53:13 +00:00
Roy Marples
2243c01390 Add snapshot and snap targets 2009-01-12 23:12:06 +00:00
Roy Marples
a52472c3c3 Fix ordering, #139 thanks to Matthias. 2009-01-12 10:24:47 +00:00
Roy Marples
f23822e082 Copyright 2009-01-12 10:24:00 +00:00
Roy Marples
8a9a2d5fe9 Use snprintf instead of strlcpy to save on size if not available. 2009-01-12 08:31:03 +00:00
Roy Marples
a33554ab18 Copyright 2009-01-11 17:17:04 +00:00
Roy Marples
baf0ce64f5 Ensure that $HOME and $USER are always set, #139 2009-01-11 17:09:13 +00:00
Roy Marples
26f70a5277 Style 2009-01-10 12:18:00 +00:00
Roy Marples
36c53e7551 Keyword novserver, #137. 2009-01-06 16:25:33 +00:00
Roy Marples
5ca3345534 Release openrc-0.4.2 2009-01-05 20:16:50 +00:00
Roy Marples
0298e4ffa0 Remove leading and trailing space on the ctrl_interface line. 2009-01-05 09:37:38 +00:00
Roy Marples
a063035b37 Make _SVNVER_SH more readable. 2009-01-02 22:51:47 +00:00
Roy Marples
213cef1739 Fix version for releases. 2009-01-02 16:48:42 +00:00
Roy Marples
386ee57432 Fix compile, #136 2009-01-02 15:11:15 +00:00
Roy Marples
631acff7aa Document the --chuid option. 2009-01-01 14:32:09 +00:00
Roy Marples
877a328179 dmesg and sysfs won't work in a vserver, #137 thanks to Hollow. 2009-01-01 14:27:29 +00:00
Roy Marples
1efa64cae8 Typo. 2008-12-30 19:08:51 +00:00
Roy Marples
22959c3963 Fix working on zsh 2008-12-30 00:05:17 +00:00
Roy Marples
2464f9e93b Add parens, #134 thanks to Matthias Schwarzott. 2008-12-29 23:06:22 +00:00
Roy Marples
d91201cb94 Skip all forcefsck checking when stopping, #134. 2008-12-28 15:25:40 +00:00
Roy Marples
1c5ec9d161 Fake get_bootparam function so that we don't check for kernel options forcefsck when doing an fsck on shutdown. 2008-12-28 14:49:07 +00:00
Roy Marples
f4b8366942 Parse retry schedule correctly, #129. Thanks to vaeth. 2008-12-28 14:05:33 +00:00
Roy Marples
438665357b Release 0.4.1 2008-12-23 10:45:16 +00:00
Roy Marples
7ad40abf64 Our error messages don't have full stops at the end 2008-12-23 10:42:25 +00:00
Roy Marples
7e12abe035 Typo. 2008-12-23 10:41:33 +00:00
Roy Marples
4dba5b1ff1 Disallow hotplug to run during sysinit, but allow elsewhere. Fixes #131. 2008-12-23 10:40:27 +00:00
Roy Marples
1ff289e305 Whitespace. 2008-12-23 10:39:45 +00:00
Roy Marples
53e2bec385 We should match on the correct args for stopping daemons when pidfiles
are not being used.
2008-12-23 10:15:41 +00:00
Roy Marples
9d9f17aa52 Allow working with the new ctrl_iface=DIR=foo directive. 2008-12-23 10:13:58 +00:00
Roy Marples
803dbbf0c8 Allow rc_runlevel/softlevel to set runlevel from kernel commandline. 2008-12-21 01:15:02 +00:00
Roy Marples
9e5e60f257 Store interactive mode after sysinit, #128 thanks to Matthias Schwarzott. 2008-12-13 22:20:21 +00:00
Roy Marples
6bf0289f33 Warn about stopping sysinit services, thanks to Matthias Schwarzott. Fixes #126. 2008-12-11 14:50:58 +00:00
Roy Marples
bdb3485b49 Punt redundant dirs from git mirgation. 2008-12-07 08:38:16 +00:00
Roy Marples
eb6daeca43 Fix dist for svn 2008-12-07 07:51:40 +00:00
Roy Marples
10e88090f6 Release 0.4.0 2008-12-07 07:49:24 +00:00
Roy Marples
8cce75925f Ignore FreeBSD targets. 2008-12-05 09:24:49 +00:00
Roy Marples
e72aeebbcd make ignore now updates svn:ignore as different OS's have different targets. 2008-12-04 19:21:47 +00:00
Roy Marples
dc712a109e runlevel override works correctly again. 2008-12-04 17:30:26 +00:00
Roy Marples
1acbfcf5ca Report invalid runlevels. 2008-12-04 17:17:09 +00:00
Roy Marples
f8210050e5 If we're building from subversion, brand the binary as such. 2008-12-04 13:12:46 +00:00
Roy Marples
38e6c9ba5c make ignore now configures the sv:ignore property. 2008-12-04 12:38:23 +00:00
Roy Marples
2c98c5326a Punt .gitignore files. 2008-12-04 12:12:09 +00:00
Roy Marples
57f90a42ba Include hotplugged services in our start list. 2008-12-01 08:46:50 +00:00
Roy Marples
bde35d03ed Actally show hotplugged services. 2008-12-01 08:46:25 +00:00
Roy Marples
8b76e1d2e0 Ignore interupts when waiting for processes to finish. Also, style fixes. 2008-11-28 10:48:01 +00:00
Roy Marples
b859710cc8 Style. 2008-11-28 10:47:17 +00:00
Roy Marples
c064393f08 Save screen space. 2008-11-28 10:46:58 +00:00
Roy Marples
e84f71596e Not needed. 2008-11-27 21:14:52 +00:00
Roy Marples
23e73957a0 Switch from select to poll and improve the no prefixing of eend calls. 2008-11-27 21:14:43 +00:00
Roy Marples
2537a07e10 Switch from select to poll and improve the no prefixing of eend calls. 2008-11-27 21:05:39 +00:00
Roy Marples
5403e70313 Save more screen space by removing the space befor the * for einfo and friends. Also remove the leading space before ... for ebegin. 2008-11-26 10:46:33 +00:00
Roy Marples
fe12134a5b Don't warn about waiting for services marked as notimeout, Gentoo #247306. 2008-11-23 18:40:43 +00:00
Roy Marples
1deaa0fae0 Fix lib. 2008-11-13 09:35:00 +00:00
Roy Marples
0cca768b82 Mark the addon code as deprecated. 2008-11-12 19:19:56 +00:00
Roy Marples
df22978de9 Punt halt init script. sysvinit should install it. See Gentoo bug #246502 on how to handle this. 2008-11-12 16:28:07 +00:00
Roy Marples
fe509db660 Save a needless malloc when re-creating PATH. 2008-11-12 10:55:42 +00:00
Roy Marples
937b1b2abf Don't set user info unless stated. 2008-11-11 19:47:30 +00:00
Roy Marples
eafbed0366 Fix stopping with a faulty pidfile. 2008-11-10 20:57:03 +00:00
Roy Marples
0786141026 Restore interface_exists, interface_up and interface_exists, #123. 2008-11-10 12:31:20 +00:00
Roy Marples
90d175ae27 Remove deprecated use of modprobe -l. If we need this functionaltiy back, we need to use something else, like say find. 2008-11-04 17:08:35 +00:00
Roy Marples
a178fd0f32 We should not update mtab here. 2008-11-04 17:07:32 +00:00
Roy Marples
03e8e0cb68 More Typos. 2008-11-04 14:28:51 +00:00
Roy Marples
a3d266e741 Use mount-ro 2008-11-04 11:32:07 +00:00
Roy Marples
42e6a95b1d Move romount to mount-ro and use the umount -r option as it's more reliable for / --bind mounts, Gentoo #239922. Thanks to Duncan. 2008-11-04 11:30:15 +00:00
Roy Marples
45044c9239 Typo 2008-11-04 11:28:24 +00:00
Roy Marples
5fc6f21169 Typo 2008-11-04 11:05:30 +00:00
Roy Marples
2cf24fe793 Ignore after dependencies for shutdown when not in the runlevel. 2008-11-04 09:32:21 +00:00
Roy Marples
cc14b55414 Now the linx fsck man page has return codes, I find them different from the BSD's so adjust accordingly. 2008-11-04 07:45:05 +00:00
Roy Marples
33d4fba5be We start off in sysinit correctly. 2008-11-04 00:21:30 +00:00
Roy Marples
32e17af92f No need for NULL here. 2008-11-03 23:13:36 +00:00
Roy Marples
77d56f5489 Avoid depends not in the runlevel for sysinit and shutdown. 2008-11-03 23:13:12 +00:00
Roy Marples
c520d4a23a --nice is -N, not -n. Also, correct default timeout. 2008-11-03 21:11:29 +00:00
Roy Marples
8a76c27325 Fix sending signals, #121. 2008-11-03 21:06:45 +00:00
Roy Marples
7467440a29 Fix fstabinfo for mounting /dev/shm, Gentoo #245367. 2008-11-03 18:00:55 +00:00
Roy Marples
282ad4bae6 Add descriptions. 2008-11-03 16:16:12 +00:00
Roy Marples
1e5a6f40e5 We shouldn't run halt.sh anymore. 2008-11-03 16:11:29 +00:00
Roy Marples
0af7d5bc20 Add a new shutdown runlevel, Gentoo #224537.
Split halt.sh into halt, killprocs, romount and savecache services.
The reboot runlevel is removed but mapped to shutdown.
The halt script should be moved to the sysvinit package.
2008-11-03 15:31:01 +00:00
Roy Marples
895c4f4149 Plug a leak and expand exec also. 2008-10-30 17:57:58 +00:00
Roy Marples
20380d3144 Allow ~ and ~user to expand for chdir and chroot. 2008-10-30 17:40:48 +00:00
Roy Marples
e1341e372b Fix --name when stopping, Gentoo #243088. 2008-10-30 16:26:05 +00:00
Roy Marples
1c73f2967c We no longer hotplug by default. 2008-10-30 15:03:12 +00:00
Roy Marples
2ff0838abb We should show hotplugged services, needed services and manually started services in rc-status. 2008-10-30 14:59:14 +00:00
Roy Marples
53ddd6ca96 Properly set PAM enviornment variables after opening session.
Without this change, modules like pam_mktemp or pam_env and similar
will be unable to change users' environments, like they are supposed
to.
2008-10-29 21:35:45 +00:00
Roy Marples
9ec6ff02bb Style and typo. 2008-10-28 15:43:36 +00:00
Roy Marples
aa991a3c99 Style. 2008-10-27 18:38:56 +00:00
Roy Marples
0d98d56188 Remove sysvinit specific code.
The runlevels shutdown, reboot, sysinit and single should be called by
init(8) and shutdown(8) and not manually.
sysvinit users will have to add sulogin to their inittab to secure the
console.
2008-10-27 18:01:03 +00:00
Roy Marples
ae692e294e Don't quote $tunnel, Gentoo #218123. 2008-10-26 19:58:57 +00:00
Roy Marples
f6e3c167ae Remove bash localisation feature, Gentoo #244444 thanks to Andrey Grozin. 2008-10-26 19:19:19 +00:00
Mike Frysinger
1d96620b84 hwclock: skip rtc checks if kernel lacks module support
Since we only use the result of the device scan to load modules, there is
no point in doing the scan if the kernel doesn't support modules in the
first place.

Signed-off-by: Mike Frysinger <vapier@gentoo.org>
2008-10-26 07:09:02 +00:00
Roy Marples
d12bb5cf3c Really fix .depend 2008-10-20 16:47:56 +00:00
Roy Marples
9c76b077d6 Enable use of .depend on gmake. Also, generate extra dependencies for our shared libraries. 2008-10-20 12:09:14 +00:00
Roy Marples
0a39145a5e Include sysinit services even in single user. 2008-10-16 17:04:44 +00:00
Roy Marples
734e60608a Ignore new scripts. 2008-10-16 09:41:14 +00:00
Roy Marples
66ae6e38a7 Compile with FreeBSD 6.x make 2008-10-15 09:02:27 +00:00
Roy Marples
8d47d6c022 Fix fuser on BSD platforms. 2008-10-15 08:35:21 +00:00
Roy Marples
c18c74e816 Fix adding just the default route, #119 thanks to pva. 2008-10-14 15:27:52 +00:00
Roy Marples
da94fad3f5 Re-evaluate sys after running initsh. 2008-10-10 14:53:50 +00:00
Roy Marples
10cb4c18df Remove hardedcoded foo here. 2008-10-10 09:35:13 +00:00
Roy Marples
50b8aba8d9 Remove coldplug and just have hotplug which is a list of allowed/disallowed services. Makes things much easier. 2008-10-10 09:08:59 +00:00
Roy Marples
72dcac8c55 Shorten common messages for prefixed output. 2008-10-10 09:03:59 +00:00
Roy Marples
d6da8e8c48 sysinit is now a real runlevel that handles things like udev, dmesg and
mounting various bits in /dev and /sys.
init.sh JUST mounts /lib/rc/init.d (and /proc for Linux systems)
To make development of this easier we now return an empty RC_STRINGLIST
instead of a NULL for empty things.

If you don't have a udev init script installed, don't reboot your box OR
roll back to an older OpenRC version.
2008-10-10 08:37:21 +00:00
Roy Marples
247766695c Fix umounting reporting exit status, Gentoo #239922. 2008-10-09 16:36:42 +00:00
Roy Marples
1a88a43aa5 Warn about sulogin timeout and then continue as normal, Gentoo #240383 2008-10-09 16:34:21 +00:00
Roy Marples
c4e673edbc Add a better, but incomplete tgoto implementation to make gcc happy. 2008-10-08 21:07:04 +00:00
Roy Marples
a872fe5590 Fix status check, #239922 2008-10-08 18:32:39 +00:00
Roy Marples
8c8751fa60 Clean up warnings regarding printf. 2008-10-08 15:56:47 +00:00
Roy Marples
5cdc489573 Fix utmp permissions, Gentoo #240437. 2008-10-08 13:58:17 +00:00
Roy Marples
4d74e94c39 Merge branch 'master' of git@git.overlays.gentoo.org:proj/openrc 2008-10-07 12:18:22 +00:00
Roy Marples
d117b2d644 Fix tests, #Gentoo 240350. 2008-10-07 12:14:53 +00:00
Roy Marples
cb44b0a46c #ifdef atexit cleanups calling free as the OS should do this for us, but valgrind debuggers need it. 2008-10-06 15:02:32 +00:00
Roy Marples
4e4c4a5bf4 kenv is not always available. 2008-10-03 17:50:30 +00:00
Roy Marples
09a1a5ecd4 Fix a segfault when profile.env does not exist. 2008-10-03 17:50:10 +00:00
Roy Marples
84f6bf4bff Release 0.3 2008-10-02 16:14:13 +00:00
Roy Marples
5f76c1121a Clean stale sockets. 2008-10-01 21:12:54 +00:00
Roy Marples
41c1e170d6 Add an env var so plugins know when leaving single means the end, or start the default level. 2008-10-01 08:46:53 +00:00
Roy Marples
f53197818b Correcly call the right runlevel for plugins when shutting down. 2008-10-01 06:10:34 +00:00
Roy Marples
bb41d2cc80 Use flock to lock PREFIX_LOCK so that multiple processes can cleanly write to the same tty. 2008-09-27 18:50:21 +00:00
Roy Marples
4291b9140e Warn when waiting for a service every few seconds. 2008-09-27 17:17:15 +00:00
Roy Marples
28d7fb9430 When stopping services, check the newlevel if given otherwise the current runlevel. Fixes #100. 2008-09-27 16:56:03 +00:00
Roy Marples
abe94bec6f Load rtc-cmos if needed, Gentoo #235647 thanks to Robin Johnson. 2008-09-27 06:48:21 +00:00
Roy Marples
c3e192a834 Stop ssd from waiting by default - most daemons are good now. 2008-09-26 23:58:57 +00:00
Roy Marples
13d88731b7 We don't check exec when starting, so don't when testing for crashed. 2008-09-22 20:07:14 +00:00
Roy Marples
ffc79a50c2 Style 2008-09-22 19:49:16 +00:00
Roy Marples
6748c0e04e Allow forcefsck instead of gentoo=forcefsck on the kernel command line. 2008-09-22 12:32:35 +00:00
Roy Marples
27805de20a Allow forcefsck on the kernel command line, Gentoo #218431 2008-09-22 12:32:11 +00:00
Roy Marples
53693367df Our match arguments could be different from the exec arguments, as only the kernel should set script arguments. 2008-09-22 12:14:47 +00:00
Roy Marples
554d2fea19 Allow interpreted daemons to detect interperter options. 2008-09-22 10:45:01 +00:00
Roy Marples
a63303971a Document the --verbose option. 2008-09-22 09:37:28 +00:00
Roy Marples
5610c8560c s-s-d now handles interpreted daemons more easily. 2008-09-22 09:34:51 +00:00
Roy Marples
2c62d095c8 Typo. 2008-09-21 09:53:48 +00:00
Roy Marples
a72dc1194a Style. 2008-09-19 11:34:35 +00:00
Roy Marples
dcc4aa131c Document the limitation of symlinking services outside of the service directory, Gentoo #237263. 2008-09-19 11:32:24 +00:00
Roy Marples
6b3d8cf598 Fix stopping wpa_supplicant incorrectly, #107 2008-09-19 11:24:21 +00:00
Roy Marples
600d1f62fb Allow configuration of bond via extra sysfs entries, #105. 2008-09-19 09:32:24 +00:00
Roy Marples
2de401bca1 Enable bonding via sysfs, #104 thanks to Wolfram Schlich 2008-09-18 22:24:58 +00:00
Roy Marples
e368a4b4f8 Add missing profile bits to env, #72. 2008-09-18 19:46:10 +00:00
Roy Marples
354fb96ee9 Use the new rc_stringlist_find function. 2008-09-18 15:36:22 +00:00
Roy Marples
312d6f3e57 Work with NULL lists. 2008-09-18 15:32:57 +00:00
Roy Marples
39ea0cb84d Use the new rc_stringlist_find function. 2008-09-18 15:28:20 +00:00
Roy Marples
17bf78a539 Use the new rc_stringlist_find function. 2008-09-18 15:20:57 +00:00
Roy Marples
072328ff60 rc_nostop now lists services we should not stop on shutdown. 2008-09-18 15:13:53 +00:00
Roy Marples
e0dfa472d1 Add new functions, rc_stringlist_find and rc_stringlist_split. 2008-09-18 15:12:43 +00:00
Roy Marples
ccc24d1086 Add a config file for ipfw, #110 2008-09-18 14:25:23 +00:00
Roy Marples
c4c024fc9d Allow an empty bridge with no options, Gentoo #237485. 2008-09-18 14:13:33 +00:00
Roy Marples
223015920c Warn about parallel still locking the system. 2008-09-18 13:59:05 +00:00
Roy Marples
aa02a5516a Use better CFLAGS - some new warnings will need to be fixed. 2008-09-18 13:49:58 +00:00
Roy Marples
80a17eb596 Clean up some compile warnings. 2008-09-18 13:09:51 +00:00
Roy Marples
39304745d4 Allow interpreted daemons to use s-s-d a little easier. 2008-09-17 16:56:23 +00:00
Roy Marples
93a3b2dd02 Fix iwconfig parsing on Linux, #111 thanks to Andrew Gaffney. 2008-09-04 14:54:56 +00:00
Roy Marples
00d010fbe0 Work without IP6 kernels, #108 2008-08-29 06:43:54 +00:00
Roy Marples
01de348ede Add rpc.lockd to netmount.in for BSD 2008-08-27 16:06:01 +00:00
Roy Marples
fabee4dc2d Actually set the umask. 2008-08-20 10:19:03 +00:00
Roy Marples
1ab1e9328a Add -k,--umask option, Gentoo #232455. 2008-08-20 10:02:11 +00:00
Roy Marples
a9f7d2d5e5 Allow dhcpcd to use global dhcpcd variable for commandline options. 2008-08-19 22:30:59 +00:00
Roy Marples
a3c8706618 Allow OpenVZ to mount /sys and device managers, #102 2008-08-19 15:27:15 +00:00
Roy Marples
1f227d62bf Allow renaming of modules, #103 thanks to Sven. 2008-08-19 15:25:06 +00:00
Roy Marples
cdace75539 OpenVZ can mount NFS shares. 2008-08-19 06:44:47 +00:00
Roy Marples
15678263d5 Add new OpenVZ detection code 2008-08-19 06:36:43 +00:00
Roy Marples
cea206014d Attempt to make s-s-d simpler by not enforcing the need for a full path and maybe working better with interpreted scripts. 2008-07-27 11:30:49 +00:00
Roy Marples
46a74f244e Typo 2008-07-24 19:02:28 +00:00
Roy Marples
c67233f15c Don't set silly defaults that may brake users. 2008-07-09 18:28:45 +00:00
Roy Marples
b15c4758f8 We should unmount / here. 2008-07-09 18:28:14 +00:00
Roy Marples
289889ebf0 Fix unmounting some more. 2008-07-09 17:05:10 +00:00
Roy Marples
7183cb1b18 Fix last commit 2008-07-09 16:20:48 +00:00
Roy Marples
b83108cd2e Add a knob to avoid the unmounting of some points. 2008-07-09 16:08:38 +00:00
Roy Marples
1ca63447c9 Hide mkdir error's 2008-07-09 15:22:15 +00:00
Roy Marples
c2781c209e Really test if we can write to RC_LIBDIR or not. 2008-07-09 15:12:56 +00:00
Roy Marples
5983add0f2 No point in re-mounting ro filesystems that are already ro. 2008-07-09 14:24:48 +00:00
Roy Marples
a566493eb8 Ignore core files 2008-07-09 14:04:40 +00:00
Roy Marples
bdd8b150cd Fix return display. 2008-07-09 13:36:37 +00:00
Roy Marples
53401cd35f STAILQ -> TAILQ 2008-07-08 10:48:21 +00:00
Roy Marples
7a6112d3b0 Punt STAILQ and just use TAILQ so we're a bit more portable. 2008-07-07 14:16:46 +00:00
Roy Marples
157db50df7 Fix is_older_than a little better, and make is_newer_than correct. 2008-07-03 13:30:17 +00:00
Roy Marples
a88a177f99 Add older_than function to complement newer_than function. Also make the userland instance reversed to be compatable with current baselayout, which truely does suck. 2008-07-03 13:11:47 +00:00
Roy Marples
d61f831896 More unit fixes. 2008-07-03 13:09:24 +00:00
Roy Marples
28a65393ca More unit fixes. 2008-07-03 13:09:10 +00:00
Roy Marples
aa57dd1ff6 More unit fixes. 2008-07-03 12:33:42 +00:00
Roy Marples
e0968a1c2e Fix test. 2008-07-03 12:20:32 +00:00
Roy Marples
2f5d2855ba Add an is_older_than unit test, thanks to zzam 2008-07-03 12:07:46 +00:00
Roy Marples
db9bf18587 Fix compile with pcc. 2008-07-02 23:20:04 +00:00
Roy Marples
feac5ea1d5 Ignore ewaitfile. 2008-06-30 13:36:59 +00:00
Roy Marples
64dbae7f61 If filtering fstab, only match additional mounts asked for. 2008-06-30 13:33:42 +00:00
Roy Marples
11e4059b05 Set the default RC_SVCDIR higher up. 2008-06-21 15:31:04 +00:00
Roy Marples
5510451bac We need to replace @LIB@ here. 2008-06-21 14:10:59 +00:00
Roy Marples
11acce3c7d Use CPPFLAGS so we work with -combine in CFLAGS. 2008-06-19 23:12:00 +00:00
Roy Marples
4f2bb5ceaf open should use 3 args when using O_CREAT. 2008-06-17 15:14:33 +00:00
Roy Marples
bf8f0da921 fuzzy dependency ordering should be started, starting, stopped whilst checking runlevel, bootlevel, any at each stage. 2008-06-10 15:19:46 +00:00
Roy Marples
9b1cb4e246 When we have dependant scheduled services, don't error if a need is stopped. 2008-06-10 15:04:29 +00:00
Roy Marples
2adc99a8f5 No need to include this. 2008-06-05 12:26:53 +00:00
Roy Marples
fc747f9894 Remove the macro ;) 2008-06-05 12:19:49 +00:00
Roy Marples
76063daee5 Update style to more BSDish and replace the big macro with a function. 2008-06-05 12:17:41 +00:00
Roy Marples
dc891b0647 Remove broken before dependencies, Gentoo #224171. 2008-06-05 10:14:11 +00:00
Roy Marples
3525e602d6 Use addu instead of another loop. 2008-06-04 19:07:09 +00:00
Roy Marples
79ebd89d19 Only add a backreference if it doesn't already exist. 2008-06-04 19:00:46 +00:00
Roy Marples
ba8008fb05 Include time headers for ewaitfile. 2008-06-04 14:09:25 +00:00
Roy Marples
5e2c3fb5fe Merge branch 'master' of git@git.overlays.gentoo.org:proj/openrc 2008-06-04 12:58:05 +00:00
Roy Marples
e6aed12328 No need to check type twice like this. 2008-06-04 12:47:06 +00:00
Roy Marples
83ade5b701 Style. 2008-06-04 12:44:45 +00:00
Roy Marples
587051ec67 Add the ewaitfile function so init scripts can wait until sockts are created, Gentoo #175783. 2008-06-03 11:57:15 +00:00
Roy Marples
f2ea7ca514 Let ifdown control all interfaces. 2008-06-03 11:51:36 +00:00
Roy Marples
b41c864fc3 openrc-0.2.5 2008-05-28 13:39:52 +00:00
Roy Marples
c409dd0570 Some ifconfig's output weird inet6 loopback addresses 2008-05-28 13:38:58 +00:00
Roy Marples
aaaa0b50d8 Be quiet when checking at start. 2008-05-27 16:48:47 +00:00
Roy Marples
ca6f289c80 When stopping with a pidfile, only read the pid once incase it vanishes but the process still hangs around. 2008-05-27 16:42:28 +00:00
Roy Marples
f640ecaebb Only check tentative when we have a carrier, Gentoo #223061 2008-05-27 16:41:53 +00:00
Roy Marples
75eff5a86b Merge branch 'master' of git@git.overlays.gentoo.org:proj/openrc 2008-05-27 13:08:14 +00:00
Roy Marples
eeadc618fb Work with madwifi craptastic drivers. Hopefuly prism54 still works. 2008-05-27 13:07:18 +00:00
Roy Marples
bb069e1618 Use iwconfig defaults and config if available. 2008-05-27 10:46:27 +00:00
Roy Marples
3a592fa31b Trap fsck for SIGINT as well, so user can ctrl-C to abort fsck and continue, Gentoo #223473. 2008-05-27 10:25:29 +00:00
Roy Marples
6b77cc624f Merge branch 'master' of git@git.overlays.gentoo.org:proj/openrc 2008-05-27 10:05:15 +00:00
Roy Marples
328215e841 Work with new beta5 options to skip hoof files. 2008-05-25 22:57:44 +00:00
Roy Marples
b03282b901 Fix tunnel, #80. Someone should fix iproute2 documentation and help files also :P 2008-05-25 22:34:05 +00:00
Roy Marples
08081f7ef4 Fix passno and IFS, #77 and #85, thanks to Nahor 2008-05-25 22:30:31 +00:00
Roy Marples
8ca8e00a89 Merge branch 'master' of git@git.overlays.gentoo.org:proj/openrc 2008-05-25 22:25:29 +00:00
Roy Marples
1df3ab05b5 realloc -> xrealloc 2008-05-19 13:41:16 +00:00
Roy Marples
775df18a70 Fix a potential segfault, thanks to Fernando J. Pereda. 2008-05-19 13:16:53 +00:00
Roy Marples
148caecc7e Merge branch 'master' of git@git.overlays.gentoo.org:proj/openrc 2008-05-13 08:41:54 +00:00
Roy Marples
d0f7a63487 Merge branch 'master' of git@git.overlays.gentoo.org:proj/openrc 2008-05-13 08:18:07 +00:00
Roy Marples
b7e598ad91 Install symlinks correctly, thanks to zlin. 2008-05-13 00:03:10 +00:00
Roy Marples
5c114d9430 When testing services to stop, we should trace it. More for #79. 2008-05-12 23:45:17 +00:00
Roy Marples
f13ea77491 The real fix for the last commit is to uncomment some code - d'oh. 2008-05-12 23:33:40 +00:00
Roy Marples
a89171ee9b When stopping, stop services that need our provide as well, #79. 2008-05-12 23:17:45 +00:00
Roy Marples
6d5d655b52 Style. 2008-05-12 23:00:05 +00:00
Roy Marples
0f51f3e863 We should add devdb to boot. 2008-05-12 15:13:35 +00:00
Roy Marples
be8f8d0ac0 Add the devdb init script. 2008-05-12 15:11:04 +00:00
Roy Marples
d667da8e5c Check we have a deptree before using it, Gentoo #220579 2008-05-12 13:20:35 +00:00
Roy Marples
9894669742 Fix help text, #75. 2008-05-12 08:34:42 +00:00
Roy Marples
b732df31ef Don't report fstab passno of 0 when using greater or less than, #76. 2008-05-12 08:32:19 +00:00
Roy Marples
762dc3d197 Work with dhcpcd-4 style options. 2008-05-10 12:29:49 +00:00
Roy Marples
30fe99dead openrc-0.2.4 2008-05-10 12:01:17 +00:00
Roy Marples
2d75eb7976 netmount may use openvpn. 2008-05-10 11:09:52 +00:00
Roy Marples
3663cf1e2a Only launch single user when RUNLEVEL == S, #74. 2008-05-10 10:04:34 +00:00
Roy Marples
766ec96e3d Add ifdown_eth0=NO so that the interface stays up for WakeOnLan, Gentoo #220875 2008-05-09 10:29:06 +00:00
Roy Marples
a854fe6d61 Simplify the wait code. 2008-05-07 09:47:07 +00:00
Roy Marples
619b0b4f37 Fix the EINTR check for waitpid, Gentoo #219929. 2008-05-06 21:53:21 +00:00
Roy Marples
c8248d05a0 Ensure that make dep ordering is correct for install. 2008-05-06 19:52:30 +00:00
Roy Marples
5ae702339e We don't need to handle SIGWINCH in sysinit, so this should fix loading a framebuffer module in init.sh (Gentoo #219929. Ideally someone should tell me why this is happening and if there is a better fix. 2008-05-06 16:21:16 +00:00
Roy Marples
d384502e57 There could be a space between #! and /sbin/runscript, Gentoo #218001. 2008-05-01 15:18:34 +00:00
Roy Marples
bdaca0baf5 Busybox find now works with -exec correctly, so remove our nasty hack. 2008-04-30 16:44:29 +00:00
Roy Marples
5188fd2592 Wups, test compiles before commiting :) 2008-04-30 16:33:54 +00:00
Roy Marples
5b800030f1 Remove redundant checking of /proc/pid/exe 2008-04-30 16:26:05 +00:00
Roy Marples
208443fa0e Save a few bytes and make it easier to read. 2008-04-30 15:26:29 +00:00
Roy Marples
a818eebf7b No need to init this. 2008-04-30 12:26:38 +00:00
Roy Marples
10910876d1 Make the function a little smaller. 2008-04-30 10:55:42 +00:00
Roy Marples
35b4978152 Style 2008-04-30 10:31:06 +00:00
Roy Marples
cedd81801a We should use correct iproute2 commands and fix busybox as it's iproute2 implementation is a little broken. 2008-04-30 09:18:20 +00:00
Roy Marples
e273b4e08e Fix another leak. 2008-04-29 11:08:02 +00:00
Roy Marples
50cff8ebc8 Tweak the last commit and fix a valgrind error. 2008-04-29 10:49:50 +00:00
Roy Marples
aec83494d6 Merge branch 'master' of git@git.overlays.gentoo.org:proj/openrc 2008-04-29 10:26:17 +00:00
Roy Marples
5ba6f0a628 We need to ensure that the init script started is correct, translating symlinks. This has a new rule - multiplexed services must exist in the same dir as the master sript. So we need to ensuret that net.lo(0) is the real script and not a symlink itself. This fixes Gentoo #219526. 2008-04-29 10:25:45 +00:00
Roy Marples
5a59542629 Fix syscons for setting the font correctly. 2008-04-29 08:00:50 +00:00
Roy Marples
52711bdca7 Release openrc-0.2.3 2008-04-28 18:39:51 +00:00
Roy Marples
53902cefb8 Add rc_program function which uses fork and signal masking to try and resolve the waitpid issue, Gentoo #219179. 2008-04-28 16:04:16 +00:00
Roy Marples
75f991068d Fix multi platform a little. 2008-04-28 12:48:20 +00:00
Roy Marples
e499e58310 Don't re-start or re-stop failed services if runlevel is changing. 2008-04-27 21:04:37 +00:00
Roy Marples
b08b6cd91b Always define template start/stop functions so that the real script name isn't hidden when errors are in the real start/stop functions, Gentoo #219179 2008-04-26 19:32:28 +00:00
Roy Marples
3c2b93fc9c Check we have a list before running depends. 2008-04-26 14:59:07 +00:00
Roy Marples
b5d829789f Check we have a list before running depends. 2008-04-26 14:57:39 +00:00
Roy Marples
1e3442f95d Work with aliases on NetBSD. 2008-04-23 13:17:13 +00:00
Roy Marples
2bda1871a1 When fsck_passno is set, show this so output is clearer when fsck is multiplexed, Gentoo #218141. 2008-04-22 13:46:53 +00:00
Roy Marples
d3b111bd58 Our init scripts normally output context in [ .. ] 2008-04-22 08:12:26 +00:00
Roy Marples
dbea63b76d Fix logic for templates. 2008-04-21 21:34:52 +00:00
Roy Marples
6a5287dbb5 Typo 2008-04-21 19:26:56 +00:00
Roy Marples
df8eeba2fb Punt is_function in favour of POSIX shell builtin command, thanks to Harald van Dijk for the idea. 2008-04-21 17:32:17 +00:00
Roy Marples
54fce42c6f Merge branch 'master' of git@git.overlays.gentoo.org:proj/openrc 2008-04-21 13:07:04 +00:00
Roy Marples
54d7aa39dd If we don't have permission to inspect the pidfile, don't report crashed. Gentoo #218028. 2008-04-21 10:56:28 +00:00
Roy Marples
dc5d63aa97 Add RC_TMPDIR so that there's a writeable location during boot. 2008-04-21 10:29:29 +00:00
Roy Marples
bab5d7767d Merge branch 'master' of git@git.overlays.gentoo.org:proj/openrc 2008-04-21 10:26:40 +00:00
Roy Marples
799686e40d Fix force_preferred, #60. 2008-04-20 14:24:35 +00:00
Roy Marples
d83ae59cca Add help for mountargs, #63 2008-04-19 17:19:59 +00:00
Mike Frysinger
18b4108755 add support for parsing newer ifconfig output
Signed-off-by: Mike Frysinger <vapier@gentoo.org>
2008-04-19 07:22:30 +00:00
Roy Marples
e96347523f We should check type output to ensure that we're really calling a shell function and not some badly named binary like stop from boinc, Gentoo #218063. 2008-04-18 23:00:43 +00:00
Roy Marples
f0aacec02e Cast to unsigned char for ctype calls. 2008-04-17 10:19:58 +00:00
Roy Marples
57e1dd7389 Fix rc-status some more. 2008-04-17 00:25:08 +00:00
Roy Marples
c89b3763fb Respect shutdown -F on Linux to force fsck, #59 2008-04-17 00:09:34 +00:00
Roy Marples
425abe40c5 Only report unassigned services when there are any, Gentoo #218005. 2008-04-16 19:47:19 +00:00
Roy Marples
725b9dc89c Use qlen instead of txqueuelen so we work with busybox iproute2, Gentoo #217948 2008-04-16 15:23:57 +00:00
Roy Marples
22d650c450 Merge branch 'master' of git@git.overlays.gentoo.org:proj/openrc 2008-04-16 15:02:19 +00:00
Roy Marples
809ac86c69 We should only check dependencies in files. 2008-04-16 15:01:52 +00:00
Roy Marples
b3310e8e10 Fix rebooting for OpenVZ systems. 2008-04-15 21:50:08 +00:00
Roy Marples
29369c44c1 Add help text for rc-service --resole. 2008-04-15 16:16:59 +00:00
227 changed files with 6453 additions and 4767 deletions

4
.gitignore vendored
View File

@@ -1,3 +1 @@
openrc-0.1.tar.bz2 *.bz2
.gdb_history
.gdbinit

View File

@@ -1,12 +1,21 @@
# OpenRC Makefile # OpenRC Makefile
# Copyright 2007-2008 Roy Marples <roy@marples.name> # Copyright (c) 2007-2009 Roy Marples <roy@marples.name>
# All rights reserved. Released under the 2-clause BSD license. # All rights reserved. Released under the 2-clause BSD license.
NAME= openrc NAME= openrc
VERSION= 0.2.2 VERSION= 0.5.0
PKG= ${NAME}-${VERSION} PKG= ${NAME}-${VERSION}
SUBDIR= conf.d doc etc init.d man net sh src SUBDIR= conf.d etc init.d man sh src
# Build our old net foo or not
_OLDNET_SH= case "${MKOLDNET}" in \
[Yy][Ee][Ss]) echo "net doc";; \
*) echo "";; \
esac
_OLDNET!= ${_OLDNET_SH}
SUBDIR+= ${_OLDNET}$(shell ${_OLDNET_SH})
# We need to ensure that runlevels is done last # We need to ensure that runlevels is done last
SUBDIR+= runlevels SUBDIR+= runlevels
@@ -17,8 +26,9 @@ include ${MK}/sys.mk
include ${MK}/os.mk include ${MK}/os.mk
include ${MK}/subdir.mk include ${MK}/subdir.mk
include ${MK}/dist.mk include ${MK}/dist.mk
include ${MK}/gitignore.mk include ${MK}/git.mk
_installafter: _installafter:
${INSTALL} -d ${DESTDIR}/${PREFIX}/${RC_LIB}/init.d ${INSTALL} -d ${DESTDIR}/${LIBEXECDIR}/init.d
${INSTALL} -d ${DESTDIR}/${PREFIX}/${RC_LIB}/tmp ${INSTALL} -d ${DESTDIR}/${LIBEXECDIR}/tmp
${ECHO} "${VERSION}${GITVER}" > ${DESTDIR}/${LIBEXECDIR}/version

3
README
View File

@@ -13,12 +13,15 @@ DESTDIR=/tmp/openrc-image
MKPAM=pam MKPAM=pam
MKTERMCAP=ncurses MKTERMCAP=ncurses
MKTERMCAP=termcap MKTERMCAP=termcap
MKOLDNET=yes
PKG_PREFIX=/usr/pkg PKG_PREFIX=/usr/pkg
LOCAL_PREFIX=/usr/local LOCAL_PREFIX=/usr/local
PREFIX=/usr/local PREFIX=/usr/local
We don't support building a static OpenRC with PAM. We don't support building a static OpenRC with PAM.
You may need to use PROGLDFLAGS=-Wl,-Bstatic on glibc instead of just -static. You may need to use PROGLDFLAGS=-Wl,-Bstatic on glibc instead of just -static.
If you debug memory under valgrind, add -DDEBUG_MEMORY to your CPPFLAGS
so that all malloc memory should be freed at exit.
You can also brand OpenRC if you so wish like so You can also brand OpenRC if you so wish like so
BRANDING=\"Gentoo/$(uname -s)\" BRANDING=\"Gentoo/$(uname -s)\"

1
conf.d/.gitignore vendored Normal file
View File

@@ -0,0 +1 @@
network

View File

@@ -1,7 +1,14 @@
DIR= ${CONFDIR} DIR= ${CONFDIR}
CONF= bootmisc fsck hostname local net urandom CONF= bootmisc fsck hostname local localmount network urandom
TARGETS+= network
CLEANFILES+= network
MK= ../mk MK= ../mk
include ${MK}/os.mk include ${MK}/os.mk
include Makefile.${OS} include Makefile.${OS}
include ${MK}/scripts.mk include ${MK}/scripts.mk
network: network.in network.${OS}
cp network.in network
[ -e network.${OS} ] && cat network.${OS} >> network || true

View File

@@ -1 +1,3 @@
CONF+= moused powerd rarpd savecore syscons CONF+= ipfw moused powerd rarpd savecore syscons
network.${OS}:

View File

@@ -1 +1 @@
CONF+= consolefont hwclock keymaps modules CONF+= consolefont dmesg hwclock keymaps modules

View File

@@ -1 +1,3 @@
CONF+= moused rarpd savecore CONF+= moused rarpd savecore
network.${OS}:

View File

@@ -1,5 +1,5 @@
# List of /tmp directories we should clean up # List of /tmp directories we should clean up
wipe_tmp_dirs="/tmp" clean_tmp_dirs="/tmp"
# Should we wipe the tmp paths completely or just selectively remove known # Should we wipe the tmp paths completely or just selectively remove known
# locks / files / etc... ? # locks / files / etc... ?

3
conf.d/dmesg Normal file
View File

@@ -0,0 +1,3 @@
# Sets the level at which logging of messages is done to the
# console. See dmesg(8) for more info.
dmesg_level="1"

14
conf.d/ipfw Normal file
View File

@@ -0,0 +1,14 @@
# ipfw provides a stateful firewall.
# This means we allow everything out, and if we have a connection we allow it
# back in. This is very flexable and quite secure.
# For ease of use, we allow auth and ssh ports through as well.
# To override the list of allowed ports
#ipfw_ports_in="auth ssh"
# You may want to enable logging of denied connections
#ipfw_log_deny="YES"
# This ports not logged
#ipfw_ports_nolog="135-139,445 1026,1027 1433,1434"

3
conf.d/localmount Normal file
View File

@@ -0,0 +1,3 @@
# Stop the unmounting of certain points.
# This could be useful for some NFS related work.
#no_umounts="/dir1:/var/dir2"

View File

@@ -5,6 +5,10 @@
#modules_2_6="tun" #modules_2_6="tun"
#modules="ohci1394" #modules="ohci1394"
# You can give modules a different name when they load - the new name
# will also be used to pick arguments below.
#modules="dummy:dummy1"
# Give the modules some arguments if needed, per version if necessary. # Give the modules some arguments if needed, per version if necessary.
#module_ieee1394_args="debug" #module_ieee1394_args="debug"
#module_ieee1394_args_2_6_23_gentoo_r5="ieee1394 ohci1394" #module_ieee1394_args_2_6_23_gentoo_r5="ieee1394 ohci1394"

31
conf.d/network.Linux Normal file
View File

@@ -0,0 +1,31 @@
# ifconfig under Linux is not that powerful and doesn't easily handle
# multiple addresses
# On the other hand, ip (iproute2) is quite powerful and is also supported
#ip_eth0="192.168.0.10/24; 192.168.10.10/24"
# Create a bonded interface
#interfaces="bond0"
#ifup_bond0="modprobe bonding; ifconfig \$int up; ifenslave \$int bge0"
#ifconfig_bond0="192.168.0.10 netmask 255.255.255.0"
#ifdown_bond0="rmmod bonding"
# Create tap interface and a bridge interface.
# We add the tap to the bridge.
# An external program, like dhcpcd, will configure the IP on the bridge
#interfaces="tun0 br0"
#ifup_tun0="tunctl -t \$int"
#ifdown_tun0="tunctl -d \$int"
#ifup_br0="brctl addbr \$int; brctl add \$int eth1; brtctl add \$int eth2"
#ifdown_br0="ifconfig \$int down; btctl delbr \$int"
# Create VLAN
#interfaces="eth0_2 eth0_3 eth0_4"
#ifup_eth0="vconfig add \$int 2; vconfig add \$int 3; vconfig add \$int 4"
#ifconfig_eth0_2="192.168.2.10 netmask 255.255.255.0"
#ifconfig_eth0_3="192.168.3.10 netmask 255.255.255.0"
#ifconfig_eth0_4="192.168.4.10 netmask 255.255.255.0"
#ifdown_eth0="vconfig rem \$int.2; vconfig rem \$int.3; vconfig rem \$int.4"
# Normally you would use wpa_supplicant to configure wireless, but you can
# use iwconfig also
#ifup_wlan0="iwconfig \$int key s:secretkey enc open essid foobar"

28
conf.d/network.in Normal file
View File

@@ -0,0 +1,28 @@
# Assign static IP addresses and run custom scripts per interface.
# Seperate commands with ;
# Prefix with ! to run a shell script.
# Use \$int to represent the interface
#ifconfig_eth0="192.168.0.10 netmask 255.255.255.0"
# You also have ifup_eth0 and ifdown_eth0 to run other commands when
# eth0 is started and stopped.
# You should note that we don't stop the network at system shutdown by default.
# If you really need this, then set shutdown_network=YES
# You can assign a default route
#defaultroute="192.168.0.1"
# Lastly, the interfaces variable pulls in virtual interfaces that cannot
# be automatically detected.
#interfaces="br0 bond0 vlan0"
# You can also use files instead of variables here if you like:
# /etc/ifconfig.eth0 is equivalent to ifconfig_eth0
# /etc/ip.eth0 is equivalent to ifconfig_eth0
# /etc/ifup.eth0 is equivalent to ifup_eth0
# /etc/ifdown.eth0 is equivalent to ifdown_eth0
# Any files found will automatically be put into the interfaces variable.
# You don't need to escape variables in files, so use $int instead of \$int.
# If you require DHCP, you should install dhcpcd and it to the boot or
# default runlevel.

View File

@@ -87,6 +87,10 @@
# is how long we wait for carrier. The current default is 3 seconds # is how long we wait for carrier. The current default is 3 seconds
#carrier_timeout_eth0=-1 #carrier_timeout_eth0=-1
# You may wish to disable the interface being brought down when stopping.
# This is only of use for WakeOnLan.
#ifdown_eth0="NO"
############################################################################## ##############################################################################
# OPTIONAL MODULES # OPTIONAL MODULES

View File

@@ -120,6 +120,10 @@
# tables you may have to set a global metric as the due to a simple read of # tables you may have to set a global metric as the due to a simple read of
# the routing table taking over a minute at a time. # the routing table taking over a minute at a time.
# You may wish to disable the interface being brought down when stopping.
# This is only of use for WakeOnLan.
#ifdown_eth0="NO"
############################################################################## ##############################################################################
# OPTIONAL MODULES # OPTIONAL MODULES
@@ -565,12 +569,18 @@
#----------------------------------------------------------------------------- #-----------------------------------------------------------------------------
# Bonding # Bonding
# For link bonding/trunking emerge net-misc/ifenslave # For link bonding/trunking on 2.4 kernels, or kernels without sysfs
# emerge net-misc/ifenslave
# To bond interfaces together # To bond interfaces together
#slaves_bond0="eth0 eth1 eth2" #slaves_bond0="eth0 eth1 eth2"
#config_bond0="null" # You may not want to assign an IP the the bond #config_bond0="null" # You may not want to assign an IP the the bond
# You can also configure the bond here, which must be done via sysfs on 2.6
# kernels or newer. See the kernel bonding documention for a description of
# these options.
#arp_ip_target_bond0="+26.0.0.0"
# If any of the slaves require extra configuration - for example wireless or # If any of the slaves require extra configuration - for example wireless or
# ppp devices - we need to depend function on the bonded interfaces # ppp devices - we need to depend function on the bonded interfaces
#rc_need_bond0="net.eth0 net.eth1" #rc_need_bond0="net.eth0 net.eth1"
@@ -1006,7 +1016,7 @@
#postdown() { #postdown() {
# # Enable Wake-On-LAN for every interface except for lo # # Enable Wake-On-LAN for every interface except for lo
# # Probably a good idea to set RC_DOWN_INTERFACE="no" in /etc/conf.d/rc # # Probably a good idea to set ifdown="no" in /etc/conf.d/net
# # as well ;) # # as well ;)
# [ "${IFACE}" != "lo" ] && ethtool -s "${IFACE}" wol g # [ "${IFACE}" != "lo" ] && ethtool -s "${IFACE}" wol g

View File

@@ -1,6 +1,8 @@
DIR= ${SYSCONFDIR} DIR= ${SYSCONFDIR}
CONF= rc.conf CONF= rc.conf
CLEANFILES+= rc.conf
MK= ../mk MK= ../mk
include ${MK}/os.mk include ${MK}/os.mk
include Makefile.${OS} include Makefile.${OS}

View File

@@ -6,20 +6,3 @@
# consolefont, numlock, etc ...) # consolefont, numlock, etc ...)
rc_tty_number=12 rc_tty_number=12
# Use this variable to control the /dev management behavior.
# devfs - use devfs (requires sys-fs/devfsd)
# mdev - use mdev (requires sys-apps/busybox)
# udev - use udev (requires sys-fs/udev)
# static - let the user manage /dev (YOU need to create ALL device nodes)
# Leave it blank to let rc work it out (udev, mdev, devfs, static)
#rc_devices=""
# UDEV OPTION:
# Set to "yes" if you want to save /dev to a tarball on shutdown
# and restore it on startup. This is useful if you have a lot of
# custom device nodes that udev does not handle/know about.
rc_device_tarball="NO"
# Sets the level at which logging of messages is done to the
# console. See dmesg(8) for more info.
dmesg_level="1"

View File

@@ -4,12 +4,21 @@
# in parallel for a slight speed improvement. When running in parallel we # in parallel for a slight speed improvement. When running in parallel we
# prefix the service output with it's name as the output will get # prefix the service output with it's name as the output will get
# jumbled up. # jumbled up.
rc_parallel="NO" # WARNING: whilst we have improved parallel, it can still potentially lock
# the boot process. Don't file bugs about this unless you can supply
# patches that fix it without breaking other things!
#rc_parallel="NO"
# Set rc_interactive to "YES" and you'll be able to press the I key during # Set rc_interactive to "YES" and you'll be able to press the I key during
# boot so you can choose to start specific services. Set to "NO" to disable # boot so you can choose to start specific services. Set to "NO" to disable
# this feature. # this feature.
rc_interactive="YES" #rc_interactive="YES"
# If we need to drop to a shell, you can specify it here.
# If not specified we use $SHELL, otherwise the one specified in /etc/passwd,
# otherwise /bin/sh
# Linux users could specify /sbin/sulogin
#rc_shell=/bin/sh
# Do we allow any started service in the runlevel to satisfy the depedency # Do we allow any started service in the runlevel to satisfy the depedency
# or do we want all of them regardless of state? For example, if net.eth0 # or do we want all of them regardless of state? For example, if net.eth0
@@ -17,44 +26,54 @@ rc_interactive="YES"
# both will be started, but services that depend on 'net' will work if either # both will be started, but services that depend on 'net' will work if either
# one comes up. With rc_depend_strict="YES" we would require them both to # one comes up. With rc_depend_strict="YES" we would require them both to
# come up. # come up.
rc_depend_strict="YES" #rc_depend_strict="YES"
# Do we allow services to be hotplugged? If not, set to rc_hotplug="NO" # rc_hotplug is a list of services that we allow to be hotplugged.
# NOTE: This does not affect anything hotplug/udev/devd related, just the # By default we do not allow hotplugging.
# starting/stopping of the init.d service triggered by it. # A hotplugged service is one started by a dynamic dev manager when a matching
rc_hotplug="YES" # hardware device is found.
# This service is intrinsically included in the boot runlevel.
# Dynamic /dev managers can trigger coldplug events which cause services to # To disable services, prefix with a !
# start before we are ready for them. If this happens, we can defer these # Example - rc_hotplug="net.wlan !net.*"
# services to start in the boot runlevel. Set rc_coldplug="NO" if you don't
# want this.
# NOTE: This also affects module coldplugging in udev-096 and higher
# If you want module coldplugging but not coldplugging of services then you
# can set rc_coldplug="YES" and rc_plug_services="!*"
rc_coldplug="YES"
# Some people want a finer grain over hotplug/coldplug. rc_plug_services is a
# list of services that are matched in order, either allowing or not. By
# default we allow services through as rc_coldplug/rc_hotplug has to be YES
# anyway.
# Example - rc_plug_services="net.wlan !net.*"
# This allows net.wlan and any service not matching net.* to be plugged. # This allows net.wlan and any service not matching net.* to be plugged.
rc_plug_services="" # Example - rc_hotplug="*"
# This allows all services to be hotplugged
#rc_hotplug="*"
# rc_logger launches a logging daemon to log the entire rc process to # rc_logger launches a logging daemon to log the entire rc process to
# /var/log/rc.log # /var/log/rc.log
rc_logger="NO" # NOTE: Linux systems require the devfs service to be started before
# logging can take place and as such cannot log the sysinit runlevel.
#rc_logger="YES"
# By default we filter the environment for our running scripts. To allow other # By default we filter the environment for our running scripts. To allow other
# variables through, add them here. Use a * to allow all variables through. # variables through, add them here. Use a * to allow all variables through.
# rc_env_allow="VAR1 VAR2" #rc_env_allow="VAR1 VAR2"
# By default we assume that all daemons will start correctly.
# However, some do not - a classic example is that they fork and return 0 AND
# then child barfs on a configuration error. Or the daemon has a bug and the
# child crashes. You can set the number of milliseconds start-stop-daemon
# waits to check that the daemon is still running after starting here.
# The default is 0 - no checking.
#rc_start_wait=100
# rc_nostop is a list of services which will not stop when changing runlevels.
# This still allows the service itself to be stopped when called directly.
#rc_nostop=""
# rc will attempt to start crashed services by default.
# However, it will not stop them by default as that could bring down other
# critical services.
#rc_crashed_stop=NO
#rc_crashed_start=YES
############################################################################## ##############################################################################
# MISC CONFIGURATION VARIABLES # MISC CONFIGURATION VARIABLES
# There variables are shared between many init scripts # There variables are shared between many init scripts
# Set unicode to YES to turn on unicode support for keyboards and screens. # Set unicode to YES to turn on unicode support for keyboards and screens.
unicode="NO" #unicode="NO"
# Network fstypes. Below is the default. # Network fstypes. Below is the default.
net_fs_list="afs cifs coda davfs fuse gfs ncpfs nfs nfs4 ocfs2 shfs smbfs" net_fs_list="afs cifs coda davfs fuse gfs ncpfs nfs nfs4 ocfs2 shfs smbfs"

View File

@@ -1,5 +1,5 @@
#!/bin/sh #!/bin/sh
# Copyright 2007-2008 Roy Marples <roy@marples.name> # Copyright (c) 2007-2008 Roy Marples <roy@marples.name>
# All rights reserved. Released under the 2-clause BSD license. # All rights reserved. Released under the 2-clause BSD license.
# Inform RC that we are in the background and hotplugged # Inform RC that we are in the background and hotplugged

View File

@@ -1,5 +1,5 @@
#!@SHELL@ #!@SHELL@
# Copyright 2007-2008 Roy Marples <roy@marples.name> # Copyright (c) 2007-2008 Roy Marples <roy@marples.name>
# All rights reserved. Released under the 2-clause BSD license. # All rights reserved. Released under the 2-clause BSD license.
# If $TERM is not set then assume default of @TERM@ # If $TERM is not set then assume default of @TERM@
@@ -10,12 +10,9 @@
trap : SIGINT trap : SIGINT
trap "echo 'Boot interrupted'; exit 1" SIGQUIT trap "echo 'Boot interrupted'; exit 1" SIGQUIT
# BSD's init works somewhat differently to sysvinit. /sbin/rc sysinit || exit 1
# This block should 'translate' from the way init calls it to the way it would /sbin/rc boot || exit 1
# be called by sysvinit on linux. /sbin/rc default
RUNLEVEL="1" /sbin/rc sysinit || exit 1
RUNLEVEL="1" /sbin/rc boot || exit 1
PREVLEVEL="1" /sbin/rc default
# We don't actually care if rc default worked or not, we should exit 0 # We don't actually care if rc default worked or not, we should exit 0
# to allow logins # to allow logins

View File

@@ -1,5 +1,5 @@
#!@SHELL@ #!@SHELL@
# Copyright 2007-2008 Roy Marples <roy@marples.name> # Copyright (c) 2007-2008 Roy Marples <roy@marples.name>
# All rights reserved. Released under the 2-clause BSD license. # All rights reserved. Released under the 2-clause BSD license.
# Handle interrupts # Handle interrupts
@@ -14,13 +14,4 @@ export LD_LIBRARY_PATH="/lib${LD_LIBRARY_PATH:+:}${LDLIBRARY_PATH}"
[ -z "$TERM" -o "$TERM" = "dumb" ] && export TERM="@TERM@" [ -z "$TERM" -o "$TERM" = "dumb" ] && export TERM="@TERM@"
action=${1:-shutdown} action=${1:-shutdown}
# BSD's init works somewhat differently to sysvinit.
# This block should 'translate' from the way init calls it to the way it would
# be called by sysvinit on linux.
case "${action}" in
reboot) export RUNLEVEL=6;;
single) export RUNLEVEL=S;;
*) export RUNLEVEL=0;;
esac
exec /sbin/rc "${action}" exec /sbin/rc "${action}"

View File

@@ -1,9 +0,0 @@
avahi-dnsconfd
avahid
dbus
hald
named
ntpd
openvpn
polkitd
sshd

View File

@@ -1,7 +1,11 @@
DIR= ${INITDIR} DIR= ${INITDIR}
SRCS= avahi-dnsconfd.in avahid.in dbus.in hald.in named.in ntpd.in \ SRCS= avahi-dnsconfd.in avahid.in dhcpcd.in dbus.in \
openvpn.in polkitd.in sshd.in hald.in named.in ntpd.in \
openvpn.in polkitd.in sshd.in wpa_supplicant.in
MK= ../mk MK= ../mk
SED_EXTRA+= -e 's:@VARBASE@:/var:g'
include ${MK}/scripts.mk include ${MK}/scripts.mk
include Makefile.${OS} include Makefile.${OS}

View File

@@ -1 +1 @@
PREFIX?= /usr/local PKG_PREFIX?= /usr/local

View File

@@ -1 +1 @@
PREFIX=/usr PKG_PREFIX?=/usr

View File

@@ -1 +1 @@
PREFIX?= /usr/pkg PKG_PREFIX?= /usr/pkg

View File

@@ -1,9 +1,9 @@
#!@PREFIX@/sbin/runscript #!@PREFIX@/sbin/runscript
# Copyright 2007-2008 Roy Marples <roy@marples.name> # Copyright (c) 2007-2008 Roy Marples <roy@marples.name>
# All rights reserved. Released under the 2-clause BSD license. # All rights reserved. Released under the 2-clause BSD license.
command=@PKG_PREFIX@/sbin/avahi-dnsconfd command=@PKG_PREFIX@/sbin/avahi-dnsconfd
command_args="${avahi_dnsconfd_args} -D" command_args="$avahi_dnsconfd_args -D"
pidfile=@VARBASE@/run/avahi-dnsconfd.pid pidfile=@VARBASE@/run/avahi-dnsconfd.pid
name="Avahi DNS Configuration Daemon" name="Avahi DNS Configuration Daemon"

View File

@@ -1,9 +1,9 @@
#!@PREFIX@/sbin/runscript #!@PREFIX@/sbin/runscript
# Copyright 2007-2008 Roy Marples <roy@marples.name> # Copyright (c) 2007-2008 Roy Marples <roy@marples.name>
# All rights reserved. Released under the 2-clause BSD license. # All rights reserved. Released under the 2-clause BSD license.
command=@PKG_PREFIX@/sbin/avahi-daemon command=@PKG_PREFIX@/sbin/avahi-daemon
command_args="${avahid_args} -D" command_args="$avahid_args -D"
pidfile=@VARBASE@/run/avahi-daemon/pid pidfile=@VARBASE@/run/avahi-daemon/pid
name="Avahi Service Advertisement Daemon" name="Avahi Service Advertisement Daemon"

View File

@@ -1,9 +1,9 @@
#!@PREFIX@/sbin/runscript #!@PREFIX@/sbin/runscript
# Copyright 2007-2008 Roy Marples <roy@marples.name> # Copyright (c) 2007-2008 Roy Marples <roy@marples.name>
# All rights reserved. Released under the 2-clause BSD license. # All rights reserved. Released under the 2-clause BSD license.
command=@PKG_PREFIX@/bin/dbus-daemon command=@PKG_PREFIX@/bin/dbus-daemon
pidfile=@VARBASE@/run/dbus/dbus.pid pidfile=@VARBASE@/run/dbus/pid
command_args="${dbusd_args---system}" command_args="${dbusd_args---system}"
name="Message Bus Daemon" name="Message Bus Daemon"

27
init.d.misc/dhcpcd.in Normal file
View File

@@ -0,0 +1,27 @@
#!@PREFIX@/sbin/runscript
# Copyright (c) 2009 Roy Marples <roy@marples.name>
# All rights reserved. Released under the 2-clause BSD license.
command=/sbin/dhcpcd
pidfile=/var/run/dhcpcd.pid
command_args=-q
name="DHCP Client Daemon"
depend()
{
provide net
need localmount
use logger
after bootmisc modules
before dns
}
stop_pre()
{
# When shutting down, kill dhcpcd but preserve network
# We do this as /var/run/dhcpcd could be cleaned out when we
# return to multiuser.
if yesno $RC_GOINGDOWN; then
: ${stopsig:=SIGKILL}
fi
}

View File

@@ -1,9 +1,9 @@
#!@PREFIX@/sbin/runscript #!@PREFIX@/sbin/runscript
# Copyright 2007-2008 Roy Marples <roy@marples.name> # Copyright (c) 2007-2008 Roy Marples <roy@marples.name>
# All rights reserved. Released under the 2-clause BSD license. # All rights reserved. Released under the 2-clause BSD license.
command=@PKG_PREFIX@/sbin/dnsmasq command=@PKG_PREFIX@/sbin/dnsmasq
command_args=${dnsmasq_args} command_args=$dnsmasq_args
pidfile=@VARBASE@/run/dnsmasq.pid pidfile=@VARBASE@/run/dnsmasq.pid
required_files=/etc/dnsmasq.conf required_files=/etc/dnsmasq.conf
@@ -18,7 +18,7 @@ depend()
reload() reload()
{ {
ebegin "Reloading ${RC_SVCNAME}" ebegin "Reloading $RC_SVCNAME"
start-stop-daemon --signal SIGHUP --pidfile "${pidfile}" start-stop-daemon --signal SIGHUP --pidfile "$pidfile"
eend $? eend $?
} }

View File

@@ -1,10 +1,10 @@
#!@PREFIX@/sbin/runscript #!@PREFIX@/sbin/runscript
# Copyright 2007-2008 Roy Marples <roy@marples.name> # Copyright (c) 2007-2008 Roy Marples <roy@marples.name>
# All rights reserved. Released under the 2-clause BSD license. # All rights reserved. Released under the 2-clause BSD license.
command=@PKG_PREFIX@/sbin/hald command=@PKG_PREFIX@/sbin/hald
pidfile=@VARBASE@/run/hald/hald.pid pidfile=@VARBASE@/run/hald/hald.pid
command_args="${hald_args}" command_args=$hald_args
name="Hardware Abstraction Layer Daemon" name="Hardware Abstraction Layer Daemon"
depend() depend()

View File

@@ -1,15 +1,25 @@
#!@PREFIX@/sbin/runscript #!@PREFIX@/sbin/runscript
# Copyright 2007-2008 Roy Marples <roy@marples.name> # Copyright (c) 2007-2008 Roy Marples <roy@marples.name>
# All rights reserved. Released under the 2-clause BSD license. # All rights reserved. Released under the 2-clause BSD license.
command=/usr/sbin/named command=/usr/sbin/named
command_args=${named_args} command_args=$named_args
pidfile=@VARBASE@/run/named/pid pidfile=@VARBASE@/run/named.pid
name="Domain Name server" name="Domain Name server"
extra_started_commands="reload" extra_started_commands="reload"
namedb=/etc/namedb namedb=/etc/namedb
named_uid=${named_uid:-bind} uid=named
case "$RC_UNAME" in
FreeBSD)
uid=bind
pidfile=@VARBASE@/run/named/pid
;;
Linux)
uid=bind
;;
esac
: ${named_uid:=${uid}}
depend() depend()
{ {
@@ -20,68 +30,71 @@ depend()
start_pre() start_pre()
{ {
if [ -n "${named_chroot}" ]; then if [ -n "$named_chroot" ]; then
# Create (or update) the chroot directory structure # Create (or update) the chroot directory structure
if [ -r /etc/mtree/BIND.chroot.dist ]; then if [ -r /etc/mtree/BIND.chroot.dist ]; then
mtree -deU -f /etc/mtree/BIND.chroot.dist -p "${named_chroot}" mtree -deU -f /etc/mtree/BIND.chroot.dist -p "$named_chroot"
else else
ewarn "/etc/mtree/BIND.chroot.dist missing," ewarn "/etc/mtree/BIND.chroot.dist missing,"
ewarn "chroot directory structure not updated" ewarn "chroot directory structure not updated"
fi fi
if [ ! -d "${named_chroot}"/. ]; then if [ ! -d "$named_chroot"/. ]; then
eerror "chroot directory ${named_chroot} missing" eerror "chroot directory $named_chroot missing"
exit 1 exit 1
fi fi
# Create /etc/namedb symlink # Create /etc/namedb symlink
if [ ! -L "${namedb}" ]; then if [ ! -L "$namedb" ]; then
if [ -d "${namedb}" ]; then if [ -d "$namedb" ]; then
ewarn "named chroot: ${namedb} is a directory!" ewarn "named chroot: $namedb is a directory!"
elif [ -e "${namedb}" ]; then elif [ -e "$namedb" ]; then
ewarn "named chroot: ${namedb} exists!" ewarn "named chroot: $namedb exists!"
else else
ln -s "${named_chroot}${namedb}" "${namedb}" ln -s "$named_chroot$namedb" "$namedb"
fi fi
else else
# Make sure it points to the right place. # Make sure it points to the right place.
ln -shf "${named_chroot}${namedb}" "${namedb}" ln -shf "$named_chroot$namedb" "$namedb"
fi fi
case "${RC_UNAME}" in case "$RC_UNAME" in
*BSD|DragonFly) *BSD|DragonFly)
# Mount a devfs in the chroot directory if needed # Mount a devfs in the chroot directory if needed
umount "${named_chroot}"/dev 2>/dev/null umount "$named_chroot"/dev 2>/dev/null
mount -t devfs dev "${named_chroot}"/dev mount -t devfs dev "$named_chroot"/dev
devfs -m "${named_chroot}"/dev ruleset devfsrules_hide_all devfs -m "$named_chroot"/dev \
devfs -m "${named_chroot}"/dev rule apply path null unhide ruleset devfsrules_hide_all
devfs -m "${named_chroot}"/dev rule apply path random unhide devfs -m "$named_chroot"/dev \
rule apply path null unhide
devfs -m "$named_chroot"/dev \
rule apply path random unhide
;; ;;
esac esac
# Copy local timezone information if it is not up to date. # Copy local timezone information if it is not up to date.
if [ -r /etc/localtime ]; then if [ -r /etc/localtime ]; then
cmp -s /etc/localtime "${named_chroot}/etc/localtime" || cmp -s /etc/localtime "$named_chroot/etc/localtime" ||
cp -p /etc/localtime "${named_chroot}/etc/localtime" cp -p /etc/localtime "$named_chroot/etc/localtime"
fi fi
command_args="${command_args} -t ${named_chroot}" command_args="$command_args -t $named_chroot"
ln -fs "${named_chroot}${pidfile}" "${pidfile}" ln -fs "$named_chroot$pidfile" "$pidfile"
fi fi
if [ ! -s "${named_chroot}${namedb}/rndc.conf" ]; then if [ ! -s "$named_chroot$namedb/rndc.conf" ]; then
local confgen="${command%/named}/rndc-confgen -a -b256 -u ${named_uid} \ local confgen="${command%/named}/rndc-confgen -a -b256 -u $named_uid \
-c ${named_chrootdir}/etc/namedb/rndc.key" -c $named_chrootdir/etc/namedb/rndc.key"
if [ -s "${named_chroot}${namedb}/rndc.key" ]; then if [ -s "$named_chroot$namedb/rndc.key" ]; then
local getuser="stat -f%Su" local getuser="stat -f%Su"
[ "${RC_UNAME}" = "Linux" ] && getuser="stat -c%U" [ "$RC_UNAME" = Linux ] && getuser="stat -c%U"
case $(${getuser} "${named_chroot}${namedb}"/rndc.key) in case $(${getuser} "$named_chroot$namedb"/rndc.key) in
root|"${named_uid}");; root|"$named_uid");;
*) ${confgen};; *) $confgen;;
esac esac
else else
${confgen} $confgen
fi fi
fi fi
} }
@@ -93,7 +106,7 @@ reload()
stop_post() stop_post()
{ {
if [ -n "${named_chroot}" -a -c "${named_chroot}"/dev/null ]; then if [ -n "$named_chroot" -a -c "$named_chroot"/dev/null ]; then
umount "${named_chroot}"/dev 2>/dev/null || true umount "$named_chroot"/dev 2>/dev/null || true
fi fi
} }

View File

@@ -1,13 +1,14 @@
#!@PREFIX@/sbin/runscript #!@PREFIX@/sbin/runscript
# Copyright 2007-2008 Roy Marples <roy@marples.name> # Copyright (c) 2007-2009 Roy Marples <roy@marples.name>
# All rights reserved. Released under the 2-clause BSD license. # All rights reserved. Released under the 2-clause BSD license.
ntpd_config=${ntpd_config:-/etc/ntp.conf} : ${ntpd_config:=/etc/ntp.conf}
ntpd_drift=${ntpd_drift:-/var/db/ntpd.drift} : ${ntpd_drift:=/var/db/ntpd.drift}
command=/usr/sbin/ntpd command=/usr/sbin/ntpd
required_files=$ntpd_config
pidfile=/var/run/ntpd.pid pidfile=/var/run/ntpd.pid
command_args="${ntpd_args} -c ${ntpd_config} -f ${ntpd_drift} -p ${pidfile}" command_args="$ntpd_args -c $ntpd_config -f $ntpd_drift -p $pidfile"
name="Network Time Protocol Daemon" name="Network Time Protocol Daemon"
depend() depend()
@@ -19,22 +20,18 @@ depend()
start_pre() start_pre()
{ {
if [ ! -r "${ntpd_config}" ]; then if [ -n "$ntpd_chroot" ]; then
eerror "${ntpd_config} is not readable" case "$RC_UNAME" in
return 1
fi
if [ -n "${ntpd_chroot}" ]; then
case "${RC_UNAME}" in
*BSD|DragonFly) *BSD|DragonFly)
if [ ! -c "${ntpd_chroot}/dev/clockctl" ]; then if [ ! -c "$ntpd_chroot/dev/clockctl" ]; then
rm -f "${ntpd_chroot}/dev/clockctl" rm -f "$ntpd_chroot/dev/clockctl"
(cd /dev; /bin/pax -rw -pe clockctl "${ntpd_chroot}/dev") (cd /dev; /bin/pax -rw -pe clockctl \
"$ntpd_chroot/dev")
fi fi
;; ;;
esac esac
ln -fs "${ntpd_chroot}${ntpd_drift}" "${ntpd_drift}" ln -fs "$ntpd_chroot$ntpd_drift" "$ntpd_drift"
command_args="${command_args} -u ntpd:ntpd -i ${ntpd_chroot}" command_args="$command_args -u ntpd:ntpd -i $ntpd_chroot"
fi fi
} }

View File

@@ -1,31 +1,32 @@
#!@PREFIX@/sbin/runscript #!@PREFIX@/sbin/runscript
# Copyright 2007-2008 Roy Marples <roy@marples.name> # Copyright (c) 2007-2008 Roy Marples <roy@marples.name>
# All rights reserved. Released under the 2-clause BSD license. # All rights reserved. Released under the 2-clause BSD license.
vpn=${RC_SVCNAME#*.} vpn=${RC_SVCNAME#*.}
name="OpenVPN" name="OpenVPN"
[ "${vpn}" != "openvpn" ] && name="${name} (${vpn})" [ "$vpn" != openvpn ] && name="$name ($vpn)"
command=@PKG_PREFIX@/sbin/openvpn command=@PKG_PREFIX@/sbin/openvpn
pidfile=@VARBASE@/run/"${RC_SVCNAME}".pid pidfile=@VARBASE@/run/"$RC_SVCNAME".pid
openvpn_dir=${openvpn_dir:-@PKG_PREFIX@/etc/openvpn} : ${openvpn_dir:=@PKG_PREFIX@/etc/openvpn}
openvpn_config=${openvpn_config:-${openvpn_dir}/${vpn}.conf} : ${openvpn_config:=$openvpn_dir/$vpn.conf}
command_args="${openvpn_args} --daemon --config ${openvpn_config} --writepid ${pidfile}" command_args="$openvpn_args --daemon --config $openvpn_config"
required_dirs="${openvpn_dir}" command_args="$command_args --writepid $pidfile"
required_files="${openvpn_config}" required_dirs=$openvpn_dir
required_files=$openvpn_config
# If we're an openvpn client, then supply a nice default config # If we're an openvpn client, then supply a nice default config
# You can find sample up/down scripts in the OpenRC support/openvpn dir # You can find sample up/down scripts in the OpenRC support/openvpn dir
if yesno "${openvpn_client}"; then if yesno $openvpn_client; then
openvpn_up=${openvpn_up:-${openvpn_dir}/up.sh} : ${openvpn_up:=${openvpn_dir}/up.sh}
openvpn_down=${openvpn_down:-${openvpn_dir}/down.sh} : ${openvpn_down:=${openvpn_dir}/down.sh}
command_args="${command_args} --nobind --up-delay --up-restart --down-pre" command_args="$command_args --nobind --up-delay --up-restart --down-pre"
command_args="${command_args} --up ${openvpn_up}" command_args="$command_args --up $openvpn_up"
command_args="${command_args} --down ${openvpn_down}" command_args="$command_args --down $openvpn_down"
required_files="${required_files} ${openvpn_up} ${openvpn_down}" required_files="$required_files $openvpn_up $openvpn_down"
in_background_fake="start stop" in_background_fake="start stop"
start_inactive="YES" start_inactive=YES
fi fi
depend() depend()
@@ -38,7 +39,7 @@ depend()
start_pre() start_pre()
{ {
# Linux has good dynamic tun/tap creation # Linux has good dynamic tun/tap creation
if [ "${RC_UNAME}" = "Linux" ]; then if [ "$RC_UNAME" = Linux ]; then
if [ ! -e /dev/net/tun ]; then if [ ! -e /dev/net/tun ]; then
if ! modprobe tun; then if ! modprobe tun; then
eerror "TUN/TAP support is not available in this kernel" eerror "TUN/TAP support is not available in this kernel"
@@ -60,8 +61,7 @@ start_pre()
fi fi
# If the config file does not specify the cd option, we do # If the config file does not specify the cd option, we do
# But if we specify it, we override the config option which we do not want if ! grep -q "^[ \t]*cd[ \t].*" "$openvpn_config"; then
if ! grep -q "^[ \t]*cd[ \t].*" "${openvpn_config}"; then command_args="$command_args --cd $openvpn_dir"
command_args="${command_args} --cd ${openvpn_dir}"
fi fi
} }

View File

@@ -1,10 +1,10 @@
#!@PREFIX@/sbin/runscript #!@PREFIX@/sbin/runscript
# Copyright 2007-2008 Roy Marples <roy@marples.name> # Copyright (c) 2007-2008 Roy Marples <roy@marples.name>
# All rights reserved. Released under the 2-clause BSD license. # All rights reserved. Released under the 2-clause BSD license.
command=@PKG_PREFIX@/sbin/polkitd command=@PKG_PREFIX@/sbin/polkitd
pidfile=@VARBASE@/run/polkitd/polkitd.pid pidfile=@VARBASE@/run/polkitd/polkitd.pid
command_args="${polkitd_args}" command_args="$polkitd_args"
name="PolicyKit Daemon" name="PolicyKit Daemon"
depend() depend()

View File

@@ -1,9 +1,9 @@
#!@PREFIX@/sbin/runscript #!@PREFIX@/sbin/runscript
# Copyright 2007-2008 Roy Marples <roy@marples.name> # Copyright (c) 2007-2008 Roy Marples <roy@marples.name>
# All rights reserved. Released under the 2-clause BSD license. # All rights reserved. Released under the 2-clause BSD license.
command=/usr/sbin/sshd command=/usr/sbin/sshd
command_args=${sshd_args} command_args=$sshd_args
pidfile=@VARBASE@/run/sshd.pid pidfile=@VARBASE@/run/sshd.pid
required_files=/etc/ssh/sshd_config required_files=/etc/ssh/sshd_config
@@ -31,5 +31,5 @@ start_pre()
eend $? || return 1 eend $? || return 1
fi fi
${command} -t $command -t
} }

View File

@@ -0,0 +1,68 @@
#!@PREFIX@/sbin/runscript
# Copyright (c) 2009 Roy Marples <roy@marples.name>
# All rights reserved. Released under the 2-clause BSD license.
command=/usr/sbin/wpa_supplicant
: ${wpa_supplicant_conf:=/etc/wpa_supplicant.conf}
wpa_supplicant_if=${wpa_supplicant_if:+-i}$wpa_supplicant_if
command_args="$wpa_supplicant_args -B -c$wpa_supplicant_conf $wpa_supplicant_if"
name="WPA Supplicant Daemon"
depend()
{
need localmount
use logger
after bootmisc modules
before dns dhcpcd net
keyword noshutdown
}
find_wireless()
{
local iface=
case "$RC_UNAME" in
Linux)
for iface in /sys/class/net/*; do
if [ -e "$iface"/wireless ]; then
echo "${iface##*/}"
return 0
fi
done
;;
*)
for iface in /dev/net/* $(ifconfig -l 2>/dev/null); do
if ifconfig "${iface##*/}" 2>/dev/null | \
grep -q "[ ]*ssid "
then
echo "${iface##*/}"
return 0
fi
done
;;
esac
return 1
}
append_wireless()
{
local iface= i=
iface=$(find_wireless)
if [ -n "$iface" ]; then
for i in $iface; do
command_args="$command_args -i$i"
done
else
eerror "Could not find a wireless interface"
fi
}
start_pre()
{
case " $command_args" in
*" -i"*) ;;
*) append_wireless;;
esac
}

31
init.d/.gitignore vendored
View File

@@ -1,28 +1,39 @@
bootmisc bootmisc
fsck fsck
halt.sh
hostname hostname
local local
localmount localmount
moused
net.lo
net.lo0
netmount netmount
network
root root
savecache
swap swap
sysctl sysctl
urandom urandom
devfs
dmesg
hwclock
consolefont
keymaps
killprocs
modules
mount-ro
mtab
numlock
procfs
sysfs
devdb
hostid hostid
moused
newsyslog newsyslog
pf pf
rarpd rarpd
rc-enabled rc-enabled
rpcbind rpcbind
savecore savecore
swap-blk
syslogd syslogd
adjkerntz ttys
devd wscons
dumpon
ipfw
mixer
nscd
powerd
syscons

View File

@@ -1,9 +1,26 @@
DIR= ${INITDIR} DIR= ${INITDIR}
SRCS= bootmisc.in fsck.in halt.sh.in hostname.in local.in localmount.in \ SRCS= bootmisc.in fsck.in hostname.in local.in localmount.in netmount.in \
netmount.in root.in swap.in sysctl.in urandom.in network.in root.in savecache.in swap.in sysctl.in urandom.in
BIN= ${OBJS} BIN= ${OBJS}
# Build our old net foo or not
_OLDNET_SH= case "${MKOLDNET}" in \
[Yy][Ee][Ss]) echo "net.lo";; \
*) echo "";; \
esac
_OLDNET!= ${_OLDNET_SH}
_NET_LO= ${_OLDNET}$(shell ${_OLDNET_SH})
INSTALLAFTER= _installafter_${_NET_LO}
CLEANFILES+= ${_NET_LO}
TARGETS+= ${_NET_LO}
MK= ../mk MK= ../mk
include ${MK}/os.mk include ${MK}/os.mk
include Makefile.${OS} include Makefile.${OS}
include ${MK}/scripts.mk include ${MK}/scripts.mk
_installafter_: realinstall
_installafter_net.lo: realinstall
${INSTALL} -m ${BINMODE} net.lo ${DESTDIR}/${INITDIR}/${NET_LO}

View File

@@ -1,3 +1,5 @@
NET_LO= net.lo0
# Generic BSD scripts # Generic BSD scripts
SRCS+= hostid.in moused.in newsyslog.in pf.in rarpd.in rc-enabled.in \ SRCS+= hostid.in moused.in newsyslog.in pf.in rarpd.in rc-enabled.in \
rpcbind.in savecore.in syslogd.in rpcbind.in savecore.in syslogd.in

View File

@@ -1,5 +1,8 @@
SRCS+= hwclock.in consolefont.in keymaps.in modules.in mtab.in numlock.in \ NET_LO= net.lo
procfs.in termencoding.in
SRCS+= devfs.in dmesg.in hwclock.in consolefont.in keymaps.in killprocs.in \
modules.in mount-ro.in mtab.in numlock.in procfs.in sysfs.in \
termencoding.in
.SUFFIXES: .Linux.in .SUFFIXES: .Linux.in
.Linux.in: .Linux.in:

View File

@@ -1,9 +1,11 @@
NET_LO= net.lo0
# Generic BSD scripts # Generic BSD scripts
SRCS+= hostid.in moused.in newsyslog.in pf.in rarpd.in rc-enabled.in \ SRCS+= hostid.in moused.in newsyslog.in pf.in rarpd.in rc-enabled.in \
rpcbind.in savecore.in syslogd.in rpcbind.in savecore.in syslogd.in
# These are NetBSD specific # These are NetBSD specific
SRCS+= swap-blk.in ttys.in wscons.in SRCS+= devdb.in swap-blk.in ttys.in wscons.in
.SUFFIXES: .BSD.in .SUFFIXES: .BSD.in
.BSD.in: .BSD.in:

View File

@@ -1,5 +1,5 @@
#!@PREFIX@/sbin/runscript #!@PREFIX@/sbin/runscript
# Copyright 2007-2008 Roy Marples <roy@marples.name> # Copyright (c) 2007-2009 Roy Marples <roy@marples.name>
# All rights reserved. Released under the 2-clause BSD license. # All rights reserved. Released under the 2-clause BSD license.
extra_commands="save" extra_commands="save"
@@ -7,8 +7,8 @@ extra_commands="save"
description="Sets the local clock to UTC or Local Time." description="Sets the local clock to UTC or Local Time."
description_save="Saves the current time in the BIOS." description_save="Saves the current time in the BIOS."
clock=${clock:-${CLOCK:-UTC}} : ${clock:=${CLOCK:-UTC}}
if [ "${clock}" = "UTC" ]; then if [ "$clock" = "UTC" ]; then
utc="UTC" utc="UTC"
else else
utc="Local Time" utc="Local Time"
@@ -18,8 +18,8 @@ depend()
{ {
provide clock provide clock
# BSD adjkerntz needs to be able to write to /etc # BSD adjkerntz needs to be able to write to /etc
if [ "${clock}" = "UTC" -a -e /etc/wall_cmos_clock ] || if [ "$clock" = "UTC" -a -e /etc/wall_cmos_clock ] ||
[ "${clock}" != "UTC" -a ! -e /etc/wall_cmos_clock ]; then [ "$clock" != "UTC" -a ! -e /etc/wall_cmos_clock ]; then
need root need root
fi fi
keyword nojail noprefix keyword nojail noprefix
@@ -28,7 +28,7 @@ depend()
start() start()
{ {
ebegin "Starting the System Clock Adjuster [${utc}]" ebegin "Starting the System Clock Adjuster [${utc}]"
if [ "${clock}" != "UTC" ]; then if [ "$clock" != "UTC" ]; then
echo >/etc/wall_cmos_clock echo >/etc/wall_cmos_clock
start-stop-daemon --start --exec /sbin/adjkerntz -- -i start-stop-daemon --start --exec /sbin/adjkerntz -- -i
else else
@@ -48,8 +48,8 @@ save()
stop() stop()
{ {
# Don't tweak the hardware clock on LiveCD halt. # Don't tweak the hardware clock on LiveCD halt.
if yesno "${clock_systohc:-${CLOCK_SYSTOHC}}"; then if yesno "${clock_systohc:-$CLOCK_SYSTOHC}"; then
[ -z "${CDBOOT}" ] && save [ -z "$CDBOOT" ] && save
fi fi
ebegin "Stopping the System Clock Adjuster" ebegin "Stopping the System Clock Adjuster"

View File

@@ -1,5 +1,5 @@
#!@PREFIX@/sbin/runscript #!@PREFIX@/sbin/runscript
# Copyright 2007-2008 Roy Marples <roy@marples.name> # Copyright (c) 2007-2009 Roy Marples <roy@marples.name>
# All rights reserved. Released under the 2-clause BSD license. # All rights reserved. Released under the 2-clause BSD license.
depend() depend()
@@ -16,30 +16,27 @@ dir_writeable()
mkdir "$1"/.test.$$ 2>/dev/null && rmdir "$1"/.test.$$ mkdir "$1"/.test.$$ 2>/dev/null && rmdir "$1"/.test.$$
} }
: ${wipe_tmp:=${WIPE_TMP:-yes}}
cleanup_tmp_dir() cleanup_tmp_dir()
{ {
local dir="$1" local dir="$1"
if ! [ -d "${dir}" ]; then if ! [ -d "$dir" ]; then
mkdir -p "${dir}" || return $? mkdir -p "$dir" || return $?
fi fi
dir_writeable "${dir}" || return 1 dir_writeable "$dir" || return 1
chmod +t "${dir}" chmod +t "$dir"
cd "${dir}" cd "$dir"
if yesno ${wipe_tmp:-${WIPE_TMP:-yes}}; then if yesno $wipe_tmp; then
ebegin "Wiping ${dir} directory" ebegin "Wiping $dir directory"
local startopts="-x . -depth" delete="-exec rm -rf -- {} ;" local startopts="-x . -depth"
[ "$RC_UNAME" = Linux ] && startopts=". -xdev -depth"
if [ "${RC_UNAME}" = "Linux" ]; then
startopts=". -xdev -depth"
# busybox find / rm cannot handle --
delete="-delete"
fi
# Faster than find # Faster than find
rm -rf -- [b-ikm-pr-zA-Z0-9\.]* rm -rf -- [^ajlq\.]*
find ${startopts} ! -name . \ find $startopts ! -name . \
! -path "./lost+found" \ ! -path "./lost+found" \
! -path "./lost+found/*" \ ! -path "./lost+found/*" \
! -path "./quota.user" \ ! -path "./quota.user" \
@@ -54,27 +51,37 @@ cleanup_tmp_dir()
! -path "./journal/*" \ ! -path "./journal/*" \
! -path "./.private" \ ! -path "./.private" \
! -path "./.private/*" \ ! -path "./.private/*" \
${delete} \ -exec rm -rf {} \;
-type d -prune
eend 0 eend 0
else else
ebegin "Cleaning ${dir} directory" ebegin "Cleaning $dir directory"
rm -rf -- "${dir}"/.X*-lock "${dir}"/esrv* "${dir}"/kio* \ rm -rf -- "$dir"/.X*-lock "$dir"/esrv* "$dir"/kio* \
"${dir}"/jpsock.* "${dir}"/.fam* "${dir}"/.esd* \ "$dir"/jpsock.* "$dir"/.fam* "$dir"/.esd* \
"${dir}"/orbit-* "${dir}"/ssh-* "${dir}"/ksocket-* \ "$dir"/orbit-* "$dir"/ssh-* "$dir"/ksocket-* \
"${dir}"/.*-unix "$dir"/.*-unix
eend 0 eend 0
fi fi
} }
mkutmp()
{
: >"$1"
# Not all systems have the utmp group
chgrp utmp "$1" 2>/dev/null
chmod 0664 "$1"
}
start() start()
{ {
local logw=false # Remove any added console dirs
rm -rf "$RC_LIBEXECDIR"/console
local logw=false runw=false
# Ensure that our basic dirs exist # Ensure that our basic dirs exist
for x in /var/log /var/run /tmp; do for x in /var/log /var/run /tmp; do
if ! [ -d "${x}" ]; then if ! [ -d $x ]; then
if ! mkdir -p "${x}"; then if ! mkdir -p $x; then
eend 1 "failed to create needed directory ${x}" eend 1 "failed to create needed directory $x"
return 1 return 1
fi fi
fi fi
@@ -82,36 +89,44 @@ start()
if dir_writeable /var/run; then if dir_writeable /var/run; then
ebegin "Creating user login records" ebegin "Creating user login records"
cp /dev/null /var/run/utmp local xtra=
if dir_writeable /var/log; then [ "$RC_UNAME" = NetBSD ] && xtra=x
logw=true for x in "" $xtra; do
[ -e /var/log/wtmp ] || cp /dev/null /var/log/wtmp mkutmp /var/run/utmp$x
chmod 0644 /var/run/utmp /var/log/wtmp done
fi [ -e /var/log/wtmp ] && mkutmp /var/log/wtmp
eend 0 eend 0
ebegin "Cleaning /var/run" ebegin "Cleaning /var/run"
for x in $(find /var/run ! -type d ! -name utmp \ for x in $(find /var/run ! -type d ! -name utmp \
! -name random-seed \ ! -name random-seed ! -name dev.db \
! -name ld-elf.so.hints ! -name ld.so.hints); ! -name ld-elf.so.hints ! -name ld.so.hints);
do do
[ ! -f "${x}" ] && continue # Clean stale sockets
if [ -S "$x" ]; then
if type fuser >/dev/null 2>&1; then
fuser "$x" 2>/dev/null || rm -- "$x"
else
rm -- "$x"
fi
fi
[ ! -f "$x" ] && continue
# Do not remove pidfiles of already running daemons # Do not remove pidfiles of already running daemons
case "${x}" in case "$x" in
*.pid) *.pid)
start-stop-daemon --test --quiet \ start-stop-daemon --test --quiet \
--stop --pidfile "${x}" && continue --stop --pidfile "$x" && continue
;; ;;
esac esac
rm -f -- "${x}" rm -f -- "$x"
done done
eend 0 eend 0
fi fi
# Clean up /tmp directories # Clean up /tmp directories
local tmp= local tmp=
for tmp in ${wipe_tmp_dirs-/tmp}; do for tmp in ${clean_tmp_dirs:-${wipe_tmp_dirs-/tmp}}; do
cleanup_tmp_dir "${tmp}" cleanup_tmp_dir "$tmp"
done done
if dir_writeable /tmp; then if dir_writeable /tmp; then
@@ -121,12 +136,14 @@ start()
rm -rf /tmp/.ICE-unix /tmp/.X11-unix rm -rf /tmp/.ICE-unix /tmp/.X11-unix
mkdir -p /tmp/.ICE-unix /tmp/.X11-unix mkdir -p /tmp/.ICE-unix /tmp/.X11-unix
chmod 1777 /tmp/.ICE-unix /tmp/.X11-unix chmod 1777 /tmp/.ICE-unix /tmp/.X11-unix
[ -x /sbin/restorecon ] && restorecon /tmp/.ICE-unix /tmp/.X11-unix if [ -x /sbin/restorecon ]; then
restorecon /tmp/.ICE-unix /tmp/.X11-unix
fi
fi fi
if ${logw} || dir_writeable /var/log; then if $logw || dir_writeable /var/log; then
# Create an 'after-boot' dmesg log # Create an 'after-boot' dmesg log
if [ "${RC_SYS}" != "VSERVER" -a "${RC_SYS}" != "OPENVZ" ]; then if [ "$RC_SYS" != VSERVER -a "$RC_SYS" != OPENVZ ]; then
dmesg > /var/log/dmesg dmesg > /var/log/dmesg
chmod 640 /var/log/dmesg chmod 640 /var/log/dmesg
fi fi
@@ -139,9 +156,12 @@ start()
stop() stop()
{ {
# Write a halt record if we're shutting down # Write a halt record if we're shutting down
case "${RC_RUNLEVEL}" in if [ "$RC_RUNLEVEL" = shutdown ]; then
reboot|shutdown) [ "${RC_UNAME}" = "Linux" ] && halt -w;; [ "$RC_UNAME" = Linux ] && halt -w
esac if [ "$RC_SYS" = OPENVZ ]; then
yesno $RC_REBOOT && printf "" >/reboot
fi
fi
return 0 return 0
} }

View File

@@ -1,5 +1,5 @@
#!@PREFIX@/sbin/runscript #!@PREFIX@/sbin/runscript
# Copyright 2007-2008 Roy Marples <roy@marples.name> # Copyright (c) 2007-2009 Roy Marples <roy@marples.name>
# All rights reserved. Released under the 2-clause BSD license. # All rights reserved. Released under the 2-clause BSD license.
description="Sets a font for the consoles." description="Sets a font for the consoles."
@@ -7,27 +7,24 @@ description="Sets a font for the consoles."
depend() depend()
{ {
need localmount termencoding need localmount termencoding
after hotplug after hotplug bootmisc
keyword noopenvz noprefix nouml novserver noxenu keyword noopenvz noprefix nouml novserver noxenu
} }
start() start()
{ {
# Forget about any font until we are successful
rm -rf "${RC_LIBDIR}"/console
ttyn=${rc_tty_number:-${RC_TTY_NUMBER:-12}} ttyn=${rc_tty_number:-${RC_TTY_NUMBER:-12}}
consolefont=${consolefont:-${CONSOLEFONT}} consolefont=${consolefont:-${CONSOLEFONT}}
unicodemap=${unicodemap:-${UNICODEMAP}} unicodemap=${unicodemap:-${UNICODEMAP}}
consoletranslation=${consoletranslation:-${CONSOLETRANSLATION}} consoletranslation=${consoletranslation:-${CONSOLETRANSLATION}}
if [ -z "${consolefont}" ]; then if [ -z "$consolefont" ]; then
ebegin "Using the default console font" ebegin "Using the default console font"
eend 0 eend 0
return 0 return 0
fi fi
if [ "${ttyn}" = 0 ]; then if [ "$ttyn" = 0 ]; then
ebegin "Skipping font setup (rc_tty_number == 0)" ebegin "Skipping font setup (rc_tty_number == 0)"
eend 0 eend 0
return 0 return 0
@@ -36,39 +33,39 @@ start()
local x= param= sf_param= retval=0 ttydev=/dev/tty local x= param= sf_param= retval=0 ttydev=/dev/tty
# Get additional parameters # Get additional parameters
if [ -n "${consoletranslation}" ]; then if [ -n "$consoletranslation" ]; then
param="${param} -m ${consoletranslation}" param="$param -m $consoletranslation"
fi fi
if [ -n "${unicodemap}" ]; then if [ -n "${unicodemap}" ]; then
param="${param} -u ${unicodemap}" param="$param -u $unicodemap"
fi fi
# Set the console font # Set the console font
ebegin "Setting console font [${consolefont}]" ebegin "Setting console font [$consolefont]"
[ -d /dev/vc ] && ttydev=/dev/vc/ [ -d /dev/vc ] && ttydev=/dev/vc/
x=1 x=1
while [ ${x} -le ${ttyn} ]; do while [ $x -le $ttyn ]; do
setfont ${consolefont} ${param} -C ${ttydev}${x} >/dev/null setfont $consolefont $param -C $ttydev$x >/dev/null
retval=$((${retval} + $?)) retval=$(($retval + $?))
x=$((${x} + 1)) x=$(($x + 1))
done done
eend ${retval} eend $retval
# Store the last font so we can use it ASAP on boot # Store the last font so we can use it ASAP on boot
if [ ${retval} -eq 0 -a -w "${RC_LIBDIR}" ]; then if [ $retval -eq 0 -a -w "$RC_LIBEXECDIR" ]; then
mkdir -p "${RC_LIBDIR}"/console mkdir -p "$RC_LIBEXECDIR"/console
for font in /usr/share/consolefonts/"${consolefont}".*; do for font in /usr/share/consolefonts/"$consolefont".*; do
: :
done done
cp "${font}" "${RC_LIBDIR}"/console cp "$font" "$RC_LIBEXECDIR"/console
echo "${font##*/}" > "${RC_LIBDIR}"/console/font echo "${font##*/}" >"$RC_LIBEXECDIR"/console/font
if yesno ${unicode:-${UNICODE}}; then if yesno ${unicode:-${UNICODE}}; then
echo "" > "${RC_LIBDIR}"/console/unicode echo "" > "$RC_LIBEXECDIR"/console/unicode
else else
rm -f "${RC_LIBDIR}"/console/unicode rm -f "$RC_LIBEXECDIR"/console/unicode
fi fi
fi fi
return ${retval} return $retval
} }

View File

@@ -1,9 +1,9 @@
#!@PREFIX@/sbin/runscript #!@PREFIX@/sbin/runscript
# Copyright 2007-2008 Roy Marples <roy@marples.name> # Copyright (c) 2007-2008 Roy Marples <roy@marples.name>
# All rights reserved. Released under the 2-clause BSD license. # All rights reserved. Released under the 2-clause BSD license.
command=/sbin/devd command=/sbin/devd
command_args=${devd_args} command_args=$devd_args
name="Device State Change Daemon" name="Device State Change Daemon"
depend() { depend() {

21
init.d/devdb.in Normal file
View File

@@ -0,0 +1,21 @@
#!@PREFIX@/sbin/runscript
# Copyright (c) 2008 Roy Marples <roy@marples.name>
# All rights reserved. Released under the 2-clause BSD license.
description="Creates the dev database"
depend()
{
need localmount
}
start()
{
ebegin "Bulding the dev database"
if [ /var/run/dev.db -nt /dev ]; then
:
else
dev_mkdb
fi
eend $?
}

36
init.d/devfs.in Normal file
View File

@@ -0,0 +1,36 @@
#!@PREFIX@/sbin/runscript
# Copyright (c) 2007-2008 Roy Marples <roy@marples.name>
# All rights reserved. Released under the 2-clause BSD license.
description="Mount system critical filesystems in /dev."
depend() {
use dev
keyword noprefix novserver
}
start() {
# Mount required stuff as user may not have then in /etc/fstab
for x in \
"devpts /dev/pts 0755 ,gid=5,mode=0620 devpts" \
"tmpfs /dev/shm 1777 ,nodev shm" \
; do
set -- $x
grep -Eq "[[:space:]]+$1$" /proc/filesystems || continue
mountinfo -q $2 && continue
if [ ! -d $2 ]; then
mkdir -m $3 -p $2 >/dev/null 2>&1 || \
ewarn "Could not create $2!"
fi
if [ -d $2 ]; then
ebegin "Mounting $2"
if ! fstabinfo --mount $2; then
mount -n -t $1 -o noexec,nosuid$4 $5 $2
fi
eend $?
fi
done
return 0
}

18
init.d/dmesg.in Normal file
View File

@@ -0,0 +1,18 @@
#!@PREFIX@/sbin/runscript
# Copyright (c) 2007-2008 Roy Marples <roy@marples.name>
# All rights reserved. Released under the 2-clause BSD license.
description="Set the dmesg level for a cleaner boot"
depend()
{
before dev modules
keyword novserver
}
start()
{
if [ -n "$dmesg_level" ]; then
dmesg -n$dmesg_level
fi
}

View File

@@ -1,5 +1,5 @@
#!@PREFIX@/sbin/runscript #!@PREFIX@/sbin/runscript
# Copyright 2007-2008 Roy Marples <roy@marples.name> # Copyright (c) 2007-2008 Roy Marples <roy@marples.name>
# All rights reserved. Released under the 2-clause BSD license. # All rights reserved. Released under the 2-clause BSD license.
description="Configures a specific kernel dump device." description="Configures a specific kernel dump device."
@@ -11,8 +11,8 @@ depend() {
start() { start() {
# Setup any user requested dump device # Setup any user requested dump device
if [ -n "${dump_device}" ]; then if [ -n "$dump_device" ]; then
ebegin "Activating kernel core dump device (${dump_device})" ebegin "Activating kernel core dump device ($dump_device)"
dumpon ${dump_device} dumpon ${dump_device}
eend $? eend $?
fi fi

View File

@@ -1,14 +1,14 @@
#!@PREFIX@/sbin/runscript #!@PREFIX@/sbin/runscript
# Copyright 2007-2008 Roy Marples <roy@marples.name> # Copyright (c) 2007-2009 Roy Marples <roy@marples.name>
# All rights reserved. Released under the 2-clause BSD license. # All rights reserved. Released under the 2-clause BSD license.
description="Check and repair filesystems according to /etc/fstab" description="Check and repair filesystems according to /etc/fstab"
_ISF=" _IFS="
" "
depend() depend()
{ {
after clock modules use dev clock modules
keyword nojail noopenvz noprefix notimeout novserver keyword nojail noopenvz noprefix notimeout novserver
} }
@@ -19,55 +19,109 @@ _abort() {
# We should only reboot when first booting # We should only reboot when first booting
_reboot() { _reboot() {
if [ "${RC_RUNLEVEL}" = "${RC_BOOTLEVEL}" ]; then if [ "$RC_RUNLEVEL" = "$RC_BOOTLEVEL" ]; then
reboot "$@" reboot "$@"
_abort || return 1 _abort || return 1
fi fi
} }
_forcefsck()
{
[ -e /forcefsck ] || get_bootparam forcefsck
}
_on_ac_power()
{
if [ -f /proc/acpi/ac_adapter/AC/state ]; then
cat /proc/acpi/ac_adapter/AC/state | while read line; do
case "$line" in
"state:"*"off-line") return 128;;
esac
done
elif [ -f /proc/pmu/info ]; then
cat /proc/pmu/info | while read line; do
case "$line" in
"AC Power"*": 0") return 128;;
esac
done
elif type envstat >/dev/null 2>&1; then
# NetBSD has envstat
envstat -d acpiacad0 2>/dev/null | while read line; do
case "$line" in
"connected:"*"OFF") return 128;;
esac
done
else
return 0
fi
[ $? != 128 ]
}
start() start()
{ {
local reboot_opts= fsck_opts= p= local fsck_opts= p= check_extra=
if [ -e /fastboot ]; then if [ -e /fastboot ]; then
ewarn "Skipping fsck due to /fastboot" ewarn "Skipping fsck due to /fastboot"
return 0 return 0
fi fi
if _forcefsck; then
fsck_opts="$fsck_opts -f"
check_extra="(check forced)"
elif ! _on_ac_power; then
ewarn "Skipping fsck due to not being on AC power"
return 0
fi
ebegin "Checking local filesystems" if [ -n "$fsck_passno" ]; then
for p in ${fsck_passno}; do check_extra="[passno $fsck_passno] $check_extra"
local IFS="${_IFS}" fi
case "${p}" in ebegin "Checking local filesystems $check_extra"
[0-9]*) p="=${p}";; for p in $fsck_passno; do
local IFS="$_IFS"
case "$p" in
[0-9]*) p="=$p";;
esac esac
set -- "$@" "$(fstabinfo --passno "${p}")" set -- "$@" $(fstabinfo --passno "$p")
unset IFS unset IFS
done done
if [ "${RC_UNAME}" = "Linux" ]; then if [ "$RC_UNAME" = Linux ]; then
fsck_opts="-C0 -T" fsck_opts="$fsck_opts -C0 -T"
if [ -z "${fsck_passno}" ]; then if [ -z "$fsck_passno" ]; then
fsck_args=${fsck_args--A -p} fsck_args=${fsck_args--A -p}
if echo 2>/dev/null >/.test.$$; then if echo 2>/dev/null >/.test.$$; then
rm -f /.test.$$ rm -f /.test.$$
fsck_opts="${fsck_opts} -R" fsck_opts="$fsck_opts -R"
fi fi
fi fi
reboot_opts="-f"
fi fi
trap : QUIT trap : INT QUIT
fsck ${fsck_args--p} ${fsck_opts} "$@" fsck ${fsck_args--p} $fsck_opts "$@"
case $? in case $? in
0) eend 0; return 0;; 0) eend 0; return 0;;
1) ewend 1 "Filesystems repaired"; return 0;; 1) ewend 1 "Filesystems repaired"; return 0;;
2|3|4) ewend 1 "Filesystems repaired, but reboot needed" 2|3) if [ "$RC_UNAME" = Linux ]; then
_reboot ${reboot_opts} || return 1;; ewend 1 "Filesystems repaired, but reboot needed"
8) ewend 1 "Operational error"; return 0;; _reboot -f
12) ewend 1 "fsck interupted"; return 1;; else
*) eend 2 "Filesystems couldn't be fixed" ewend 1 "Filesystems still have errors;" \
_abort || return 1;; "manual fsck required"
_abort
fi;;
4) if [ "$RC_UNAME" = Linux ]; then
ewend 1 "Fileystem errors left uncorrected, aborting"
_abort
else
ewend 1 "Filesystems repaired, but reboot needed"
_reboot
fi;;
8) ewend 1 "Operational error"; return 0;;
12) ewend 1 "fsck interupted";;
*) eend 2 "Filesystems couldn't be fixed";;
esac esac
_abort || return 1
} }
stop() stop()
@@ -75,7 +129,8 @@ stop()
# Fake function so we always shutdown correctly. # Fake function so we always shutdown correctly.
_abort() { return 0; } _abort() { return 0; }
_reboot() { return 0; } _reboot() { return 0; }
_forcefsck() { return 1; }
yesno "${fsck_shutdown}" && start yesno $fsck_shutdown && start
return 0 return 0
} }

View File

@@ -1,99 +0,0 @@
#!@SHELL@
# Copyright 2007-2008 Roy Marples <roy@marples.name>
# All rights reserved. Released under the 2-clause BSD license.
. @SYSCONFDIR@/init.d/functions.sh
. "${RC_LIBDIR}"/sh/rc-functions.sh
[ -r @SYSCONFDIR@/rc.conf ] && . @SYSCONFDIR@/rc.conf
# Support LiveCD foo
if [ -r /sbin/livecd-functions.sh ]; then
. /sbin/livecd-functions.sh
livecd_read_commandline
fi
stop_addon devfs
stop_addon udev
# Really kill things off before unmounting
if [ -x /sbin/killall5 ]; then
killall5 -15
killall5 -9
fi
# Flush all pending disk writes now
sync; sync
# If we are in a VPS, we don't need anything below here, because
# 1) we don't need (and by default can't) umount anything (VServer) or
# 2) the host utils take care of all umounting stuff (OpenVZ)
if [ "${RC_SYS}" = "VSERVER" -o "${RC_SYS}" = "OPENVZ" ]; then
if [ -e @SYSCONFDIR@/init.d/"$1".sh ]; then
. @SYSCONFDIR@/init.d/"$1".sh
else
exit 0
fi
fi
# If $svcdir is still mounted, preserve it if we can
mnt=$(mountinfo --node "${RC_SVCDIR}")
if [ -n "${mnt}" -a -w "${RC_LIBDIR}" ]; then
f_opts="-m -c"
[ "${RC_UNAME}" = "Linux" ] && f_opts="-c"
if type fuser >/dev/null 2>&1; then
if [ -n "$(fuser ${f_opts} "${svcdir}" 2>/dev/null)" ]; then
fuser -k ${f_opts} "${svcdir}" >/dev/null 2>&1
sleep 2
fi
fi
cp -p "${RC_SVCDIR}"/deptree "${RC_SVCDIR}"/depconfig \
"${RC_SVCDIR}"/softlevel "${RC_SVCDIR}"/nettree \
"${RC_SVCDIR}"/rc.log \
"${RC_LIBDIR}" 2>/dev/null
umount "${RC_SVCDIR}"
rm -rf "${RC_SVCDIR}"/*
# Pipe errors to /dev/null as we may have future timestamps
cp -p "${RC_LIBDIR}"/deptree "${RC_LIBDIR}"/depconfig \
"${RC_LIBDIR}"/softlevel "${RC_LIBDIR}"/nettree \
"${RC_LIBDIR}"/rc.log \
"${RC_SVCDIR}" 2>/dev/null
rm -f "${RC_LIBDIR}"/deptree "${RC_LIBDIR}"/depconfig \
"${RC_LIBDIR}"/softlevel "${RC_LIBDIR}"/nettree \
"${RC_LIBDIR}"/rc.log
# Release the memory disk if we used it
case "${mnt}" in
"/dev/md"[0-9]*) mdconfig -d -u "${mnt#/dev/md*}";;
esac
fi
unmounted=0
# Remount the remaining filesystems read-only
# Most BSD's don't need this as the kernel handles it nicely
if [ "${RC_UNAME}" = "Linux" ]; then
ebegin "Remounting remaining filesystems read-only"
# We need the do_unmount function
. "${RC_LIBDIR}"/sh/rc-mount.sh
eindent
fs=
for x in ${net_fs_list}; do
fs="${fs}${fs:+|}${x}"
done
[ -n "${fs}" ] && fs="^(${fs})$"
do_unmount "mount -n -o remount,ro" \
--skip-point-regex "^(/dev|/dev/.*|/proc|/proc/.*|/sys|/sys/.*)$" \
${fs:+--skip-fstype-regex} ${fs} --nonetdev
eoutdent
eend $?
unmounted=$?
fi
if [ ${unmounted} -ne 0 ]; then
[ -x /sbin/sulogin ] && sulogin -t 10 /dev/console
exit 1
fi
# Load the final script - not needed on BSD so they should not exist
[ -e @SYSCONFDIR@/init.d/"$1".sh ] && . @SYSCONFDIR@/init.d/"$1".sh
# Always exit 0 here
exit 0

View File

@@ -1,13 +1,13 @@
#!@PREFIX@/sbin/runscript #!@PREFIX@/sbin/runscript
# Copyright 2007-2008 Roy Marples <roy@marples.name> # Copyright (c) 2007-2009 Roy Marples <roy@marples.name>
# All rights reserved. Released under the 2-clause BSD license. # All rights reserved. Released under the 2-clause BSD license.
extra_commands="reset" extra_commands="reset"
hostid_file=${hostid_file:-/etc/hostid} : ${hostid_file:=/etc/hostid}
depend() depend()
{ {
need root use root
before devd net before devd net
keyword nojail noprefix keyword nojail noprefix
} }
@@ -20,14 +20,14 @@ _set()
id=$(echo "$1" | md5) id=$(echo "$1" | md5)
id="0x${id%????????????????????????}" id="0x${id%????????????????????????}"
fi fi
ebegin "Setting Host ID: ${id}" ebegin "Setting Host ID: $id"
sysctl -w kern.hostid="${id}" >/dev/null sysctl -w kern.hostid="$id" >/dev/null
eend $? || return 1 eend $? || return 1
if sysctl -n kern.hostuuid >/dev/null 2>&1; then if sysctl -n kern.hostuuid >/dev/null 2>&1; then
[ -n "$1" ] && id=$1 [ -n "$1" ] && id=$1
ebegin "Setting Host UUID: ${id}" ebegin "Setting Host UUID: $id"
sysctl kern.hostuuid="${id}" >/dev/null sysctl kern.hostuuid="$id" >/dev/null
eend $? || return 1 eend $? || return 1
fi fi
@@ -38,35 +38,37 @@ _set()
# otherwise we generate a random UUID. # otherwise we generate a random UUID.
reset() reset()
{ {
local uuid=$(kenv smbios.system.uuid 2>/dev/null) local uuid= x="[0-9a-f]" y="$x$x$x$x"
local x="[0-9a-f]"
local y="${x}${x}${x}${x}" if type kenv >/dev/null 2>&1; then
case "${uuid}" in uuid=$(kenv smbios.system.uuid 2>/dev/null)
${y}${y}-${y}-${y}-${y}-${y}${y}${y});; fi
case "$uuid" in
$y$y-$y-$y-$y-$y$y$y);;
*) uuid=;; *) uuid=;;
esac esac
if [ -n "${uuid}" ]; then if [ -n "$uuid" ]; then
rm -f "${hostid_file}" rm -f "$hostid_file"
else else
uuid=$(uuidgen) uuid=$(uuidgen)
if [ -z "${uuid}" ]; then if [ -z "$uuid" ]; then
eerror "Unable to generate a UUID" eerror "Unable to generate a UUID"
return 1 return 1
fi fi
if ! echo "${uuid}" > "${hostid_file}"; then if ! echo "$uuid" >"$hostid_file"; then
eerror "Failed to store UUID in \`${hostid_file}'" eerror "Failed to store UUID in \`$hostid_file'"
return 1 return 1
fi fi
fi fi
_set "${uuid}" _set "$uuid"
} }
start() start()
{ {
if [ -r "${hostid_file}" ]; then if [ -r "$hostid_file" ]; then
_set $(cat "${hostid_file}") _set $(cat "$hostid_file")
else else
reset reset
fi fi

View File

@@ -1,5 +1,5 @@
#!@PREFIX@/sbin/runscript #!@PREFIX@/sbin/runscript
# Copyright 2007-2008 Roy Marples <roy@marples.name> # Copyright (c) 2007-2009 Roy Marples <roy@marples.name>
# All rights reserved. Released under the 2-clause BSD license. # All rights reserved. Released under the 2-clause BSD license.
description="Sets the hostname of the machine." description="Sets the hostname of the machine."
@@ -11,7 +11,7 @@ depend() {
start() start()
{ {
hostname=${hostname-${HOSTNAME-localhost}} hostname=${hostname-${HOSTNAME-localhost}}
ebegin "Setting hostname to ${hostname}" ebegin "Setting hostname to $hostname"
hostname "${hostname}" hostname "$hostname"
eend $? "Failed to set the hostname" eend $? "Failed to set the hostname"
} }

View File

@@ -1,5 +1,5 @@
#!@PREFIX@/sbin/runscript #!@PREFIX@/sbin/runscript
# Copyright 2007-2008 Roy Marples <roy@marples.name> # Copyright (c) 2007-2008 Roy Marples <roy@marples.name>
# All rights reserved. Released under the 2-clause BSD license. # All rights reserved. Released under the 2-clause BSD license.
extra_commands="save show" extra_commands="save show"
@@ -8,12 +8,11 @@ description="Sets the local clock to UTC or Local Time."
description_save="Saves the current time in the BIOS." description_save="Saves the current time in the BIOS."
description_show="Displays the current time in the BIOS." description_show="Displays the current time in the BIOS."
clock_adjfile=${clock_adjfile:-${CLOCK_ADJFILE}} : ${clock_adjfile:=${CLOCK_ADJFILE}}
clock_args=${clock_args:-${CLOCK_OPTS}} : ${clock_args:=${CLOCK_OPTS}}
clock_systohc=${clock_systohc:-${CLOCK_SYSTOHC}} : ${clock_systohc:=${CLOCK_SYSTOHC}}
: ${clock:=${CLOCK:-UTC}}
clock=${clock:-${CLOCK:-UTC}} if [ "$clock" = "UTC" ]; then
if [ "${clock}" = "UTC" ]; then
utc="UTC" utc="UTC"
utc_cmd="--utc" utc_cmd="--utc"
else else
@@ -24,7 +23,7 @@ fi
depend() depend()
{ {
provide clock provide clock
if yesno ${clock_adjfile}; then if yesno $clock_adjfile; then
use root use root
else else
before * before *
@@ -47,7 +46,7 @@ setupopts()
;; ;;
esac esac
case "${utc}" in case "$utc" in
UTC|Local" "Time);; UTC|Local" "Time);;
*) unset utc_cmd;; *) unset utc_cmd;;
esac esac
@@ -58,7 +57,7 @@ _hwclock()
{ {
local err="$(hwclock "$@" 2>&1 >/dev/null)" local err="$(hwclock "$@" 2>&1 >/dev/null)"
[ -z "${err}" ] && return 0 [ -z "$err" ] && return 0
echo "${err}" >&2 echo "${err}" >&2
return 1 return 1
} }
@@ -68,32 +67,38 @@ start()
local retval=0 errstr="" local retval=0 errstr=""
setupopts setupopts
if [ -z "${utc_cmd}" ]; then if [ -z "$utc_cmd" ]; then
ewarn "Not setting clock for ${utc} system" ewarn "Not setting clock for $utc system"
return 0 return 0
fi fi
ebegin "Setting system clock using the hardware clock [${utc}]" ebegin "Setting system clock using the hardware clock [$utc]"
if [ -e /proc/modules -a ! -e /dev/rtc ]; then if [ -e /proc/modules ]; then
modprobe -q rtc || modprobe -q genrtc local rtc=
for rtc in /dev/rtc /dev/rtc[0-9]*; do
[ -e "$rtc" ] && break
done
if [ ! -e "${rtc}" ]; then
modprobe -q rtc-cmos || modprobe -q rtc || modprobe -q genrtc
fi
fi fi
if [ -e /etc/adjtime ] && yesno ${clock_adjfile}; then if [ -e /etc/adjtime ] && yesno $clock_adjfile; then
_hwclock --adjust ${utc_cmd} _hwclock --adjust $utc_cmd
retval=$((${retval} + $?)) retval=$(($retval + $?))
fi fi
# If setting UTC, don't bother to run hwclock when first booting # If setting UTC, don't bother to run hwclock when first booting
# as that's the default # as that's the default
if [ "${PREVLEVEL}" != "N" -o \ if [ "$PREVLEVEL" != N -o \
"${utc_cmd}" != "--utc" -o \ "$utc_cmd}" != --utc -o \
-n "${clock_args}" ]; -n "$clock_args" ];
then then
_hwclock --hctosys ${utc_cmd} ${clock_args} _hwclock --hctosys $utc_cmd $clock_args
retval=$((${retval} + $?)) retval=$(($retval + $?))
fi fi
eend ${retval} "Failed to set the system clock" eend $retval "Failed to set the system clock"
return 0 return 0
} }
@@ -101,37 +106,37 @@ start()
stop() stop()
{ {
# Don't tweak the hardware clock on LiveCD halt. # Don't tweak the hardware clock on LiveCD halt.
[ -n "${CDBOOT}" ] && return 0 [ -n "$CDBOOT" ] && return 0
yesno ${clock_systohc} || return 0 yesno $clock_systohc || return 0
local retval=0 errstr="" local retval=0 errstr=""
setupopts setupopts
[ -z "${utc_cmd}" ] && return 0 [ -z "$utc_cmd" ] && return 0
ebegin "Setting hardware clock using the system clock" "[${utc}]" ebegin "Setting hardware clock using the system clock" "[$utc]"
if ! yesno "${clock_adjfile}"; then if ! yesno $clock_adjfile; then
# Some implementations don't handle adjustments # Some implementations don't handle adjustments
if LC_ALL=C hwclock --help | grep -q "\-\-noadjfile"; then if LC_ALL=C hwclock --help | grep -q "\-\-noadjfile"; then
utc_cmd="${utc_cmd} --noadjfile" utc_cmd="$utc_cmd --noadjfile"
fi fi
fi fi
_hwclock --systohc ${utc_cmd} ${clock_args} _hwclock --systohc $utc_cmd $clock_args
retval=$? retval=$?
eend ${retval} "Failed to sync clocks" eend $retval "Failed to sync clocks"
} }
save() save()
{ {
clock_systohc="yes" clock_systohc=yes
stop stop
} }
show() show()
{ {
setupopts setupopts
hwclock --show "${utc_cmd}" ${clock_args} hwclock --show "$utc_cmd" $clock_args
} }

View File

@@ -1,5 +1,5 @@
#!@PREFIX@/sbin/runscript #!@PREFIX@/sbin/runscript
# Copyright 2007-2008 Roy Marples <roy@marples.name> # Copyright (c) 2007-2009 Roy Marples <roy@marples.name>
# All rights reserved. Released under the 2-clause BSD license. # All rights reserved. Released under the 2-clause BSD license.
# This is based on /etc/rc.firewall and /etc/rc.firewall6 from FreeBSD # This is based on /etc/rc.firewall and /etc/rc.firewall6 from FreeBSD
@@ -20,6 +20,10 @@ ipfw() {
/sbin/ipfw -f -q "$@" /sbin/ipfw -f -q "$@"
} }
have_ip6() {
sysctl net.ipv6 2>/dev/null
}
init() { init() {
# Load the kernel module # Load the kernel module
if ! sysctl net.inet.ip.fw.enable=1 >/dev/null 2>&1; then if ! sysctl net.inet.ip.fw.enable=1 >/dev/null 2>&1; then
@@ -36,13 +40,15 @@ init() {
ipfw add deny all from any to 127.0.0.0/8 ipfw add deny all from any to 127.0.0.0/8
ipfw add deny ip from 127.0.0.0/8 to any ipfw add deny ip from 127.0.0.0/8 to any
ipfw add pass ip6 from any to any via lo0 if have_ip6; then
ipfw add deny ip6 from any to ::1 ipfw add pass ip6 from any to any via lo0
ipfw add deny ip6 from ::1 to any ipfw add deny ip6 from any to ::1
ipfw add deny ip6 from ::1 to any
ipfw add pass ip6 from :: to ff02::/16 proto ipv6-icmp ipfw add pass ip6 from :: to ff02::/16 proto ipv6-icmp
ipfw add pass ip6 from fe80::/10 to fe80::/10 proto ipv6-icmp ipfw add pass ip6 from fe80::/10 to fe80::/10 proto ipv6-icmp
ipfw add pass ip6 from fe80::/10 to ff02::/16 proto ipv6-icmp ipfw add pass ip6 from fe80::/10 to ff02::/16 proto ipv6-icmp
fi
} }
start() { start() {
@@ -62,9 +68,11 @@ start() {
ipfw add pass udp from me to any keep-state ipfw add pass udp from me to any keep-state
ipfw add pass icmp from me to any keep-state ipfw add pass icmp from me to any keep-state
ipfw add pass tcp from me6 to any setup keep-state if have_ip6; then
ipfw add pass udp from me6 to any keep-state ipfw add pass tcp from me6 to any setup keep-state
ipfw add pass icmp from me6 to any keep-state ipfw add pass udp from me6 to any keep-state
ipfw add pass icmp from me6 to any keep-state
fi
# Allow DHCP. # Allow DHCP.
ipfw add pass udp from 0.0.0.0 68 to 255.255.255.255 67 out ipfw add pass udp from 0.0.0.0 68 to 255.255.255.255 67 out
@@ -77,32 +85,34 @@ start() {
# Allow "mandatory" ICMP in. # Allow "mandatory" ICMP in.
ipfw add pass icmp from any to any icmptype 3,4,11 ipfw add pass icmp from any to any icmptype 3,4,11
# Allow ICMPv6 destination unreach if have_ip6; then
ipfw add pass ip6 from any to any icmp6types 1 proto ipv6-icmp # Allow ICMPv6 destination unreach
ipfw add pass ip6 from any to any icmp6types 1 proto ipv6-icmp
# Allow NS/NA/toobig (don't filter it out)
ipfw add pass ip6 from any to any icmp6types 2,135,136 proto ipv6-icmp # Allow NS/NA/toobig (don't filter it out)
ipfw add pass ip6 from any to any icmp6types 2,135,136 proto ipv6-icmp
fi
# Add permits for this workstations published services below # Add permits for this workstations published services below
# Only IPs and nets in firewall_allowservices is allowed in. # Only IPs and nets in firewall_allowservices is allowed in.
for i in ${ipfw_ip_in}; do for i in $ipfw_ip_in; do
for p in ${ipfw_ports_in}; do for p in $ipfw_ports_in; do
ipfw add pass tcp from ${i} to me ${p} ipfw add pass tcp from $i to me $p
done done
done done
# Allow all connections from trusted IPs. # Allow all connections from trusted IPs.
# Playing with the content of firewall_trusted could seriously # Playing with the content of firewall_trusted could seriously
# degrade the level of protection provided by the firewall. # degrade the level of protection provided by the firewall.
for i in ${ipfw_ip_trust}; do for i in $ipfw_ip_trust; do
ipfw add pass ip from ${i} to me ipfw add pass ip from $i to me
done done
ipfw add 65000 count ip from any to any ipfw add 65000 count ip from any to any
# Drop packets to ports where we don't want logging # Drop packets to ports where we don't want logging
for p in ${ipfw_ports_nolog}; do for p in $ipfw_ports_nolog; do
ipfw add deny { tcp or udp } from any to any ${p} in ipfw add deny { tcp or udp } from any to any $p in
done done
# Broadcasts and muticasts # Broadcasts and muticasts
@@ -119,10 +129,10 @@ start() {
# Deny and (if wanted) log the rest unconditionally. # Deny and (if wanted) log the rest unconditionally.
if yesno ${ipfw_log_deny:-no}; then if yesno ${ipfw_log_deny:-no}; then
log="log" log=log
sysctl net.inet.ip.fw.verbose=1 >/dev/null sysctl net.inet.ip.fw.verbose=1 >/dev/null
fi fi
ipfw add deny ${log} ip from any to any ipfw add deny $log ip from any to any
eend 0 eend 0
} }

View File

@@ -1,26 +1,27 @@
#!@PREFIX@/sbin/runscript #!@PREFIX@/sbin/runscript
# Copyright 2007-2008 Roy Marples <roy@marples.name> # Copyright (c) 2007-2008 Roy Marples <roy@marples.name>
# All rights reserved. Released under the 2-clause BSD license. # All rights reserved. Released under the 2-clause BSD license.
description="Applies a keymap for the consoles." description="Applies a keymap for the consoles."
ttyn=${rc_tty_number:-${RC_TTY_NUMBER:-12}}
unicode=${unicode:-${UNICODE}}
keymap=${keymap:-${KEYMAP}}
extended_keymaps=${extended_keymaps:-${EXTENDED_KEYMAPS}}
windowkeys=${windowkeys:-${SET_WINDOWSKEYS}}
fix_euro=${fix_euro:-${FIX_EURO}}
dumpkeys_charset=${dumpkeys_charset:-${DUMPKEYS_CHARSET}}
depend() depend()
{ {
need localmount termencoding need localmount termencoding
after bootmisc
keyword noopenvz noprefix nouml novserver noxenu keyword noopenvz noprefix nouml novserver noxenu
} }
start() start()
{ {
if [ -z "${keymap}" ]; then ttyn=${rc_tty_number:-${RC_TTY_NUMBER:-12}}
: ${unicode:=$UNICODE}
: =${keymap:=$KEYMAP}
: ${extended_keymaps:=$EXTENDED_KEYMAPS}
: ${windowkeys:=$SET_WINDOWSKEYS}
: ${fix_euro:=$FIX_EURO}
: ${dumpkeys_charset:=${DUMPKEYS_CHARSET}}
if [ -z "$keymap" ]; then
eerror "You need to setup keymap in /etc/conf.d/keymaps first" eerror "You need to setup keymap in /etc/conf.d/keymaps first"
return 1 return 1
fi fi
@@ -33,18 +34,18 @@ start()
echo 1 > /proc/sys/dev/mac_hid/keyboard_sends_linux_keycodes echo 1 > /proc/sys/dev/mac_hid/keyboard_sends_linux_keycodes
fi fi
ebegin "Loading key mappings [${keymap}]" ebegin "Loading key mappings [$keymap]"
local loadkeys_uni= wkeys= kmode="-a" msg="ASCII" local loadkeys_uni= wkeys= kmode="-a" msg="ASCII"
if yesno ${unicode}; then if yesno $unicode; then
loadkeys_uni="--unicode" loadkeys_uni="--unicode"
kmode="-u" kmode="-u"
msg="UTF-8" msg="UTF-8"
fi fi
yesno ${windowkeys} && wkeys="windowkeys" yesno $windowkeys && wkeys="windowkeys"
loadkeys -q ${loadkeys_uni} ${wkeys} ${keymap} ${extended_keymaps} loadkeys -q $loadkeys_uni $wkeys $keymap $extended_keymaps
eend $? "Error loading key mappings" || return $? eend $? "Error loading key mappings" || return $?
if yesno ${fix_euro}; then if yesno $fix_euro; then
ebegin "Fixing font for euro symbol" ebegin "Fixing font for euro symbol"
# Fix some fonts displaying the Euro, #173528. # Fix some fonts displaying the Euro, #173528.
echo "altgr keycode 18 = U+20AC" | loadkeys -q echo "altgr keycode 18 = U+20AC" | loadkeys -q
@@ -53,15 +54,21 @@ start()
# Set terminal encoding to either ASCII or UNICODE. # Set terminal encoding to either ASCII or UNICODE.
# See utf-8(7) for more information. # See utf-8(7) for more information.
ebegin "Setting keyboard mode [${msg}]" ebegin "Setting keyboard mode [$msg]"
if yesno ${unicode}; then if yesno $unicode; then
dumpkeys ${dumpkeys_charset:+-c} \ dumpkeys ${dumpkeys_charset:+-c} \
${dumpkeys_charset} | loadkeys --unicode $dumpkeys_charset | loadkeys --unicode
fi fi
n=1 n=1
while [ ${n} -le "${ttyn}" ]; do while [ $n -le $ttyn ]; do
kbd_mode "${kmode}" -C "${ttydev}${n}" kbd_mode $kmode -C $ttydev$n
n=$((${n} + 1)) n=$(($n + 1))
done done
eend 0 eend 0
# Save the keymapping for use immediately at boot
if [ -w "$RC_LIBEXECDIR" ]; then
mkdir -p "$RC_LIBEXECDIR"/console
dumpkeys >"$RC_LIBEXECDIR"/console/keymap
fi
} }

22
init.d/killprocs.in Normal file
View File

@@ -0,0 +1,22 @@
#!@PREFIX@/sbin/runscript
# Copyright (c) 2007-2008 Roy Marples <roy@marples.name>
# All rights reserved. Released under the 2-clause BSD license.
description="Kill all processes so we can unmount disks cleanly."
depend()
{
keyword noprefix
}
start()
{
ebegin "Terminating remaining processes"
killall5 -15
sleep 1
eend 0
ebegin "Killing remaining processes"
killall5 -9
sleep 1
eend 0
}

View File

@@ -1,5 +1,5 @@
#!@PREFIX@/sbin/runscript #!@PREFIX@/sbin/runscript
# Copyright 2007-2008 Roy Marples <roy@marples.name> # Copyright (c) 2007-2008 Roy Marples <roy@marples.name>
# All rights reserved. Released under the 2-clause BSD license. # All rights reserved. Released under the 2-clause BSD license.
description="Executes user commands in /etc/conf.d/local" description="Executes user commands in /etc/conf.d/local"
@@ -39,5 +39,5 @@ stop()
. @SYSCONFDIR@/conf.d/local.stop . @SYSCONFDIR@/conf.d/local.stop
fi fi
eend $? $"Failed to stop local" eend $? "Failed to stop local"
} }

View File

@@ -1,5 +1,5 @@
#!@PREFIX@/sbin/runscript #!@PREFIX@/sbin/runscript
# Copyright 2007-2008 Roy Marples <roy@marples.name> # Copyright (c) 2007-2009 Roy Marples <roy@marples.name>
# All rights reserved. Released under the 2-clause BSD license. # All rights reserved. Released under the 2-clause BSD license.
description="Mounts disks and swap according to /etc/fstab." description="Mounts disks and swap according to /etc/fstab."
@@ -15,12 +15,12 @@ start()
{ {
# Mount local filesystems in /etc/fstab. # Mount local filesystems in /etc/fstab.
local types="noproc" x= local types="noproc" x=
for x in ${net_fs_list}; do for x in $net_fs_list; do
types="${types},${x}" types="${types},${x}"
done done
ebegin "Mounting local filesystems" ebegin "Mounting local filesystems"
mount -at "${types}" mount -at "$types"
eend $? "Some local filesystem failed to mount" eend $? "Some local filesystem failed to mount"
# Always return 0 - some local mounts may not be critical for boot # Always return 0 - some local mounts may not be critical for boot
@@ -30,40 +30,34 @@ start()
stop() stop()
{ {
# We never unmount / or /dev or $RC_SVCDIR # We never unmount / or /dev or $RC_SVCDIR
local x= no_umounts="/|/dev|/dev/.*|${RC_SVCDIR}" local x= no_umounts_r="/|/dev|/dev/.*|${RC_SVCDIR}"
no_umounts_r="${no_umounts_r}|/bin|/sbin|/lib|/libexec"
# RC_NO_UMOUNTS is an env var that can be set by plugins # RC_NO_UMOUNTS is an env var that can be set by plugins
OIFS=${IFS} SIFS=${IFS-y} OIFS=$IFS SIFS=${IFS-y}
IFS=$IFS: IFS=$IFS:
for x in ${no_umounts} ${RC_NO_UMOUNTS}; do for x in $no_umounts $RC_NO_UMOUNTS; do
no_umounts="${no_umounts}|${x}" no_umounts_r="$no_umounts_r|$x"
done done
if [ "${SIFS}" = "y" ]; then if [ "$SIFS" = y ]; then
IFS=$OIFS IFS=$OIFS
else else
unset IFS unset IFS
fi fi
if [ "${RC_UNAME}" = "Linux" ]; then if [ "$RC_UNAME" = Linux ]; then
no_umounts="${no_umounts}|/proc|/proc/.*|/sys|/sys/.*" no_umounts_r="$no_umounts_r|/proc|/proc/.*|/sys|/sys/.*"
fi fi
no_umounts="^(${no_umounts})$" no_umounts_r="^($no_umounts_r)$"
# Flush all pending disk writes now # Flush all pending disk writes now
sync; sync sync; sync
# Try to unmount all tmpfs filesystems not in use, else a deadlock may . "$RC_LIBEXECDIR"/sh/rc-mount.sh
# occure, bug #13599.
# As $RC_SVCDIR may also be tmpfs we cd to it to lock it
cd "${RC_SVCDIR}"
umount -a -t tmpfs 2>/dev/null
. "${RC_LIBDIR}"/sh/rc-mount.sh
# Umount loopback devices # Umount loopback devices
einfo "Unmounting loopback devices" einfo "Unmounting loopback devices"
eindent eindent
do_unmount "umount -d" --skip-point-regex "${no_umounts}" \ do_unmount "umount -d" --skip-point-regex "$no_umounts_r" \
--node-regex "^/dev/loop" --node-regex "^/dev/loop"
eoutdent eoutdent
@@ -72,12 +66,12 @@ stop()
einfo "Unmounting filesystems" einfo "Unmounting filesystems"
eindent eindent
local fs= local fs=
for x in ${net_fs_list}; do for x in $net_fs_list; do
fs="${fs}${fs:+|}${x}" fs="$fs${fs:+|}$x"
done done
[ -n "${fs}" ] && fs="^(${fs})$" [ -n "$fs" ] && fs="^($fs)$"
do_unmount "umount" --skip-point-regex "${no_umounts}" \ do_unmount umount --skip-point-regex "$no_umounts_r" \
${fs:+--skip-fstype-regex} ${fs} --nonetdev ${fs:+--skip-fstype-regex} $fs --nonetdev
eoutdent eoutdent
return 0 return 0

View File

@@ -1,5 +1,5 @@
#!@PREFIX@/sbin/runscript #!@PREFIX@/sbin/runscript
# Copyright 2007-2008 Roy Marples <roy@marples.name> # Copyright (c) 2007-2008 Roy Marples <roy@marples.name>
# All rights reserved. Released under the 2-clause BSD license. # All rights reserved. Released under the 2-clause BSD license.
extra_commands="restore" extra_commands="restore"
@@ -17,8 +17,8 @@ restore()
eindent eindent
for mixer in /dev/mixer*; do for mixer in /dev/mixer*; do
if [ -r "/var/db/${mixer#/dev/}-state" ]; then if [ -r "/var/db/${mixer#/dev/}-state" ]; then
vebegin "${mixer}" vebegin "$mixer"
mixer -f "${mixer}" \ mixer -f "$mixer" \
$(cat "/var/db/${mixer#/dev/}-state") >/dev/null $(cat "/var/db/${mixer#/dev/}-state") >/dev/null
veend $? veend $?
: $((retval += $?)) : $((retval += $?))
@@ -37,11 +37,11 @@ stop()
ebegin "Saving mixer settings" ebegin "Saving mixer settings"
eindent eindent
for mixer in /dev/mixer*; do for mixer in /dev/mixer*; do
vebegin "${mixer}" vebegin "$mixer"
mixer -f "${mixer}" -s >/var/db/"${mixer#/dev/}"-state mixer -f "$mixer" -s >/var/db/"${mixer#/dev/}"-state
veend $? veend $?
: $((retval += $?)) : $((retval += $?))
done done
eoutdent eoutdent
eend ${retval} eend $retval
} }

View File

@@ -1,5 +1,5 @@
#!@PREFIX@/sbin/runscript #!@PREFIX@/sbin/runscript
# Copyright 2007-2008 Roy Marples <roy@marples.name> # Copyright (c) 2007-2009 Roy Marples <roy@marples.name>
# All rights reserved. Released under the 2-clause BSD license. # All rights reserved. Released under the 2-clause BSD license.
description="Loads a user defined list of kernel modules." description="Loads a user defined list of kernel modules."
@@ -23,36 +23,41 @@ start()
x=${KV#*.*.} x=${KV#*.*.}
local KV_MICRO=${x%%-*} local KV_MICRO=${x%%-*}
local list= x= xx= y= args= cnt=0 local list= x= xx= y= args= mpargs= cnt=0 a=
for x in "${KV}" \ for x in "$KV" \
${KV_MAJOR}.${KV_MINOR}.${KV_MICRO} \ $KV_MAJOR.$KV_MINOR.$KV_MICRO \
${KV_MAJOR}.${KV_MINOR} \ $KV_MAJOR.$KV_MINOR \
; do ; do
eval list=\$modules_$(shell_var "${x}") eval list=\$modules_$(shell_var "$x")
[ -n "${list}" ] && break [ -n "$list" ] && break
done done
[ -z "${list}" ] && list=${modules} [ -z "$list" ] && list=$modules
for x in ${list}; do for x in $list; do
ebegin "Loading module ${x}" a=${x#*:}
xx=$(shell_var "${x}") if [ "$a" = "$x" ]; then
for y in "${KV}" \ unset mpargs
${KV_MAJOR}.${KV_MINOR}.${KV_MICRO} \ ebegin "Loading module $x"
${KV_MAJOR}.${KV_MINOR} \ else
x=${x%%:*}
mpargs="-o $a"
ebegin "Loading module $x as $a"
fi
aa=$(shell_var "$a")
xx=$(shell_var "$x")
for y in "$KV" \
$KV_MAJOR.$KV_MINOR.$KV_MICRO \
$KV_MAJOR.$KV_MINOR \
; do ; do
eval args=\$module_${xx}_args_$(shell_var "${y}") eval args=\$module_${aa}_args_$(shell_var "$y")
[ -n "${args}" ] && break
eval args=\$module_${xx}_args_$(shell_var "$y")
[ -n "${args}" ] && break [ -n "${args}" ] && break
done done
[ -z "${args}" ] && eval args=\$module_${xx}_args [ -z "$args" ] && eval args=\$module_${aa}_args
eval modprobe -q "${x}" "${args}" [ -z "$args" ] && eval args=\$module_${xx}_args
eend $? "Failed to load ${x}" && cnt=$((${cnt} + 1)) eval modprobe -q "$mpargs" "$x" "$args"
eend $? "Failed to load $x" && cnt=$(($cnt + 1))
done done
einfo "Autoloaded ${cnt} module(s)" einfo "Autoloaded $cnt module(s)"
# Just in case a sysadmin prefers generic symbolic links in
# /lib/modules/boot for boot time modules we will load these modules
[ -n "$(modprobe -l -t boot)" ] && modprobe -a -t boot \* 2>/dev/null
# Above test clobbers the return
return 0
} }

46
init.d/mount-ro.in Normal file
View File

@@ -0,0 +1,46 @@
#!@PREFIX@/sbin/runscript
# Copyright (c) 2007-2009 Roy Marples <roy@marples.name>
# All rights reserved. Released under the 2-clause BSD license.
description="Re-mount filesytems read-only for a clean reboot."
depend()
{
need killprocs savecache
keyword noprefix noopenvz novserver
}
start()
{
# Flush all pending disk writes now
sync; sync
ebegin "Remounting remaining filesystems read-only"
# We need the do_unmount function
. "$RC_LIBEXECDIR"/sh/rc-mount.sh
eindent
local m="/dev|/dev/.*|/proc|/proc.*|/sys|/sys/.*|${RC_SVCDIR}" x= fs=
m="$m|/bin|/sbin|/lib|/libexec"
# RC_NO_UMOUNTS is an env var that can be set by plugins
local OIFS=$IFS SIFS=${IFS-y} IFS=$IFS
IFS=$IFS:
for x in $no_umounts $RC_NO_UMOUNTS; do
m="$m|$x"
done
if [ "$SIFS" = y ]; then
IFS=$OIFS
else
unset IFS
fi
m="^($m)$"
fs=
for x in $net_fs_list; do
fs="$fs${fs:+|}$x"
done
[ -n "$fs" ] && fs="^($fs)$"
do_unmount "umount -r" \
--skip-point-regex "$m" \
${fs:+--skip-fstype-regex} $fs --nonetdev
eoutdent
eend $?
}

View File

@@ -1,16 +1,16 @@
#!@PREFIX@/sbin/runscript #!@PREFIX@/sbin/runscript
# Copyright 2007-2008 Roy Marples <roy@marples.name> # Copyright (c) 2007-2009 Roy Marples <roy@marples.name>
# All rights reserved. Released under the 2-clause BSD license. # All rights reserved. Released under the 2-clause BSD license.
mouse=${RC_SVCNAME##*.} mouse=${RC_SVCNAME##*.}
if [ -n "${name}" -a "${mouse}" != "moused" ]; then if [ -n "$mouse" -a "$mouse" != "moused" ]; then
moused_device=/dev/"${mouse}" moused_device=/dev/"$mouse"
pidfile=/var/run/moused-"${mouse}".pid pidfile=/var/run/moused-"$mouse".pid
else else
pidfile=/var/run/moused.pid pidfile=/var/run/moused.pid
fi fi
name="Console Mouse Daemon" name="Console Mouse Daemon"
[ -n "${moused_device}" ] && name="${name} (${moused_device})" [ -n "$moused_device" ] && name="$name ($moused_device)"
depend() depend()
{ {
@@ -21,42 +21,42 @@ depend()
start() start()
{ {
ebegin "Starting ${name}" ebegin "Starting $name"
if [ -z "${moused_device}" ]; then if [ -z "$moused_device" ]; then
local dev= local dev=
for dev in /dev/psm[0-9]* /dev/ums[0-9]*; do for dev in /dev/psm[0-9]* /dev/ums[0-9]*; do
[ -c "${dev}" ] || continue [ -c "$dev" ] || continue
[ -e /var/run/moused-"${dev##*/}".pid ] && continue [ -e /var/run/moused-"${dev##*/}".pid ] && continue
moused_device=${dev} moused_device=$dev
eindent eindent
einfo "Using mouse on ${moused_device}" einfo "Using mouse on $moused_device"
eoutdent eoutdent
break break
done done
fi fi
if [ -z "${moused_device}" ]; then if [ -z "$moused_device" ]; then
eend 1 "No mouse device found" eend 1 "No mouse device found"
return 1 return 1
fi fi
local args= local args=
eval args=\$moused_args_${moused_device##*/} eval args=\$moused_args_${moused_device##*/}
[ -z "${args}" ] && args=${moused_args} [ -z "$args" ] && args=$moused_args
start-stop-daemon --start --exec /usr/sbin/moused \ start-stop-daemon --start --exec /usr/sbin/moused \
--pidfile "${pidfile}" \ --pidfile "$pidfile" \
-- ${args} -p "${moused_device}" -I "${pidfile}" -- $args -p "$moused_device" -I "$pidfile"
local retval=$? local retval=$?
if [ ${retval} = 0 ]; then if [ $retval = 0 ]; then
local ttyv= local ttyv=
for ttyv in /dev/ttyv*; do for ttyv in /dev/ttyv*; do
vidcontrol < "${ttyv}" -m on vidcontrol < "$ttyv" -m on
: $((retval+= $?)) : $((retval+= $?))
done done
fi fi
eend ${retval} "Failed to start moused" eend $retval "Failed to start moused"
} }

View File

@@ -1,5 +1,5 @@
#!@PREFIX@/sbin/runscript #!@PREFIX@/sbin/runscript
# Copyright 2007-2008 Roy Marples <roy@marples.name> # Copyright (c) 2007-2008 Roy Marples <roy@marples.name>
# All rights reserved. Released under the 2-clause BSD license. # All rights reserved. Released under the 2-clause BSD license.
description="Update /etc/mtab to match what the kernel knows about" description="Update /etc/mtab to match what the kernel knows about"

View File

@@ -1,8 +1,8 @@
#!@PREFIX@/sbin/runscript #!@PREFIX@/sbin/runscript
# Copyright 2007-2008 Roy Marples <roy@marples.name> # Copyright (c) 2007-2009 Roy Marples <roy@marples.name>
# All rights reserved. Released under the 2-clause BSD license. # All rights reserved. Released under the 2-clause BSD license.
MODULESDIR="${RC_LIBDIR}/net" MODULESDIR="${RC_LIBEXECDIR}/net"
MODULESLIST="${RC_SVCDIR}/nettree" MODULESLIST="${RC_SVCDIR}/nettree"
_config_vars="config routes" _config_vars="config routes"
@@ -28,7 +28,7 @@ depend()
*) after net.lo net.lo0;; *) after net.lo net.lo0;;
esac esac
if type depend_${IFVAR} >/dev/null 2>&1; then if [ "$(command -v "depend_${IFVAR}")" = "depend_${IFVAR}" ]; then
depend_${IFVAR} depend_${IFVAR}
fi fi
@@ -344,7 +344,7 @@ _load_modules()
# Wrap our provides # Wrap our provides
local f= local f=
for f in pre_start start post_start; do for f in pre_start start post_start; do
eval "${provides}_${f}() { type ${mod}_${f} >/dev/null 2>&1 || return 0; ${mod}_${f} \"\$@\"; }" eval "${provides}_${f}() { [ "$(command -v "${mod}_${f}")" = "${mod}_${f}" ] || return 0; ${mod}_${f} \"\$@\"; }"
done done
eval module_${mod}_provides="${provides}" eval module_${mod}_provides="${provides}"
@@ -358,7 +358,7 @@ _load_modules()
eval x=\$module_${mod}_provides eval x=\$module_${mod}_provides
[ -z "${x}" ] && continue [ -z "${x}" ] && continue
for f in pre_start start post_start; do for f in pre_start start post_start; do
eval "${x}_${f}() { type ${mod}_${f} >/dev/null 2>&1 || return 0; ${mod}_${f} \"\$@\"; }" eval "${x}_${f}() { [ "$(command -v "${mod}_${f}")" = "${mod}_${f}" ] || return 0; ${mod}_${f} \"\$@\"; }"
done done
eval module_${x}_providedby="${mod}" eval module_${x}_providedby="${mod}"
;; ;;
@@ -445,6 +445,35 @@ _load_config()
config_index=-1 config_index=-1
} }
# Support functions
_run_if()
{
local cmd=$1 iface=$2 ifr=${IFACE} ifv=${IFVAR}
# Ensure that we don't stamp on real values
local IFACE= IFVAR=
shift
if [ -n "${iface}" ]; then
IFACE="${iface}"
[ "${iface}" != "${ifr}" ] && IFVAR=$(shell_var "${IFACE}")
else
IFACE=${ifr}
IFVAR=${ifv}
fi
${cmd}
}
interface_exists()
{
_run_if _exists "$@"
}
interface_up()
{
_run_if _up "$@"
}
interface_down()
{
_run_if _down "$@"
}
start() start()
{ {
local IFACE=${RC_SVCNAME#*.} oneworked=false module= local IFACE=${RC_SVCNAME#*.} oneworked=false module=
@@ -462,7 +491,7 @@ start()
# We up the iface twice if we have a preup to ensure it's up if # We up the iface twice if we have a preup to ensure it's up if
# available in preup and afterwards incase the user inadvertently # available in preup and afterwards incase the user inadvertently
# brings it down # brings it down
if type preup >/dev/null 2>&1; then if [ "$(command -v preup)" = "preup" ]; then
_up 2>/dev/null _up 2>/dev/null
ebegin "Running preup" ebegin "Running preup"
eindent eindent
@@ -473,7 +502,7 @@ start()
_up 2>/dev/null _up 2>/dev/null
for module in ${MODULES}; do for module in ${MODULES}; do
if type "${module}_pre_start" >/dev/null 2>&1; then if [ "$(command -v "${module}_pre_start")" = "${module}_pre_start" ]; then
${module}_pre_start || exit $? ${module}_pre_start || exit $?
fi fi
done done
@@ -522,7 +551,7 @@ start()
null) :;; null) :;;
[0-9]*|*:*) _add_address ${config};; [0-9]*|*:*) _add_address ${config};;
*) *)
if type "${config}_start" >/dev/null 2>&1; then if [ "$(command -v "${config}_start")" = "${config}_start" ]; then
"${config}"_start "${config}"_start
else else
eerror "nothing provides \`${config}'" eerror "nothing provides \`${config}'"
@@ -547,7 +576,7 @@ start()
done done
if ! ${oneworked}; then if ! ${oneworked}; then
if type failup >/dev/null 2>&1; then if [ "$(command -v failup)" = "failup" ]; then
ebegin "Running failup" ebegin "Running failup"
eindent eindent
failup failup
@@ -566,7 +595,7 @@ ${routes}"
fi fi
fi fi
local OIFS="${IFS}" SIFS=${IFS-y} local OIFS="${IFS}" SIFS="${IFS-y}"
local IFS="$__IFS" local IFS="$__IFS"
for cmd in ${routes}; do for cmd in ${routes}; do
unset IFS unset IFS
@@ -581,7 +610,8 @@ ${routes}"
-net" "*|-host" "*);; -net" "*|-host" "*);;
*" "netmask" "*) cmd="-net ${cmd}";; *" "netmask" "*) cmd="-net ${cmd}";;
*.*.*.*/32*) cmd="-host ${cmd}";; *.*.*.*/32*) cmd="-host ${cmd}";;
*.*.*.*/*|0.0.0.0" "*|default" "*) cmd="-net ${cmd}";; *.*.*.*/*|0.0.0.0|0.0.0.0" "*) cmd="-net ${cmd}";;
default|default" "*) cmd="-net ${cmd}";;
*) cmd="-host ${cmd}";; *) cmd="-host ${cmd}";;
esac esac
if ${hidefirstroute}; then if ${hidefirstroute}; then
@@ -600,12 +630,12 @@ ${routes}"
fi fi
for module in ${MODULES}; do for module in ${MODULES}; do
if type "${module}_post_start" >/dev/null 2>&1; then if [ "$(command -v "${module}_post_start")" = "${module}_post_start" ]; then
${module}_post_start || exit $? ${module}_post_start || exit $?
fi fi
done done
if type postup >/dev/null 2>&1; then if [ "$(command -v postup)" = "postup" ]; then
ebegin "Running postup" ebegin "Running postup"
eindent eindent
postup postup
@@ -628,7 +658,7 @@ stop()
_load_modules false _load_modules false
fi fi
if type predown >/dev/null 2>&1; then if [ "$(command -v predown)" = "predown" ]; then
ebegin "Running predown" ebegin "Running predown"
eindent eindent
predown || return 1 predown || return 1
@@ -641,35 +671,40 @@ stop()
fi fi
for module in ${MODULES}; do for module in ${MODULES}; do
if type "${module}_pre_stop" >/dev/null 2>&1; then if [ "$(command -v "${module}_pre_stop")" = "${module}_pre_stop" ]; then
${module}_pre_stop || exit $? ${module}_pre_stop || exit $?
fi fi
done done
for module in ${MODULES}; do for module in ${MODULES}; do
if type "${module}_stop" >/dev/null 2>&1; then if [ "$(command -v "${module}_stop")" = "${module}_stop" ]; then
${module}_stop ${module}_stop
fi fi
done done
# Only delete addresses for non PPP interfaces # Only delete addresses for interfaces that exist
if ! type is_ppp >/dev/null 2>&1 || ! is_ppp; then if _exists; then
_delete_addresses "${IFACE}" _delete_addresses "${IFACE}"
fi fi
for module in ${MODULES}; do for module in ${MODULES}; do
if type "${module}_post_stop" >/dev/null 2>&1; then if [ "$(command -v "${module}_post_stop")" = "${module}_post_stop" ]; then
${module}_post_stop ${module}_post_stop
fi fi
done done
! yesno ${IN_BACKGROUND} && \ # If not in background, and not loopback then bring the interface down
[ "${IFACE}" != "lo" -a "${IFACE}" != "lo0" ] && \ # unless overridden.
_down 2>/dev/null if ! yesno ${IN_BACKGROUND} && \
[ "${IFACE}" != "lo" -a "${IFACE}" != "lo0" ]; then
eval module=\$ifdown_${IFVAR}
module=${module:-${ifdown:-YES}}
yesno ${module} && _down 2>/dev/null
fi
type resolvconf >/dev/null 2>&1 && resolvconf -d "${IFACE}" 2>/dev/null type resolvconf >/dev/null 2>&1 && resolvconf -d "${IFACE}" 2>/dev/null
if type postdown >/dev/null 2>&1; then if [ "$(command -v "postdown")" = "postdown" ]; then
ebegin "Running postdown" ebegin "Running postdown"
eindent eindent
postdown postdown

View File

@@ -1,5 +1,5 @@
#!@PREFIX@/sbin/runscript #!@PREFIX@/sbin/runscript
# Copyright 2007-2008 Roy Marples <roy@marples.name> # Copyright (c) 2007-2009 Roy Marples <roy@marples.name>
# All rights reserved. Released under the 2-clause BSD license. # All rights reserved. Released under the 2-clause BSD license.
description="Mounts network shares according to /etc/fstab." description="Mounts network shares according to /etc/fstab."
@@ -11,7 +11,7 @@ need_portmap()
" "
set -- $(fstabinfo --options --fstype nfs,nfs4) set -- $(fstabinfo --options --fstype nfs,nfs4)
for opts; do for opts; do
case ,${opts}, in case ,$opts, in
*,noauto,*|*,nolock,*);; *,noauto,*|*,nolock,*);;
*) return 0;; *) return 0;;
esac esac
@@ -27,14 +27,15 @@ depend()
if need_portmap; then if need_portmap; then
pmap="rpc.statd" pmap="rpc.statd"
[ -x @SYSCONFDIR@/init.d/rpcbind ] \ [ -x @SYSCONFDIR@/init.d/rpcbind ] \
&& pmap="${pmap} rpcbind" \ && pmap="$pmap rpcbind" \
|| pmap="${pmap} portmap" || pmap="$pmap portmap"
fi fi
config /etc/fstab config /etc/fstab
need net ${pmap} need net $pmap
use afc-client amd autofs dns nfs nfsmount portmap rpcbind rpc.statd use afc-client amd autofs openvpn
keyword nojail noopenvz noprefix novserver use dns nfs nfsmount portmap rpcbind rpc.statd rpc.lockd
keyword nojail noprefix novserver
} }
start() start()
@@ -43,8 +44,8 @@ start()
[ -x @SYSCONFDIR@/init.d/rpcbind ] && pmap="rpcbind" [ -x @SYSCONFDIR@/init.d/rpcbind ] && pmap="rpcbind"
local x= fs= local x= fs=
for x in ${net_fs_list}; do for x in $net_fs_list; do
case "${x}" in case "$x" in
nfs|nfs4) nfs|nfs4)
# If the nfsmount script took care of the nfs # If the nfsmount script took care of the nfs
# filesystems, then there's no point in trying # filesystems, then there's no point in trying
@@ -54,16 +55,16 @@ start()
# Only try to mount NFS filesystems if portmap was # Only try to mount NFS filesystems if portmap was
# started. This is to fix "hang" problems for new # started. This is to fix "hang" problems for new
# users who do not add portmap to the default runlevel. # users who do not add portmap to the default runlevel.
if need_portmap && ! service_started "${pmap}"; then if need_portmap && ! service_started "$pmap"; then
continue continue
fi fi
;; ;;
esac esac
fs="${fs}${fs:+,}${x}" fs="$fs${fs:+,}$x"
done done
ebegin "Mounting network filesystems" ebegin "Mounting network filesystems"
mount -at ${fs} mount -at $fs
ewend $? "Could not mount all network filesystems" ewend $? "Could not mount all network filesystems"
return 0 return 0
} }
@@ -73,24 +74,24 @@ stop()
local x= fs= local x= fs=
ebegin "Unmounting network filesystems" ebegin "Unmounting network filesystems"
. "${RC_LIBDIR}/sh/rc-mount.sh" . "$RC_LIBEXECDIR"/sh/rc-mount.sh
for x in ${net_fs_list}; do for x in $net_fs_list; do
fs="${fs}${fs:+,}${x}" fs="$fs${fs:+,}$x"
done done
if [ -n "${fs}" ]; then if [ -n "$fs" ]; then
umount -at ${fs} || eerror "Failed to simply unmount filesystems" umount -at $fs || eerror "Failed to simply unmount filesystems"
fi fi
eindent eindent
fs= fs=
for x in ${net_fs_list}; do for x in $net_fs_list; do
fs="${fs}${fs:+|}${x}" fs="$fs${fs:+|}$x"
done done
[ -n "${fs}" ] && fs="^(${fs})$" [ -n "$fs" ] && fs="^($fs)$"
do_unmount "umount" ${fs:+--fstype-regex} ${fs} --netdev do_unmount umount ${fs:+--fstype-regex} $fs --netdev
retval=$? retval=$?
eoutdent eoutdent
eend ${retval} "Failed to unmount network filesystems" eend $retval "Failed to unmount network filesystems"
} }

267
init.d/network.in Normal file
View File

@@ -0,0 +1,267 @@
#!@PREFIX@/sbin/runscript
# Copyright (c) 2009 Roy Marples <roy@marples.name>
# All rights reserved. Released under the 2-clause BSD license.
# This script was inspired by the equivalent rc.d network from NetBSD.
description="Configures network interfaces."
__nl="
"
depend()
{
need localmount
after bootmisc
provide net
keyword nojail noprefix novserver
}
uniqify()
{
local result= i=
for i; do
case " $result " in
*" $i "*);;
*) result="$result $i";;
esac
done
echo "${result# *}"
}
reverse()
{
local result= i=
for i; do
result="$i $result"
done
echo "${result# *}"
}
sys_interfaces()
{
case "$RC_UNAME" in
Linux)
local w= rest= i= cmd=$1
while read w rest; do
i=${w%%:*}
[ "$i" != "$w" ] || continue
if [ "$cmd" = u ]; then
ifconfig "$i" | grep -q "[ ]*UP" || continue
fi
printf "%s " "$i"
done </proc/net/dev
;;
*)
ifconfig -l$1
;;
esac
}
auto_interfaces()
{
local ifs= c= f=
case "$RC_UNAME" in
NetBSD)
for c in $(ifconfig -C 2>/dev/null); do
for f in /etc/ifconfig.${c}[0-9]*; do
[ -f "$f" ] && printf "%s" "$f{##*.} "
done
done
;;
*)
for f in /etc/ifconfig.*; do
[ -f "$f" ] && printf "%s" "${f##*.} "
done
for f in /etc/ip.*; do
[ -f "$f" ] && printf "%s" "${f##*.} "
done
;;
esac
echo
}
interfaces()
{
uniqify $(sys_interfaces "$@") $interfaces $(auto_interfaces)
}
dumpargs()
{
local f="$1"
shift
case "$@" in
'') [ -f "$f" ] && cat "$f";;
*"$__nl"*) echo "$@";;
*)
(
set -o noglob
IFS=';'; set -- $@
IFS="$__nl"; echo "$*"
);;
esac
}
runip()
{
local int="$1" err=
shift
err=$(LC_ALL=C ip address add "$@" dev "$int" 2>&1)
[ -z "$err" ] && return 0
if [ "$err" = "RTNETLINK answers: File exists" ]; then
ip address del "$@" dev "$int" 2>/dev/null
fi
# Localise the error
ip address add "$@" dev "$int"
}
routeflush()
{
if [ "$RC_UNAME" = Linux ]; then
if [ -x /sbin/ip ]; then
ip route flush scope global
else
# Sadly we also delete some link routes, but
# this cannot be helped
local dest= gate= net= flags= rest=
route -n | while read dest gate net flags rest; do
[ -z "$net" ] && continue
case "$dest" in
[0-9]*) ;;
*) continue;;
esac
local xtra= netmask="netmask $net"
case "$flags" in
U) continue;;
*H*) flags=-host; netmask=;;
*!*) flags=-net; xtra=reject;;
*) flags=-net;;
esac
route del $flags $dest $netmask $xtra
done
fi
else
route -qn flush
fi
}
runargs()
{
dumpargs "$@" | while read -r args; do
case "$args" in
''|"#"*) ;;
*)
(
eval vebegin "${args#*!}"
eval "${args#*!}"
veend $?
);;
esac
done
}
start()
{
local cr=0 r= int= intv= cmd= args= upcmd=
einfo "Starting network"
routeflush
if [ "$RC_UNAME" = "Linux" ]; then
ifconfig lo 127.0.0.1 netmask 255.0.0.0 || cr=1
route add -net 127.0.0.0 netmask 255.0.0.0 \
gw 127.0.0.1 2>/dev/null
route add -net 127.0.0.0 netmask 255.0.0.0 \
gw 127.0.0.1 reject 2>/dev/null
else
ifconfig lo0 127.0.0.1 netmask 255.0.0.0 || cr=1
route -q add -inet 127.0.0.0 -netmask 255.0.0.0 \
127.0.0.1 -reject || cr=1
fi
eindent
for int in $(interfaces); do
local func= cf=
intv=$(shell_var "$int")
eval upcmd=\$ifup_$intv
for func in ip ifconfig; do
eval cmd=\$${func}_$intv
if [ -n "$cmd" -o -f /etc/"$func.$int" ]; then
cf=/etc/"$func.$int"
break
fi
done
[ -n "$cf" -o -n "$upcmd" -o \
-f /etc/ifup."$int" -o -f "$cf" ] || continue
veinfo "$int"
case "$func" in
ip) func=runip;;
esac
eindent
runargs /etc/ifup."$int" "$upcmd"
r=0
dumpargs "$cf" "$cmd" | while read -r args; do
case "$args" in
''|"#"*) ;;
"!"*)
(
eval vebegin "${args#*!}"
eval "${args#*!}"
veend $?
);;
*)
(
set -o noglob
eval set -- "$args"
vebegin "$@"
$func "$int" "$@"
veend $?
);;
esac
done
eoutdent
done
eoutdent
eend $cr
if [ -n "$defaultroute" ]; then
ebegin "Setting default route $defaultroute"
if [ "$RC_UNAME" = Linux ]; then
route add default gw $defaultroute
else
route add default $defaultroute
fi
eend $?
fi
return 0
}
stop()
{
# Don't stop the network at shutdown.
# We don't use the noshutdown keyword so that we are started again
# correctly if we go back to multiuser.
yesno ${shutdown_network:-YES} && yesno $RC_GOINGDOWN && return 0
local int= intv= cmd= downcmd= r=
einfo "Stopping network"
routeflush
eindent
for int in $(reverse $(interfaces u)); do
intv=$(shell_var "$int")
eval downcmd=\$ifdown_$intv
eval cmd=\$ip_$intv
[ -z "$cmd" ] && eval cmd=\$ifconfig_$intv
if [ -n "$cmd" -o -f /etc/ip."$int" -o \
-f /etc/ifconfig."$int" -o \
-n "$downcmd" -o -f /etc/ifdown."$int" ];
then
veinfo "$int"
runargs /etc/ifdown."$int" "$downcmd"
ifconfig "$int" down 2>/dev/null
ifconfig "$int" destroy 2>/dev/null
fi
done
eoutdent
eend 0
}

View File

@@ -1,5 +1,5 @@
#!@PREFIX@/sbin/runscript #!@PREFIX@/sbin/runscript
# Copyright 2007-2008 Roy Marples <roy@marples.name> # Copyright (c) 2007-2009 Roy Marples <roy@marples.name>
# All rights reserved. Released under the 2-clause BSD license. # All rights reserved. Released under the 2-clause BSD license.
required_files="/etc/newsyslog.conf" required_files="/etc/newsyslog.conf"
@@ -13,6 +13,6 @@ depend()
start() start()
{ {
ebegin "Creating and/or trimming log files" ebegin "Creating and/or trimming log files"
newsyslog -s ${newsyslog_args} newsyslog -s $newsyslog_args
eend $? eend $?
} }

View File

@@ -1,9 +1,9 @@
#!@PREFIX@/sbin/runscript #!@PREFIX@/sbin/runscript
# Copyright 2007-2008 Roy Marples <roy@marples.name> # Copyright (c) 2007-2008 Roy Marples <roy@marples.name>
# All rights reserved. Released under the 2-clause BSD license. # All rights reserved. Released under the 2-clause BSD license.
command=/usr/sbin/nscd command=/usr/sbin/nscd
command_args="${nscd_args}" command_args=$nscd_args
pidfile=/var/run/nscd.pid pidfile=/var/run/nscd.pid
name="Name Service Cache Daemon" name="Name Service Cache Daemon"
@@ -16,7 +16,7 @@ depend() {
} }
flush() { flush() {
ebegin "Flushing ${name}" ebegin "Flushing $name"
nscd -I all >/dev/null nscd -I all >/dev/null
eend $? eend $?
} }

View File

@@ -1,10 +1,10 @@
#!@PREFIX@/sbin/runscript #!@PREFIX@/sbin/runscript
# Copyright 2007-2008 Roy Marples <roy@marples.name> # Copyright (c) 2007-2009 Roy Marples <roy@marples.name>
# All rights reserved. Released under the 2-clause BSD license. # All rights reserved. Released under the 2-clause BSD license.
description="Turns numlock on for the consoles." description="Turns numlock on for the consoles."
ttyn=${rc_tty_number:-${RC_TTY_NUMBER}:-12} ttyn=${rc_tty_number:-${RC_TTY_NUMBER:-12}}
depend() depend()
{ {
@@ -19,12 +19,12 @@ _setleds()
local dev=/dev/tty t= i=1 retval=0 local dev=/dev/tty t= i=1 retval=0
[ -d /dev/vc ] && dev=/dev/vc/ [ -d /dev/vc ] && dev=/dev/vc/
while [ ${i} -le ${ttyn} ]; do while [ $i -le $ttyn ]; do
setleds -D "$1"num < ${dev}${i} || retval=1 setleds -D "$1"num < $dev$i || retval=1
i=$((${i} + 1)) i=$(($i + 1))
done done
return ${retval} return $retval
} }
start() start()

View File

@@ -1,10 +1,10 @@
#!@PREFIX@/sbin/runscript #!@PREFIX@/sbin/runscript
# Copyright 2007-2008 Roy Marples <roy@marples.name> # Copyright (c) 2007-2009 Roy Marples <roy@marples.name>
# All rights reserved. Released under the 2-clause BSD license. # All rights reserved. Released under the 2-clause BSD license.
name="Packet Filter" name="Packet Filter"
pf_conf=${pf_conf:-${pf_rules:-/etc/pf.conf}} : ${pf_conf:=${pf_rules:-/etc/pf.conf}}
required_files=${pf_conf} required_files=$pf_conf
extra_commands="checkconfig showstatus" extra_commands="checkconfig showstatus"
extra_started_commands="reload" extra_started_commands="reload"
@@ -16,39 +16,39 @@ depend() {
start() start()
{ {
ebegin "Starting ${name}" ebegin "Starting $name"
if type kldload >/dev/null 2>&1; then if type kldload >/dev/null 2>&1; then
kldload pf 2>/dev/null kldload pf 2>/dev/null
fi fi
pfctl -q -F all pfctl -q -F all
pfctl -q -f "${pf_conf}" ${pf_args} pfctl -q -f "$pf_conf" $pf_args
pfctl -q -e pfctl -q -e
eend $? eend $?
} }
stop() stop()
{ {
ebegin "Stopping ${name}" ebegin "Stopping $name"
pfctl -q -d pfctl -q -d
eend $? eend $?
} }
checkconfig() checkconfig()
{ {
ebegin "Checking ${name} configuration" ebegin "Checking $name configuration"
pfctl -n -f "${pf_conf}" pfctl -n -f "$pf_conf"
eend $? eend $?
} }
reload() reload()
{ {
ebegin "Reloading ${name} rules." ebegin "Reloading $name rules."
pfctl -q -n -f "${pf_conf}" && \ pfctl -q -n -f "$pf_conf" && \
{ {
# Flush everything but existing state entries that way when # Flush everything but existing state entries that way when
# rules are read in, it doesn't break established connections. # rules are read in, it doesn't break established connections.
pfctl -q -Fnat -Fqueue -Frules -FSources -Finfo -FTables -Fosfp pfctl -q -Fnat -Fqueue -Frules -FSources -Finfo -FTables -Fosfp
pfctl -q -f "${pf_conf}" ${pf_args} pfctl -q -f "$pf_conf" $pf_args
} }
eend $? eend $?
} }

View File

@@ -1,9 +1,9 @@
#!@PREFIX@/sbin/runscript #!@PREFIX@/sbin/runscript
# Copyright 2007-2008 Roy Marples <roy@marples.name> # Copyright (c) 2007-2009 Roy Marples <roy@marples.name>
# All rights reserved. Released under the 2-clause BSD license. # All rights reserved. Released under the 2-clause BSD license.
command=/usr/sbin/powerd command=/usr/sbin/powerd
command_args=${powerd_args} command_args=$powerd_args
pidfile=/var/run/powerd.pid pidfile=/var/run/powerd.pid
name="Power Control Daemon" name="Power Control Daemon"
@@ -17,11 +17,11 @@ depend()
start_pre() start_pre()
{ {
if [ -n "${powerd_battery_mode}" ]; then if [ -n "$powerd_battery_mode" ]; then
command_args="${command_args} -b ${powerd_battery_mode}" command_args="$command_args -b $powerd_battery_mode"
fi fi
if [ -n "${powerd_ac_mode}" ]; then if [ -n "${powerd_ac_mode}" ]; then
command_args="${command_args} -a ${powerd_ac_mode}" command_args="$command_args -a $powerd_ac_mode"
fi fi
} }
@@ -29,7 +29,7 @@ stop_post()
{ {
local level=$(sysctl -n dev.cpu.0.freq_levels | local level=$(sysctl -n dev.cpu.0.freq_levels |
sed -e 's:/.*::') sed -e 's:/.*::')
if [ -n "${level}" ]; then if [ -n "$level" ]; then
sysctl dev.cpu.0.freq="${level}" >/dev/null sysctl dev.cpu.0.freq="$level" >/dev/null
fi fi
} }

View File

@@ -1,11 +1,12 @@
#!@PREFIX@/sbin/runscript #!@PREFIX@/sbin/runscript
# Copyright 2007-2008 Roy Marples <roy@marples.name> # Copyright (c) 2007-2009 Roy Marples <roy@marples.name>
# All rights reserved. Released under the 2-clause BSD license. # All rights reserved. Released under the 2-clause BSD license.
description="Mounts misc filesystems in /proc." description="Mounts misc filesystems in /proc."
depend() depend()
{ {
use modules devfs
need localmount need localmount
keyword noopenvz noprefix novserver keyword noopenvz noprefix novserver
} }
@@ -24,13 +25,13 @@ start()
# while older kernels have 'usbdevfs'. # while older kernels have 'usbdevfs'.
if [ -d /proc/bus/usb -a ! -e /proc/bus/usb/devices ]; then if [ -d /proc/bus/usb -a ! -e /proc/bus/usb/devices ]; then
local usbfs=$(grep -Fow usbfs /proc/filesystems || local usbfs=$(grep -Fow usbfs /proc/filesystems ||
grep -Fow usbdevfs /proc/filesystems) grep -Fow usbdevfs /proc/filesystems)
if [ -n "${usbfs}" ]; then if [ -n "$usbfs" ]; then
ebegin "Mounting USB device filesystem (${usbfs})" ebegin "Mounting USB device filesystem [$usbfs]"
local usbgid="$(getent group usb | \ local usbgid="$(getent group usb | \
sed -e 's/.*:.*:\(.*\):.*/\1/')" sed -e 's/.*:.*:\(.*\):.*/\1/')"
mount -t ${usbfs} \ mount -t $usbfs \
-o ${usbgid:+devmode=0664,devgid=${usbgid},}noexec,nosuid \ -o ${usbgid:+devmode=0664,devgid=$usbgid,}noexec,nosuid \
usbfs /proc/bus/usb usbfs /proc/bus/usb
eend $? eend $?
fi fi
@@ -39,7 +40,7 @@ start()
# Setup Kernel Support for the NFS daemon status # Setup Kernel Support for the NFS daemon status
if [ -d /proc/fs/nfsd ] && ! mountinfo -q /proc/fs/nfsd; then if [ -d /proc/fs/nfsd ] && ! mountinfo -q /proc/fs/nfsd; then
if grep -qs nfsd /proc/filesystems; then if grep -qs nfsd /proc/filesystems; then
ebegin "Mounting nfsd filesystem" ebegin "Mounting NFS filesystem"
mount -t nfsd -o nodev,noexec,nosuid \ mount -t nfsd -o nodev,noexec,nosuid \
nfsd /proc/fs/nfsd nfsd /proc/fs/nfsd
eend $? eend $?
@@ -47,7 +48,8 @@ start()
fi fi
# Setup Kernel Support for miscellaneous Binary Formats # Setup Kernel Support for miscellaneous Binary Formats
if [ -d /proc/sys/fs/binfmt_misc ] && ! mountinfo -q /proc/sys/fs/binfmt_misc; then if [ -d /proc/sys/fs/binfmt_misc ] \
&& ! mountinfo -q /proc/sys/fs/binfmt_misc; then
if grep -qs binfmt_misc /proc/filesystems; then if grep -qs binfmt_misc /proc/filesystems; then
ebegin "Mounting misc binary format filesystem" ebegin "Mounting misc binary format filesystem"
mount -t binfmt_misc -o nodev,noexec,nosuid \ mount -t binfmt_misc -o nodev,noexec,nosuid \
@@ -56,26 +58,6 @@ start()
fi fi
fi fi
# Setup Kernel Support for securityfs
if [ -d /sys/kernel/security ] && ! mountinfo -q /sys/kernel/security; then
if grep -qs securityfs /proc/filesystems; then
ebegin "Mounting security filesystem"
mount -t securityfs -o nodev,noexec,nosuid \
securityfs /sys/kernel/security
eend $?
fi
fi
# Setup Kernel Support for debugfs
if [ -d /sys/kernel/debug ] && ! mountinfo -q /sys/kernel/debug; then
if grep -qs debugfs /proc/filesystems; then
ebegin "Mounting debug filesystem"
mount -t debugfs -o nodev,noexec,nosuid \
debugfs /sys/kernel/debug
eend $?
fi
fi
# Setup Kernel Support for SELinux # Setup Kernel Support for SELinux
if [ -d /selinux ] && ! mountinfo -q /selinux; then if [ -d /selinux ] && ! mountinfo -q /selinux; then
if grep -qs selinuxfs /proc/filesystems; then if grep -qs selinuxfs /proc/filesystems; then

View File

@@ -1,28 +1,23 @@
#!@PREFIX@/sbin/runscript #!@PREFIX@/sbin/runscript
# Copyright 2007-2008 Roy Marples <roy@marples.name> # Copyright (c) 2007-2008 Roy Marples <roy@marples.name>
# All rights reserved. Released under the 2-clause BSD license. # All rights reserved. Released under the 2-clause BSD license.
command=/usr/sbin/rarpd command=/usr/sbin/rarpd
command_args="-f ${rarpd_args}" command_args="-f $rarpd_args"
pidfile=/var/run/rarpd.pid pidfile=/var/run/rarpd.pid
name="Reverse ARP Daemon" name="Reverse ARP Daemon"
required_files="/etc/ethers" required_files=/etc/ethers
if [ -z "${rarpd_interface}" ]; then if [ -z "$rarpd_interface" ]; then
command_args="${command_args} -a" command_args="$command_args -a"
else else
command_args="${command_args} ${rarpd_interface}" command_args="$command_args $rarpd_interface"
fi fi
command_background="YES" command_background=YES
depend() depend()
{ {
need localmount need localmount
after bootmisc after bootmisc
need net
if [ -z "${rarpd_interface}" ]; then
need net
else
net net."${rarpd_interface}"
fi
} }

View File

@@ -1,5 +1,5 @@
#!@PREFIX@/sbin/runscript #!@PREFIX@/sbin/runscript
# Copyright 2007-2008 Roy Marples <roy@marples.name> # Copyright (c) 2007-2009 Roy Marples <roy@marples.name>
# All rights reserved. Released under the 2-clause BSD license. # All rights reserved. Released under the 2-clause BSD license.
depend() depend()
@@ -13,28 +13,29 @@ depend()
start() start()
{ {
ebegin "Starting local rc services" ebegin "Starting local rc services"
local svc= enabled= retval=0 service= local svc= enabled= retval=0 service= pkgdir=
for svc in $(rcorder /etc/rc.d/* @PKG_PREFIX@/etc/rc.d/* 2>/dev/null); do [ -n "@PKG_PREFIX@" ] && pkgdir="@PKG_PREFIX@/etc/rc.d/*"
for svc in $(rcorder /etc/rc.d/* $pkgdir 2>/dev/null); do
[ -x "$svc" ] || continue [ -x "$svc" ] || continue
service=${svc##*/} service=${svc##*/}
# Skip these services # Skip these services
for s in cleartmp moused; do for s in cleartmp moused; do
[ "${s}" = "${service}" ] && continue 2 [ "$s" = "$service" ] && continue 2
done done
# If we have an init script for this service, continue # If we have an init script for this service, continue
rc-service --exists "${service}" && continue rc-service --exists "$service" && continue
# Ensure that the users rc.conf will start us - ignore the defaults # Ensure that the users rc.conf will start us
eval enabled=\$${svc##*/}_enable eval enabled=\$${svc##*/}_enable
yesno ${enabled} || yesno ${svc##*/} || continue yesno $enabled || yesno ${svc##*/} || continue
# Good to go! # Good to go!
"$svc" start && started="${started} ${svc}" "$svc" start && started="$started $svc"
: $((retval += $?)) : $((retval += $?))
done done
service_set_value started "${started}" service_set_value started "$started"
eend $retval "Some local rc services failed to start" eend $retval "Some local rc services failed to start"
return 0 return 0
} }
@@ -44,7 +45,7 @@ stop()
ebegin "Stopping local rc services" ebegin "Stopping local rc services"
local svc= retval=0 local svc= retval=0
for svc in $(rcorder $(service_get_value started) 2>/dev/null | sort -r); do for svc in $(rcorder $(service_get_value started) 2>/dev/null | sort -r); do
"${svc}" stop "$svc" stop
: $((retval += $?)) : $((retval += $?))
done done
eend $retval "Some local rc services failed to stop" eend $retval "Some local rc services failed to stop"

View File

@@ -1,5 +1,5 @@
#!@PREFIX@/sbin/runscript #!@PREFIX@/sbin/runscript
# Copyright 2007-2008 Roy Marples <roy@marples.name> # Copyright (c) 2007-2009 Roy Marples <roy@marples.name>
# All rights reserved. Released under the 2-clause BSD license. # All rights reserved. Released under the 2-clause BSD license.
description="Mount the root fs read/write" description="Mount the root fs read/write"
@@ -12,16 +12,21 @@ depend()
start() start()
{ {
case ",$(fstabinfo -o /)," in
*,ro,*) return 0;;
esac
if echo 2>/dev/null >/.test.$$; then if echo 2>/dev/null >/.test.$$; then
rm -f /.test.$$ /fastboot rm -f /.test.$$ /fastboot /forcefsck
return 0 return 0
fi fi
ebegin "Remounting root filesystem read/write" ebegin "Remounting root filesystem read/write"
case "${RC_UNAME}" in case "$RC_UNAME" in
Linux) mount -n -o remount,rw /;; Linux) mount -n -o remount,rw /;;
*) mount -u -o rw /;; *) mount -u -o rw /;;
esac esac
eend $? "Root filesystem could not be mounted read/write" if eend $? "Root filesystem could not be mounted read/write"; then
rm -f /fastboot rm -f /fastboot /forcefsck
fi
} }

View File

@@ -1,9 +1,9 @@
#!@PREFIX@/sbin/runscript #!@PREFIX@/sbin/runscript
# Copyright 2007-2008 Roy Marples <roy@marples.name> # Copyright (c) 2007-2009 Roy Marples <roy@marples.name>
# All rights reserved. Released under the 2-clause BSD license. # All rights reserved. Released under the 2-clause BSD license.
command=/usr/sbin/rpcbind command=/usr/sbin/rpcbind
command_args=${rpcbind_args} command_args=$rpcbind_args
name="RPC program number mapper" name="RPC program number mapper"
depend() depend()

32
init.d/savecache.in Normal file
View File

@@ -0,0 +1,32 @@
#!@PREFIX@/sbin/runscript
# Copyright (c) 2007-2009 Roy Marples <roy@marples.name>
# All rights reserved. Released under the 2-clause BSD license.
description="Saves the caches OpenRC uses to non volatile storage"
start()
{
if [ -e "$RC_SVCDIR"/clock-skewed ]; then
ewarn "WARNING: clock skew detected!"
if ! yesno "savecache_skewed"; then
eerror "Not saving deptree cache"
return 1
fi
fi
ebegin "Saving dependency cache"
if [ ! -d "$RC_LIBEXECDIR"/cache ]; then
rm -rf "$RC_LIBEXECDIR"/cache
if ! mkdir "$RC_LIBEXECDIR"/cache; then
eend $?
return $?
fi
fi
local save=
for x in deptree depconfig softlevel nettree rc.log; do
[ -e "$RC_SVCDIR/$x" ] && save="$save $RC_SVCDIR/$x"
done
if [ -n "$save" ]; then
cp -p $save "$RC_LIBEXECDIR"/cache 2>/dev/null
fi
eend $?
}

View File

@@ -1,5 +1,5 @@
#!@PREFIX@/sbin/runscript #!@PREFIX@/sbin/runscript
# Copyright 2007-2008 Roy Marples <roy@marples.name> # Copyright (c) 2007-2009 Roy Marples <roy@marples.name>
# All rights reserved. Released under the 2-clause BSD license. # All rights reserved. Released under the 2-clause BSD license.
description="Saves a kernel dump." description="Saves a kernel dump."
@@ -12,25 +12,25 @@ depend()
start() start()
{ {
local dump_dir=${dump_dir:-/var/crash} : ${dump_dir:=/var/crash}
if ! [ -d "${dump_dir}" ]; then if ! [ -d "$dump_dir" ]; then
mkdir -p "${dump_dir}" mkdir -p "$dump_dir"
chmod 700 "${dump_dir}" chmod 700 "$dump_dir"
fi fi
if [ "${RC_UNAME}" = "FreeBSD" ]; then if [ "$RC_UNAME" = FreeBSD ]; then
# Don't quote ${dump_device}, so that if it's unset, # Don't quote ${dump_device}, so that if it's unset,
# savecore will check on the partitions listed in fstab # savecore will check on the partitions listed in fstab
# without errors in the output # without errors in the output
savecore -C "${dump_dir}" ${dump_device} >/dev/null savecore -C "$dump_dir" $dump_device >/dev/null
else else
ls "${dump_dir}"/bsd* > /dev/null 2>&1 ls "$dump_dir"/bsd* > /dev/null 2>&1
fi fi
[ $? = 0 ] || return 0 [ $? = 0 ] || return 0
local sopts="${dump_dir} ${dump_device}" local sopts="$dump_dir $dump_device"
yesno ${dump_compress} && sopts="-z ${sopts}" yesno $dump_compress && sopts="-z $sopts"
ebegin "Saving kernel core dump in ${dump_dir}" ebegin "Saving kernel core dump in $dump_dir"
savecore ${sopts} >/dev/null savecore $sopts >/dev/null
eend $? eend $?
} }

View File

@@ -1,5 +1,5 @@
#!@PREFIX@/sbin/runscript #!@PREFIX@/sbin/runscript
# Copyright 2007-2008 Roy Marples <roy@marples.name> # Copyright (c) 2007-2008 Roy Marples <roy@marples.name>
# All rights reserved. Released under the 2-clause BSD license. # All rights reserved. Released under the 2-clause BSD license.
depend() depend()

View File

@@ -1,5 +1,5 @@
#!@PREFIX@/sbin/runscript #!@PREFIX@/sbin/runscript
# Copyright 2007-2008 Roy Marples <roy@marples.name> # Copyright (c) 2007-2009 Roy Marples <roy@marples.name>
# All rights reserved. Released under the 2-clause BSD license. # All rights reserved. Released under the 2-clause BSD license.
depend() depend()
@@ -11,7 +11,7 @@ depend()
start() start()
{ {
ebegin "Activating swap devices" ebegin "Activating swap devices"
case "${RC_UNAME}" in case "$RC_UNAME" in
NetBSD|OpenBSD) swapctl -A -t noblk >/dev/null;; NetBSD|OpenBSD) swapctl -A -t noblk >/dev/null;;
*) swapon -a >/dev/null;; *) swapon -a >/dev/null;;
esac esac
@@ -21,7 +21,13 @@ start()
stop() stop()
{ {
ebegin "Deactivating swap devices" ebegin "Deactivating swap devices"
case "${RC_UNAME}" in
# Try to unmount all tmpfs filesystems not in use, else a deadlock may
# occure. As $RC_SVCDIR may also be tmpfs we cd to it to lock it
cd "$RC_SVCDIR"
umount -a -t tmpfs 2>/dev/null
case "$RC_UNAME" in
NetBSD|OpenBSD) swapctl -U -t noblk >/dev/null;; NetBSD|OpenBSD) swapctl -U -t noblk >/dev/null;;
*) swapoff -a >/dev/null;; *) swapoff -a >/dev/null;;
esac esac

View File

@@ -1,5 +1,5 @@
#!@PREFIX@/sbin/runscript #!@PREFIX@/sbin/runscript
# Copyright 2007-2008 Roy Marples <roy@marples.name> # Copyright (c) 2007-2009 Roy Marples <roy@marples.name>
# All rights reserved. Released under the 2-clause BSD license. # All rights reserved. Released under the 2-clause BSD license.
depend() { depend() {
@@ -8,29 +8,29 @@ depend() {
} }
start() { start() {
if [ -n "${allscreen_flags}" ]; then if [ -n "$allscreen_flags" ]; then
ebegin "Setting mode to ${allscreen_flags} for all screens" ebegin "Setting mode to $allscreen_flags for all screens"
for v in /dev/ttyv*; do for v in /dev/ttyv*; do
vidcontrol ${allscreen_flags} <"${v}" vidcontrol $allscreen_flags <$v
done done
eend $? eend $?
fi fi
if [ -n "${keymap}" ]; then if [ -n "$keymap" ]; then
ebegin "Setting keymap to ${keymap}" ebegin "Setting keymap to $keymap"
kbdcontrol -l ${keymap} </dev/console kbdcontrol -l $keymap </dev/console
eend $? eend $?
fi fi
if [ -n "${keyrate}" ]; then if [ -n "$keyrate" ]; then
ebegin "Setting keyrate to ${keyrate}" ebegin "Setting keyrate to $keyrate"
kbdcontrol -r ${keyrate} </dev/console kbdcontrol -r $keyrate </dev/console
eend $? eend $?
fi fi
if [ -n "${keychange}" ]; then if [ -n "$keychange" ]; then
ebegin "Changing function keys" ebegin "Changing function keys"
eval set -- "${keychange}" eval set -- "$keychange"
eindent eindent
while [ $# -gt 0 ]; do while [ $# -gt 0 ]; do
veinfo "F$1 -> \`$2'" veinfo "F$1 -> \`$2'"
@@ -41,40 +41,40 @@ start() {
eoutdent eoutdent
fi fi
if [ -n "${cursor}" ]; then if [ -n "$cursor" ]; then
ebegin "Setting cursor" ebegin "Setting cursor"
vidcontrol -c ${cursor} vidcontrol -c $cursor
eend $? eend $?
fi fi
local v= f= local v= f=
for v in font8x16 font8x14 font8x8; do for v in font8x16 font8x14 font8x8; do
f=$(eval \$"${v}") eval f=\$$v
if [ -n "${f}" ]; then if [ -n "$f" ]; then
ebegin "Setting font ${f}" ebegin "Setting font $f"
vidcontrol -f ${v##FONT} ${f} vidcontrol -f ${v##font} $f
eend $? eend $?
fi fi
done done
if [ -n "${blanktime}" ]; then if [ -n "$blanktime" ]; then
ebegin "Setting blanktime" ebegin "Setting blanktime"
vidcontrol -t ${blanktime} vidcontrol -t $blanktime
eend $? eend $?
fi fi
if [ -n "${saver}" ]; then if [ -n "$saver" ]; then
local i= local i=
for i in $(kldstat | sed -n -e 's/.* \(splash_.*\)/\1/p'); do for i in $(kldstat | sed -n -e 's/.* \(splash_.*\)/\1/p'); do
kldunload "${i}" kldunload "$i"
done done
kldstat -v | grep -q _saver || kldload ${saver}_saver kldstat -v | grep -q _saver || kldload ${saver}_saver
fi fi
if [ -n "${kbdflags}" ]; then if [ -n "$kbdflags" ]; then
ebegin "Setting keyboard flags for all screens" ebegin "Setting keyboard flags for all screens"
for v in /dev/ttyv*; do for v in /dev/ttyv*; do
kbdcontrol ${kbdflags} <${v} kbdcontrol $kbdflags <$v
done done
eend $? eend $?
fi fi

View File

@@ -1,5 +1,5 @@
#!@PREFIX@/sbin/runscript #!@PREFIX@/sbin/runscript
# Copyright 2007-2008 Roy Marples <roy@marples.name> # Copyright (c) 2007-2009 Roy Marples <roy@marples.name>
# All rights reserved. Released under the 2-clause BSD license. # All rights reserved. Released under the 2-clause BSD license.
depend() depend()
@@ -15,10 +15,10 @@ start()
local retval=0 var= comments= local retval=0 var= comments=
ebegin "Configuring kernel parameters" ebegin "Configuring kernel parameters"
while read var comments; do while read var comments; do
case "${var}" in case "$var" in
""|"#"*) continue;; ""|"#"*) continue;;
esac esac
sysctl -w "${var}" >/dev/null || retval=1 sysctl -w "$var" >/dev/null || retval=1
done < /etc/sysctl.conf done < /etc/sysctl.conf
eend ${retval} "Some errors were encountered" eend $retval "Some errors were encountered"
} }

View File

@@ -1,5 +1,5 @@
#!@PREFIX@/sbin/runscript #!@PREFIX@/sbin/runscript
# Copyright 2007-2008 Roy Marples <roy@marples.name> # Copyright (c) 2007-2008 Roy Marples <roy@marples.name>
# All rights reserved. Released under the 2-clause BSD license. # All rights reserved. Released under the 2-clause BSD license.
depend() depend()

64
init.d/sysfs.in Normal file
View File

@@ -0,0 +1,64 @@
#!@PREFIX@/sbin/runscript
# Copyright (c) 2007-2009 Roy Marples <roy@marples.name>
# All rights reserved. Released under the 2-clause BSD license.
description="Mount the sys filesystem."
depend()
{
keyword noprefix novserver
}
mount_sys()
{
grep -Eq "[[:space:]]+sysfs$" /proc/filesystems || return 1
mountinfo -q /sys && return 0
if [ ! -d /sys ]; then
if ! mkdir -m 0755 /sys; then
ewarn "Could not create /sys!"
return 1
fi
fi
ebegin "Mounting /sys"
if ! fstabinfo --mount /sys; then
mount -n -t sysfs -o noexec,nosuid,nodev sysfs /sys
fi
eend $?
}
mount_misc()
{
# Setup Kernel Support for securityfs
if [ -d /sys/kernel/security ] && \
! mountinfo -q /sys/kernel/security; then
if grep -qs securityfs /proc/filesystems; then
ebegin "Mounting security filesystem"
mount -n -t securityfs -o nodev,noexec,nosuid \
securityfs /sys/kernel/security
eend $?
fi
fi
# Setup Kernel Support for debugfs
if [ -d /sys/kernel/debug ] && ! mountinfo -q /sys/kernel/debug; then
if grep -qs debugfs /proc/filesystems; then
ebegin "Mounting debug filesystem"
mount -n -t debugfs -o nodev,noexec,nosuid \
debugfs /sys/kernel/debug
eend $?
fi
fi
}
start()
{
local retval
mount_sys
retval=$?
if [ $retval -eq 0 ]; then
mount_misc
fi
return $retval
}

View File

@@ -1,10 +1,10 @@
#!@PREFIX@/sbin/runscript #!@PREFIX@/sbin/runscript
# Copyright 2007-2008 Roy Marples <roy@marples.name> # Copyright (c) 2007-2009 Roy Marples <roy@marples.name>
# All rights reserved. Released under the 2-clause BSD license. # All rights reserved. Released under the 2-clause BSD license.
command=/usr/sbin/syslogd command=/usr/sbin/syslogd
command_args=${syslogd_args} command_args=$syslogd_args
case "${RC_UNAME}" in case "$RC_UNAME" in
FreeBSD|DragonFly) pidfile=/var/run/syslog.pid;; FreeBSD|DragonFly) pidfile=/var/run/syslog.pid;;
*) pidfile=/var/run/syslogd.pid;; *) pidfile=/var/run/syslogd.pid;;
esac esac

View File

@@ -1,11 +1,11 @@
#!@PREFIX@/sbin/runscript #!@PREFIX@/sbin/runscript
# Copyright 2008 Roy Marples <roy@marples.name> # Copyright (c) 2008-2009 Roy Marples <roy@marples.name>
# All rights reserved. Released under the 2-clause BSD license. # All rights reserved. Released under the 2-clause BSD license.
description="Configures terminal encoding." description="Configures terminal encoding."
ttyn=${rc_tty_number:-${RC_TTY_NUMBER:-12}} ttyn=${rc_tty_number:-${RC_TTY_NUMBER:-12}}
unicode=${unicode:-${UNICODE}} : ${unicode:=${UNICODE}}
depend() depend()
{ {
@@ -25,11 +25,11 @@ start()
termmsg="UTF-8" termmsg="UTF-8"
fi fi
ebegin "Setting terminal encoding [${termmsg}]" ebegin "Setting terminal encoding [$termmsg]"
n=1 n=1
while [ ${n} -le "${ttyn}" ]; do while [ ${n} -le "$ttyn" ]; do
printf "\033%s" "${termencoding}" >"${ttydev}${n}" printf "\033%s" "$termencoding" >$ttydev$n
n=$((${n} + 1)) n=$(($n + 1))
done done
eend 0 eend 0
} }

View File

@@ -1,5 +1,5 @@
#!@PREFIX@/sbin/runscript #!@PREFIX@/sbin/runscript
# Copyright 2008 Roy Marples <roy@marples.name> # Copyright (c) 2008 Roy Marples <roy@marples.name>
# All rights reserved. Released under the 2-clause BSD license. # All rights reserved. Released under the 2-clause BSD license.
depend() depend()

View File

@@ -1,9 +1,8 @@
#!@PREFIX@/sbin/runscript #!@PREFIX@/sbin/runscript
# Copyright 2007-2008 Roy Marples <roy@marples.name> # Copyright (c) 2007-2009 Roy Marples <roy@marples.name>
# All rights reserved. Released under the 2-clause BSD license. # All rights reserved. Released under the 2-clause BSD license.
urandom_seed=${urandom_seed:-${URANDOM_SEED:-/var/run/random-seed}} : ${urandom_seed:=${URANDOM_SEED:-/var/run/random-seed}}
description="Initializes the random number generator." description="Initializes the random number generator."
depend() depend()
@@ -22,19 +21,19 @@ save_seed()
( # sub shell to prevent umask pollution ( # sub shell to prevent umask pollution
umask 077 umask 077
dd if=/dev/urandom of="${urandom_seed}" count=${psz} 2>/dev/null dd if=/dev/urandom of="$urandom_seed" count=${psz} 2>/dev/null
) )
} }
start() start()
{ {
[ -c /dev/urandom ] || return [ -c /dev/urandom ] || return
if [ -f "${urandom_seed}" ]; then if [ -f "$urandom_seed" ]; then
ebegin "Initializing random number generator" ebegin "Initializing random number generator"
cat "${urandom_seed}" > /dev/urandom cat "$urandom_seed" > /dev/urandom
eend $? "Error initializing random number generator" eend $? "Error initializing random number generator"
fi fi
rm -f "${urandom_seed}" && save_seed rm -f "$urandom_seed" && save_seed
return 0 return 0
} }

View File

@@ -1,5 +1,5 @@
#!@PREFIX@/sbin/runscript #!@PREFIX@/sbin/runscript
# Copyright 2008 Roy Marples <roy@marples.name> # Copyright (c) 2008-2009 Roy Marples <roy@marples.name>
# All rights reserved. Released under the 2-clause BSD license. # All rights reserved. Released under the 2-clause BSD license.
depend() depend()
@@ -19,82 +19,82 @@ start()
# screen idx scr emul # screen idx scr emul
# font name width height enc file # font name width height enc file
while read type arg1 arg2 arg3 arg4 arg5; do while read type arg1 arg2 arg3 arg4 arg5; do
case "${type}" in case "$type" in
\#*|"") \#*|"")
continue continue
;; ;;
font) font)
cmd=${wsfld} cmd=$wsfld
[ "${arg2}" != "-" ] && cmd="${cmd} -w ${arg2}" [ "$arg2" != "-" ] && cmd="$cmd -w $arg2"
[ "${arg3}" != "-" ] && cmd="${cmd} -h ${arg3}" [ "$arg3" != "-" ] && cmd="$cmd -h $arg3"
[ "${arg4}" != "-" ] && cmd="${cmd} -e ${arg4}" [ "$arg4" != "-" ] && cmd="$cmd -e $arg4"
cmd="${cmd} -N ${arg1} ${arg5}" cmd="$cmd -N $arg1 $arg5"
eval "${cmd}" eval "$cmd"
;; ;;
screen) screen)
cmd=${wscfg} cmd=$wscfg
[ "${arg2}" != "-" ] && cmd="${cmd} -t ${arg2}" [ "$arg2" != "-" ] && cmd="$cmd -t $arg2"
[ "${arg3}" != "-" ] && cmd="${cmd} -e ${arg3}" [ "$arg3" != "-" ] && cmd="$cmd -e $arg3"
cmd="${cmd} ${arg1}" cmd="$cmd $arg1"
eval "${cmd}" eval "$cmd"
;; ;;
keyboard) keyboard)
cmd=${wscfg} cmd=$wscfg
case "${arg1}" in case "$arg1" in
-|auto) -|auto)
cmd="${cmd} -k" cmd="$cmd -k"
;; ;;
*) *)
cmd="${cmd} -k ${arg1}" cmd="$cmd -k $arg1"
;; ;;
esac esac
${cmd} $cmd
;; ;;
encoding) encoding)
eval ${wsctl} -w "\"encoding=${arg1}\"" eval $wsctl -w "\"encoding=$arg1\""
;; ;;
mapfile) mapfile)
local entry= local entry=
while read entry; do while read entry; do
case "${entry}" in case "$entry" in
\#*|"") \#*|"")
continue continue
;; ;;
*) *)
cmd="${wsctl} -w \"map+=${entry}\"" cmd="$wsctl -w \"map+=$entry\""
eval "${cmd} >/dev/null" eval "$cmd >/dev/null"
;; ;;
esac esac
done < "${arg1}" done < "$arg1"
;; ;;
mux) mux)
eval "${wscfg} -m ${arg1}" eval "$wscfg -m $arg1"
;; ;;
setvar) setvar)
case "${arg1}" in case "$arg1" in
keyboard) keyboard)
cmd="${wsctl} -kw ${arg2}" cmd="$wsctl -kw $arg2"
;; ;;
display) display)
cmd="${wsctl} -dw ${arg2}" cmd="$wsctl -dw $arg2"
;; ;;
mouse) mouse)
cmd="${wsctl} -mw ${arg2}" cmd="$wsctl -mw $arg2"
;; ;;
*) *)
cmd="${wsctl} -w ${arg1}" cmd="$wsctl -w $arg1"
;; ;;
esac esac
eval "${cmd}" eval "$cmd"
;; ;;
esac esac
done < "${config}" done < "$config"
} }

View File

@@ -1,4 +1,4 @@
.\" Copyright 2007-2008 Roy Marples .\" Copyright (c) 2007-2008 Roy Marples
.\" All rights reserved .\" All rights reserved
.\" .\"
.\" Redistribution and use in source and binary forms, with or without .\" Redistribution and use in source and binary forms, with or without
@@ -202,4 +202,4 @@ Rinse and repeat for the other verbose functions.
.Sh SEE ALSO .Sh SEE ALSO
.Xr printf 3 , .Xr printf 3 ,
.Sh AUTHORS .Sh AUTHORS
.An "Roy Marples" Aq roy@marples.name .An Roy Marples <roy@marples.name>

View File

@@ -1,4 +1,4 @@
.\" Copyright 2008 Roy Marples .\" Copyright (c) 2008-2009 Roy Marples
.\" All rights reserved .\" All rights reserved
.\" .\"
.\" Redistribution and use in source and binary forms, with or without .\" Redistribution and use in source and binary forms, with or without
@@ -22,7 +22,7 @@
.\" OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF .\" OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
.\" SUCH DAMAGE. .\" SUCH DAMAGE.
.\" .\"
.Dd Mar 26, 2008 .Dd May 1, 2009
.Dt RC-SERVICE 8 SMM .Dt RC-SERVICE 8 SMM
.Os OpenRC .Os OpenRC
.Sh NAME .Sh NAME
@@ -30,20 +30,26 @@
.Nd locate and run an OpenRC service with the given arguments .Nd locate and run an OpenRC service with the given arguments
.Sh SYNOPSIS .Sh SYNOPSIS
.Nm .Nm
.Op Fl i , -ifexists
.Ar service cmd .Ar service cmd
.Op Ar ... .Op Ar ...
.Nm .Nm
.Fl l , -list
.Nm
.Fl e , -exists .Fl e , -exists
.Ar service .Ar service
.Nm .Nm
.Fl l , -list
.Nm
.Fl r , -resolve .Fl r , -resolve
.Ar service .Ar service
.Sh DESCRIPTION .Sh DESCRIPTION
Service scripts could be in different places on different systems. Service scripts could be in different places on different systems.
.Nm .Nm
locates the specified service and runs it with the given arguments. locates the specified service and runs it with the given arguments.
If
.Fl i , -ifexists
is given then
.Nm
returns 0 even if the service does not exist.
.Pp .Pp
If given the If given the
.Fl l , -list .Fl l , -list
@@ -51,14 +57,14 @@ argument then
.Nm .Nm
will list all available services. will list all available services.
.Pp .Pp
.Fl -e , exists .Fl e , -exists
return 0 if it can find return 0 if it can find
.Ar service , .Ar service ,
otherwise -1. otherwise -1.
.Fl -r , resolve .Fl r , -resolve
does the same and also prints the full path of the service to stdout. does the same and also prints the full path of the service to stdout.
.Sh SEE ALSO .Sh SEE ALSO
.Xr rc 8 , .Xr rc 8 ,
.Xr stdout 3 .Xr stdout 3
.Sh AUTHORS .Sh AUTHORS
.An "Roy Marples" Aq roy@marples.name .An Roy Marples <roy@marples.name>

View File

@@ -1,4 +1,4 @@
.\" Copyright 2007-2008 Roy Marples .\" Copyright (c) 2007-2009 Roy Marples
.\" All rights reserved .\" All rights reserved
.\" .\"
.\" Redistribution and use in source and binary forms, with or without .\" Redistribution and use in source and binary forms, with or without
@@ -22,7 +22,7 @@
.\" OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF .\" OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
.\" SUCH DAMAGE. .\" SUCH DAMAGE.
.\" .\"
.Dd Arp 9, 2008 .Dd April 24, 2008
.Dt RC-STATUS 8 SMM .Dt RC-STATUS 8 SMM
.Os OpenRC .Os OpenRC
.Sh NAME .Sh NAME
@@ -30,7 +30,7 @@
.Nd show status info about runlevels .Nd show status info about runlevels
.Sh SYNOPSIS .Sh SYNOPSIS
.Nm .Nm
.Op Fl alsuC .Op Fl aclsuC
.Op Ar runlevel .Op Ar runlevel
.Sh DESCRIPTION .Sh DESCRIPTION
.Nm .Nm
@@ -43,6 +43,8 @@ The options are as follows:
.Bl -tag -width ".Fl test , test string" .Bl -tag -width ".Fl test , test string"
.It Fl a , -all .It Fl a , -all
Show all runlevels and their services. Show all runlevels and their services.
.It Fl c , -crashed
List all services that have crashed.
.It Fl l , -list .It Fl l , -list
List all defined runlevels. List all defined runlevels.
.It fl r , -runlevel .It fl r , -runlevel
@@ -57,8 +59,11 @@ Disable color output.
Show information only for the named Show information only for the named
.Ar runlevel . .Ar runlevel .
.El .El
.Sh EXIT STATUS
.Nm
exits 0, except when checking for crashed services and it doesn't find any.
.Sh SEE ALSO .Sh SEE ALSO
.Xr rc 8 , .Xr rc 8 ,
.Xr rc-update 8 .Xr rc-update 8
.Sh AUTHORS .Sh AUTHORS
.An "Roy Marples" Aq roy@marples.name .An Roy Marples <roy@marples.name>

View File

@@ -1,4 +1,4 @@
.\" Copyright 2007-2008 Roy Marples .\" Copyright (c) 2007-2009 Roy Marples
.\" All rights reserved .\" All rights reserved
.\" .\"
.\" Redistribution and use in source and binary forms, with or without .\" Redistribution and use in source and binary forms, with or without
@@ -22,7 +22,7 @@
.\" OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF .\" OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
.\" SUCH DAMAGE. .\" SUCH DAMAGE.
.\" .\"
.Dd Jan 15, 2008 .Dd May 2, 2009
.Dt RC-UPDATE 8 SMM .Dt RC-UPDATE 8 SMM
.Os OpenRC .Os OpenRC
.Sh NAME .Sh NAME
@@ -30,14 +30,17 @@
.Nd add and remove services to and from a runlevel .Nd add and remove services to and from a runlevel
.Sh SYNOPSIS .Sh SYNOPSIS
.Nm .Nm
.Op Fl s , -stack
.Ar add .Ar add
.Ar service .Ar service
.Op Ar runlevel ... .Op Ar runlevel ...
.Nm .Nm
.Op Fl s , -stack
.Ar delete .Ar delete
.Ar service .Ar service
.Op Ar runlevel ... .Op Ar runlevel ...
.Nm .Nm
.Op Fl u , -update
.Op Fl v , -verbose .Op Fl v , -verbose
.Ar show .Ar show
.Op Ar runlevel ... .Op Ar runlevel ...
@@ -50,10 +53,11 @@ All services must reside in the
.Pa /etc/init.d .Pa /etc/init.d
or or
.Pa /usr/local/etc/init.d .Pa /usr/local/etc/init.d
directories. They must also conform to the OpenRC runscript standard. directories.
They must also conform to the OpenRC runscript standard.
.Pp .Pp
.Bl -tag -width "Fl a , -delete service" .Bl -tag -width "Fl a , -delete service"
.It Fl a , -add Ar service .It Ar add Ar service
Add the Add the
.Ar service .Ar service
to the to the
@@ -72,9 +76,18 @@ Show all enabled services and the runlevels they belong to. If you specify
runlevels to show, then only those will be included in the output. runlevels to show, then only those will be included in the output.
.It Fl v , -verbose .It Fl v , -verbose
Show all services. Show all services.
.It Fl u , -update
Forces an update of the dependency tree cache.
This may be needed in the event of clock skew (a file in /etc is newer than the
system clock).
.El .El
.Pp
If the
.Fl s , -stack
option is given then we either add or remove the runlevel from the runlevel.
This allows inheritance of runlevels.
.Sh SEE ALSO .Sh SEE ALSO
.Xr rc 8 , .Xr rc 8 ,
.Xr rc-status 8 .Xr rc-status 8
.Sh AUTHORS .Sh AUTHORS
.An "Roy Marples" Aq roy@marples.name .An Roy Marples <roy@marples.name>

View File

@@ -1,4 +1,4 @@
.\" Copyright 2007-2008 Roy Marples .\" Copyright (c) 2007-2009 Roy Marples
.\" All rights reserved .\" All rights reserved
.\" .\"
.\" Redistribution and use in source and binary forms, with or without .\" Redistribution and use in source and binary forms, with or without
@@ -22,7 +22,7 @@
.\" OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF .\" OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
.\" SUCH DAMAGE. .\" SUCH DAMAGE.
.\" .\"
.Dd Feb 22, 2008 .Dd May 2, 2009
.Dt RC 8 SMM .Dt RC 8 SMM
.Os OpenRC .Os OpenRC
.Sh NAME .Sh NAME
@@ -35,10 +35,11 @@
.Sh DESCRIPTION .Sh DESCRIPTION
.Nm .Nm
first stops any services that are not for the runlevel and then starts any first stops any services that are not for the runlevel and then starts any
services added by services in the runlevel and from stacked runlevels added by
.Nm rc-update .Nm rc-update
that are not currently started. If no runlevel is specified then we use the that are not currently started.
current runlevel the system is currently in. If no runlevel is specified then we use the current runlevel the system
is currently in.
.Pp .Pp
There are some special runlevels that you should be aware of: There are some special runlevels that you should be aware of:
.Bl -tag -width "shutdown" .Bl -tag -width "shutdown"
@@ -60,18 +61,27 @@ sysinit always runs when the host first starts should not be run again.
Generally the only services you should add to the boot runlevel are those Generally the only services you should add to the boot runlevel are those
which deal with the mounting of filesystems, set the initial state of attached which deal with the mounting of filesystems, set the initial state of attached
peripherals and logging. peripherals and logging.
Coldplugged services are added to the boot runlevel by the system. Hotplugged services are added to the boot runlevel by the system.
All services in the boot runlevel are automatically included in all other All services in the boot and sysinit runlevels are automatically included
runlevels except for those listed here. in all other runlevels except for those listed here.
.It Ar single .It Ar single
Stops all services and enters single user mode. Stops all services except for those in the sysinit runlevel.
.It Ar reboot .It Ar reboot
Changes to the single runlevel and then reboots the host. Changes to the shutdown runlevel and then reboots the host.
.It Ar shutdown .It Ar shutdown
Changes to the single runlevel and then halts the host. Changes to the shutdown runlevel and then halts the host.
.El .El
.Pp
You should not call any of these runlevels yourself.
Instead you should use
.Xr init 8
and
.Xr shutdown 8
and let them call these special runlevels.
.Sh SEE ALSO .Sh SEE ALSO
.Xr rc-status 8 , .Xr rc-status 8 ,
.Xr rc-update 8 .Xr rc-update 8 ,
.Xr init 8 ,
.Xr shutdown 8
.Sh AUTHORS .Sh AUTHORS
.An "Roy Marples" Aq roy@marples.name .An Roy Marples Aq roy@marples.name

View File

@@ -1,4 +1,4 @@
.\" Copyright 2007-2008 Roy Marples .\" Copyright (c) 2007-2008 Roy Marples
.\" All rights reserved .\" All rights reserved
.\" .\"
.\" Redistribution and use in source and binary forms, with or without .\" Redistribution and use in source and binary forms, with or without
@@ -70,4 +70,4 @@ is set to
.Xr rc_stringlist_free 3 , .Xr rc_stringlist_free 3 ,
.Xr sh 1 .Xr sh 1
.Sh AUTHORS .Sh AUTHORS
.An "Roy Marples" Aq roy@marples.name .An Roy Marples <roy@marples.name>

Some files were not shown because too many files have changed in this diff Show More