Re: [PATCH 1/3] genirq: Get rid of unneeded force parameter inirq_finalize_oneshot()

From: Alexander Gordeev
Date: Thu Mar 22 2012 - 07:06:28 EST


On Thu, Mar 22, 2012 at 11:32:26AM +0100, Thomas Gleixner wrote:
> Wrong.
>
> CPU 0 CPU 1
>
> do_exit()
> check(PF_EXITING)
> set_bit(IRQTF_RUNTHREAD)
> ...
> set(PF_EXITING)
> exit_irq_thread()

Thomas,

Did not you pick this code with 7140ea1 commit?

@@ -845,6 +842,13 @@ void exit_irq_thread(void)

desc = irq_to_desc(action->irq);

+ /*
+ * If IRQTF_RUNTHREAD is set, we need to decrement
+ * desc->threads_active and wake possible waiters.
+ */
+ if (test_and_clear_bit(IRQTF_RUNTHREAD, &action->thread_flags))
+ wake_threads_waitq(desc);
+
/* Prevent a stale desc->threads_oneshot */
irq_finalize_oneshot(desc, action, true);
}

>
> if (test_bit(IRQTF_RUNTHREAD))
> goto out;
>
> -> FAIL
>
> Thanks,
>
> tglx

--
Regards,
Alexander Gordeev
agordeev@xxxxxxxxxx
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/