TASKING Compiler (-compiler tasking)

Задайте Altium ОПРЕДЕЛЯЮЩИЙ ЗАДАЧУ для компилятора

Описание

Задайте tasking для Compiler (-compiler) если вы компилируете свой код с помощью Altium® ОПРЕДЕЛЕНИЕ ЗАДАЧУ для компилятора. Путем определения компилятора можно избежать ошибок компиляции от синтаксиса, который не является частью Стандарта, но прибывает из расширений языка.

Затем задайте свой тип целевого процессора. Если вы выбираете tasking для Compiler, в пользовательском интерфейсе Polyspace® десктопные решения, вы видите, что только процессоры допускали ОПРЕДЕЛЯЮЩИЙ ЗАДАЧУ компилятор. Ваш выбор целевого процессора определяет размер основополагающих типов данных, порядок байтов целевой машины и определенных определений ключевого слова.

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

Программное обеспечение поддерживает различные версии ОПРЕДЕЛЯЮЩЕГО ЗАДАЧУ компилятора, в зависимости от цели:

  • TriCore: 6.x и более старые версии

  • C166: 4.x и более старые версии

  • ARM: 5.x и более старые версии

  • RH850: 2.x и более старые версии

Настройки

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

Цель'char'короткийintдолгодолго долгоfloat'double'долго дваждыptrЗнак по умолчанию charПорядок байтовВыравнивание
tricore81632326432646432со знакомМало 32
c16681616326432646432со знакомМало16
rh85081632326432646432со знакомМало64
arm81632326432646432со знакомБольшой64

Кроме того, wchar_t интерпретирован как unsigned short и size_t интерпретирован как unsigned int.

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

Советы

  • Polyspace не поддерживает некоторые построения, характерные для ОПРЕДЕЛЯЮЩЕГО ЗАДАЧУ компилятора.

    Для списка неподдерживаемых построений смотрите codeprover_limitations.pdf в polyspaceroot\polyspace\verifier\code_prover_desktop. Здесь, polyspaceroot папка установки Polyspace, например, C:\Program Files\Polyspace\R2019a.

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

    • Disabled preprocessor definitions (-U): Не задайте макро-__CPU_TC1793B__.

    • Preprocessor definitions (-D): Задайте макро-__CPU__. Войдите __ центральный процессор __ =xxx, где xxx имя вашего центрального процессора.

      Кроме того, задайте эквивалент макро-__CPU_TC1793B__ для вашего центрального процессора. Например, введите __CPU_TC1793A__.

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

  • Для некоторых ошибок, связанных с ОПРЕДЕЛЕНИЕМ ЗАДАЧУ для специфичных для компилятора построений, смотрите решения в Ошибках компиляции Polyspace Фиксации, Связанных с ОПРЕДЕЛЕНИЕМ ЗАДАЧУ для Компилятора.

  • Если вы используете Polyspace в качестве Вас Расширения кода в ИДАХ, введите эту опцию в файл опций анализа. Смотрите файл опций.

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

Параметр: -compiler tasking -target
Значение: tricore | c166 | rh850 | arm
Значение по умолчанию: tricore
Пример (Bug Finder): polyspace-bug-finder -compiler tasking -target tricore
Пример (Code Prover): polyspace-code-prover -compiler tasking -target tricore
Пример (сервер Bug Finder): polyspace-bug-finder-server -compiler tasking -target tricore
Пример (сервер Code Prover): polyspace-code-prover-server -compiler tasking -target tricore
Введенный в R2017a