Факторы диаграммы Stateflow

hisf_0064: Операции сдвига для данных Stateflow, чтобы улучшить соответствие кода

ID: Заголовокhisf_0064: Операции сдвига для данных Stateflow®, чтобы улучшить соответствие кода
ОписаниеЧтобы улучшить соответствие кода сгенерированного кода с операциями сдвига бита Stateflow, не выполняйте:
A

Операции сдвига вправо, больше, чем битная ширина входного типа, или отрицательной величиной.

B

Операции сдвига влево, больше, чем битная ширина выходного типа, или отрицательной величиной.

Примечание

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

ОбъяснениеA, B Избегать операций сдвига в сгенерированном коде, который может быть кодирующим стандартным нарушением.
Образцовые проверки советника
  • Задачей> Моделирование Стандартов для DO-178C/DO-331> Системы Высокой Целостности> Stateflow> использование Проверки операций сдвига для данных Stateflow

  • Задачей> Моделирование Стандартов для IEC 61508> Системы Высокой Целостности> Stateflow> использование Проверки операций сдвига для данных Stateflow

  • Задачей> Моделирование Стандартов для IEC 62304> Системы Высокой Целостности> Stateflow> использование Проверки операций сдвига для данных Stateflow

  • Задачей> Моделирование Стандартов для EN 50128> Системы Высокой Целостности> Stateflow> использование Проверки операций сдвига для данных Stateflow

  • Задачей> Моделирование Стандартов для ISO 26262> Системы Высокой Целостности> Stateflow> использование Проверки операций сдвига для данных Stateflow

Для получения дополнительной информации проверки смотрите использование Проверки операций сдвига для данных Stateflow.

Ссылки
  • Раздел DO 331 MB.6.3.1.b 'Требования высокого уровня точен и сопоставим'
    Раздел DO 331 MB.6.3.2.b 'Низкоуровневые требования точен и сопоставим'

  • IEC 61508–3, Таблица A.3 (2) язык программирования Со строгим контролем типов
    IEC 61508–3, Табличное A.4 (3) Безопасное программирование

  • IEC 62304, 5.5.3 - критерии допустимости Программного блока

  • ISO 26262-6, Табличное 1 (1b) Использование языковых подмножеств
    ISO 26262-6, Табличное 1 (1c) Осуществление строгого контроля типов
    ISO 26262-6, Табличное 1 (1d) Использование защитных методов реализации

  • EN 50128, таблица A.4 (8) язык программирования со строгим контролем типов
    EN 50128, табличное A.3 (1) безопасное программирование

Предпосылкиhisl_0060: Параметры конфигурации, которые улучшают соответствие MISRA C:2012
В последний раз измененныйR2017b

hisf_0065: Введите операции броска в Stateflow, чтобы улучшить соответствие кода

ID: Заголовокhisf_0065: Введите операции броска в Stateflow, чтобы улучшить соответствие кода
ОписаниеЧтобы улучшить соответствие кода сгенерированного кода, защитите от Stateflow, бросив вычисления целочисленной и фиксированной точки к более широким типам данных, чем типы входных данных:
A

Используя: = обозначение в диаграммах Stateflow, которые используют язык действия C

Примечание

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

ОбъяснениеAИзбегать неявных бросков в сгенерированном коде, который может быть нарушением стандартов кодирования.
Образцовые проверки советника
  • Задачей> Моделирование Стандартов для DO-178C/DO-331> Системы Высокой Целостности> Stateflow> операции присвоения Проверки в диаграммах Stateflow

  • Задачей> Моделирование Стандартов для IEC 61508> Системы Высокой Целостности> Stateflow> операции присвоения Проверки в диаграммах Stateflow

  • Задачей> Моделирование Стандартов для IEC 62304> Системы Высокой Целостности> Stateflow> операции присвоения Проверки в диаграммах Stateflow

  • Задачей> Моделирование Стандартов для EN 50128> Системы Высокой Целостности> Stateflow> операции присвоения Проверки в диаграммах Stateflow

  • Задачей> Моделирование Стандартов для ISO 26262> Системы Высокой Целостности> Stateflow> операции присвоения Проверки в диаграммах Stateflow

Для получения дополнительной информации проверки смотрите операции присвоения Проверки в диаграммах Stateflow.

Ссылки
  • Раздел DO 331 MB.6.3.1.b 'Требования высокого уровня точен и сопоставим'
    Раздел DO 331 MB.6.3.2.b 'Низкоуровневые требования точен и сопоставим'

  • IEC 61508–3, Таблица A.3 (2) язык программирования Со строгим контролем типов
    IEC 61508–3, Табличное A.4 (3) Безопасное программирование

  • IEC 62304, 5.5.3 - критерии допустимости Программного блока

  • ISO 26262-6, Табличное 1 (1b) Использование языковых подмножеств
    ISO 26262-6, Табличное 1 (1c) Осуществление строгого контроля типов
    ISO 26262-6, Табличное 1 (1d) Использование защитных методов реализации

  • EN 50128, таблица A.4 (8) язык программирования со строгим контролем типов
    EN 50128, табличное A.3 (1) безопасное программирование

