powerpc/iseries: Use kstrdup
authorJulia Lawall <julia@diku.dk>
Fri, 14 May 2010 09:31:26 +0000 (09:31 +0000)
committerBenjamin Herrenschmidt <benh@kernel.crashing.org>
Fri, 9 Jul 2010 01:28:36 +0000 (11:28 +1000)
Use kstrdup when the goal of an allocation is copy a string into the
allocated region.

The semantic patch that makes this change is as follows:
(http://coccinelle.lip6.fr/)

// <smpl>
@@
expression from,to;
expression flag,E1,E2;
statement S;
@@

-  to = kmalloc(strlen(from) + 1,flag);
+  to = kstrdup(from, flag);
   ... when != \(from = E1 \| to = E1 \)
   if (to==NULL || ...) S
   ... when != \(from = E2 \| to = E2 \)
-  strcpy(to, from);
// </smpl>

Signed-off-by: Julia Lawall <julia@diku.dk>
Signed-off-by: Benjamin Herrenschmidt <benh@kernel.crashing.org>
arch/powerpc/platforms/iseries/vio.c

index 00b6730bc48f07392f0604eab8b472badb121242..b6db7cef83b46d19ceff11fab07e660911380426 100644 (file)
@@ -87,12 +87,11 @@ static struct device_node *new_node(const char *path,
 
        if (!np)
                return NULL;
-       np->full_name = kmalloc(strlen(path) + 1, GFP_KERNEL);
+       np->full_name = kstrdup(path, GFP_KERNEL);
        if (!np->full_name) {
                kfree(np);
                return NULL;
        }
-       strcpy(np->full_name, path);
        of_node_set_flag(np, OF_DYNAMIC);
        kref_init(&np->kref);
        np->parent = of_node_get(parent);