From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1753416AbcKRLXF (ORCPT ); Fri, 18 Nov 2016 06:23:05 -0500 Received: from userp1040.oracle.com ([156.151.31.81]:26702 "EHLO userp1040.oracle.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1753188AbcKRLXC (ORCPT ); Fri, 18 Nov 2016 06:23:02 -0500 Subject: Re: [PATCH v3 1/3] Coccinelle: misc: Improve the matching of rules To: Julia Lawall References: <53a9e7344bd2fe5756c245ab0e1646976c1e0fbd.1477293469.git.vaishali.thakkar@oracle.com> Cc: mmarek@suse.com, Gilles Muller , nicolas.palix@imag.fr, cocci@systeme.lip6.fr, linux-kernel@vger.kernel.org, lars@metafoo.de From: Vaishali Thakkar Message-ID: <582EE465.4010408@oracle.com> Date: Fri, 18 Nov 2016 16:52:13 +0530 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:38.0) Gecko/20100101 Thunderbird/38.5.1 MIME-Version: 1.0 In-Reply-To: Content-Type: text/plain; charset=windows-1252 Content-Transfer-Encoding: 7bit X-Source-IP: aserv0022.oracle.com [141.146.126.234] Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Saturday 12 November 2016 11:36 PM, Julia Lawall wrote: > > > On Mon, 24 Oct 2016, Vaishali Thakkar wrote: > >> Currently because of the left associativity of the operators, pattern >> IRQF_ONESHOT | flags does not match with the pattern when we have more >> than one flag after the disjunction. This eventually results in giving >> false positives by the script. This patch eliminates these FPs by >> improving the rule. >> >> Signed-off-by: Vaishali Thakkar >> --- >> Changes since v2: >> - No change in this patch >> Changes since v1: >> - Splitted patch in the patchset >> --- >> scripts/coccinelle/misc/irqf_oneshot.cocci | 30 ++++++++++++++++++++++++------ >> 1 file changed, 24 insertions(+), 6 deletions(-) >> >> diff --git a/scripts/coccinelle/misc/irqf_oneshot.cocci b/scripts/coccinelle/misc/irqf_oneshot.cocci >> index b421150..a8537fb 100644 >> --- a/scripts/coccinelle/misc/irqf_oneshot.cocci >> +++ b/scripts/coccinelle/misc/irqf_oneshot.cocci >> @@ -18,13 +18,12 @@ virtual report >> expression dev; >> expression irq; >> expression thread_fn; >> -expression flags; >> position p; >> @@ >> ( >> request_threaded_irq@p(irq, NULL, thread_fn, >> ( >> -flags | IRQF_ONESHOT >> +IRQF_ONESHOT | ... >> | >> IRQF_ONESHOT >> ) >> @@ -32,20 +31,39 @@ IRQF_ONESHOT >> | >> devm_request_threaded_irq@p(dev, irq, NULL, thread_fn, >> ( >> -flags | IRQF_ONESHOT >> +IRQF_ONESHOT | ... >> | >> IRQF_ONESHOT >> ) >> , ...) >> ) >> >> -@depends on patch@ >> +@r2@ >> expression dev; >> expression irq; >> expression thread_fn; >> expression flags; >> +expression ret; >> position p != r1.p; >> @@ >> +flags = IRQF_ONESHOT | ...; >> +( >> +ret = request_threaded_irq@p(irq, NULL, thread_fn, flags, ...); >> +| >> +ret = devm_request_threaded_irq@p(dev, irq, NULL, thread_fn, flags, ...); >> +| >> +return request_threaded_irq@p(irq, NULL, thread_fn, flags, ...); >> +| >> +return devm_request_threaded_irq@p(dev, irq, NULL, thread_fn, flags, ...); >> +) > > This rule needs some improvement. > > flags = IRQF_ONESHOT | ...; > > should be replaced by: > > ( > flags = IRQF_ONESHOT | ... > | > flags |= IRQF_ONESHOT | ... > ) > ... when != flags = e > > where e should be a new expression metavariable. This effects a number of > changes. 1) Dropping the ; after the assignment allows an isomorphism to > trigger that allows it to match a variable declaration as well, 2) > IRQF_ONESHOT can be added after the original initialization by a |=, 3) > there can be some instructions between the initialization of flags and the > use. Ok, this makes sense. > Afterwards, the big disjunction with the irq calls is too specific. > In particular, these calls can also occur in an if test. The disjunction > should be replaced by the following: > > ( > request_threaded_irq@p(irq, NULL, thread_fn, flags, ...) > | > devm_request_threaded_irq@p(dev, irq, NULL, thread_fn, flags, ...) > ) Ok, primary motivation with having specified pattern was to have less running time. But as discussed, it doesn't make much difference. So, going with the more general way sounds good. Thanks for the suggestions. I'll send the the revised version with these changes. > julia > > >> + >> +@depends on patch@ >> +expression dev; >> +expression irq; >> +expression thread_fn; >> +expression flags; >> +position p != {r1.p,r2.p}; >> +@@ >> ( >> request_threaded_irq@p(irq, NULL, thread_fn, >> ( >> @@ -69,13 +87,13 @@ devm_request_threaded_irq@p(dev, irq, NULL, thread_fn, >> ) >> >> @depends on context@ >> -position p != r1.p; >> +position p != {r1.p,r2.p}; >> @@ >> *request_threaded_irq@p(...) >> >> @match depends on report || org@ >> expression irq; >> -position p != r1.p; >> +position p != {r1.p,r2.p}; >> @@ >> request_threaded_irq@p(irq, NULL, ...) >> >> -- >> 2.1.4 >> >> -- Vaishali