分类: LINUX
2007-01-18 21:56:43
unsigned long copy_from_user
(void * to, const void __user * from, unsigned long n);
Destination address, in kernel space.
Source address, in user space.
Number of bytes to copy.
User context only. This function may sleep.
Copy data from user space to kernel space.
Returns number of bytes that could not be copied. On success, this will be zero.
If some data could not be copied, this function will pad the copied data to the requested size using zero bytes.
unsigned long copy_to_user
(void __user * to, const void * from, unsigned long n);
Destination address, in user space.
Source address, in kernel space.
Number of bytes to copy.
User context only. This function may sleep.
Copy data from kernel space to user space.
Returns number of bytes that could not be copied. On success, this will be zero.
put_user
( x, ptr);
Value to copy to user space.
Destination address, in user space.
User context only. This function may sleep.
This macro copies a single simple value from kernel space to user space. It supports simple types like char and int, but not larger data types like structures or arrays.
ptr must have pointer-to-simple-variable type, and x must be assignable to the result of dereferencing ptr.
Returns zero on success, or -EFAULT on error.
get_user
( x, ptr);
Variable to store result.
Source address, in user space.
User context only. This function may sleep.
This macro copies a single simple variable from user space to kernel space. It supports simple types like char and int, but not larger data types like structures or arrays.
ptr must have pointer-to-simple-variable type, and the result of dereferencing ptr must be assignable to x without a cast.
Returns zero on success, or -EFAULT on error. On error, the variable x is set to zero.