On Fri, Jan 07, 2011 at 11:43:13AM -0800, Dmitry Torokhov wrote: > On Fri, Jan 07, 2011 at 11:32:33AM -0800, Arjan van de Ven wrote: > > On 1/7/2011 11:29 AM, Dmitry Torokhov wrote: > > >On Fri, Jan 07, 2011 at 10:24:34AM -0800, Kristen Carlson Accardi wrote: > > >>On Thu, 6 Jan 2011 22:04:56 -0800 > > >>Dmitry Torokhov<dmitry.torokhov@xxxxxxxxx> wrote: > > >> > > >>>On Thu, Jan 06, 2011 at 02:24:48PM -0800, Kristen Carlson Accardi wrote: > > >>>>If the handler that injected an event is the same, > > >>>>just skip the filter, but allow the handler->event() > > >>>>routine to be called. This allows evdev to be able to > > >>>>be used to loopback events. > > >>>Why is it needed? Could you please give some examples? > > >>> > > >>>Thanks. > > >>> > > >>We have a customer who has a touchscreen device which sends > > >>a bitmap into a gesture engine, which then interprets that > > >>result and feeds it back into the kernel through a virtual > > >>input driver that X is listening to. > > >That really should be done though uinput. > > > > quite possible. > > > > but the application already exists, and works just fine in 2.6.35... > > causing this to be classified as a kernel ABI regression ;-( > > > > Hmm... I'd probably call it "relying on implementation details not > spelled out anywhere". > > Anyway, let me ponder this one a bit... > OK, I think if we apply the patch below and then completely revert 5fdbe44d033d059cc56c2803e6b4dbd8cb4e5e39 we'll get the behavior we want. Jason, could you please try this and see if SysRq still works for you? Thanks! -- Dmitry Input: sysrq - rework re-inject logic From: Dmitry Torokhov <dmitry.torokhov@xxxxxxxxx> Internally 'disable' the filter when re-injecting Alt-SysRq instead of relying on input core to suppress delivery of injected events to the originating handler. This allows to revert commit 5fdbe44d033d059cc56c2803e6b4dbd8cb4e5e39 which causes problems with existing userspace programs trying to loopback the events via evdev. Reported-by: Kristen Carlson Accardi <kristen@xxxxxxxxxxxxxxx> Signed-off-by: Dmitry Torokhov <dtor@xxxxxxx> --- drivers/tty/sysrq.c | 17 ++++++++++++++++- 1 files changed, 16 insertions(+), 1 deletions(-) diff --git a/drivers/tty/sysrq.c b/drivers/tty/sysrq.c index c556ed9..ef3a983 100644 --- a/drivers/tty/sysrq.c +++ b/drivers/tty/sysrq.c @@ -571,6 +571,7 @@ struct sysrq_state { unsigned int alt_use; bool active; bool need_reinject; + bool reinjecting; }; static void sysrq_reinject_alt_sysrq(struct work_struct *work) @@ -581,6 +582,10 @@ static void sysrq_reinject_alt_sysrq(struct work_struct *work) unsigned int alt_code = sysrq->alt_use; if (sysrq->need_reinject) { + /* we do not want the assignment to be reordered */ + sysrq->reinjecting = true; + mb(); + /* Simulate press and release of Alt + SysRq */ input_inject_event(handle, EV_KEY, alt_code, 1); input_inject_event(handle, EV_KEY, KEY_SYSRQ, 1); @@ -589,6 +594,9 @@ static void sysrq_reinject_alt_sysrq(struct work_struct *work) input_inject_event(handle, EV_KEY, KEY_SYSRQ, 0); input_inject_event(handle, EV_KEY, alt_code, 0); input_inject_event(handle, EV_SYN, SYN_REPORT, 1); + + mb(); + sysrq->reinjecting = false; } } @@ -599,6 +607,13 @@ static bool sysrq_filter(struct input_handle *handle, bool was_active = sysrq->active; bool suppress; + /* + * Do not filter anything if we are in the process of re-injecting + * Alt+SysRq combination. + */ + if (sysrq->reinjecting) + return false; + switch (type) { case EV_SYN: @@ -629,7 +644,7 @@ static bool sysrq_filter(struct input_handle *handle, sysrq->alt_use = sysrq->alt; /* * If nothing else will be pressed we'll need - * to * re-inject Alt-SysRq keysroke. + * to re-inject Alt-SysRq keysroke. */ sysrq->need_reinject = true; } -- To unsubscribe from this list: send the line "unsubscribe linux-input" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html