Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1753761AbZGVQob (ORCPT ); Wed, 22 Jul 2009 12:44:31 -0400 Received: (majordomo@vger.kernel.org) by vger.kernel.org id S1753713AbZGVQoa (ORCPT ); Wed, 22 Jul 2009 12:44:30 -0400 Received: from www.tglx.de ([62.245.132.106]:40866 "EHLO www.tglx.de" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751865AbZGVQo3 (ORCPT ); Wed, 22 Jul 2009 12:44:29 -0400 Date: Wed, 22 Jul 2009 18:43:32 +0200 (CEST) From: Thomas Gleixner To: David Brownell cc: Dmitry Torokhov , Mark Brown , Trilok Soni , Pavel Machek , Arve Hj?nnev?g , kernel list , Brian Swetland , linux-input@vger.kernel.org, Andrew Morton , linux-i2c@vger.kernel.org, Joonyoung Shim , m.szyprowski@samsung.com, t.fujak@samsung.com, kyungmin.park@samsung.com, Peter Zijlstra Subject: Re: Threaded interrupts for synaptic touchscreen in HTC dream In-Reply-To: <200907220939.33399.david-b@pacbell.net> Message-ID: References: <20090714100634.GA4054@elf.ucw.cz> <20090721160436.GD4352@dtor-d630.eng.vmware.com> <200907220939.33399.david-b@pacbell.net> User-Agent: Alpine 2.00 (LFD 1167 2008-08-23) MIME-Version: 1.0 Content-Type: TEXT/PLAIN; charset=US-ASCII Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 1353 Lines: 34 On Wed, 22 Jul 2009, David Brownell wrote: > On Tuesday 21 July 2009, Thomas Gleixner wrote: > > Interesting. The model is then to switch over to __set_irq_handler(), > or maybe set_irq_chip_and_handler(), to replace the toplevel dispatch > code for will-be-threaded IRQs which happen to be hooked up to inputs > that don't sense edges. (Agree, that seems like a goof. But hardware > designers sometimes have any choices there.) > > The normal model is that boards don't get involved with that level of > logic ... all IRQs get set up once on generic code, and flow handlers > don't change. Or if they do change, it's done when changing the IRQ's > trigger mode from edge to level, or vice versa. > > Can that be cleaned up a bit, so that the handle_level_oneshot_irq() > and unmask_oneshot_irq() stuff kicks in automatically when needed, > instead of requiring board-specific (or driver-specific) code to get > that stuff right? The only way I can see is to set a special trigger flag like IRQF_TRIGGER_RISING & Co. i.e. IRQF_TRIGGER_LEVEL | IRQF_TRIGGER_ONESHOT That might work. Thanks, tglx -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/