From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1761217AbXLLTut (ORCPT ); Wed, 12 Dec 2007 14:50:49 -0500 Received: (majordomo@vger.kernel.org) by vger.kernel.org id S1761041AbXLLTuf (ORCPT ); Wed, 12 Dec 2007 14:50:35 -0500 Received: from ms-smtp-02.nyroc.rr.com ([24.24.2.56]:39208 "EHLO ms-smtp-02.nyroc.rr.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1761013AbXLLTue (ORCPT ); Wed, 12 Dec 2007 14:50:34 -0500 Date: Wed, 12 Dec 2007 14:50:02 -0500 (EST) From: Steven Rostedt X-X-Sender: rostedt@gandalf.stny.rr.com To: LKML , linux-rt-users cc: Ingo Molnar , Thomas Gleixner Subject: [PATCH] handle IRQ_PENDING for simple irq handler Message-ID: 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 With the IO-APIC pcix hack (level=>edge masking), we can receive interrupts while masked. But these interrupts might be missed. Also, normal "simple" interrupts might be missed too on leaving of thread handler. Signed-off-by: Steven Rostedt Index: linux-2.6.21-rt-hack/kernel/irq/manage.c =================================================================== --- linux-2.6.21-rt-hack.orig/kernel/irq/manage.c +++ linux-2.6.21-rt-hack/kernel/irq/manage.c @@ -628,14 +628,17 @@ static void thread_simple_irq(irq_desc_t unsigned int irq = desc - irq_desc; irqreturn_t action_ret; - if (action && !desc->depth) { + do { + if (!action || desc->depth) + break; + desc->status &= ~IRQ_PENDING; spin_unlock(&desc->lock); action_ret = handle_IRQ_event(irq, action); cond_resched_hardirq_context(); spin_lock_irq(&desc->lock); if (!noirqdebug) note_interrupt(irq, desc, action_ret); - } + } while (desc->status & IRQ_PENDING); desc->status &= ~IRQ_INPROGRESS; }