Compiler (-compiler)

Задайте компилятор, который вы используете, чтобы создать ваш исходный код

Описание

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

Polyspace® полностью поддерживает наиболее распространенные компиляторы, используемые, чтобы разработать встраиваемые приложения. См. список ниже. Для этих компиляторов можно запустить анализ просто путем определения компилятора и целевого процессора. Для других компиляторов задайте generic как имя компилятора. Если вы сталкиваетесь с ошибками компиляции, явным образом задаете специфичные для компилятора расширения, чтобы работать вокруг ошибок.

Установите опцию

Пользовательский интерфейс (только десктопные решения): В вашей настройке проекта опция находится на узле Target & Compiler.

Командная строка и файл опций: Используйте опцию -compiler. Смотрите информацию о командной строке.

Почему использование эта опция

Polyspace использует эту информацию, чтобы интерпретировать синтаксис, который не является частью Стандарта C/C++, но прибывает из расширений языка.

Например, опция позволяет дополнительные ключевые слова языка, такие как sfr, sbit, и bit. Если вы не задаете свой компилятор, эти дополнительные ключевые слова могут вызвать ошибки компиляции во время анализа Polyspace.

Polyspace на самом деле не вызывает ваш компилятор для компиляции. В частности:

  • Вы не можете задать флаги компилятора непосредственно в анализе Polyspace. Чтобы эмулировать ваши флаги компилятора, проследите свою команду сборки или вручную задайте эквивалентные опции анализа Polyspace. Смотрите Задают Поведение Целевого окружения и Компилятора.

  • Code Prover имеет соединяющуюся политику, которая более строга, чем обычные компиляторы. Например, если ваш компилятор позволяет несоответствия объявления с определенными параметрами компилятора, вы не можете эмулировать эту политику соединения в Code Prover. Смотрите Компиляцию Поиска и устранения неисправностей и Соединение Ошибок.

Настройки

Значение по умолчанию: generic

generic

Анализ позволяет только стандартный синтаксис.

Стандарт языка определяется вашим выбором для следующих опций:

Если вы не задаете стандарт явным образом, стандарт зависит от вашего выбора компилятора.

gnu3.4

Анализ позволяет синтаксис GCC 3.4.

gnu4.6

Анализ позволяет синтаксис GCC 4.6.

gnu4.7

Анализ позволяет синтаксис GCC 4.7.

Для неподдерживаемых расширений GCC смотрите Ограничения.

gnu4.8

Анализ позволяет синтаксис GCC 4.8.

Для неподдерживаемых расширений GCC смотрите Ограничения.

gnu4.9

Анализ позволяет синтаксис GCC 4.9.

Для неподдерживаемых расширений GCC смотрите Ограничения.

gnu5.x

Анализ позволяет GCC 5.x синтаксис. Для списка доступного GCC 5.x релизы, см. релизы GCC.

Если вы выбираете gnu5.x, опция Target processor type (-target) показывает только подмножество целей, которые позволены для базирующегося компилятора GCC. Для других целей используйте опцию Generic target options.

Для неподдерживаемых расширений GCC смотрите Ограничения.

gnu6.x

Анализ позволяет GCC 6.x синтаксис. Для списка доступного GCC 6.x релизы, см. релизы GCC.

Если вы выбираете gnu6.x, опция Target processor type (-target) показывает только подмножество целей, которые позволены для базирующегося компилятора GCC. Для других целей используйте опцию Generic target options.

Для неподдерживаемых расширений GCC смотрите Ограничения.

gnu7.x

Анализ позволяет GCC 7.x синтаксис. Для списка доступного GCC 7.x релизы, см. релизы GCC.

Если вы выбираете gnu7.x, опция Target processor type (-target) показывает только подмножество целей, которые позволены для базирующегося компилятора GCC. Для других целей используйте опцию Generic target options.

Для неподдерживаемых расширений GCC смотрите Ограничения.

gnu8.x

Анализ позволяет GCC 8.x синтаксис. Для списка доступного GCC 8.x релизы, см. релизы GCC.

Если вы выбираете gnu8.x, опция Target processor type (-target) показывает только подмножество целей, которые позволены для базирующегося компилятора GCC. Для других целей используйте опцию Generic target options.

Для неподдерживаемых расширений GCC смотрите Ограничения.

gnu9.x

Анализ позволяет GCC 9.x синтаксис. Для списка доступного GCC 9.x релизы, см. релизы GCC.

Если вы выбираете gnu9.x, опция Target processor type (-target) показывает только подмножество целей, которые позволены для базирующегося компилятора GCC. Для других целей используйте опцию Generic target options.

