diff options
author | Alexey Khoroshilov <khoroshilov@ispras.ru> | 2013-03-22 16:36:44 -0400 |
---|---|---|
committer | J. Bruce Fields <bfields@redhat.com> | 2013-04-03 15:32:32 -0400 |
commit | a7823c797b4d29727499f0a75ddf3ed07af8ad0a (patch) | |
tree | d5a4d2cb12ef87e91296fac1f4765394ff9a147f | |
parent | ff7c4b3693cbc7e938f49ed89e2f649a33f03ed1 (diff) |
SUNRPC/cache: add module_put() on error path in cache_open()
If kmalloc() fails in cache_open(), module cd->owner left locked.
The patch adds module_put(cd->owner) on this path.
Found by Linux Driver Verification project (linuxtesting.org).
Signed-off-by: Alexey Khoroshilov <khoroshilov@ispras.ru>
Signed-off-by: J. Bruce Fields <bfields@redhat.com>
-rw-r--r-- | net/sunrpc/cache.c | 4 |
1 files changed, 3 insertions, 1 deletions
diff --git a/net/sunrpc/cache.c b/net/sunrpc/cache.c index 25d58e766014..1d3c5144a331 100644 --- a/net/sunrpc/cache.c +++ b/net/sunrpc/cache.c | |||
@@ -986,8 +986,10 @@ static int cache_open(struct inode *inode, struct file *filp, | |||
986 | nonseekable_open(inode, filp); | 986 | nonseekable_open(inode, filp); |
987 | if (filp->f_mode & FMODE_READ) { | 987 | if (filp->f_mode & FMODE_READ) { |
988 | rp = kmalloc(sizeof(*rp), GFP_KERNEL); | 988 | rp = kmalloc(sizeof(*rp), GFP_KERNEL); |
989 | if (!rp) | 989 | if (!rp) { |
990 | module_put(cd->owner); | ||
990 | return -ENOMEM; | 991 | return -ENOMEM; |
992 | } | ||
991 | rp->offset = 0; | 993 | rp->offset = 0; |
992 | rp->q.reader = 1; | 994 | rp->q.reader = 1; |
993 | atomic_inc(&cd->readers); | 995 | atomic_inc(&cd->readers); |