Системный вызов, который вводит ошибку. В моем случае я прыгаю на какой -то случайный адрес, который, вероятно, недействителен, который имитирует ошибку потока управления. Вот код: < /li>
< /ul>
Код: Выделить всё
#include
#include
SYSCALL_DEFINE0(fine) {
printk("==== FINE systemcall ====\n");
printk("==== START ====\n");
asm volatile("jmp 0x01");
printk("==== JUMPED ====\n");
printk("==== END ====\n");
return 0;
}
< /code>
Программа C, которая вызывает вышеуказанный системный вызов, инициируя инъекцию неисправности. Вот этот код: < /li>
< /ul>
#include
#include
int main(){
printf("Calling the system call...\n");
printf("syscall output: %d\n", syscall(600)); // custom syscall code (fine_syscall)
printf("System call is called!\n");
return 0;
}
< /code>
Virtual Linux (OS Pop On VirtualBox) для установки пользовательского ядра и вызова системы. < /li>
< /ul>
Эта настройка работает (после решения многих проблем) и системного вызова фактически вызывается, но программа убивается, и вот вывод DMESG < /code> после запуска программы:
< img alt = "Окно терминала, отображающее выход вывода команды sudo dmesg, показывающий ошибку страницы" src = "https://i.sstatic.net/nsezes1p.png"/>
Пока я управлял Чтобы ввести ошибку, но я хочу превратить эту ошибку в ошибку и сбой. Предпочтительно, я хочу, чтобы система сбоя и перезагрузилась. Мой вопрос: как я могу это сделать? Или я могу сделать это, редактируя место для прыжка на что -то «менее» недействительным? Учитывая мое отсутствие знаний о ядре Linux (это моя первая встреча с ним XD), я не знаю, как эффективно закрутить ядро. Заранее спасибо: d
Обновление 1: Я работал над проблемой, имея два системных вызова, один выполняющий jmp Подробнее здесь: https://stackoverflow.com/questions/794 ... am-counter
Мобильная версия