From mboxrd@z Thu Jan 1 00:00:00 1970 From: d.granat@samsung.com (Daniel Granat) Date: Fri, 27 Mar 2015 11:32:16 +0100 Subject: [Cocci] [PATCH] Add coccinelle script that makes sure that tables are NULL terminated In-Reply-To: <1425043313-15844-1-git-send-email-d.granat@samsung.com> References: <1425043313-15844-1-git-send-email-d.granat@samsung.com> Message-ID: <551531B0.4090108@samsung.com> To: cocci@systeme.lip6.fr List-Id: cocci@systeme.lip6.fr Hi, Could you please review my patch I sent last month? It checks if tables in kernel are NULL terminated. Script matches only names specified in source code by postfix='*_device_id$' and by list of prefixes which is now prefix_list = ['platform', 'of', 'i2c']. I think it could by useful in kernel sources. On 02/27/2015 02:21 PM, Daniel Granat wrote: >
 > Signed-off-by: Daniel Granat <d.granat at samsung.com>
 > ---
 > scripts/coccinelle/misc/device_id_tables.cocci | 95 
++++++++++++++++++++++++++
 > 1 file changed, 95 insertions(+)
 > create mode 100644 scripts/coccinelle/misc/device_id_tables.cocci
 >
 > diff --git a/scripts/coccinelle/misc/device_id_tables.cocci 
b/scripts/coccinelle/misc/device_id_tables.cocci
 > new file mode 100644
 > index 0000000..5968984
 > --- /dev/null
 > +++ b/scripts/coccinelle/misc/device_id_tables.cocci
 > @@ -0,0 +1,95 @@
 > +/// Make sure '*_device_id$' tables are NULL terminated
 > +//
 > +// Keywords: device_id
 > +// Confidence: Medium
 > +// Options: --include-headers
 > +
 > +virtual org
 > +virtual report
 > +virtual patch
 > +
 > + at initialize:python@
 > +@@
 > +import re
 > +
 > +postfix = '_device_id$'
 > +prefix_list = ['platform', 'of', 'i2c']
 > +
 > + at r1 depends on patch || org || report@
 > +position p1;
 > +identifier var, arr;
 > +identifier struct_name;
 > +expression E;
 > +@@
 > +
 > +(
 > +struct struct_name arr[] = {
 > + ...,
 > + {
 > + .var = E,
 > + }
 > + @p1
 > +};
 > +|
 > +struct struct_name arr[] = {
 > + ...,
 > + { ..., var, ... },
 > + @p1
 > +};
 > +)
 > +
 > + at script:python depends on report@
 > +struct_name << r1.struct_name;
 > +p1 << r1.p1;
 > +arr << r1.arr;
 > +pattern;
 > +@@
 > +
 > +for i in prefix_list:
 > + pattern = str(i)+postfix
 > + if re.match(pattern, struct_name) != None:
 > + print "\nCOCCI: \"%s\" matchs required pattern \"%s\"" % 
(struct_name, pattern)
 > + msg = "\"%s\" is not NULL terminated at line %s" % (arr, p1[0].line)
 > + coccilib.report.print_report(p1[0],msg)
 > + break
 > +
 > + at script:python match depends on patch@
 > +struct_name << r1.struct_name;
 > +matched_name;
 > +pattern;
 > +@@
 > +
 > +coccinelle.matched_name = ''
 > +
 > +for i in prefix_list:
 > + pattern = str(i)+postfix
 > + if re.match(pattern, struct_name) != None:
 > + coccinelle.matched_name = struct_name
 > + break
 > +
 > + at r2 depends on patch@
 > +position r1.p1;
 > +identifier var, arr;
 > +identifier match.matched_name;
 > +expression E;
 > +@@
 > +
 > +(
 > +struct matched_name arr[] = {
 > + ...,
 > + {
 > + .var = E,
 > +- }
 > + @p1
 > ++ },
 > ++ {},
 > +};
 > +|
 > +struct matched_name arr[] = {
 > + ...,
 > + { ..., var, ... },
 > + @p1
 > ++ {},
 > +};
 > +)
 > +
 > 
