Date: Thu, 02 Mar 2006 10:28:37 -0800 From: Maksim Yevmenkin <maksim.yevmenkin@savvis.net> To: Brooks Davis <brooks@one-eyed-alien.net> Cc: freebsd-current@freebsd.org Subject: Re: [PATCH] kbdmux(4) and devd(8) Message-ID: <44073955.6050202@savvis.net> In-Reply-To: <20060302180612.GB12226@odin.ac.hmc.edu> References: <44062DE7.8090508@savvis.net> <20060302180612.GB12226@odin.ac.hmc.edu>
next in thread | previous in thread | raw e-mail | index | archive | help
Brooks Davis wrote:
> On Wed, Mar 01, 2006 at 03:27:35PM -0800, Maksim Yevmenkin wrote:
>
>>Dear Hackers,
>>
>>any comments/objections/etc. to the following devd.conf patch? the idea
>>is to prevent devd(8) from trying to switch keyboards when kbdmux(4) is
>>the default keyboard.
>>
>>the 'attach' action will fail anyway, however, the 'detach' action may
>>succeed (if /dev/kbd0 is not is the kbdmux(4)).
>
>
> This seems OK if a bit ugly to me. Another idea might be to add some
> new methods to /etc/rc.d/syscons (or create a new keyboard management
> script) to hide the logic there.
do you mean something like
--- syscons.orig Thu Jan 5 15:36:02 2006
+++ syscons Thu Mar 2 10:25:49 2006
@@ -34,8 +34,10 @@
. /etc/rc.subr
name="syscons"
+extra_commands="setkeyboard"
start_precmd="syscons_precmd"
start_cmd="syscons_start"
+setkeyboard_cmd="syscons_setkeyboard"
# stdin must be redirected because it might be for a serial console
#
@@ -206,5 +208,19 @@
echo '.'
}
+syscons_setkeyboard()
+{
+ kbd=$1
+
+ if [ -z "${kbd}" ]; then
+ return 1
+ fi
+
+ kbdcontrol -i < ${kbddev} | grep kbdmux > /dev/null 2>&1
+ if [ $? != 0 ]; then
+ kbdcontrol -k /dev/${kbd} < ${kbddev} > /dev/null 2>&1
+ fi
+}
+
load_rc_config $name
-run_rc_command "$1"
+run_rc_command $*
thanks,
max
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?44073955.6050202>
