Commit be40a5e2 authored by Tapasweni Pathak's avatar Tapasweni Pathak Committed by Greg Kroah-Hartman

staging: unisys: visorchannel: Improved cleanup code

kfree on NULL pointer is a no-op.

This patch used the following semantic patch to find an instance where NULL
check is present before kfree

// <smpl>
@@ expression E; @@
- if (E != NULL) { kfree(E); }
+ kfree(E);
@@ expression E; @@
- if (E != NULL) { kfree(E); E = NULL; }
+ kfree(E);
+ E = NULL;
// </smpl>

Code is made more simpler by breaking up of sequence of kmallocs and adding
some more exit labels.
Removed unnecessary initialization of buf and fmtbuf to NULL as they are local
variables.
Suggested-by: default avatarArnd Bergmann <arnd@arndb.de>
Suggested-by: default avatarJulia Lawall <julia.lawall@lip6.fr>
Signed-off-by: default avatarTapasweni Pathak <tapaswenipathak@gmail.com>
Acked-by: default avatarJulia Lawall <julia.lawall@lip6.fr>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent a707edd2
...@@ -650,15 +650,17 @@ visorchannel_dump_section(VISORCHANNEL *chan, char *s, ...@@ -650,15 +650,17 @@ visorchannel_dump_section(VISORCHANNEL *chan, char *s,
fmtbufsize = 100 * COVQ(len, 16); fmtbufsize = 100 * COVQ(len, 16);
buf = kmalloc(len, GFP_KERNEL|__GFP_NORETRY); buf = kmalloc(len, GFP_KERNEL|__GFP_NORETRY);
if (!buf)
return;
fmtbuf = kmalloc(fmtbufsize, GFP_KERNEL|__GFP_NORETRY); fmtbuf = kmalloc(fmtbufsize, GFP_KERNEL|__GFP_NORETRY);
if (buf == NULL || fmtbuf == NULL) if (!fmtbuf)
goto Away; goto fmt_failed;
errcode = visorchannel_read(chan, off, buf, len); errcode = visorchannel_read(chan, off, buf, len);
if (errcode < 0) { if (errcode < 0) {
ERRDRV("%s failed to read %s from channel errcode=%d", ERRDRV("%s failed to read %s from channel errcode=%d",
s, __func__, errcode); s, __func__, errcode);
goto Away; goto read_failed;
} }
seq_printf(seq, "channel %s:\n", s); seq_printf(seq, "channel %s:\n", s);
tbuf = buf; tbuf = buf;
...@@ -670,14 +672,9 @@ visorchannel_dump_section(VISORCHANNEL *chan, char *s, ...@@ -670,14 +672,9 @@ visorchannel_dump_section(VISORCHANNEL *chan, char *s,
len -= 16; len -= 16;
} }
Away: read_failed:
if (buf != NULL) { kfree(fmtbuf);
kfree(buf); fmt_failed:
buf = NULL; kfree(buf);
}
if (fmtbuf != NULL) {
kfree(fmtbuf);
fmtbuf = NULL;
}
} }
EXPORT_SYMBOL_GPL(visorchannel_dump_section); EXPORT_SYMBOL_GPL(visorchannel_dump_section);
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment