diff options
| author | Julia Lawall <Julia.Lawall@lip6.fr> | 2012-01-14 17:41:54 -0500 |
|---|---|---|
| committer | Michal Marek <mmarek@suse.cz> | 2012-01-14 18:05:46 -0500 |
| commit | 29a36d4dec6cf7ad72e6e3337bf954096cbbb4cf (patch) | |
| tree | 15ac5f3d0df3f56f233603e8626b5d383e6ab278 /scripts/coccinelle/api | |
| parent | fb3f8af4ff52faf9b31e6c4e8ca0b0b16332808c (diff) | |
scripts/coccinelle: improve the coverage of some semantic patches
This patch ensures that all semantic patches in the scripts/coccinelle
directory provide the report option. Report messages that include line
numbers now have the line number preceded by "line" for easier subsequent
processing.
Signed-off-by: Julia Lawall <Julia.Lawall@lip6.fr>
Signed-off-by: Michal Marek <mmarek@suse.cz>
Diffstat (limited to 'scripts/coccinelle/api')
| -rw-r--r-- | scripts/coccinelle/api/kstrdup.cocci | 75 | ||||
| -rw-r--r-- | scripts/coccinelle/api/memdup.cocci | 34 | ||||
| -rw-r--r-- | scripts/coccinelle/api/memdup_user.cocci | 39 |
3 files changed, 132 insertions, 16 deletions
diff --git a/scripts/coccinelle/api/kstrdup.cocci b/scripts/coccinelle/api/kstrdup.cocci index e0805ad08d3..07a74b2c619 100644 --- a/scripts/coccinelle/api/kstrdup.cocci +++ b/scripts/coccinelle/api/kstrdup.cocci | |||
| @@ -1,16 +1,19 @@ | |||
| 1 | /// Use kstrdup rather than duplicating its implementation | 1 | /// Use kstrdup rather than duplicating its implementation |
| 2 | /// | 2 | /// |
| 3 | // Confidence: High | 3 | // Confidence: High |
| 4 | // Copyright: (C) 2010 Nicolas Palix, DIKU. GPLv2. | 4 | // Copyright: (C) 2010-2012 Nicolas Palix. GPLv2. |
| 5 | // Copyright: (C) 2010 Julia Lawall, DIKU. GPLv2. | 5 | // Copyright: (C) 2010-2012 Julia Lawall, INRIA/LIP6. GPLv2. |
| 6 | // Copyright: (C) 2010 Gilles Muller, INRIA/LiP6. GPLv2. | 6 | // Copyright: (C) 2010-2012 Gilles Muller, INRIA/LiP6. GPLv2. |
| 7 | // URL: http://coccinelle.lip6.fr/ | 7 | // URL: http://coccinelle.lip6.fr/ |
| 8 | // Comments: | 8 | // Comments: |
| 9 | // Options: -no_includes -include_headers | 9 | // Options: -no_includes -include_headers |
| 10 | 10 | ||
| 11 | virtual patch | 11 | virtual patch |
| 12 | virtual context | ||
| 13 | virtual org | ||
| 14 | virtual report | ||
| 12 | 15 | ||
| 13 | @@ | 16 | @depends on patch@ |
| 14 | expression from,to; | 17 | expression from,to; |
| 15 | expression flag,E1,E2; | 18 | expression flag,E1,E2; |
| 16 | statement S; | 19 | statement S; |
| @@ -23,7 +26,7 @@ statement S; | |||
| 23 | ... when != \(from = E2 \| to = E2 \) | 26 | ... when != \(from = E2 \| to = E2 \) |
| 24 | - strcpy(to, from); | 27 | - strcpy(to, from); |
| 25 | 28 | ||
| 26 | @@ | 29 | @depends on patch@ |
| 27 | expression x,from,to; | 30 | expression x,from,to; |
| 28 | expression flag,E1,E2,E3; | 31 | expression flag,E1,E2,E3; |
| 29 | statement S; | 32 | statement S; |
| @@ -37,3 +40,65 @@ statement S; | |||
| 37 | if (to==NULL || ...) S | 40 | if (to==NULL || ...) S |
| 38 | ... when != \(x = E3 \| from = E3 \| to = E3 \) | 41 | ... when != \(x = E3 \| from = E3 \| to = E3 \) |
| 39 | - memcpy(to, from, x); | 42 | - memcpy(to, from, x); |
| 43 | |||
| 44 | // --------------------------------------------------------------------- | ||
| 45 | |||
| 46 | @r1 depends on !patch exists@ | ||
| 47 | expression from,to; | ||
| 48 | expression flag,E1,E2; | ||
| 49 | statement S; | ||
| 50 | position p1,p2; | ||
| 51 | @@ | ||
| 52 | |||
| 53 | * to = kmalloc@p1(strlen(from) + 1,flag); | ||
| 54 | ... when != \(from = E1 \| to = E1 \) | ||
| 55 | if (to==NULL || ...) S | ||
| 56 | ... when != \(from = E2 \| to = E2 \) | ||
| 57 | * strcpy@p2(to, from); | ||
| 58 | |||
| 59 | @r2 depends on !patch exists@ | ||
| 60 | expression x,from,to; | ||
| 61 | expression flag,E1,E2,E3; | ||
| 62 | statement S; | ||
| 63 | position p1,p2; | ||
| 64 | @@ | ||
| 65 | |||
| 66 | * x = strlen(from) + 1; | ||
| 67 | ... when != \( x = E1 \| from = E1 \) | ||
| 68 | * to = \(kmalloc@p1\|kzalloc@p2\)(x,flag); | ||
| 69 | ... when != \(x = E2 \| from = E2 \| to = E2 \) | ||
| 70 | if (to==NULL || ...) S | ||
| 71 | ... when != \(x = E3 \| from = E3 \| to = E3 \) | ||
| 72 | * memcpy@p2(to, from, x); | ||
| 73 | |||
| 74 | @script:python depends on org@ | ||
| 75 | p1 << r1.p1; | ||
| 76 | p2 << r1.p2; | ||
| 77 | @@ | ||
| 78 | |||
| 79 | cocci.print_main("WARNING opportunity for kstrdep",p1) | ||
| 80 | cocci.print_secs("strcpy",p2) | ||
| 81 | |||
| 82 | @script:python depends on org@ | ||
| 83 | p1 << r2.p1; | ||
| 84 | p2 << r2.p2; | ||
| 85 | @@ | ||
| 86 | |||
| 87 | cocci.print_main("WARNING opportunity for kstrdep",p1) | ||
| 88 | cocci.print_secs("memcpy",p2) | ||
| 89 | |||
| 90 | @script:python depends on report@ | ||
| 91 | p1 << r1.p1; | ||
| 92 | p2 << r1.p2; | ||
| 93 | @@ | ||
| 94 | |||
| 95 | msg = "WARNING opportunity for kstrdep (strcpy on line %s)" % (p2[0].line) | ||
| 96 | coccilib.report.print_report(p1[0], msg) | ||
| 97 | |||
| 98 | @script:python depends on report@ | ||
| 99 | p1 << r2.p1; | ||
| 100 | p2 << r2.p2; | ||
| 101 | @@ | ||
| 102 | |||
| 103 | msg = "WARNING opportunity for kstrdep (memcpy on line %s)" % (p2[0].line) | ||
| 104 | coccilib.report.print_report(p1[0], msg) | ||
diff --git a/scripts/coccinelle/api/memdup.cocci b/scripts/coccinelle/api/memdup.cocci index b5d722077dc..4dceab6d54d 100644 --- a/scripts/coccinelle/api/memdup.cocci +++ b/scripts/coccinelle/api/memdup.cocci | |||
| @@ -1,14 +1,17 @@ | |||
| 1 | /// Use kmemdup rather than duplicating its implementation | 1 | /// Use kmemdup rather than duplicating its implementation |
| 2 | /// | 2 | /// |
| 3 | // Confidence: High | 3 | // Confidence: High |
| 4 | // Copyright: (C) 2010 Nicolas Palix, DIKU. GPLv2. | 4 | // Copyright: (C) 2010-2012 Nicolas Palix. GPLv2. |
| 5 | // Copyright: (C) 2010 Julia Lawall, DIKU. GPLv2. | 5 | // Copyright: (C) 2010-2012 Julia Lawall, INRIA/LIP6. GPLv2. |
| 6 | // Copyright: (C) 2010 Gilles Muller, INRIA/LiP6. GPLv2. | 6 | // Copyright: (C) 2010-2012 Gilles Muller, INRIA/LiP6. GPLv2. |
| 7 | // URL: http://coccinelle.lip6.fr/ | 7 | // URL: http://coccinelle.lip6.fr/ |
| 8 | // Comments: | 8 | // Comments: |
| 9 | // Options: -no_includes -include_headers | 9 | // Options: -no_includes -include_headers |
| 10 | 10 | ||
| 11 | virtual patch | 11 | virtual patch |
| 12 | virtual context | ||
| 13 | virtual org | ||
| 14 | virtual report | ||
| 12 | 15 | ||
| 13 | @r1@ | 16 | @r1@ |
| 14 | expression from,to; | 17 | expression from,to; |
| @@ -28,7 +31,7 @@ position p; | |||
| 28 | ... when != \( x = E1 \| from = E1 \) | 31 | ... when != \( x = E1 \| from = E1 \) |
| 29 | to = \(kmalloc@p\|kzalloc@p\)(x,flag); | 32 | to = \(kmalloc@p\|kzalloc@p\)(x,flag); |
| 30 | 33 | ||
| 31 | @@ | 34 | @depends on patch@ |
| 32 | expression from,to,size,flag; | 35 | expression from,to,size,flag; |
| 33 | position p != {r1.p,r2.p}; | 36 | position p != {r1.p,r2.p}; |
| 34 | statement S; | 37 | statement S; |
| @@ -38,3 +41,26 @@ statement S; | |||
| 38 | + to = kmemdup(from,size,flag); | 41 | + to = kmemdup(from,size,flag); |
| 39 | if (to==NULL || ...) S | 42 | if (to==NULL || ...) S |
| 40 | - memcpy(to, from, size); | 43 | - memcpy(to, from, size); |
| 44 | |||
| 45 | @r depends on !patch@ | ||
| 46 | expression from,to,size,flag; | ||
| 47 | position p != {r1.p,r2.p}; | ||
| 48 | statement S; | ||
| 49 | @@ | ||
| 50 | |||
| 51 | * to = \(kmalloc@p\|kzalloc@p\)(size,flag); | ||
| 52 | to = kmemdup(from,size,flag); | ||
| 53 | if (to==NULL || ...) S | ||
| 54 | * memcpy(to, from, size); | ||
| 55 | |||
| 56 | @script:python depends on org@ | ||
| 57 | p << r.p; | ||
| 58 | @@ | ||
| 59 | |||
| 60 | coccilib.org.print_todo(p[0], "WARNING opportunity for kmemdep") | ||
| 61 | |||
| 62 | @script:python depends on report@ | ||
| 63 | p << r.p; | ||
| 64 | @@ | ||
| 65 | |||
| 66 | coccilib.report.print_report(p[0], "WARNING opportunity for kmemdep") | ||
diff --git a/scripts/coccinelle/api/memdup_user.cocci b/scripts/coccinelle/api/memdup_user.cocci index 72ce012e878..2efac289fd5 100644 --- a/scripts/coccinelle/api/memdup_user.cocci +++ b/scripts/coccinelle/api/memdup_user.cocci | |||
| @@ -1,23 +1,25 @@ | |||
| 1 | /// Use kmemdup_user rather than duplicating its implementation | 1 | /// Use memdup_user rather than duplicating its implementation |
| 2 | /// This is a little bit restricted to reduce false positives | 2 | /// This is a little bit restricted to reduce false positives |
| 3 | /// | 3 | /// |
| 4 | // Confidence: High | 4 | // Confidence: High |
| 5 | // Copyright: (C) 2010 Nicolas Palix, DIKU. GPLv2. | 5 | // Copyright: (C) 2010-2012 Nicolas Palix. GPLv2. |
| 6 | // Copyright: (C) 2010 Julia Lawall, DIKU. GPLv2. | 6 | // Copyright: (C) 2010-2012 Julia Lawall, INRIA/LIP6. GPLv2. |
| 7 | // Copyright: (C) 2010 Gilles Muller, INRIA/LiP6. GPLv2. | 7 | // Copyright: (C) 2010-2012 Gilles Muller, INRIA/LiP6. GPLv2. |
| 8 | // URL: http://coccinelle.lip6.fr/ | 8 | // URL: http://coccinelle.lip6.fr/ |
| 9 | // Comments: | 9 | // Comments: |
| 10 | // Options: -no_includes -include_headers | 10 | // Options: -no_includes -include_headers |
| 11 | 11 | ||
| 12 | virtual patch | 12 | virtual patch |
| 13 | virtual context | ||
| 14 | virtual org | ||
| 15 | virtual report | ||
| 13 | 16 | ||
| 14 | @@ | 17 | @depends on patch@ |
| 15 | expression from,to,size,flag; | 18 | expression from,to,size,flag; |
| 16 | position p; | ||
| 17 | identifier l1,l2; | 19 | identifier l1,l2; |
| 18 | @@ | 20 | @@ |
| 19 | 21 | ||
| 20 | - to = \(kmalloc@p\|kzalloc@p\)(size,flag); | 22 | - to = \(kmalloc\|kzalloc\)(size,flag); |
| 21 | + to = memdup_user(from,size); | 23 | + to = memdup_user(from,size); |
| 22 | if ( | 24 | if ( |
| 23 | - to==NULL | 25 | - to==NULL |
| @@ -33,3 +35,26 @@ identifier l1,l2; | |||
| 33 | - -EFAULT | 35 | - -EFAULT |
| 34 | - ...+> | 36 | - ...+> |
| 35 | - } | 37 | - } |
| 38 | |||
| 39 | @r depends on !patch@ | ||
| 40 | expression from,to,size,flag; | ||
| 41 | position p; | ||
| 42 | statement S1,S2; | ||
| 43 | @@ | ||
| 44 | |||
| 45 | * to = \(kmalloc@p\|kzalloc@p\)(size,flag); | ||
| 46 | if (to==NULL || ...) S1 | ||
| 47 | if (copy_from_user(to, from, size) != 0) | ||
| 48 | S2 | ||
| 49 | |||
| 50 | @script:python depends on org@ | ||
| 51 | p << r.p; | ||
| 52 | @@ | ||
| 53 | |||
| 54 | coccilib.org.print_todo(p[0], "WARNING opportunity for memdep_user") | ||
| 55 | |||
| 56 | @script:python depends on report@ | ||
| 57 | p << r.p; | ||
| 58 | @@ | ||
| 59 | |||
| 60 | coccilib.report.print_report(p[0], "WARNING opportunity for memdep_user") | ||