> > From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1752369AbbC0Kco (ORCPT ); Fri, 27 Mar 2015 06:32:44 -0400 Received: from mailout1.w1.samsung.com ([210.118.77.11]:18296 "EHLO mailout1.w1.samsung.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751715AbbC0Kcn (ORCPT ); Fri, 27 Mar 2015 06:32:43 -0400 X-AuditID: cbfec7f4-b7f126d000001e9a-72-55153120601c Message-id: <551531B0.4090108@samsung.com> Date: Fri, 27 Mar 2015 11:32:16 +0100 From: Daniel Granat User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:31.0) Gecko/20100101 Thunderbird/31.4.0 MIME-version: 1.0 Newsgroups: gmane.linux.kernel,gmane.comp.version-control.coccinelle To: Julia.Lawall@lip6.fr, cocci@systeme.lip6.fr, linux-kernel@vger.kernel.org Cc: Gilles.Muller@lip6.fr, nicolas.palix@imag.fr, Karol Wrona Subject: Re: [PATCH] Add coccinelle script that makes sure that tables are NULL terminated References: <1425043313-15844-1-git-send-email-d.granat@samsung.com> In-reply-to: <1425043313-15844-1-git-send-email-d.granat@samsung.com> Content-type: text/plain; charset=windows-1252; format=flowed Content-transfer-encoding: 7bit X-Brightmail-Tracker: H4sIAAAAAAAAA+NgFjrELMWRmVeSWpSXmKPExsVy+t/xa7oKhqKhBmubWS1+bFrNZjH75yUm i2UPTjNanFq2n8ni8q45bBbHXi5ncmDzOHasldlj75Ysj74tqxg9Hi27z+LxeZNcAGsUl01K ak5mWWqRvl0CV8aBs54FV8Uq1s7/xdrA2C/YxcjJISFgIrHt1X02CFtM4sK99UA2F4eQwFJG iY4Hv1ghnE+MEjNmrGQBqeIV0JI40vgMqIqDg0VAVeL+aSmQMBtQ+PKdB0wgtqhAhMT8Y6+Z IcoFJX5MvgfWyifgItHVsYMRxBYR8JW4sGc6WJxZIFRi+rS/7CC2sECMxP3vC1hBbCGg+qm9 nWD1nAKuElc37GKCqLeVWPB+HVSvvMTmNW+ZJzAKzkKybhaSsllIyhYwMq9iFE0tTS4oTkrP NdQrTswtLs1L10vOz93ECAn3LzsYFx+zOsQowMGoxMNrcFA4VIg1say4MvcQowQHs5II78rH IqFCvCmJlVWpRfnxRaU5qcWHGJk4OKUaGBt2RNjvWfZvtuf1LSdd7BaJGX790M/3teb7b8lZ ok/kshNfcX9fNWXjMYk3x/+HbWlmYWDXuBvjOLmTS9r8wqWHklaXPkwS0LAMiw03dtQ2Eg52 3GG61+HRrtlL+hZGVZ+8uPqykMaiB8oa6pskVqzYcHjzBD5VGW99nQ1PVPMOvzDLmrjkkKIS S3FGoqEWc1FxIgAwP7tPVQIAAA== Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi, Could you please review my patch I sent last month? It checks if tables in kernel are NULL terminated. Script matches only names specified in source code by postfix='*_device_id$' and by list of prefixes which is now prefix_list = ['platform', 'of', 'i2c']. I think it could by useful in kernel sources. On 02/27/2015 02:21 PM, Daniel Granat wrote: >
 > Signed-off-by: Daniel Granat <d.granat@samsung.com>
 > ---
 > scripts/coccinelle/misc/device_id_tables.cocci | 95 
++++++++++++++++++++++++++
 > 1 file changed, 95 insertions(+)
 > create mode 100644 scripts/coccinelle/misc/device_id_tables.cocci
 >
 > diff --git a/scripts/coccinelle/misc/device_id_tables.cocci 
b/scripts/coccinelle/misc/device_id_tables.cocci
 > new file mode 100644
 > index 0000000..5968984
 > --- /dev/null
 > +++ b/scripts/coccinelle/misc/device_id_tables.cocci
 > @@ -0,0 +1,95 @@
 > +/// Make sure '*_device_id$' tables are NULL terminated
 > +//
 > +// Keywords: device_id
 > +// Confidence: Medium
 > +// Options: --include-headers
 > +
 > +virtual org
 > +virtual report
 > +virtual patch
 > +
 > +@initialize:python@
 > +@@
 > +import re
 > +
 > +postfix = '_device_id$'
 > +prefix_list = ['platform', 'of', 'i2c']
 > +
 > +@r1 depends on patch || org || report@
 > +position p1;
 > +identifier var, arr;
 > +identifier struct_name;
 > +expression E;
 > +@@
 > +
 > +(
 > +struct struct_name arr[] = {
 > + ...,
 > + {
 > + .var = E,
 > + }
 > + @p1
 > +};
 > +|
 > +struct struct_name arr[] = {
 > + ...,
 > + { ..., var, ... },
 > + @p1
 > +};
 > +)
 > +
 > +@script:python depends on report@
 > +struct_name << r1.struct_name;
 > +p1 << r1.p1;
 > +arr << r1.arr;
 > +pattern;
 > +@@
 > +
 > +for i in prefix_list:
 > + pattern = str(i)+postfix
 > + if re.match(pattern, struct_name) != None:
 > + print "\nCOCCI: \"%s\" matchs required pattern \"%s\"" % 
(struct_name, pattern)
 > + msg = "\"%s\" is not NULL terminated at line %s" % (arr, p1[0].line)
 > + coccilib.report.print_report(p1[0],msg)
 > + break
 > +
 > +@script:python match depends on patch@
 > +struct_name << r1.struct_name;
 > +matched_name;
 > +pattern;
 > +@@
 > +
 > +coccinelle.matched_name = ''
 > +
 > +for i in prefix_list:
 > + pattern = str(i)+postfix
 > + if re.match(pattern, struct_name) != None:
 > + coccinelle.matched_name = struct_name
 > + break
 > +
 > +@r2 depends on patch@
 > +position r1.p1;
 > +identifier var, arr;
 > +identifier match.matched_name;
 > +expression E;
 > +@@
 > +
 > +(
 > +struct matched_name arr[] = {
 > + ...,
 > + {
 > + .var = E,
 > +- }
 > + @p1
 > ++ },
 > ++ {},
 > +};
 > +|
 > +struct matched_name arr[] = {
 > + ...,
 > + { ..., var, ... },
 > + @p1
 > ++ {},
 > +};
 > +)
 > +
 > 
> >