提交 b2d82ee3 编写于 作者: F Fang Wenqi 提交者: Miklos Szeredi

fuse: fix large stack use

gcc 4.4 warns about:
  fs/fuse/dev.c: In function ‘fuse_notify_inval_entry’:
  fs/fuse/dev.c:925: warning: the frame size of 1060 bytes is larger than 1024 bytes

The problem is we declare two structures and a large array on the stack,
I move the array alway from the stack and allocate memory for it dynamically.
Signed-off-by: NFang Wenqi <antonf@turbolinux.com.cn>
Signed-off-by: NMiklos Szeredi <mszeredi@suse.cz>
上级 b21dda43
...@@ -881,10 +881,15 @@ static int fuse_notify_inval_entry(struct fuse_conn *fc, unsigned int size, ...@@ -881,10 +881,15 @@ static int fuse_notify_inval_entry(struct fuse_conn *fc, unsigned int size,
struct fuse_copy_state *cs) struct fuse_copy_state *cs)
{ {
struct fuse_notify_inval_entry_out outarg; struct fuse_notify_inval_entry_out outarg;
int err = -EINVAL; int err = -ENOMEM;
char buf[FUSE_NAME_MAX+1]; char *buf;
struct qstr name; struct qstr name;
buf = kzalloc(FUSE_NAME_MAX + 1, GFP_KERNEL);
if (!buf)
goto err;
err = -EINVAL;
if (size < sizeof(outarg)) if (size < sizeof(outarg))
goto err; goto err;
...@@ -910,9 +915,11 @@ static int fuse_notify_inval_entry(struct fuse_conn *fc, unsigned int size, ...@@ -910,9 +915,11 @@ static int fuse_notify_inval_entry(struct fuse_conn *fc, unsigned int size,
if (fc->sb) if (fc->sb)
err = fuse_reverse_inval_entry(fc->sb, outarg.parent, &name); err = fuse_reverse_inval_entry(fc->sb, outarg.parent, &name);
up_read(&fc->killsb); up_read(&fc->killsb);
kfree(buf);
return err; return err;
err: err:
kfree(buf);
fuse_copy_finish(cs); fuse_copy_finish(cs);
return err; return err;
} }
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册