Date: Mon, 26 Feb 2007 13:58:33 +0100 (CET) From: Jeremie Le Hen <jeremie@le-hen.org> To: FreeBSD-gnats-submit@FreeBSD.org Subject: conf/109562: [rc.d] [patch] Make rc.d/devfs usable from command-line Message-ID: <20070226125833.787CC405B@obiwan.tataz.chchile.org> Resent-Message-ID: <200702261320.l1QDK7LF016385@freefall.freebsd.org>
next in thread | raw e-mail | index | archive | help
>Number: 109562 >Category: conf >Synopsis: [rc.d] [patch] Make rc.d/devfs usable from command-line >Confidential: no >Severity: non-critical >Priority: low >Responsible: freebsd-bugs >State: open >Quarter: >Keywords: >Date-Required: >Class: change-request >Submitter-Id: current-users >Arrival-Date: Mon Feb 26 13:20:06 GMT 2007 >Closed-Date: >Last-Modified: >Originator: Jeremie Le Hen <jeremie@le-hen.org> >Release: FreeBSD 7.0-CURRENT i386 >Organization: >Environment: FreeBSD jarjarbinks 7.0-CURRENT FreeBSD 7.0-CURRENT #23: Sun Feb 25 20:01:52 UTC 2007 root@jarjarbinks/usr/obj/usr/src/sys/JARJARBINKS i386 >Description: The attached patch allows to provide arguments to rc.d/devfs with the same syntax as $devfs_set_rulesets. This is then easier to mount manually devfs inside a directory and apply some predefined rulesets on it. Before this patch you had to manually apply rules to the devfs mount point, provided pre-configured rulesets had been loaded into the kernel (with rc.subr's devfs_init_rulesets()). Example: % mount_devfs none /space/chroot/dev % /etc/rc.d/devfs start /space/chroot/dev=devfsrules_jail >How-To-Repeat: >Fix: --- rc.d_devfs.patch begins here --- Index: devfs =================================================================== RCS file: /home/ncvs/src/etc/rc.d/devfs,v retrieving revision 1.12 diff -u -p -r1.12 devfs --- devfs 21 Jan 2006 14:31:45 -0000 1.12 +++ devfs 22 Feb 2007 08:04:16 -0000 @@ -14,8 +14,27 @@ name="devfs" start_cmd='devfs_start' stop_cmd=':' +set_rulesets() +{ + local _dir_set + local _dir + local _set + for _dir_set in "$@"; do + _dir=${_dir_set%=*} + _set=${_dir_set#*=} + devfs_set_ruleset $_set $_dir + devfs_apply_ruleset $_set $_dir + done +} + devfs_start() { + if [ $# -gt 0 ]; then + devfs_init_rulesets + set_rulesets "$@" + return + fi + if [ -n "$devfs_system_ruleset" -o -n "$devfs_set_rulesets" ]; then devfs_init_rulesets if [ -n "$devfs_system_ruleset" ]; then @@ -23,15 +42,7 @@ devfs_start() devfs_apply_ruleset $devfs_system_ruleset /dev fi if [ -n "$devfs_set_rulesets" ]; then - local _dir_set - local _dir - local _set - for _dir_set in $devfs_set_rulesets; do - _dir=${_dir_set%=*} - _set=${_dir_set#*=} - devfs_set_ruleset $_set $_dir - devfs_apply_ruleset $_set $_dir - done + set_rulesets "$devfs_set_rulesets" fi fi read_devfs_conf @@ -67,4 +78,4 @@ read_devfs_conf() } load_rc_config $name -run_rc_command "$1" +run_rc_command "$@" --- rc.d_devfs.patch ends here --- >Release-Note: >Audit-Trail: >Unformatted:
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?20070226125833.787CC405B>