watchdog: coh901327_wdt: constify watchdog_ops structure
authorGustavo A. R. Silva <garsilva@embeddedor.com>
Sat, 8 Jul 2017 00:33:30 +0000 (19:33 -0500)
committerWim Van Sebroeck <wim@iguana.be>
Sat, 9 Sep 2017 18:06:38 +0000 (20:06 +0200)
Check for watchdog_ops structures that are only stored in the ops field of
a watchdog_device structure. This field is declared const, so watchdog_ops
structures that have this property can be declared as const also.

This issue was detected using Coccinelle and the following semantic patch:

@r
disable optional_qualifier@
identifier i;
position p;
@@
static struct watchdog_ops i@p = { ... };

@ok@
identifier r.i;
struct watchdog_device e;
position p;
@@
e.ops = &i@p;

@bad@
position p != {r.p,ok.p};
identifier r.i;
struct watchdog_ops e;
@@
e@i@p

@depends on !bad disable optional_qualifier@
identifier r.i;
@@
static
+const
 struct watchdog_ops i = { ... };

Signed-off-by: Gustavo A. R. Silva <garsilva@embeddedor.com>
Reviewed-by: Guenter Roeck <linux@roeck-us.net>
Signed-off-by: Guenter Roeck <linux@roeck-us.net>
Signed-off-by: Wim Van Sebroeck <wim@iguana.be>
drivers/watchdog/coh901327_wdt.c

index 38dd60f0cfcc636d0b5df5197c06ffcb9f09adbf..4410337f4f7fcfff64cb7b58b764e74315899868 100644 (file)
@@ -218,7 +218,7 @@ static const struct watchdog_info coh901327_ident = {
        .identity = DRV_NAME,
 };
 
-static struct watchdog_ops coh901327_ops = {
+static const struct watchdog_ops coh901327_ops = {
        .owner = THIS_MODULE,
        .start = coh901327_start,
        .stop = coh901327_stop,