Для неподдерживаемых расширений GCC смотрите Ограничения.

gnu10.x

Анализ позволяет GCC 10.x синтаксис. Для списка доступного GCC 10.x релизы, см. релизы GCC.

Если вы выбираете gnu10.x, опция Target processor type (-target) показывает только подмножество целей, которые позволены для базирующегося компилятора GCC. Для других целей используйте опцию Generic target options.

Для неподдерживаемых расширений GCC смотрите Ограничения.

clang3.x

Анализ позволяет Лязг 3.5, 3.6, 3.7, 3.8, и 3,9 синтаксиса.

clang4.x

Анализ позволяет Лязг 4.0.0 и 4.0.1 синтаксиса.

clang5.x

Анализ позволяет Лязг 5.0.0, 5.0.1, и 5.0.2 синтаксиса.

visual9.0

Анализ разрешает Microsoft® Visual C++® 2 008 синтаксисов.

visual10.0

Анализ позволяет Microsoft Visual C++ 2 010 синтаксисов.

Эта опция неявно включает опции -no-stl-stubs.

visual11.0

Анализ позволяет Microsoft Visual C++ 2 012 синтаксисов.

Эта опция неявно включает опции -no-stl-stubs.

visual12.0

Анализ позволяет Microsoft Visual C++ 2 013 синтаксисов.

Эта опция неявно включает опции -no-stl-stubs.

visual14.0

Анализ позволяет Microsoft Visual C++ 2 015 синтаксисов (поддерживает Microsoft Visual Studio® обновитесь 2).

Эта опция неявно включает опции -no-stl-stubs.

visual15.x

Анализ позволяет Microsoft Visual C++ 2 017 синтаксисов. Для списка доступного Microsoft Visual Studio 2 017 версий см. Visual Studio 2 017 Историй Информации о релизах.

Эта опция неявно включает опции -no-stl-stubs.

visual16.x

Анализ позволяет Microsoft Visual C++ 2 019 синтаксисов. Для списка доступного Microsoft Visual Studio 2 019 версий см. Visual Studio 2 019 Историй Информации о релизах.

Эта опция неявно включает опции -no-stl-stubs.

keil

Анализ позволяет не-ANSI® Синтаксис C и семантика сопоставили с продуктами Keil™ от ARM (www.keil.com).

iar

Анализ позволяет Синтаксис C не-ANSI и семантику, сопоставленную с компиляторами от Систем IAR (www.iar.com).

armcc

Анализ позволяет Синтаксис C не-ANSI и семантику, сопоставленную с ARM® компилятор v5.

Если вы выбираете armcc, в пользовательском интерфейсе десктопных решений Polyspace, опции Target processor type (-target) показывает только цели, которые позволены для компилятора ARM v5.

Смотрите ARM v5 Compiler (-compiler armcc).

armclang

Анализ позволяет Синтаксис C не-ANSI и семантику, сопоставленную с компилятором ARM v6.

Если вы выбираете armclang, в пользовательском интерфейсе десктопных решений Polyspace, опции Target processor type (-target) показывает только цели, которые позволены для компилятора ARM v6.

Смотрите ARM v6 Compiler (-compiler armclang).

codewarrior

Анализ позволяет Синтаксис C не-ANSI и семантику, сопоставленную с NXP CodeWarrior® компилятор.

Если вы выбираете codewarrior, в пользовательском интерфейсе десктопных решений Polyspace, опции Target processor type (-target) показывает только цели, которые позволены для компилятора NXP CodeWarrior.

Смотрите NXP CodeWarrior Compiler (-compiler codewarrior).

cosmic

Анализ позволяет Синтаксис C не-ANSI и семантику, сопоставленную с Космическим компилятором.

Если вы выбираете cosmic, в пользовательском интерфейсе десктопных решений Polyspace, опции Target processor type (-target) показывает только цели, которые позволены для Комического компилятора.

Смотрите Cosmic Compiler (-compiler cosmic).

diab

Анализ позволяет Синтаксис C не-ANSI и семантику, сопоставленную с Wind River® Компилятор Diab.

Если вы выбираете diab, в пользовательском интерфейсе десктопных решений Polyspace, опции Target processor type (-target) показывает только цели, которые позволены для компилятора NXP CodeWarrior.

Смотрите Diab Compiler (-compiler diab).

greenhills

Анализ позволяет Синтаксис C не-ANSI и семантику, сопоставленную с Зеленым Выступы® компилятор.

