From owner-freebsd-hackers@FreeBSD.ORG Thu Feb 23 22:27:09 2006 Return-Path: X-Original-To: freebsd-hackers@freebsd.org Delivered-To: freebsd-hackers@freebsd.org Received: from mx1.FreeBSD.org (mx1.freebsd.org [216.136.204.125]) by hub.freebsd.org (Postfix) with ESMTP id 4663A16A420 for ; Thu, 23 Feb 2006 22:27:09 +0000 (GMT) (envelope-from maksim.yevmenkin@savvis.net) Received: from ismybrain.com (ismybrain.com [64.246.42.25]) by mx1.FreeBSD.org (Postfix) with ESMTP id E373943D45 for ; Thu, 23 Feb 2006 22:27:08 +0000 (GMT) (envelope-from maksim.yevmenkin@savvis.net) Received: from [10.254.186.111] (localhost.localdomain [127.0.0.1]) by ismybrain.com (8.11.6/8.11.6) with ESMTP id k1NMR6M23996; Thu, 23 Feb 2006 17:27:07 -0500 Message-ID: <43FE36B8.7070601@savvis.net> Date: Thu, 23 Feb 2006 14:27:04 -0800 From: Maksim Yevmenkin User-Agent: Mozilla Thunderbird 1.0.2 (X11/20050404) X-Accept-Language: en-us, en MIME-Version: 1.0 To: Norbert Koch References: <000001c6379d$63036d80$4801a8c0@ws-ew-3.demig.intra> <43FE2C4F.6030909@savvis.net> In-Reply-To: <43FE2C4F.6030909@savvis.net> Content-Type: text/plain; charset=KOI8-R; format=flowed Content-Transfer-Encoding: 7bit Cc: freebsd-hackers@freebsd.org Subject: Re: does ukbd delay break scan codes? X-BeenThere: freebsd-hackers@freebsd.org X-Mailman-Version: 2.1.5 Precedence: list List-Id: Technical Discussions relating to FreeBSD List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Thu, 23 Feb 2006 22:27:09 -0000 Maksim Yevmenkin wrote: > Norbert, > > [...] > >> I still do not know where it comes from, >> but what I found so far is, >> that the usb keyboard (or ukbd driver) >> seems to delay the break codes for >> keys with prefix E0 (which may or may not >> have anything to do with my problem). >> >> E.g., I press Keypad-Enter and see >> E0 1C E0 >> ^prefix >> ^make code >> ^prefix >> and nothing else. As soon as I press >> e.g. Enter (any key works) I see >> 9C 1C 9C >> ^break code >> ^make code >> ^delayed break code. >> >> Does anyone have an idea where that >> may come from? > > i see this to on week old -current. if ukbd(4) delays break code then > this might explain state synchronization problem with kbdmux(4). i guess > we should start digging into ukbd(4), starting with ukbd_interrupt() to > see why this happening. just by looking at the code, i think, that ukbd_check_char() should also return "true" if ks_buffered_char[0] != 0, i.e. try the following untested patch --- ukbd.c.orig Thu Feb 23 14:24:21 2006 +++ ukbd.c Thu Feb 23 14:25:47 2006 @@ -1145,9 +1145,7 @@ state = (ukbd_state_t *)kbd->kb_data; if (!(state->ks_flags & COMPOSE) && (state->ks_composed_char > 0)) return TRUE; - if (state->ks_inputs > 0) - return TRUE; - return FALSE; + return ukbd_check(kbd); } /* some useful control functions */ === i will try this as soon as my buildworld/buildkernel completes. thanks, max