Добавил:
Опубликованный материал нарушает ваши авторские права? Сообщите нам.
Вуз: Предмет: Файл:
Скачиваний:
92
Добавлен:
03.06.2014
Размер:
1.76 Mб
Скачать

9. Команды mmx (MultiMedia eXtension) расширения

Эта группа команд появилась, начиная с процессора i586 (PentiumP54C), ориентирована на обработку мультимедийных приложений и предназначена для повышения эффективности выполнения программ, работающих с большими потоками данных (большими массивами целых чисел) по несложным алгоритмам (обработка графики и видеоизображений, синтез и обработка звука).

MMXрасширение включает в себя дополнительные регистры, типы данных и команды, ориентированные на одновременную обработку нескольких целых чисел.

    1. Регистры ММХ

Расширение ММХ использует восемь 64-битных регистра MM0 –MM7, физически размещающихся в поле мантиссы восьми регистровFPUR0 –R7. При записи числа в ММiполе экспонентыRi[64-79] заполняется единицами. Кроме того, полеTOPрегистраSRFPUи весь регистр теговTWобнуляются. Поэтому нельзя одновременно пользоваться командамиFPUи командами ММХ. При необходимости этого следует пользоваться командамиFSAVE/FRSTORпри переходе от командыFPUк ММХ и обратно для сохранения и восстановления регистровFPUили ММХ соответственно.

    1. Типы данных

Расширение ММХ использует 4 новых типа данных:

  1. Учетверенное слово (64-битное число).

  2. Упакованные двойные слова (два 32-битных двойных слова, упакованных в 64-битное данное).

  3. Упакованные слова (четыре 16-битных слова, упакованных в 64-битное данное).

  4. Упакованные байты (восемь байт, упакованных в 64-битное данное).

Отличительные особенности обработки данных:

1. Перемещение данных в память или в регистры осуществляется в упакованном виде, а логическая или арифметическая обработка выполняются над каждым элементом (полем) отдельно.

2. Арифметические операции в ММХ используют специальный способ обработки переполнения, который называется «насыщение». Если результат операции больше (меньше) максимального (минимального) значения соответствующего типа данных, то его полагают равным этому максимальному (минимальному) значению. Так, при операциях с цветом насыщение позволяет сохранять чисто белый цвет при переполнении и

чисто черный при антипереполнении, а обычная арифметика привела бы к инверсии цвета.

    1. Команды ММХ

(Кроме пересылок все остальные команды начинаются с буквы P.)

  1. Пересылка

MOVDd,s– пересылка двойных слов.

Если приемник – регистр ММХ, двойное слово записывается в его младшую половину (биты 0 – 31), если источник – регистр ММХ, в приемник записывается младшее двойное слово этого регистра.

MOVQd,s– пересылка учетверенных слов.

  1. Преобразование типов (упаковка со знаковым насыщением).

PACKSSWBd,s– упаковывает и насыщает слова со знаком в байты.

Четыре слова, находящиеся в приемнике (регистре ММХ), копируются в четыре младших байта приемника, а четыре слова источника (регистр ММХ или переменная) копируются в старшие четыре байта приемника. Если значение какого-либо слова больше 127 или меньше -128, в байт помещается число +127 или –128 соответственно.

PACKSSDWd,s– упаковывает и насыщает двойные слова со знаком в слова.

Аналогично, два двойных слова из приемника копируются в два младших слова приемника, а два двойных слова из источника копируются в старшие два слова приемника.

  1. Распаковка и объединение старших элементов.

PUNPCKHBW d,s– распаковка байтов и объединение в слова,

PUNPCKHWD d,s– распаковка слов и объединение в двойные слова,

PUNPCKHDQ d, s – распаковка двойных слов и объединение в учетверенное слово.

Команды распаковывают старшие элементы источника (регистр ММХ или переменная) и приемника (регистр ММХ) и записывают их в приемник через один.

Пример:

  1. Арифметические операции.

PADDB/W/D d, s – сложение отдельных байтов/слов/двойных слов без учета переноса

PADDSB/Wd,s– сложение с насыщением

PADDUSB/Wd,s– сложение без учета знака с насыщением

Аналогичные команды имеются для операций вычитания (PSUBB/W/D, PSUBSB/W, PSUBUSB/W).

PMULHWd,s– умножение с фиксацией старших слов результатов

PMULLWd,s– умножение с фиксацией младших слов результатов

Эти команды умножают каждое из 4 слов источника на соответствующее слово приемника. Затем старшее (младшее) слово каждого из результатов записывается в соответствующую позицию приемника.

PMADDWDd,s– умножение со сложением.

Каждое из четырех слов источника умножается на соответствующее слово приемника. Произведения двух старших пар слов складываются и их сумма записывается в старшее двойное слово приемника, а сумма произведений двух младших пар слов записывается в младшее двойное слово приемника (команда применяется при реализации алгоритмов фильтрации изображений и т.п.).

  1. Сравнения.

PCMPEQB/PCMPEQW/PCMPEQD d,s– сравнение на равенство

Команды сравнивают отдельные байты/слова/двойные слова источника и приемника и в случае их равенства соответствующий элемент приемника заполняется единицами, а иначе – нулями.

PCMPGTB/PCMPGTW/PCMPGTDd,s– сравнение на больше .

Команды аналогичны предыдущим, но заполнение приемника единицами происходит, если элемент приемника больше элемента источника.

  1. Логические команды.

PANDd,s– логическое И

PANDNd,s– логическое НЕ-И (штрих Шеффера)

PORd,s– логическое ИЛИ

PXORd,s– логическое исключающее ИЛИ

Команды выполняют побитовые логические операции над источником и приемником и сохраняют результирующие биты в приемнике.