程序运行时,CPU访问的用户空间的虚地址,Linux采用请页机制来节约物理内存(物理内存对于磁盘来说是相当小的),也就是说它仅仅把当前所要使用的用户空间的少量页装入物理内存。若虚地址有效,但其对应的页并不在当前的物理内存,就是缺页异常,这时就要从磁盘中或者交换文件中将其装入物理内存。但是如果是要访问在用户空间(3GB)之外的地址,则该地址无效,并且会被终止运行。
1.却页异常处理程序
当一个进程执行时莫若果CPU访问到一个有小的虚地址,但是这个地址对应的页没有在内存中,则CPU产生一个却页异常。
当发生却页异常时,将调用却页异常处理函数do_page_fault()。该函数将先读取一起缺页异常的虚地址。如果没找到,则说明访问了非法的虚地址(即找到用户空间意外的地址),Linux会发信号终止进程,如果能找到该虚地址,也要检查缺页类型,若果是非法类型(越界错误,段权限错误等)同样要发信号终止进程。(缺页异常只能发生在内核态,如果发生在用户态,则必然是错误的)。
对有效的虚地址,如果发生缺页异常,必须要判断页是在交换文件中,还是可执行映像中。如果该页的页表项非空,但对应的的页不在内存,则说明该页处于交换文件中,操作系统要从交换文件装入页。如果错误由写访问引起,该函数检查这个虚存区是否可写。如果不可写,则对这种错误进行相应的处理;如果可写,则采用写时复制技术。如果错误由读或执行访问引起,该函数检查这一页是否已经存在于物理内存中,如果在,错误的发生就是由于进程试图访问用户态下的一个有特权的页面