fs: move kernel_read to fs/read_write.c
Signed-off-by: Christoph Hellwig <hch@lst.de> Signed-off-by: Al Viro <viro@zeniv.linux.org.uk>
This commit is contained in:
parent
ac452acae1
commit
c41fbad015
17
fs/exec.c
17
fs/exec.c
|
@ -885,23 +885,6 @@ struct file *open_exec(const char *name)
|
||||||
}
|
}
|
||||||
EXPORT_SYMBOL(open_exec);
|
EXPORT_SYMBOL(open_exec);
|
||||||
|
|
||||||
int kernel_read(struct file *file, loff_t offset,
|
|
||||||
char *addr, unsigned long count)
|
|
||||||
{
|
|
||||||
mm_segment_t old_fs;
|
|
||||||
loff_t pos = offset;
|
|
||||||
int result;
|
|
||||||
|
|
||||||
old_fs = get_fs();
|
|
||||||
set_fs(get_ds());
|
|
||||||
/* The cast to a user pointer is valid due to the set_fs() */
|
|
||||||
result = vfs_read(file, (void __user *)addr, count, &pos);
|
|
||||||
set_fs(old_fs);
|
|
||||||
return result;
|
|
||||||
}
|
|
||||||
|
|
||||||
EXPORT_SYMBOL(kernel_read);
|
|
||||||
|
|
||||||
int kernel_read_file(struct file *file, void **buf, loff_t *size,
|
int kernel_read_file(struct file *file, void **buf, loff_t *size,
|
||||||
loff_t max_size, enum kernel_read_file_id id)
|
loff_t max_size, enum kernel_read_file_id id)
|
||||||
{
|
{
|
||||||
|
|
|
@ -415,6 +415,22 @@ ssize_t __vfs_read(struct file *file, char __user *buf, size_t count,
|
||||||
}
|
}
|
||||||
EXPORT_SYMBOL(__vfs_read);
|
EXPORT_SYMBOL(__vfs_read);
|
||||||
|
|
||||||
|
int kernel_read(struct file *file, loff_t offset, char *addr,
|
||||||
|
unsigned long count)
|
||||||
|
{
|
||||||
|
mm_segment_t old_fs;
|
||||||
|
loff_t pos = offset;
|
||||||
|
int result;
|
||||||
|
|
||||||
|
old_fs = get_fs();
|
||||||
|
set_fs(get_ds());
|
||||||
|
/* The cast to a user pointer is valid due to the set_fs() */
|
||||||
|
result = vfs_read(file, (void __user *)addr, count, &pos);
|
||||||
|
set_fs(old_fs);
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
EXPORT_SYMBOL(kernel_read);
|
||||||
|
|
||||||
ssize_t vfs_read(struct file *file, char __user *buf, size_t count, loff_t *pos)
|
ssize_t vfs_read(struct file *file, char __user *buf, size_t count, loff_t *pos)
|
||||||
{
|
{
|
||||||
ssize_t ret;
|
ssize_t ret;
|
||||||
|
|
Loading…
Reference in New Issue