Merge branch 'work.set_fs' of git://git.kernel.org/pub/scm/linux/kernel/git/viro/vfs
Pull more set_fs removal from Al Viro: "Christoph's 'use kernel_read and friends rather than open-coding set_fs()' series" * 'work.set_fs' of git://git.kernel.org/pub/scm/linux/kernel/git/viro/vfs: fs: unexport vfs_readv and vfs_writev fs: unexport vfs_read and vfs_write fs: unexport __vfs_read/__vfs_write lustre: switch to kernel_write gadget/f_mass_storage: stop messing with the address limit mconsole: switch to kernel_read btrfs: switch write_buf to kernel_write net/9p: switch p9_fd_read to kernel_write mm/nommu: switch do_mmap_private to kernel_read serial2002: switch serial2002_tty_write to kernel_{read/write} fs: make the buf argument to __kernel_write a void pointer fs: fix kernel_write prototype fs: fix kernel_read prototype fs: move kernel_read to fs/read_write.c fs: move kernel_write to fs/read_write.c autofs4: switch autofs4_write to __kernel_write ashmem: switch to ->read_iter
This commit is contained in:
@@ -539,33 +539,23 @@ static struct btrfs_path *alloc_path_for_send(void)
|
||||
static int write_buf(struct file *filp, const void *buf, u32 len, loff_t *off)
|
||||
{
|
||||
int ret;
|
||||
mm_segment_t old_fs;
|
||||
u32 pos = 0;
|
||||
|
||||
old_fs = get_fs();
|
||||
set_fs(KERNEL_DS);
|
||||
|
||||
while (pos < len) {
|
||||
ret = vfs_write(filp, (__force const char __user *)buf + pos,
|
||||
len - pos, off);
|
||||
ret = kernel_write(filp, buf + pos, len - pos, off);
|
||||
/* TODO handle that correctly */
|
||||
/*if (ret == -ERESTARTSYS) {
|
||||
continue;
|
||||
}*/
|
||||
if (ret < 0)
|
||||
goto out;
|
||||
return ret;
|
||||
if (ret == 0) {
|
||||
ret = -EIO;
|
||||
goto out;
|
||||
return -EIO;
|
||||
}
|
||||
pos += ret;
|
||||
}
|
||||
|
||||
ret = 0;
|
||||
|
||||
out:
|
||||
set_fs(old_fs);
|
||||
return ret;
|
||||
return 0;
|
||||
}
|
||||
|
||||
static int tlv_put(struct send_ctx *sctx, u16 attr, const void *data, int len)
|
||||
|
Reference in New Issue
Block a user