Если вы выбираете greenhills, в пользовательском интерфейсе десктопных решений Polyspace, опции Target processor type (-target) показывает только цели, которые позволены для компилятора Green Hills.

Смотрите Green Hills Compiler (-compiler greenhills).

iar-ew

Анализ позволяет Синтаксис C не-ANSI и семантику, сопоставленную с компилятором IAR Embedded Workbench.

Если вы выбираете iar-ew, в пользовательском интерфейсе десктопных решений Polyspace, опции Target processor type (-target) показывает только цели, которые позволены для компилятора IAR Embedded Workbench.

Смотрите IAR Embedded Workbench Compiler (-compiler iar-ew).

microchip

Анализ позволяет Синтаксис C не-ANSI и семантику, сопоставленную с компилятором C MPLAB XC8.

Если вы выбираете microchip, в пользовательском интерфейсе десктопных решений Polyspace, опции Target processor type (-target) показывает только цели, которые позволены для компилятора C MPLAB XC8.

Смотрите MPLAB XC8 C Compiler (-compiler microchip).

renesas

Анализ позволяет Синтаксис C не-ANSI и семантику, сопоставленную с Renesas® компилятор.

Если вы выбираете renesas, в пользовательском интерфейсе десктопных решений Polyspace, опции Target processor type (-target) показывает только цели, которые позволены для компилятора Renesas.

Смотрите Renesas Compiler (-compiler renesas).

tasking

Анализ позволяет Синтаксис C не-ANSI и семантику, сопоставленную с ОПРЕДЕЛЯЮЩИМ ЗАДАЧУ компилятором.

Если вы выбираете tasking, в пользовательском интерфейсе десктопных решений Polyspace, опции Target processor type (-target) показывает только цели, которые позволены для ОПРЕДЕЛЯЮЩЕГО ЗАДАЧУ компилятора.

Смотрите TASKING Compiler (-compiler tasking).

ti

Анализ позволяет Синтаксис C не-ANSI и семантику, сопоставленную с Instruments™compiler Техаса.

Если вы выбираете ti, в пользовательском интерфейсе десктопных решений Polyspace, опции Target processor type (-target) показывает только цели, которые позволены для компилятора Texas Instruments.

Смотрите Texas Instruments Compiler (-compiler ti).

cosmic

Анализ позволяет Синтаксис C не-ANSI и семантику, сопоставленную с компилятором, используемым в Космических инструментах разработки программного обеспечения.

Если вы выбираете cosmic, в пользовательском интерфейсе десктопных решений Polyspace, опции Target processor type (-target) показывает только цели, которые позволены для Космического компилятора.

Смотрите Cosmic Compiler (-compiler cosmic).

Советы

  • Ваша спецификация компилятора определяет значения многих специфичные для компилятора макросы. В случае, если вы хотите знать, как Polyspace задает определенный макрос, используйте опцию -dump-preprocessing-info.

  • Если вы используете компилятор Visual Studio, необходимо использовать Target processor type (-target) опция, которая устанавливает long long к 64 битам. Совместимые цели включают: i386, sparc, m68k, powerpc, tms320c3x, sharc21x61, mpc5xx, x86_64, или mcpu с long long установите на 64 (-long-long-is-64bits в командной строке).

  • Если вы используете опцию Check JSF AV C++ rules (-jsf-coding-rules), выберите компилятор generic. Если вы используете другой компилятор, Polyspace не может проверять JSF® кодирование управляет, которые требуют приспосабливания стандарту ISO. Например, Правило 8 AV: “Весь код должен соответствовать ISO/IEC 14882:2002 (E) стандартный C++”.

Ограничения

Компиляторы GNU