Предпосылкиhisl_0060: Параметры конфигурации, которые улучшают соответствие MISRA C:2012
В последний раз измененныйR2017b

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

ID: Заголовокhisf_0211: Защитите от использования унарных операторов в диаграммах Stateflow, чтобы улучшить соответствие кода
ОписаниеУлучшить соответствие кода сгенерированного кода:
A

Не используйте операторы унарный минус на типах данных без знака

Примечание

MATLAB® и языки действия C не ограничивают использование операторов унарный минус по выражениям без знака.

ОбъяснениеAУлучшите соответствие кода сгенерированного кода.
Образцовые проверки советника
  • Задачей> Моделирование Стандартов для DO-178C/DO-331> Моделирование Стандартов для DO-178C/DO-331> Системы Высокой Целостности> Stateflow> диаграммы Stateflow Проверки для унарных операторов

  • Задачей> Моделирование Стандартов для IEC 61508> Системы Высокой Целостности> Stateflow> диаграммы Stateflow Проверки для унарных операторов

  • Задачей> Моделирование Стандартов для IEC 62304> Системы Высокой Целостности> Stateflow> диаграммы Stateflow Проверки для унарных операторов

  • Задачей> Моделирование Стандартов для EN 50128> Системы Высокой Целостности> Stateflow> диаграммы Stateflow Проверки для унарных операторов

  • Задачей> Моделирование Стандартов для ISO 26262> Системы Высокой Целостности> Stateflow> диаграммы Stateflow Проверки для унарных операторов

Для получения дополнительной информации проверки смотрите диаграммы Stateflow Проверки для унарных операторов.

Ссылки
  • Раздел DO 331 MB.6.3.1.b 'Требования высокого уровня точен и сопоставим'
    Раздел DO 331 MB.6.3.2.b 'Низкоуровневые требования точен и сопоставим'

  • IEC 61508–3, Таблица A.3 (2) язык программирования Со строгим контролем типов
    IEC 61508–3, Табличное A.4 (3) Безопасное программирование

  • IEC 62304, 5.5.3 - критерии допустимости Программного блока

  • ISO 26262-6, Табличное 1 (1b) Использование языковых подмножеств
    ISO 26262-6, Табличное 1 (1c) Осуществление строгого контроля типов
    ISO 26262-6, Табличное 1 (1d) Использование защитных методов реализации

  • EN 50128, таблица A.4 (8) язык программирования со строгим контролем типов
    EN 50128, табличное A.3 (1) безопасное программирование

  • MISRA C:2012, правило 10.1

В последний раз измененныйR2017b

hisf_0213: Защитите от вычислений деления на нуль в диаграммах Stateflow, чтобы улучшить соответствие MISRA C:2012

ID: Заголовокhisf_0213: Защитите от вычислений деления на нуль в диаграммах Stateflow, чтобы улучшить соответствие MISRA C:2012
ОписаниеЧтобы улучшить соответствие MISRA C:2012 сгенерированного кода для и основанных на целом числе операций с плавающей точкой, выполнить одно из следующих действий:
A

Выполните статический анализ модели, чтобы доказать, что деление на нуль не возможно

B

Обеспечьте ошибку времени выполнения, регистрируясь в сгенерированном коде C путем явного моделирования проверки ошибок в Stateflow

C

Измените процесс генерации кода, пользующийся Заменяющими Библиотеками Кода (CRLs), чтобы защитить от деления на нуль

D

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

Примечание

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

Можно использовать функциональность поиска ошибок проектирования в Simulink® Design Verifier™, чтобы выполнить статический анализ. Для получения дополнительной информации смотрите Статическое Обнаружение Ошибки времени выполнения (Simulink Design Verifier). Также, если у вас есть лицензия Simulink Design Verifier, можно использовать Образцовую проверку Советника, Обнаруживают Деление на нуль, чтобы идентифицировать ошибки деления на нуль в модели.

Если статический анализ решает, что разделы кода могут иметь деление на нуль, то добавьте защиту во время выполнения в тот раздел модели (см. пример). Используя измененный CRL или выбор параметра Удаляют код, который защищает от арифметических исключений деления, защищает операции деления от операций деления на нуль. Однако это действие действительно представляет дополнительный вычислительный и память наверху.

Используйте только одну из мер защиты во время выполнения (B, C или D) в модели. Используя больше чем одну опцию может привести к избыточным операциям защиты.

ОбъяснениеA, B ,
CD
Улучшите соответствие MISRA C:2012 сгенерированного кода
Ссылки
  • MISRA C:2012, Dir 4.1

Смотрите также
В последний раз измененныйR2018a
Пример

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