[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

[Xen-devel] [RFC v5 025/126] scripts: add coccinelle script to use auto propagated errp



Signed-off-by: Vladimir Sementsov-Ogievskiy <vsementsov@xxxxxxxxxxxxx>
---

CC: Gerd Hoffmann <kraxel@xxxxxxxxxx>
CC: "Gonglei (Arei)" <arei.gonglei@xxxxxxxxxx>
CC: Eduardo Habkost <ehabkost@xxxxxxxxxx>
CC: Igor Mammedov <imammedo@xxxxxxxxxx>
CC: Laurent Vivier <lvivier@xxxxxxxxxx>
CC: Amit Shah <amit@xxxxxxxxxx>
CC: Kevin Wolf <kwolf@xxxxxxxxxx>
CC: Max Reitz <mreitz@xxxxxxxxxx>
CC: John Snow <jsnow@xxxxxxxxxx>
CC: Ari Sundholm <ari@xxxxxxxxxx>
CC: Pavel Dovgalyuk <pavel.dovgaluk@xxxxxxxxx>
CC: Paolo Bonzini <pbonzini@xxxxxxxxxx>
CC: Stefan Hajnoczi <stefanha@xxxxxxxxxx>
CC: Fam Zheng <fam@xxxxxxxxxx>
CC: Stefan Weil <sw@xxxxxxxxxxx>
CC: Ronnie Sahlberg <ronniesahlberg@xxxxxxxxx>
CC: Peter Lieven <pl@xxxxxxx>
CC: Eric Blake <eblake@xxxxxxxxxx>
CC: "Denis V. Lunev" <den@xxxxxxxxxx>
CC: Markus Armbruster <armbru@xxxxxxxxxx>
CC: Alberto Garcia <berto@xxxxxxxxxx>
CC: Jason Dillaman <dillaman@xxxxxxxxxx>
CC: Wen Congyang <wencongyang2@xxxxxxxxxx>
CC: Xie Changlong <xiechanglong.d@xxxxxxxxx>
CC: Liu Yuan <namei.unix@xxxxxxxxx>
CC: "Richard W.M. Jones" <rjones@xxxxxxxxxx>
CC: Jeff Cody <codyprime@xxxxxxxxx>
CC: "Marc-André Lureau" <marcandre.lureau@xxxxxxxxxx>
CC: "Daniel P. Berrangé" <berrange@xxxxxxxxxx>
CC: Richard Henderson <rth@xxxxxxxxxxx>
CC: Greg Kurz <groug@xxxxxxxx>
CC: "Michael S. Tsirkin" <mst@xxxxxxxxxx>
CC: Marcel Apfelbaum <marcel.apfelbaum@xxxxxxxxx>
CC: Beniamino Galvani <b.galvani@xxxxxxxxx>
CC: Peter Maydell <peter.maydell@xxxxxxxxxx>
CC: "Cédric Le Goater" <clg@xxxxxxxx>
CC: Andrew Jeffery <andrew@xxxxxxxx>
CC: Joel Stanley <joel@xxxxxxxxx>
CC: Andrew Baumann <Andrew.Baumann@xxxxxxxxxxxxx>
CC: "Philippe Mathieu-Daudé" <philmd@xxxxxxxxxx>
CC: Antony Pavlov <antonynpavlov@xxxxxxxxx>
CC: Jean-Christophe Dubois <jcd@xxxxxxxxxxxxxxx>
CC: Peter Chubb <peter.chubb@xxxxxxxxxxxx>
CC: Subbaraya Sundeep <sundeep.lkml@xxxxxxxxx>
CC: Eric Auger <eric.auger@xxxxxxxxxx>
CC: Alistair Francis <alistair@xxxxxxxxxxxxx>
CC: "Edgar E. Iglesias" <edgar.iglesias@xxxxxxxxx>
CC: Stefano Stabellini <sstabellini@xxxxxxxxxx>
CC: Anthony Perard <anthony.perard@xxxxxxxxxx>
CC: Paul Durrant <paul@xxxxxxx>
CC: Paul Burton <pburton@xxxxxxxxxxxx>
CC: Aleksandar Rikalo <arikalo@xxxxxxxxxxxx>
CC: Chris Wulff <crwulff@xxxxxxxxx>
CC: Marek Vasut <marex@xxxxxxx>
CC: David Gibson <david@xxxxxxxxxxxxxxxxxxxxx>
CC: Cornelia Huck <cohuck@xxxxxxxxxx>
CC: Halil Pasic <pasic@xxxxxxxxxxxxx>
CC: Christian Borntraeger <borntraeger@xxxxxxxxxx>
CC: "Hervé Poussineau" <hpoussin@xxxxxxxxxxx>
CC: Xiao Guangrong <xiaoguangrong.eric@xxxxxxxxx>
CC: Aurelien Jarno <aurelien@xxxxxxxxxxx>
CC: Aleksandar Markovic <amarkovic@xxxxxxxxxxxx>
CC: Mark Cave-Ayland <mark.cave-ayland@xxxxxxxxxxxx>
CC: Jason Wang <jasowang@xxxxxxxxxx>
CC: Laszlo Ersek <lersek@xxxxxxxxxx>
CC: Yuval Shaia <yuval.shaia@xxxxxxxxxx>
CC: Palmer Dabbelt <palmer@xxxxxxxxxx>
CC: Sagar Karandikar <sagark@xxxxxxxxxxxxxxxxx>
CC: Bastian Koppelmann <kbastian@xxxxxxxxxxxxxxxxxxxxx>
CC: David Hildenbrand <david@xxxxxxxxxx>
CC: Thomas Huth <thuth@xxxxxxxxxx>
CC: Eric Farman <farman@xxxxxxxxxxxxx>
CC: Matthew Rosato <mjrosato@xxxxxxxxxxxxx>
CC: Hannes Reinecke <hare@xxxxxxxx>
CC: Michael Walle <michael@xxxxxxxx>
CC: Artyom Tarasenko <atar4qemu@xxxxxxxxx>
CC: Stefan Berger <stefanb@xxxxxxxxxxxxx>
CC: Samuel Thibault <samuel.thibault@xxxxxxxxxxxx>
CC: Alex Williamson <alex.williamson@xxxxxxxxxx>
CC: Tony Krowiak <akrowiak@xxxxxxxxxxxxx>
CC: Pierre Morel <pmorel@xxxxxxxxxxxxx>
CC: Michael Roth <mdroth@xxxxxxxxxxxxxxxxxx>
CC: Hailiang Zhang <zhang.zhanghailiang@xxxxxxxxxx>
CC: Juan Quintela <quintela@xxxxxxxxxx>
CC: "Dr. David Alan Gilbert" <dgilbert@xxxxxxxxxx>
CC: Luigi Rizzo <rizzo@xxxxxxxxxxxx>
CC: Giuseppe Lettieri <g.lettieri@xxxxxxxxxxxx>
CC: Vincenzo Maffione <v.maffione@xxxxxxxxx>
CC: Jan Kiszka <jan.kiszka@xxxxxxxxxxx>
CC: Anthony Green <green@xxxxxxxxxxxxxx>
CC: Stafford Horne <shorne@xxxxxxxxx>
CC: Guan Xuetao <gxt@xxxxxxxxxxxxxxx>
CC: Max Filippov <jcmvbkbc@xxxxxxxxx>
CC: qemu-block@xxxxxxxxxx
CC: integration@xxxxxxxxxxx
CC: sheepdog@xxxxxxxxxxxxxx
CC: qemu-arm@xxxxxxxxxx
CC: xen-devel@xxxxxxxxxxxxxxxxxxxx
CC: qemu-ppc@xxxxxxxxxx
CC: qemu-s390x@xxxxxxxxxx
CC: qemu-riscv@xxxxxxxxxx

 scripts/coccinelle/auto-propagated-errp.cocci | 118 ++++++++++++++++++
 1 file changed, 118 insertions(+)
 create mode 100644 scripts/coccinelle/auto-propagated-errp.cocci

diff --git a/scripts/coccinelle/auto-propagated-errp.cocci 
b/scripts/coccinelle/auto-propagated-errp.cocci
new file mode 100644
index 0000000000..d9731620aa
--- /dev/null
+++ b/scripts/coccinelle/auto-propagated-errp.cocci
@@ -0,0 +1,118 @@
+@rule0@
+// Add invocation to errp-functions where necessary
+identifier fn, local_err;
+symbol errp;
+@@
+
+ fn(..., Error **errp, ...)
+ {
++   ERRP_AUTO_PROPAGATE();
+    <+...
+(
+    error_append_hint(errp, ...);
+|
+    error_prepend(errp, ...);
+|
+    Error *local_err = NULL;
+)
+    ...+>
+ }
+
+@@
+// Drop doubled invocation
+identifier rule0.fn;
+@@
+
+ fn(...)
+{
+-   ERRP_AUTO_PROPAGATE();
+    ERRP_AUTO_PROPAGATE();
+    ...
+}
+
+@rule1@
+// Drop local_err
+identifier fn, local_err;
+symbol errp;
+@@
+
+ fn(..., Error **errp, ...)
+ {
+     <...
+-    Error *local_err = NULL;
+     ...>
+ }
+
+@@
+// Handle pattern with goto, otherwise we'll finish up
+// with labels at function end which will not compile.
+identifier rule1.fn;
+identifier rule1.local_err;
+identifier OUT;
+@@
+
+ fn(...)
+ {
+     <...
+-    goto OUT;
++    return;
+     ...>
+- OUT:
+-    error_propagate(errp, local_err);
+ }
+
+@@
+identifier rule1.fn;
+identifier rule1.local_err;
+@@
+
+ fn(...)
+ {
+     <...
+(
+-    error_free(local_err);
+-    local_err = NULL;
++    error_free_errp(errp);
+|
+-    error_free(local_err);
++    error_free_errp(errp);
+|
+-    error_report_err(local_err);
++    error_report_errp(errp);
+|
+-    warn_report_err(local_err);
++    warn_report_errp(errp);
+|
+-    error_propagate_prepend(errp, local_err,
++    error_prepend(errp,
+                              ...);
+|
+-    error_propagate(errp, local_err);
+)
+     ...>
+ }
+
+@@
+identifier rule1.fn;
+identifier rule1.local_err;
+@@
+
+ fn(...)
+ {
+     <...
+(
+-    &local_err
++    errp
+|
+-    local_err
++    *errp
+)
+     ...>
+ }
+
+@@
+symbol errp;
+@@
+
+- *errp != NULL
++ *errp
-- 
2.21.0


_______________________________________________
Xen-devel mailing list
Xen-devel@xxxxxxxxxxxxxxxxxxxx
https://lists.xenproject.org/mailman/listinfo/xen-devel

 


Rackspace

Lists.xenproject.org is hosted with RackSpace, monitoring our
servers 24x7x365 and backed by RackSpace's Fanatical Support®.