diff options
Diffstat (limited to 'fs/fuse')
| -rw-r--r-- | fs/fuse/dev.c | 30 | ||||
| -rw-r--r-- | fs/fuse/inode.c | 2 |
2 files changed, 16 insertions, 16 deletions
diff --git a/fs/fuse/dev.c b/fs/fuse/dev.c index 51d9e33d634f..eb7e9423691f 100644 --- a/fs/fuse/dev.c +++ b/fs/fuse/dev.c | |||
| @@ -865,13 +865,10 @@ static int fuse_notify_inval_inode(struct fuse_conn *fc, unsigned int size, | |||
| 865 | 865 | ||
| 866 | down_read(&fc->killsb); | 866 | down_read(&fc->killsb); |
| 867 | err = -ENOENT; | 867 | err = -ENOENT; |
| 868 | if (!fc->sb) | 868 | if (fc->sb) { |
| 869 | goto err_unlock; | 869 | err = fuse_reverse_inval_inode(fc->sb, outarg.ino, |
| 870 | 870 | outarg.off, outarg.len); | |
| 871 | err = fuse_reverse_inval_inode(fc->sb, outarg.ino, | 871 | } |
| 872 | outarg.off, outarg.len); | ||
| 873 | |||
| 874 | err_unlock: | ||
| 875 | up_read(&fc->killsb); | 872 | up_read(&fc->killsb); |
| 876 | return err; | 873 | return err; |
| 877 | 874 | ||
| @@ -884,10 +881,15 @@ static int fuse_notify_inval_entry(struct fuse_conn *fc, unsigned int size, | |||
| 884 | struct fuse_copy_state *cs) | 881 | struct fuse_copy_state *cs) |
| 885 | { | 882 | { |
| 886 | struct fuse_notify_inval_entry_out outarg; | 883 | struct fuse_notify_inval_entry_out outarg; |
| 887 | int err = -EINVAL; | 884 | int err = -ENOMEM; |
| 888 | char buf[FUSE_NAME_MAX+1]; | 885 | char *buf; |
| 889 | struct qstr name; | 886 | struct qstr name; |
| 890 | 887 | ||
| 888 | buf = kzalloc(FUSE_NAME_MAX + 1, GFP_KERNEL); | ||
| 889 | if (!buf) | ||
| 890 | goto err; | ||
| 891 | |||
| 892 | err = -EINVAL; | ||
| 891 | if (size < sizeof(outarg)) | 893 | if (size < sizeof(outarg)) |
| 892 | goto err; | 894 | goto err; |
| 893 | 895 | ||
| @@ -910,16 +912,14 @@ static int fuse_notify_inval_entry(struct fuse_conn *fc, unsigned int size, | |||
| 910 | 912 | ||
| 911 | down_read(&fc->killsb); | 913 | down_read(&fc->killsb); |
| 912 | err = -ENOENT; | 914 | err = -ENOENT; |
| 913 | if (!fc->sb) | 915 | if (fc->sb) |
| 914 | goto err_unlock; | 916 | err = fuse_reverse_inval_entry(fc->sb, outarg.parent, &name); |
| 915 | |||
| 916 | err = fuse_reverse_inval_entry(fc->sb, outarg.parent, &name); | ||
| 917 | |||
| 918 | err_unlock: | ||
| 919 | up_read(&fc->killsb); | 917 | up_read(&fc->killsb); |
| 918 | kfree(buf); | ||
| 920 | return err; | 919 | return err; |
| 921 | 920 | ||
| 922 | err: | 921 | err: |
| 922 | kfree(buf); | ||
| 923 | fuse_copy_finish(cs); | 923 | fuse_copy_finish(cs); |
| 924 | return err; | 924 | return err; |
| 925 | } | 925 | } |
diff --git a/fs/fuse/inode.c b/fs/fuse/inode.c index 1a822ce2b24b..ec14d19ce501 100644 --- a/fs/fuse/inode.c +++ b/fs/fuse/inode.c | |||
| @@ -850,7 +850,7 @@ static void fuse_send_init(struct fuse_conn *fc, struct fuse_req *req) | |||
| 850 | req->in.args[0].size = sizeof(*arg); | 850 | req->in.args[0].size = sizeof(*arg); |
| 851 | req->in.args[0].value = arg; | 851 | req->in.args[0].value = arg; |
| 852 | req->out.numargs = 1; | 852 | req->out.numargs = 1; |
| 853 | /* Variable length arguement used for backward compatibility | 853 | /* Variable length argument used for backward compatibility |
| 854 | with interface version < 7.5. Rest of init_out is zeroed | 854 | with interface version < 7.5. Rest of init_out is zeroed |
| 855 | by do_get_request(), so a short reply is not a problem */ | 855 | by do_get_request(), so a short reply is not a problem */ |
| 856 | req->out.argvar = 1; | 856 | req->out.argvar = 1; |
