mirror of
git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-08-05 16:54:27 +00:00
x86: mm: introduce helper function in fault.c
Impact: cleanup Introduce helper function fault_in_kernel_address() to make editors happy. Signed-off-by: Hiroshi Shimamoto <h-shimamoto@ct.jp.nec.com> Signed-off-by: H. Peter Anvin <hpa@linux.intel.com>
This commit is contained in:
parent
010060741a
commit
0973a06cde
1 changed files with 10 additions and 5 deletions
|
@ -775,6 +775,15 @@ static inline int access_error(unsigned long error_code, int write,
|
|||
return 0;
|
||||
}
|
||||
|
||||
static int fault_in_kernel_space(unsigned long address)
|
||||
{
|
||||
#ifdef CONFIG_X86_32
|
||||
return address >= TASK_SIZE;
|
||||
#else /* !CONFIG_X86_32 */
|
||||
return address >= TASK_SIZE64;
|
||||
#endif /* CONFIG_X86_32 */
|
||||
}
|
||||
|
||||
/*
|
||||
* This routine handles page faults. It determines the address,
|
||||
* and the problem, and then passes it off to one of the appropriate
|
||||
|
@ -817,11 +826,7 @@ void __kprobes do_page_fault(struct pt_regs *regs, unsigned long error_code)
|
|||
* (error_code & 4) == 0, and that the fault was not a
|
||||
* protection error (error_code & 9) == 0.
|
||||
*/
|
||||
#ifdef CONFIG_X86_32
|
||||
if (unlikely(address >= TASK_SIZE)) {
|
||||
#else
|
||||
if (unlikely(address >= TASK_SIZE64)) {
|
||||
#endif
|
||||
if (unlikely(fault_in_kernel_space(address))) {
|
||||
if (!(error_code & (PF_RSVD|PF_USER|PF_PROT)) &&
|
||||
vmalloc_fault(address) >= 0)
|
||||
return;
|
||||
|
|
Loading…
Add table
Reference in a new issue