[<prev] [next>] [day] [month] [year] [list]
Message-Id: <1287956254-15563-1-git-send-email-npalix.work@gmail.com>
Date: Sun, 24 Oct 2010 23:37:31 +0200
From: Nicolas Palix <npalix.work@...il.com>
To: Randy Dunlap <rdunlap@...otime.net>,
Nicolas Palix <npalix.work@...il.com>,
Julia Lawall <julia@...u.dk>, Michal Marek <mmarek@...e.cz>,
Kulikov Vasiliy <segooon@...il.com>,
Gilles Muller <Gilles.Muller@...6.fr>,
Sam Ravnborg <sam@...nborg.org>,
Joerg Roedel <joerg.roedel@....com>,
linux-kernel@...r.kernel.org, linux-doc@...r.kernel.org,
cocci@...u.dk
Cc: Julia Lawall <julia@...u.dk>
Subject: [PATCH 1/4] Coccinelle: Find nested lock+irqsave functions that use the same flags variables.
From: Julia Lawall <julia@...u.dk>
Signed-off-by: Julia Lawall <julia@...u.dk>
Signed-off-by: Nicolas Palix <npalix.work@...il.com>
---
scripts/coccinelle/locks/flags.cocci | 80 ++++++++++++++++++++++++++++++++++
1 files changed, 80 insertions(+), 0 deletions(-)
create mode 100644 scripts/coccinelle/locks/flags.cocci
diff --git a/scripts/coccinelle/locks/flags.cocci b/scripts/coccinelle/locks/flags.cocci
new file mode 100644
index 0000000..b4344d8
--- /dev/null
+++ b/scripts/coccinelle/locks/flags.cocci
@@ -0,0 +1,80 @@
+/// Find nested lock+irqsave functions that use the same flags variables
+///
+// Confidence: High
+// Copyright: (C) 2010 Nicolas Palix, DIKU. GPLv2.
+// Copyright: (C) 2010 Julia Lawall, DIKU. GPLv2.
+// Copyright: (C) 2010 Gilles Muller, INRIA/LiP6. GPLv2.
+// URL: http://coccinelle.lip6.fr/
+// Comments:
+// Options: -no_includes -include_headers
+
+virtual context
+virtual org
+virtual report
+
+@r@
+expression lock1,lock2,flags;
+position p1,p2;
+@@
+
+(
+spin_lock_irqsave@p1(lock1,flags)
+|
+read_lock_irqsave@p1(lock1,flags)
+|
+write_lock_irqsave@p1(lock1,flags)
+)
+... when != flags
+(
+spin_lock_irqsave(lock1,flags)
+|
+read_lock_irqsave(lock1,flags)
+|
+write_lock_irqsave(lock1,flags)
+|
+spin_lock_irqsave@p2(lock2,flags)
+|
+read_lock_irqsave@p2(lock2,flags)
+|
+write_lock_irqsave@p2(lock2,flags)
+)
+
+@d@
+expression f <= r.flags;
+expression lock1,lock2,flags;
+position r.p1, r.p2;
+@@
+
+(
+*spin_lock_irqsave@p1(lock1,flags)
+|
+*read_lock_irqsave@p1(lock1,flags)
+|
+*write_lock_irqsave@p1(lock1,flags)
+)
+... when != f
+(
+*spin_lock_irqsave@p2(lock2,flags)
+|
+*read_lock_irqsave@p2(lock2,flags)
+|
+*write_lock_irqsave@p2(lock2,flags)
+)
+
+// ----------------------------------------------------------------------
+
+@...ipt:python depends on d && org@
+p1 << r.p1;
+p2 << r.p2;
+@@
+
+cocci.print_main("original lock",p1)
+cocci.print_secs("nested lock+irqsave that reuses flags",p2)
+
+@...ipt:python depends on d && report@
+p1 << r.p1;
+p2 << r.p2;
+@@
+
+msg="ERROR: nested lock+irqsave that reuses flags from %s." % (p1[0].line)
+coccilib.report.print_report(p2[0], msg)
--
1.7.0.4
--
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