Polyspace не поддерживает определенные функции компиляторов GNU:

  • GNU® версии компиляторов 4.7 и позже:

    • Вложенные функции.

      Например, функциональный bar вкладывается в функциональном foo:

      int foo (int a, int b)
      {
        int bar (int c) { return c * c; }
      
        return bar (a) + bar (b);
      }

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

      Например, в операции сложения, 2+a, 2 используется в качестве краткого обозначения для {2,2,2,2}.

      typedef int v4si __attribute__ ((vector_size (16)));
      v4si res, a = {1,2,3,4};
      
      res = 2 + a;  /* means {2,2,2,2} + a  */

    • Предописание параметров функции.

      Например, параметр len вперед объявляется:

      void func (int len; char data[len][len], int len)
      {
        /* … */
      }

    • Типы данных комплексного целого числа.

      Однако комплексные типы данных с плавающей запятой поддерживаются.

    • Инициализация структур с членами массива с переменными границами, использующими список инициализаций.

      Например, структура S имеет член массива с переменными границами tab. Переменная типа S непосредственно инициализируется списком инициализаций.

      struct S {
          int x;
          int tab[];            /* flexible array member - not supported */
      };
      struct S s = { 0, 1, 2} ;
      Вы видите предупреждение во время анализа и красной регистрации результатов, когда вы разыменовываете, например, s.tab[1].

    • 128-битные переменные.

      Polyspace не может анализировать этот тип данных семантически. Bug Finder позволяет использование 128-битных типов данных, но Code Prover показывает ошибку компиляции, если вы используете такой тип данных, например, дополнительный __float128 GCC.

  • Версия 7.x компиляторов GNU:

    • Имена типов _FloatN и _FloatNx семантически не поддерживаются. Анализ обрабатывает их как тип float'double', или long double.

    • Константы типа _FloatN или _FloatNx с суффиксами fN, FN, или fNx, такой как 1.2f123 или 2.3F64x не поддерживаются.

Компиляторы Visual Studio

Polyspace не поддерживает определенные функции компиляторов Visual Studio:

  • Ускоренный крупный параллелизм (AMP) C++.

    AMP C++ является функцией Visual Studio, которая ускоряет ваше подписание Кода С++ для определенных типов параллельного данным оборудования на определенных целях. Вы обычно используете restrict ключевое слово, чтобы активировать эту опцию.

    void Buffer() restrict(amp) 
    {
      ... 
    }

  • __assume операторы.

    Вы обычно используете __assume с условием, которое является ложным. Оператор указывает, что оптимизатор должен принять условие быть впредь верным. Code Prover не может согласовать это противоречие. Вы получаете ошибку:

    Asked for compulsory presence of absent entity : assert

  • Управляемые Расширения для C++ (требуемый для Среды.NET), или ее преемник, C++ / CLI (C++, измененный для Общеязыковой инфраструктуры)

  • __declspec ключевое слово с атрибутами кроме noreturn, nothrow, selectany или thread.

Системные заголовки Polyspace

Если вы не задаете путь к своим заголовкам компилятора, Polyspace использует свои собственные системные заголовки, и ваш проект не может скомпилировать, даже если ваш код компилирует с вашим компилятором.

Убедиться, что Polyspace использует ваши заголовочные файлы компилятора, запуск polyspace-configure или задайте пути к своим заголовочным файлам компилятора вручную. Смотрите Обеспечивают Стандартные Заголовки Библиотеки для Анализа Polyspace.

Информация о командной строке

Параметр: -compiler
Значение: armcc | armclang | clang3.x | clang4.x | clang5.x | codewarrior | cosmic | diab | generic | gnu3.4 | gnu4.6 | gnu4.7 | gnu4.8 | gnu4.9 | gnu5.x | gnu6.x | gnu7.x | gnu8.x | gnu9.x | gnu10.x | greenhills | iar | iar-ew | keil | microchip | renesas | tasking | ti | visual10.0 | visual11.0 | visual12.0 | visual14.0 | visual15.x | visual16.x | visual9.0
Значение по умолчанию: generic
Пример 1 (Bug Finder): Polyspace Bug Finder - Ленг c - источники "file1.c,file2.c" - компилятор gnu4.6
Пример 2 (Bug Finder): Polyspace Bug Finder - Ленг cpp - источники "file1.cpp,file2.cpp" - компилятор visual9.0
Пример 1 (Code Prover): Polyspace Code Prover - Ленг c - источники "file1.c,file2.c" - Ленг c - компилятор gnu4.6
Пример 2 (Code Prover): Polyspace Code Prover - Ленг cpp - источники "file1.cpp,file2.cpp" - компилятор visual9.0
Пример 1 (Сервер Bug Finder): сервер средства поиска ошибки полипробела - Ленг c - источники "file1.c,file2.c" - компилятор gnu4.6
Пример 2 (Сервер Bug Finder): сервер средства поиска ошибки полипробела - Ленг cpp - источники "file1.cpp,file2.cpp" - компилятор visual9.0
Пример 1 (Сервер Code Prover): сервер программы автоматического доказательства полипробела кода - Ленг c - источники "file1.c,file2.c" - Ленг c - компилятор gnu4.6
Пример 2 (Сервер Code Prover): сервер программы автоматического доказательства полипробела кода - Ленг cpp - источники "file1.cpp,file2.cpp" - компилятор visual9.0