/arch (x86)
Задает архитектуру для создания кода на платформе x86. См. также /arch (x64) и /arch (ARM).
/arch:[IA32|SSE|SSE2|AVX|AVX2]
Аргументы
/arch:IA32
Указывает на то, что расширенные инструкции не используются. Также указывает на использование инструкций x87 для вычислений с плавающей запятой./arch:SSE
Позволяет использовать инструкции SSE./arch:SSE2
Позволяет использовать инструкции SSE2. Это инструкция по умолчанию на платформах x86, если параметр /arch не указан./arch:AVX
Позволяет использовать инструкции Intel AVX./arch:AVX2
Позволяет использовать инструкции Intel AVX 2.
Заметки
Наборы инструкций SSE и SSE2 имеются в различных процессорах Intel и AMD. Инструкции AVX существуют в процессорах Intel Sandy Bridge и процессорах AMD Bulldozer. Инструкции AVX2 поддерживаются процессорами Intel Haswell и Broadwell, а также процессорами на основе AMD Excavator.
Макросы _M_IX86_FP, __AVX__ и __AVX2__ указывают, какой параметр компиляции /arch использовался (если использовался). Для получения дополнительной информации см. Предустановленный макрос. Параметр /arch:AVX2 и макрос __AVX2__ появились в Visual Studio 2013 с обновлением 2 версии 12.0.34567.1.
Если указан параметр /arch, то оптимизатор выбирает, где и как применять наборы инструкций SSE и SSE2. Наборы инструкций SSE и SSE2 будут использоваться при некоторых скалярных вычислениях с плавающей запятой, если будет обнаружено, что регистры и инструкции SSE или SSE2 дают выигрыш во времени по сравнению со стеком регистров с плавающей запятой x87. В результате код будет использовать для вычислений с плавающей запятой как инструкции x87, так и SSE/SSE2. Кроме того, с параметром /arch:SSE2 набор инструкций SSE2 может использоваться для операций с целыми 64-разрядными числами.
В дополнение к наборам инструкций SSE и SSE2 компилятор также использует другие инструкции, имеющиеся в редакциях процессоров, поддерживающих SSE и SSE2. Примером может служить инструкция CMOV, которая впервые появилась в редакции Pentium Pro процессоров Intel.
Компилятор x86 создает код, который по умолчанию использует инструкции SSE2. Поэтому чтобы отключить создание инструкций SSE и SSE2 для процессоров x86, необходимо указать параметр /arch:IA32.
/arch влияет только на создание кода для собственных функций. При компиляции с помощью /clr параметр /arch не оказывает влияния на создание кода для управляемых функций.
Нельзя использовать /arch и /QIfist в одной единице компиляции. В частности, если вы не используете _controlfp для изменения контрольного слова FP, то код запуска времени выполнения установит 53 бита для поля управления точностью контрольного слова FPU x87. Поэтому каждая операция с типами float и double в выражении выполняется с 53-разрядной мантиссой и 15-разрядной экспонентой. Тем не менее, все операции SSE одиночной точности используют 24-разрядную значащую часть и 8-разрядную экспоненту, а операции SSE2 двойной точности используют 53-разрядную значимую часть и 11-разрядную экспоненту. Для получения дополнительной информации см. _control87, _controlfp, __control87_2. Подобные отличия возможны в пределах одного дерева выражения, но не в том случае, когда после каждой части выражения стоит пользовательское присваивание. Рассмотрим следующий пример.
r = f1 * f2 + d; // Different results are possible on SSE/SSE2.
Рассмотрим другую ситуацию.
t = f1 * f2; // Do f1 * f2, round to the type of t.
r = t + d; // This should produce the same overall result
// whether x87 stack is used or SSE/SSE2 is used.
Установка параметра компилятора для AVX, AVX2, IA32, SSE или SSE2 в Visual Studio
Откройте диалоговое окно Страницы свойств проекта. Для получения дополнительной информации см. Открытие свойств страниц проекта.
Выберите папку Свойства конфигурации, а затем папку C/C++.
Выберете страницу свойств Создание кода.
Измените свойство Включить расширенный набор инструкций.
Установка данного параметра компилятора программным способом
- См. раздел EnableEnhancedInstructionSet.