SSE3 - SSE3

SSE3, Потоковые расширения SIMD 3, также известный Intel кодовое название Новые инструкции Prescott (PNI), является третьей итерацией SSE набор инструкций для IA-32 (x86) архитектура. Intel представила SSE3 в начале 2004 года с Прескотт пересмотр их Pentium 4 ЦПУ. В апреле 2005 г. AMD представили подмножество SSE3 в версии E (Венеция и Сан-Диего) своих Athlon 64 ЦП. Ранее SIMD наборы инструкций по x86 платформы, от старых к новейшим, MMX, 3DNow! (разработан AMD, но не поддерживается процессорами Intel), SSE, и SSE2.

SSE3 содержит 13 новых инструкций сверх SSE2.

Изменения

Наиболее заметное изменение - это возможность работать в регистре горизонтально, в отличие от более или менее строго вертикальной работы всех предыдущих инструкций SSE. Более конкретно, были добавлены инструкции для сложения и вычитания нескольких значений, хранящихся в одном регистре. Эти инструкции можно использовать для ускорения реализации ряда DSP и 3D операции. Также есть новая инструкция для преобразования значений с плавающей запятой в целые числа без изменения глобального режима округления, что позволяет избежать дорогостоящих трубопровод ларьки. Наконец, расширение добавляет LDDQU, альтернативную загрузку смещенных целочисленных векторов, которая имеет лучшую производительность на NetBurst платформы на основе для нагрузок, которые пересекают границы строки кэша.

Процессоры с SSE3

Новые инструкции

Общие инструкции

Арифметика

  • ADDSUBPD - (Добавить-вычесть-упаковано-двойное)
    • Ввод: {A0, A1}, {B0, B1}
    • Выход: {A0 - B0, A1 + B1}
  • ДОБАВИТЬ ПОДПС - (Сложить-вычесть-упаковано-одиночное)
    • Ввод: {A0, A1, A2, A3}, {B0, B1, B2, B3}
    • Выход: {A0 - B0, A1 + B1, A2 - B2, A3 + B3}

AOS (массив структур)

  • HADDPD - (Горизонтально-Добавить-Упакованный-Двойной)
    • Ввод: {A0, A1}, {B0, B1}
    • Выход: {A0 + A1, B0 + B1}
  • HADDPS (Горизонтально-Добавить-Упакованный-Одиночный)
    • Ввод: {A0, A1, A2, A3}, {B0, B1, B2, B3}
    • Выход: {A0 + A1, A2 + A3, B0 + B1, B2 + B3}
  • HSUBPD - (Горизонтальное-вычитание-упакованное-двойное)
    • Ввод: {A0, A1}, {B0, B1}
    • Выход: {A0 - A1, B0 - B1}
  • HSUBPS - (Горизонтальное-вычитание-упакованное-одиночное)
    • Ввод: {A0, A1, A2, A3}, {B0, B1, B2, B3}
    • Выход: {A0 - A1, A2 - A3, B0 - B1, B2 - B3}
  • LDDQU - Как указано выше, это альтернативная загрузка целочисленного вектора с неверным выравниванием. Это может быть полезно для задач сжатия видео.
  • MOVDDUP, MOVSHDUP, MOVSLDUP - полезны для комплексных чисел и расчета волн, таких как звук.
  • FISTTP - аналогично старой инструкции x87 FISTP, но игнорирует настройки режима округления регистра управления с плавающей запятой и вместо этого использует режим «измельчения» (усечения). Позволяет исключить дорогостоящую загрузку и повторную загрузку регистра управления на таких языках, как C, где преобразование float-to-int требует стандартного поведения усечения.

Инструкции Intel

  • MONITOR, MWAIT - оптимизируют многопоточные приложения, предоставляя процессорам Hyper Threading лучшая производительность.

Рекомендации

внешняя ссылка