35 lines
482 B
ArmAsm
35 lines
482 B
ArmAsm
/*
|
|
* page.s contains the low-level page-exception code.
|
|
* the real work is done in mm.c
|
|
*/
|
|
|
|
.globl _page_fault
|
|
|
|
_page_fault:
|
|
xchgl %eax,(%esp)
|
|
pushl %ecx
|
|
pushl %edx
|
|
push %ds
|
|
push %es
|
|
push %fs
|
|
movl $0x10,%edx
|
|
mov %dx,%ds
|
|
mov %dx,%es
|
|
mov %dx,%fs
|
|
movl %cr2,%edx
|
|
pushl %edx
|
|
pushl %eax
|
|
testl $1,%eax
|
|
jne 1f
|
|
call _do_no_page
|
|
jmp 2f
|
|
1: call _do_wp_page
|
|
2: addl $8,%esp
|
|
pop %fs
|
|
pop %es
|
|
pop %ds
|
|
popl %edx
|
|
popl %ecx
|
|
popl %eax
|
|
iret
|