Описание системы команд (1110646), страница 8
Текст из файла (страница 8)
Если внимательно посмотреть, то у многих команд можно заметить одинаковыезначения флагов для перехода. Это объясняется наличием нескольких ситуаций, которыемогут вызвать одинаковое состояние флагов. В этом случае с целью удобства ассемблердопускает несколько различных мнемонических обозначений одной и той же машиннойкоманды условного перехода. Эти команды ассемблера по действию абсолютноравнозначны, так как это одна и та же машинная команда.
Изначально в микропроцессореi8086 команды условного перехода могли осуществлять только короткие переходы впределах -128...+127 байт, считая от следующей команды. Начиная с микропроцессораi386, эти команды уже могли выполнять любые переходы в пределах текущего сегментакоманд. Это стало возможным за счет введения в систему команд микропроцессорадополнительных машинных команд.
Для реализации межсегментных переходовнеобходимо комбинировать команды условного перехода и команду безусловногоперехода jmp. При этом можно воспользоваться тем, что практически все командыусловного перехода парные, то есть имеют команды, проверяющие обратные условия.Применение jcxz/jecxz:Команда Состояние флагов в eflags/flags Условие переходаJCXZне влияетесли регистр CX=0JECXZне влияетесли регистр ECX=0Команду jcxz/jecxz удобно использовать со всеми командами, использующими регистрecx/cx для своей работы.
Это команды организации цикла и цепочечные команды. Оченьважно отметить то, что команда jcxz/jecxz, в отличие от других команд перехода, можетвыполнять только близкие переходы в пределах -128...+127 байт, считая от следующейкоманды. Поэтому для нее особенно актуальна проблема передачи управления далее чем вуказанном диапазоне.
Для этого можно привлечь команду безусловного перехода jmp.Например, команду jcxz/jecxz можно использовать для предварительной проверкисчетчика цикла в регистре cx для обхода цикла, если его счетчик нулевой....jcxzm1если cx=0cycl:;некоторый циклloopcyclm1:...;обойти цикл,См. также: уроки 10, 11 и команду jmpJMP(JuMP)Переход безусловныйjmp меткаСхема команды:Назначение: используется в программе для организации безусловного перехода каквнутри текущего сегмента команд, так и за его пределы. При определенных условиях взащищенном режиме работы команда jmp может использоваться для переключения задач.СинтаксисАлгоритм работы:Команда jmp в зависимости от типа своего операнда изменяет содержимое либо толькоодного регистра eip, либо обоих регистров cs и eip:••если операнд в команде jmp — метка в текущем сегменте команд (a8, 16, 32), тоассемблер формирует машинную команду, операнд которой является значением сознаком, являющимся смещением перехода относительно следующей за jmpкоманды.
При этом виде перехода изменяется только регистр eip/ip;если операнд в команде jmp — символический идентификатор ячейки памяти (m16,32, 48), то ассемблер предполагает, что в ней находится адрес, по которомунеобходимо передать управление. Этот адрес может быть трех видов:o значением абсолютного смещения метки перехода относительно началасегмента кода. Размер этого смещения может быть 16 или 32 бит взависимости от режима адресации;o дальним указателем на метку перехода в реальном и защищенном режимах,содержащим два компонента адреса — сегментный и смещение. Размерыэтих компонентов также зависят от установленного режима адресации(use16 или use32).
Если текущим режимом является use16, то адрес сегментаи смещение занимают по 16 бит, причем смещение располагается вмладшем слове двойного слова, отводимого под этот полный адрес меткиперехода. Если текущим режимом является use32, то адрес сегмента исмещение занимают, соответственно, 16 и 32 бит, — в младшем двойномслове находится смещение, в старшем — адрес сегмента;o адресом в одном из 16 или 32-разрядных регистров — этот адреспредставляет собой абсолютное смещение метки, на которую необходимопередать управление, относительно начала сегмента команд.Для понимания различий механизмов перехода в реальном и защищенном режимах нужнопомнить следующее.
В реальном режиме микропроцессор просто изменяет cs и eip/ip всоответствии с содержимым указателя в памяти. В защищенном режиме микропроцессорпредварительно анализирует байт прав доступа AR в дескрипторе, номер которогоопределяется по содержимому сегментной части указателя. В зависимости от состояниябайта AR микропроцессор выполняет либо переход, либо переключение задач.Состояние флагов после выполнения команды (за исключением случая переключениязадач):выполнение команды не влияет на флагиПрименение:Команду jmp применяют для осуществления ближних и дальних безусловных переходовбез сохранения контекста точки перехода.См. также: урок 10, команды call, jccLAHF(Load AH register from register Flags)Загрузка регистра AH флагами из регистра eFlags/FlagslahfСхема команды:Назначение: извлечение содержимого младшего байта регистра eflags/flags, в которомсодержатся пять флагов: cf, pf, af, zf и sf.СинтаксисАлгоритм работы:команда загружает регистр ah содержимым младшего байта регистра eflags/flags.Состояние флагов после выполнения команды:выполнение команды не влияет на флагиПрименение:Из-за того, что регистр флагов непосредственно недоступен, команду lahf можноприменять для анализа и последующего изменения командой sahf состояния некоторыхфлагов регистра eflags/flags.;сбросить в ноль флаг cflahfandah,11111110bsahfСм.
также: команду sahfLDS/LES/LFS/LGS/LSS(Load pointer into ds/es/fs/gs/ss segment register)Загрузка сегментного регистра ds/es/fs/gs/ss указателем из памятиlds приемник,источникles приемник,источникlfs приемник,источникСхема команды:lgs приемник,источникlss приемник,источникНазначение: получение полного указателя в виде сегментной составляющей и смещения.СинтаксисАлгоритм работы:Алгоритм работы команды зависит от действующего режима адресации (use16 или use32):••если use16, то загрузить первые два байта из ячейки памяти источник в 16разрядный регистр, указанный операндом приемник. Следующие два байта вобласти источник должны содержать сегментную составляющую некоторогоадреса; они загружаются в регистр ds/es/fs/gs/ss;если use32, то загрузить первые четыре байта из ячейки памяти источник в 32разрядный регистр, указанный операндом приемник.
Следующие два байта вобласти источник должны содержать сегментную составляющую, или селектор,некоторого адреса; они загружаются в регистр ds/es/fs/gs/ss.Состояние флагов после выполнения команды:выполнение команды не влияет на флагиПрименение:Таким образом, с помощью данных команд в паре регистров ds/es/fs/gs/ss и приемникоказывается полный адрес некоторой ячейки памяти.
Это обстоятельство можноиспользовать, к примеру, при работе с цепочечными командами, где существуют жесткиесоглашения на размещение адресов обрабатываемых строк. Помните, что любая загрузкасегментного регистра приводит к обновлению соответствующего теневого регистра (см.урок 16). Смотрите также описание команды cmps с примером использования.См. также: уроки 5, 7, 11, команды lea и операторы ассемблера seg и offsetLEA(Load Effective Address)Загрузка эффективного адресаlea приемник,источникСхема команды:Назначение: получение эффективного адреса (смещения) источника.СинтаксисАлгоритм работы:алгоритм работы команды зависит от действующего режима адресации (use16 или use32):••если use16, то в регистр приемник загружается 16-битное значение смещенияоперанда источник;если use32, то в регистр приемник загружается 32-битное значение смещенияоперанда источник.Состояние флагов после выполнения команды:выполнение команды не влияет на флагиПрименение:Данная команда является альтернативой оператору ассемблера offset.
В отличие от offsetкоманда lea допускает индексацию операнда, что позволяет более гибко организоватьадресацию операндов.;загрузить в регистр bx адрес пятогоэлемента массива mas.datamasdb10 dup (0).code...movdi,4leabx,mas[di];илиleabx,mas[4];илиleabx,mas+4См. также: уроки 5, 7, 11 и команды lea, lds, les, lss, lgs, lfs, операторы ассемблера seg иoffsetLEAVE(LEAVE from procedure)Выход из процедурыleaveСхема команды:Назначение: удаление из стека области локальных (динамических) переменных,выделенной командой enter.СинтаксисАлгоритм работы:команда выполняет обратные команде enter действия:••содержимое ebp/bp копируется в esp/sp, тем самым восстанавливается значениеesp/sp, которое было до вызова данной процедуры.
С другой стороны,восстановление старого значения esp/sp означает освобождение пространства встеке, отведенного для завершающейся процедуры (локальные переменныепроцедуры уничтожаются);из стека восстанавливается содержимое ebp/bp, которое было до входа впроцедуру. После этого действия значение esp/sp также становится таким, какимоно было до входа в процедуру.В результате этих двух действий также восстанавливается кадр стека, если он был,вызывающей программы.Состояние флагов после выполнения команды:выполнение команды не влияет на флагиПрименение:Команда leave не имеет операндов и выполняет обратные команде enter действия. Этакоманда должна находиться непосредственно перед командой ret, которая в зависимостиот соглашений конкретного языка по вызову процедур удаляет или не удаляет аргументыиз стека (см.
урок 14)..286proc1...proc1procenter16,0leaveretendpСм. также: урок 14 и команды enter, ret/retfLGDT(Load Global Descriptor Table)Загрузка регистра глобальной дескрипторной таблицыlgdt источникСхема команды:Назначение: загрузка регистра gdtr значениями базового адреса и размера глобальнойдескрипторной таблицы GDT.СинтаксисАлгоритм работы:команда выполняет загрузку 16 бит размера и 32 бит значения базового адреса началатаблицы GDT в памяти в системный регистр gdtr. Эта загрузка производится всоответствии с форматом этого регистра (см. урок 16).
Состояние флагов послевыполнения команды:выполнение команды не влияет на флагиПрименение:Команду lgdt применяют при подготовке к переходу в защищенный режим для загрузкисистемного регистра gdtr. В качестве операнда в команде указывается адрес области вформате 16+32.
Младшее слово области — размер GDT, двойное слово по старшемуадресу — значение базового адреса начала этой таблицы. Данные два компонента должныбыть сформированы в памяти заранее..286;структура для описанияпсевдодескриптора gdtrpointSTRUClimdw0adrdd0ENDS.datapoint_gdtpoint.code...;загружаем gdtrxoreax,eaxmovax,gdt_segshleax,4movpoint_gdt.adr,eaxlgdtpoint_gdt...См. также: уроки 16, 17 и команду sgdtLIDT(Load Interrupt Descriptor Table)Загрузка регистра глобальной дескрипторной таблицыlidt источникСхема команды:Назначение: загрузка регистра idtr значениями базового адреса и размера глобальнойдескрипторной таблицы IDT.СинтаксисАлгоритм работы:Команда lidt аналогична lgdt, но для дескрипторной таблицы прерываний IDT (см.
урок17).Состояние флагов после выполнения команды:выполнение команды не влияет на флагиПрименение:Команду lidt применяют при подготовке к переходу в защищенный режим для загрузкисистемного регистра idtr. В качестве операнда в команде указывается адрес области вформате 16+32. Младшее слово области — размер IDT, двойное слово по старшемуадресу — значение базового адреса начала этой таблицы.