[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <alpine.DEB.2.10.1503221128480.2475@hadrien>
Date: Sun, 22 Mar 2015 11:29:13 +0100 (CET)
From: Julia Lawall <julia.lawall@...6.fr>
To: Valentin Rothberg <valentinrothberg@...il.com>
cc: Peter Senna Tschudin <peter.senna@...il.com>,
Julia Lawall <Julia.Lawall@...6.fr>,
Gilles Muller <Gilles.Muller@...6.fr>,
Nicolas Palix <nicolas.palix@...g.fr>,
Michal Marek <mmarek@...e.cz>, cocci@...teme.lip6.fr,
linux-kernel@...r.kernel.org
Subject: Re: [PATCH] irqf_oneshot.cocci: add check of
devm_request_threaded_irq()
Acked-by: Julia Lawall <julia.lawall@...6.fr>
Good fix, thanks!
On Wed, 4 Mar 2015, Valentin Rothberg wrote:
> Since commit 1c6c69525b40eb76de8adf039409722015927dc3 ("genirq: Reject
> bogus threaded irq requests") threaded IRQs without a primary handler
> need to be requested with IRQF_ONESHOT, otherwise the request will fail.
>
> Until now, this coccinelle script only checked request_threaded_irq().
> However, the counterpart devm function (see kernel/irq/devres.c) is also
> affected by the missing flag which can be detected with this patch.
>
> Signed-off-by: Valentin Rothberg <valentinrothberg@...il.com>
> Signed-off-by: Peter Senna Tschudin <peter.senna@...il.com>
> ---
> scripts/coccinelle/misc/irqf_oneshot.cocci | 24 ++++++++++++++++++++++++
> 1 file changed, 24 insertions(+)
>
> diff --git a/scripts/coccinelle/misc/irqf_oneshot.cocci b/scripts/coccinelle/misc/irqf_oneshot.cocci
> index 6cfde94..a24a754 100644
> --- a/scripts/coccinelle/misc/irqf_oneshot.cocci
> +++ b/scripts/coccinelle/misc/irqf_oneshot.cocci
> @@ -12,11 +12,13 @@ virtual org
> virtual report
>
> @r1@
> +expression dev;
> expression irq;
> expression thread_fn;
> expression flags;
> position p;
> @@
> +(
> request_threaded_irq@p(irq, NULL, thread_fn,
> (
> flags | IRQF_ONESHOT
> @@ -24,13 +26,24 @@ flags | IRQF_ONESHOT
> IRQF_ONESHOT
> )
> , ...)
> +|
> +devm_request_threaded_irq@p(dev, irq, NULL, thread_fn,
> +(
> +flags | IRQF_ONESHOT
> +|
> +IRQF_ONESHOT
> +)
> +, ...)
> +)
>
> @depends on patch@
> +expression dev;
> expression irq;
> expression thread_fn;
> expression flags;
> position p != r1.p;
> @@
> +(
> request_threaded_irq@p(irq, NULL, thread_fn,
> (
> -0
> @@ -40,6 +53,17 @@ request_threaded_irq@p(irq, NULL, thread_fn,
> +flags | IRQF_ONESHOT
> )
> , ...)
> +|
> +devm_request_threaded_irq@p(dev, irq, NULL, thread_fn,
> +(
> +-0
> ++IRQF_ONESHOT
> +|
> +-flags
> ++flags | IRQF_ONESHOT
> +)
> +, ...)
> +)
>
> @depends on context@
> position p != r1.p;
> --
> 1.9.1
>
>
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
Powered by blists - more mailing lists