работает технология SSE в современных x86-64 процессорах?
Как я понимаю суть в том, что в современных процессорах, например от Intel, начиная с Pentium 3 существуют 8-мь, а в современных аж 16-ть 128-битных XMM регистров, предназначенных для параллельного вычисления, а также для работы с числами с плавающей точкой, с обычной/двойной точностью?
Каждый такой регистр, это пачка из нескольких значений, то как процессор будет их интерпретировать зависит от используемой инструкции, каждый регистр имеет размер 128 бит в котором может поместится 4 32ух битных флота или 2 64ёх битных дабла, в более новых версиях SSE добавили целочисленные инструкции, которые по принципу работы похожи на MMX
не паралельное вычислление, а работа с "пачкой" данных идет в 1й инструкции. все это следует из самого названия - SIMD
В 32х битах по 8 xmm, ymm регистров, в 64х битах - по 16. zmm-регистров 32 в 64х битах, в 32х битах не помню. Инфу брать в манах Intel: xk8.ru/inteldoc Тами описание отдельных инструкций и куча всякой инфы. А вообще, если поискать на озоне книги со словами "Ассемблер avx", найдётся 2 книги про SIMD (тут они тоже есть: xk8.ru/asmlinks)
Ну я сейчас Йо Ван Гуя читаю, пока всё не прочел, прочитал 1/3, на счет xmm в целом понял, потихоньку работаю с SIMD инструкциями, смотрю что в регистрах... Просто хотелось поглубже разобраться, но мне кажется пока смысла в этом нет, процессоры я не проектирую и компиляторы не пишу.
Ну вот как раз потом можно и Куссвюрма почитать :) Прежде чем копать вглубь, сначала пойми всё на более высоком уровне абстракции.
В целом, с вами согласен. Основные, фундаментальные вещи, я более-менее понимаю, поэтому постепенно спускаюсь с уровня высоких абстракций ниже и ниже...
Ахах, я кстати думал с чего лучше начать, выбирал между двумя этими авторами, меня Кусвюрм сильно зацепил с первых же страниц, но пришел к выводу что лучше начать с Ван Гуя)
Ну а особо выбирать и не из чего. Если на русском языке :) Это 2 свежие книги.
Обсуждают сегодня