Цель - получить знакомство с системными вызывами, используемыми для получения/освобождения памяти от ядра. Получить представление о том, как может работать JIT компилятор.
- Выделить память с помощью mmap(2).
- Записать в выделенную память машинный код, соответсвующий какой-либо функции.
- Изменить права на выделенную память - чтение и исполнение. See: mprotect(2).
- Вызвать функцию по указателю на выделенную память.
- Освободить выделенную память.
- man objdump
- help disassemble в gdb
Сильные духом призываются к возможности модификации кода выполняемой функции в runtime. Например, вы можете получить аргументом вызова вашей программы какое-то число и пропатчить машинный код этим числом. Эта часть задания будет оцениваться в дополнительные баллы.
./os-jit <code file>
Interpret Brainfuck code with Just-In-Time optimization
Interpreted program reads symbols from stdin and writes to stdout
Use ./run_tests <interpreter executable>
for running tests