Re: copy_to_user to a kmapped address

Russell King (rmk@arm.linux.org.uk)
Mon, 26 Aug 2002 21:33:04 +0100


On Mon, Aug 26, 2002 at 04:19:37PM -0500, Jeff Dike wrote:
> Is this (in file_read_actor) bogus or am I missing something?
>
> 1621 kaddr = kmap(page);
> 1622 left = __copy_to_user(desc->buf, kaddr + offset, size);
> 1623 kunmap(page);
>
> It seems to me that copy_to_user should be able to assume that the destination
> address is a user address.
>
> This is biting me because I'm moving the UML kernel into a separate address
> space, so there's no way, in general, to tell the difference between a kernel
> address and a userspace address.

Umm, that's copying from kaddr + offset _to_ desc->buf. desc->buf
should be the user space address, and kaddr + offset a kernel address:

unsigned long __copy_to_user(void *to, const void *from, unsigned long n)

-- 
Russell King (rmk@arm.linux.org.uk)                The developer of ARM Linux
             http://www.arm.linux.org.uk/personal/aboutme.html

- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/