Измените или отключите проверки на этапе выполнения Code Prover

Анализ Code Prover исчерпывающе проверяет исходный код на общие ошибки времени выполнения. Исчерпывающая природа статического анализа спроектирована, чтобы препятствовать ошибкам произойти во время выполнения в безопасности критическое программное обеспечение. Из-за безопасности критическое намерение анализа Code Prover не позволяет вам:

  • Выборочно отключите определенные проверки на этапе выполнения.

  • Скройте результаты проверок на этапе выполнения от списка результатов до аннотаций исходного кода. Можно выровнять по ширине результаты через аннотации, но выровненные по ширине результаты продолжают появляться в списке результатов.

Можно принять решение подавить определенные результаты путем применения фильтров после анализа или даже создания отфильтрованных отчетов. Если вы создаете отфильтрованный отчет из результатов Code Prover, отчет показывает фильтры и отражает ваш выбор. Для получения дополнительной информации см.:

Однако можно изменить поведение по умолчанию определенных проверок и полностью отключить проверки на инициализацию. Когда вы генерируете отчет от результатов анализа, отчет показывает использование этих опций.

Эта тема перечисляет опции, которые изменяют поведение по умолчанию определенных проверок на этапе выполнения. Обратите внимание на то, что, хотя опция, в основном, обращается к определенному типу проверки, на проверки других типов также влияют. Смотрите, что Анализ Code Prover Следует за Красными и Оранжевыми Проверками.

Целочисленное переполнение

ПроверятьПоведение по умолчаниюОпция
Invalid shift operations

Сдвиги влево не позволены на операндах со знаком.

Allow negative operand for left shifts (-allow-negative-operand-in-shift)
Overflow

Переполнение целого числа со знаком запрещается.

Overflow mode for signed integer (-signed-integer-overflows)
Overflow

Переполнение беззнаковых целых чисел не обнаруживается.

Overflow mode for unsigned integer (-unsigned-integer-overflows)

Переполнение с плавающей точкой

ПроверятьПоведение по умолчаниюОпция

Неличные плавания не рассматриваются.

Subnormal float

Субнормальные результаты не обнаруживаются.

Subnormal detection mode (-check-subnormal)

Инициализация

ПроверятьПоведение по умолчаниюОпция

Проверки на инициализацию выполнены только, когда переменная читается.

Disable checks for non-initialization (-disable-initialization-checks)

Global variable not assigned a value in initialization code

Проверки на инициализацию глобальной переменной выполнены только, когда переменная читается.

Библиотечные функции

ПроверятьПоведение по умолчаниюОпция
Invalid use of standard library routine

Только Стандартные Библиотечные подпрограммы проверяются на валидность аргументов. Пользовательские библиотечные функции не проверяются.

-code-behavior-specifications

Указатели

ПроверятьПоведение по умолчаниюОпция
Illegally dereferenced pointer

Указатели на поле структуры не могут указать на другое поле.

Enable pointer arithmetic across fields (-allow-ptr-arith-on-struct)

Illegally dereferenced pointer

Указатели на структуру должны иметь достаточно буфера для целой структуры.

Allow incomplete or partial allocation of structures (-size-in-bytes)
Illegally dereferenced pointerУказатель вершины стека разыменовывает внешний осциллограф, не обнаруживается.Detect stack pointer dereference outside scope (-detect-pointer-escape)
Correctness conditionНесоответствия указателя функции не позволены.Permissive function pointer calls (-permissive-function-pointer)

Недостижимый код или мертвый код

Средство проверкиПоведение по умолчаниюОпция

О невостребованных функциях и функциях, вызванных из недостижимого кода, не сообщают.

Detect uncalled functions (-uncalled-function-checks)

Похожие темы