From: Al Viro Date: Mon, 27 Aug 2012 00:39:16 +0000 (-0400) Subject: switch itanic perfmonctl(2) to fget_light() X-Git-Tag: next-20120928~93^2~33 X-Git-Url: https://git.karo-electronics.de/?a=commitdiff_plain;h=7456a29bcf3484dee37457370f89d57814299c76;p=karo-tx-linux.git switch itanic perfmonctl(2) to fget_light() Signed-off-by: Al Viro --- diff --git a/arch/ia64/kernel/perfmon.c b/arch/ia64/kernel/perfmon.c index 3fa4bc536953..79826c13b8b6 100644 --- a/arch/ia64/kernel/perfmon.c +++ b/arch/ia64/kernel/perfmon.c @@ -4791,6 +4791,7 @@ sys_perfmonctl (int fd, int cmd, void __user *arg, int count) int narg, completed_args = 0, call_made = 0, cmd_flags; int (*func)(pfm_context_t *ctx, void *arg, int count, struct pt_regs *regs); int (*getsize)(void *arg, size_t *sz); + int fput_needed; #define PFM_MAX_ARGSIZE 4096 /* @@ -4879,7 +4880,7 @@ restart_args: ret = -EBADF; - file = fget(fd); + file = fget_light(fd, &fput_needed); if (unlikely(file == NULL)) { DPRINT(("invalid fd %d\n", fd)); goto error_args; @@ -4920,7 +4921,7 @@ abort_locked: error_args: if (file) - fput(file); + fput_light(file, fput_needed); kfree(args_k);