Commit ec695579 authored by Al Viro's avatar Al Viro

read_code(): go through vfs_read() instead of calling the method directly

... and don't skip on sanity checks.  It's *not* a hot path, TYVM
(a couple of calls per a.out execve(), for pity sake) and headers of
random a.out binary are not to be trusted.
Signed-off-by: default avatarAl Viro <viro@zeniv.linux.org.uk>
parent 0165e810
...@@ -810,7 +810,7 @@ EXPORT_SYMBOL(kernel_read); ...@@ -810,7 +810,7 @@ EXPORT_SYMBOL(kernel_read);
ssize_t read_code(struct file *file, unsigned long addr, loff_t pos, size_t len) ssize_t read_code(struct file *file, unsigned long addr, loff_t pos, size_t len)
{ {
ssize_t res = file->f_op->read(file, (void __user *)addr, len, &pos); ssize_t res = vfs_read(file, (void __user *)addr, len, &pos);
if (res > 0) if (res > 0)
flush_icache_range(addr, addr + len); flush_icache_range(addr, addr + len);
return res; return res;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment