forked from torvalds/linux
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
add probe_kernel_read() and probe_kernel_write(). Uninlined and restricted to kernel range memory only, as suggested by Linus. Signed-off-by: Ingo Molnar <[email protected]> Reviewed-by: Thomas Gleixner <[email protected]>
- Loading branch information
Ingo Molnar
committed
Apr 17, 2008
1 parent
4b119e2
commit c33fa9f
Showing
3 changed files
with
72 additions
and
1 deletion.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,49 @@ | ||
/* | ||
* Access kernel memory without faulting. | ||
*/ | ||
#include <linux/uaccess.h> | ||
#include <linux/module.h> | ||
#include <linux/mm.h> | ||
|
||
/** | ||
* probe_kernel_read(): safely attempt to read from a location | ||
* @dst: pointer to the buffer that shall take the data | ||
* @src: address to read from | ||
* @size: size of the data chunk | ||
* | ||
* Safely read from address @src to the buffer at @dst. If a kernel fault | ||
* happens, handle that and return -EFAULT. | ||
*/ | ||
long probe_kernel_read(void *dst, void *src, size_t size) | ||
{ | ||
long ret; | ||
|
||
pagefault_disable(); | ||
ret = __copy_from_user_inatomic(dst, | ||
(__force const void __user *)src, size); | ||
pagefault_enable(); | ||
|
||
return ret ? -EFAULT : 0; | ||
} | ||
EXPORT_SYMBOL_GPL(probe_kernel_read); | ||
|
||
/** | ||
* probe_kernel_write(): safely attempt to write to a location | ||
* @dst: address to write to | ||
* @src: pointer to the data that shall be written | ||
* @size: size of the data chunk | ||
* | ||
* Safely write to address @dst from the buffer at @src. If a kernel fault | ||
* happens, handle that and return -EFAULT. | ||
*/ | ||
long probe_kernel_write(void *dst, void *src, size_t size) | ||
{ | ||
long ret; | ||
|
||
pagefault_disable(); | ||
ret = __copy_to_user_inatomic((__force void __user *)dst, src, size); | ||
pagefault_enable(); | ||
|
||
return ret ? -EFAULT : 0; | ||
} | ||
EXPORT_SYMBOL_GPL(probe_kernel_write); |