Commit 69a6aba7 authored by Wu Fengguang's avatar Wu Fengguang Committed by james toy

> @@ -547,20 +541,20 @@ static ssize_t write_kmem(struct file *

>  		if (!kbuf)
>  			return wrote ? wrote : -ENOMEM;
>  		while (count > 0) {
> -			int len = size_inside_page(p, count);
> +			unsigned long sz = size_inside_page(p, count);
>
> -			written = copy_from_user(kbuf, buf, len);
> -			if (written) {
> +			sz = copy_from_user(kbuf, buf, sz);

Sorry, it introduced a bug: the "sz" will be zero in normal,

> +			if (sz) {
>  				if (wrote + virtr)
>  					break;
>  				free_page((unsigned long)kbuf);
>  				return -EFAULT;
>  			}
> -			len = vwrite(kbuf, (char *)p, len);
> +			sz = vwrite(kbuf, (char *)p, sz);

and get passed to vwrite here.

This patch fixes it, the new var "n" will be used in another bug
fixing patch following this one.
Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
parent 49ed04e0
...@@ -541,9 +541,10 @@ static ssize_t write_kmem(struct file * file, const char __user * buf, ...@@ -541,9 +541,10 @@ static ssize_t write_kmem(struct file * file, const char __user * buf,
return wrote ? wrote : -ENOMEM; return wrote ? wrote : -ENOMEM;
while (count > 0) { while (count > 0) {
unsigned long sz = size_inside_page(p, count); unsigned long sz = size_inside_page(p, count);
unsigned long n;
sz = copy_from_user(kbuf, buf, sz); n = copy_from_user(kbuf, buf, sz);
if (sz) { if (n) {
if (wrote + virtr) if (wrote + virtr)
break; break;
free_page((unsigned long)kbuf); free_page((unsigned long)kbuf);
......
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