Skip site navigation (1)Skip section navigation (2)
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>