提交 434b5a2e 编写于 作者: A Al Viro

sound_firmware: don't bother with filp_close()

it's opened read-only and never installed into any descriptor tables;
fput() will do just as well.
Signed-off-by: NAl Viro <viro@zeniv.linux.org.uk>
上级 264bd660
#include <linux/vmalloc.h> #include <linux/vmalloc.h>
#include <linux/module.h> #include <linux/module.h>
#include <linux/fs.h> #include <linux/fs.h>
#include <linux/file.h>
#include <linux/mm.h> #include <linux/mm.h>
#include <linux/sched.h> #include <linux/sched.h>
#include <asm/uaccess.h> #include <asm/uaccess.h>
...@@ -23,14 +24,14 @@ static int do_mod_firmware_load(const char *fn, char **fp) ...@@ -23,14 +24,14 @@ static int do_mod_firmware_load(const char *fn, char **fp)
if (l <= 0 || l > 131072) if (l <= 0 || l > 131072)
{ {
printk(KERN_INFO "Invalid firmware '%s'\n", fn); printk(KERN_INFO "Invalid firmware '%s'\n", fn);
filp_close(filp, NULL); fput(filp);
return 0; return 0;
} }
dp = vmalloc(l); dp = vmalloc(l);
if (dp == NULL) if (dp == NULL)
{ {
printk(KERN_INFO "Out of memory loading '%s'.\n", fn); printk(KERN_INFO "Out of memory loading '%s'.\n", fn);
filp_close(filp, NULL); fput(filp);
return 0; return 0;
} }
pos = 0; pos = 0;
...@@ -38,10 +39,10 @@ static int do_mod_firmware_load(const char *fn, char **fp) ...@@ -38,10 +39,10 @@ static int do_mod_firmware_load(const char *fn, char **fp)
{ {
printk(KERN_INFO "Failed to read '%s'.\n", fn); printk(KERN_INFO "Failed to read '%s'.\n", fn);
vfree(dp); vfree(dp);
filp_close(filp, NULL); fput(filp);
return 0; return 0;
} }
filp_close(filp, NULL); fput(filp);
*fp = dp; *fp = dp;
return (int) l; return (int) l;
} }
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册