Система команд x86 |
|
Программирование - Архитектура и система команд микропроцессоров x86 |
PMULHW
Влияние команды на флаги и форматы команды:
0F E5 /r |
PMULHW mm,mm/m64 |
Вычислить для упакованных знаковых слов mm * mm/m64, старшие слова результатов поместить в mm |
pmulhw mm6,[eax] |
Описание:
Команда PMULHW умножает 4 знаковых слова операнда-назначения на 4 соответствующих знаковых слова операнда-источника. Старшие 16 бит 32-разрядного результата записываются в соответствующие слова операнда-назначения.
Операндом-назначением является MMX-регистр. Операндом-источником может быть как MMX-регистр, так и операнд в памяти.
Операция:
DEST(15..0) = HighOrderWord(DEST(15..0) * SRC(15..0));
DEST(31..16) = HighOrderWord(DEST(31..16) * SRC(31..16));
DEST(47..32) = HighOrderWord(DEST(47..32) * SRC(47..32));
DEST(63..48) = HighOrderWord(DEST(63..48) * SRC(63..48));
Особые ситуации защищенного режима:
#GP(0), если используется некорректный эффективный адрес операнда в памяти в сегментах CS, DS, ES, FS, GS или нулевой селектор.
#SS(0) при использовании некорректного эффективного адреса в сегменте SS.
#UD, если CRO.EM=1.
#NM, если CRO.TS=1.
#MF, если есть отложенные необработанные незамаскированные исключения FPU.
#PF(Код ошибки) при страничной ошибке.
#AC(0) при невыровненной ссылке в память при текущем уровне привилегий равном 3.
Особые ситуации режима реальной адресации:
#GP, если любая часть операнда находится вне пространства эффективных адресов в сегментах CS, DS, ES, FS или GS.
#UD, если CRO.EM=1.
#NM, если CRO.TS=1.
#MF, если есть отложенные необработанные незамаскированные исключения FPU.
Особые ситуации режима V86:
Такие же, как и в режиме реальной адресации.
#PF(Код ошибки) при страничной ошибке.
#AC(0) при невыровненной ссылке в память.
Все права защищены © Алексей Ровдо, 1994-2023. Перепечатка возможна только по согласованию с владельцем авторских прав. admin@club155.ru