Lab 2: Базовые команды и кодирование для процессора #2

Merged
mrqiz merged 21 commits from labs/02 into main 2024-09-22 18:15:51 +03:00
5 changed files with 83 additions and 0 deletions
Showing only changes of commit 3ff51630f5 - Show all commits

View File

@ -53,6 +53,13 @@
6. После SIB идет displacement байты (1 или 4 в зависимости от поля mod в ModR/M). Заполняем их согласно выделенному количеству
7. После dispacement идет immediate байты - они могут встретиться если в табличке в колонке opcode на этой строке есть что-то похожее на `ib` или другие, которые мы упоминали. заполняем сколько надо
NOTE: По какой-то причине это не указано в руководстве Intel, но по крайней мере если верить сайту, который я использовал для ассемблирования инструкций, то нужно обязательно учитыать префиксы к опкоду прежде чем начинать кодировать (опять же все по опыту):
1. `0x67` - ставится если команда **адресуется** при помощи 32-битных регистров
2. `0x66` - ставится, если программа иссользует хотя бы 1 16-битный регистр
Благо для 8-битных операций другие опкоды и хотя бы на них не надо префиксы запоминать)
<!--- Пока что я думаю эта инфа лишняя, может потом верну и раскомментирую
### Чутка про префикс REX