xen/privcmd: return -EFAULT on error
__copy_to_user() returns the number of bytes remaining to be copied but we want to return a negative error code here. Acked-by: Andres Lagar-Cavilla <andres@lagarcavilla.org> Signed-off-by: Dan Carpenter <dan.carpenter@oracle.com> Signed-off-by: Konrad Rzeszutek Wilk <konrad.wilk@oracle.com>
This commit is contained in:
parent
1714df7f2c
commit
9d2be92871
@ -389,8 +389,11 @@ static long privcmd_ioctl_mmap_batch(void __user *udata, int version)
|
|||||||
state.err = err_array;
|
state.err = err_array;
|
||||||
ret = traverse_pages(m.num, sizeof(xen_pfn_t),
|
ret = traverse_pages(m.num, sizeof(xen_pfn_t),
|
||||||
&pagelist, mmap_return_errors_v1, &state);
|
&pagelist, mmap_return_errors_v1, &state);
|
||||||
} else if (version == 2)
|
} else if (version == 2) {
|
||||||
ret = __copy_to_user(m.err, err_array, m.num * sizeof(int));
|
ret = __copy_to_user(m.err, err_array, m.num * sizeof(int));
|
||||||
|
if (ret)
|
||||||
|
ret = -EFAULT;
|
||||||
|
}
|
||||||
|
|
||||||
/* If we have not had any EFAULT-like global errors then set the global
|
/* If we have not had any EFAULT-like global errors then set the global
|
||||||
* error to -ENOENT if necessary. */
|
* error to -ENOENT if necessary. */
|
||||||
|
Loading…
Reference in New Issue
Block a user