Обработка ошибочного адреса, не входящего в адресное Пространство
Если адрес address не принадлежит адресному пространству процесса, функция do page fault о выполняет операторы после метки bad_area. Если ошибка возникла в режиме пользователя, функция посылает текущему процессу сигнал sigsegv и завершает работу:
bad_area:
up_read (&tsk->mm->mmap_sem) ; bad_area_nosemaphore:
if (error_code & 4) { / User Mode / tsk->thread.cr2 = address;
tsk->thread.error_code = error_code | (address >= TASK_SIZE);
tsk->thread.trap_no = 14;
info.si_signo = SIGSEGV;
info.si_errno = 0;
info.si_addr = (void ) address;
force_sig_info(SIGSEGV, &info, tsk);
return;}
Функция force_sig_info() обеспечивает, что процесс не проигнорирует и не заблокирует сигнал sigsegv, и отправляет сигнал процессу режима пользователя, одновременно передавая некоторую дополнительную информацию в локальной переменной info. Поле info.si code уже содержит значение segv maperr (если исключение было вызвано обращением к несуществующему страничному кадру) или segv accerr (если исключение было вызвано недопустимым обращением к существующему страничному кадру).
Если исключение произошло в режиме ядра (бит 2 параметра error code сброшен), остается два возможных случая:
- исключение возникло из-за линейного адреса, переданного ядру в качестве параметра системного вызова;
- исключение возникло из-за ошибки в ядре.
Функция различает эти ситуации следующим образом:
no_context:
if ((fixup = search_exception_table(regs->eip)) != 0) { regs->eip = fixup; return;}
В первом случае выполняется код обработки”, который обычно сводится к отправке сигнала sigsegv процессу current или к завершению обработчика системного вызова с соответствующим кодом ошибки Во втором случае функция выводит полный дамп регистров процессора и стека режима ядра на консоль и в буфер системных сообщений. После этого она уничтожает текущий процесс с помощью функции do exito Это так называемая ошибка Kernel oops”. Выведенные сообщения могут быть использованы специалистами для реконструкции ситуации и поиска и исправления ошибки.
Предыдущая страница | 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 | Следующая страница