Jump to content

MISRA C

From Wikipedia, the free encyclopedia

MISRA Cis a set of software development guidelines for theCprogramming languagedeveloped byThe MISRA Consortium.Its aims are to facilitate codesafety,security,portabilityand reliability in the context ofembedded systems,specifically those systems programmed inISO C/ C90 /C99.[1]

There is also a set of guidelines for MISRA C++ not covered by this article.

History

[edit]
  • Draft: 1997[2]
  • First edition: 1998 (rules, required/advisory)
  • Second edition: 2004 (rules, required/advisory)
  • Third edition: 2012 (directives; rules, Decidable/Undecidable)
  • MISRA compliance: 2016, updated 2020
  • MISRA C:2023 (MISRA C Third edition, Second revision)

For the first two editions of MISRA-C (1998 and 2004) all Guidelines were considered as Rules. With the publication of MISRA C:2012 a new category of Guideline was introduced - theDirectivewhose compliance is more open to interpretation, or relates to process or procedural matters.

Adoption

[edit]

Although originally specifically targeted at the automotive industry, MISRA C has evolved as a widely accepted model for best practices by leading developers in sectors including automotive, aerospace, telecom, medical devices, defense, railway, and others. For example:

  • TheJoint Strike Fighterproject C++ Coding Standards[3]are based on MISRA-C:1998.
  • TheNASAJet Propulsion LaboratoryC Coding Standards[4]are based on MISRA-C:2004.
  • IEC 81001-5-1:2021Health software and health IT systems safety, effectiveness and security - Part 5-1: Security - Activities in the product lifecyclecites MISRA C as an example of secure coding best practices.
  • ISO 26262Functional Safety - Road Vehiclescites MISRA C as being an appropriate sub-set of the C language:
    • ISO 26262-6:2011Part 6: Product development at the software level[5]cites MISRA-C:2004 and MISRA AC AGC.
    • ISO 26262-6:2018Part 6: Product development at the software level[6]cites MISRA C:2012.
  • TheAUTOSARGeneral Software Specification (SRS_BSW_00007) likewise cites MISRA C:
    • The AUTOSAR 4.2 General Software Specification[7]requires thatIf the BSW Module implementation is written in C language, then it shall conform to the MISRA C:2004 Standard.
    • The AUTOSAR 4.3 General Software Specification[8]requires thatIf the BSW Module implementation is written in C language, then it shall conform to the MISRA C:2012 Standard.

Guideline classification and categorization

[edit]

When a new software project is started, the latest MISRA standard should be used. Previous standards are still available for use with legacy software projects that need to refer to it.[9]

Classification

[edit]

Each Guideline is classified[10]asMandatory(new for MISRA C:2012),RequiredorAdvisory.Furthermore, the MISRA Compliance document permitsAdvisoryguidelines to beDisapplied.

  • Mandatoryguidelines shall always be complied with
  • Requiredguidelines shall be complied with, unless subject to aDeviation
  • Advisoryguidelines are considered good practice, but compliance is less formal.

Categorization

[edit]

The rules can be divided logically into a number of categories:

  • Avoiding possible compiler differences, for example, the size of C'sinttype may vary butint16_t(standardized in C99) is always 16 bits.
  • Avoiding using functions and constructs that are prone to failure, for example,mallocmay fail.
  • Produce maintainable and debuggable code, for example, naming conventions and commenting.
  • Best practice rules.
  • Complexity limits.

Scope

[edit]

MISRA C:2012 separately classifies each guideline as eitherSingleTranslation UnitorSystem.[10]

Decidability

[edit]

MISRA C:2012 classifies therules(but not thedirectives) asDecidableorUndecidable.

Achieving compliance

[edit]

MISRA compliance

[edit]

MISRA published documents to provide additional guidance to understand and achieve MISRA compliance.

  • MISRA Compliance:2016,was released by MISRA in April 2016.[11]
  • MISRA Compliance:2020,revised edition, was released in February 2020.[12]

Compliance

[edit]

In order for a piece of software to claim to be compliant to the MISRA C Guidelines, allmandatoryrules shall be met and allrequiredrules and directives shall either be met or subject to a formal deviation.Advisoryrules may be disapplied without a formal deviation, but this should still be recorded in the project documentation.

Note: For compliance purposes, there is no distinction betweenrulesanddirectives.

Deviations

[edit]

Many MISRA Crulescan be characterized asguidelinesbecause under certain condition software engineers may deviate from rules and still be considered compliant with the standard. Deviations must be documented either in the code or in a file. In addition; proof must be provided that the software engineer has considered the safety of the system and that deviating from the rule will not have a negative impact, requirements for deviations also include:

  • The rule deviated from.
  • Rationale for deviation.[13]

Published documents

[edit]

MISRA C:1998

[edit]

The first edition of MISRA C, "Guidelines for the use of the C language in vehicle based software", which was published in 1998 and is officially known asMISRA-C:1998.[14]

MISRA-C:1998 has 127 rules, of which 93 are required and 34 are advisory; the rules are numbered in sequence from 1 to 127.

MISRA C:2004

[edit]

In 2004, a second edition "Guidelines for the use of the C language incritical systems",orMISRA-C:2004was produced, with many substantial changes to the guidelines, including a complete renumbering of the rules.

MISRA-C:2004 contains 142 rules, of which 122 are "required" and 20 are "advisory"; they are divided into 21 topical categories, from "Environment" to "Run-time failures".

MISRA C:2012

[edit]

Main document

[edit]

In 2013, the third edition, MISRA C:2012, was published. MISRA C:2012 extends support to theC99version of the C language (while maintaining guidelines for C90), in addition to including a number of improvements that can reduce the cost and complexity of compliance, whilst aiding consistent, safe use of C in critical systems.[15]

MISRA-C:2012 contains 143 rules and 16 "directives" (that is, rules whose compliance is more open to interpretation, or relates to process or procedural matters); each of which is classified asmandatory,required,oradvisory.They are separately classified as eitherSingle Translation UnitorSystem.Additionally, the rules are classified asDecidableorUndecidable.

Amendment 1

[edit]

In April 2016, MISRA published (as a free download)MISRA C:2012 - Amendment 1: Additional Security Guidelines[16]which added fourteen newsecurityguidelines.

Amendment 2

[edit]

In February 2020, MISRA published (as a free download)MISRA C:2012 - Amendment 2: Updates for ISO/IEC 9899:2011/18 Core functionality[17]which adds mapping for the undefined, unspecified and implementation defined behaviours within C11/C18.

Supporting documents

[edit]

MISRA have published the following addenda to support MISRA C:2012:

  • MISRA C:2012 - Addendum 1: Rule Mappings,[18]which contains bi-directional rule mappings between MISRA C:2004 and the new version. It is intended to assist users in migration.
  • MISRA C:2012 - Addendum 2: Coverage of MISRA C:2012 against ISO/IEC TS 17961:2013 "C Secure"[19]
  • MISRA C:2012 - Addendum 3: Coverage of MISRA C:2012 against CERT C[20]

MISRA C:2023

[edit]

In May 2023 MISRA published MISRA C:2023 (MISRA C Third edition, Second revision) which incorporates Amendments 2 – 4 (AMD2, AMD3, AMD4) and Technical Corrigendum 2 (TC2) and incorporates support forC11andC17language features.[21]

Example suite

[edit]

An exemplar suite (for MISRA-C:2004 and MISRA C:2012) is available from the MISRAGitLab[22]repository (login required). This allows tool-users to evaluate and compare the checking support provided by the various MISRA tools; additionally, it gives tool-implementers some guidance as to the intent of the MISRA Guidelines.

Tools

[edit]

While there exist many software tools that claim to check code for "MISRA conformance", there is no MISRA certification process.[23]

Most of the guidelines can be checked using tools that performstatic code analysis.The remaining guidelines require the use ofdynamic code analysis.

Tools that check code for MISRA conformance include:

C/C++ compilers that support MISRA conformance include:

Criticism

[edit]

Some research results question the effectiveness of MISRA C 2004.

In a paper that compares earlier work on MISRA C:1998 with MISRA C:2004,Les Hattoncomes to the conclusion that:[30]

In view of the apparent widening influence of the MISRA C standard, this paper attempts to assess whether important deficiencies in the original standard have been addressed satisfactorily. Unfortunately, they have not and the important real to false positive ratio is not much better in MISRA C 2004 than it was in MISRA C 1998 and it is unacceptably low in both.

He goes on to state:[30]

In its present form, the only people to benefit from the MISRA C 2004 update would appear to be tool vendors and it is to be hoped that steps will be taken both to simplify the wording and to reduce the false positive ratio in future revisions by taking a little more notice of published experimental data and being less tempted to invent rules on the basis that they seem a good idea.

A study at theTU Delft,by Cathal Boogerd and Leon Moonen, empirically assesses the value of MISRA C:2004. It comes to similar results:[31]

From the data obtained, we can make the following key observations. First, there are 9 out of 72 rules for which violations were observed that perform significantly better (α = 0.05) than a random predictor at locating fault-related lines. The true positive rates for these rules range from 24-100%. Second, we observed a negative correlation between MISRA rule violations and observed faults. In addition, 29 out of 72 rules had a zero true positive rate. Taken together with Adams' observation that all modifications have a non-zero probability of introducing a fault, this makes it possible that adherence to the MISRA standard as a whole would have made the software less reliable.

See also

[edit]

References

[edit]
  1. ^"MISRA clarifies safe and secure uses of the C language".misra.org.uk. Archived fromthe originalon 2020-08-04.Retrieved2019-10-09.
  2. ^In spring 1997 software engineers at theAustin Rover Group(ARG) sent a draft C coding standard to Programming Research Ltd (PRL) for review. The review was performed by PRL's then senior consultant, David Blyth, who proposed replacing the draft with an appreciably stronger set of coding rules. Those rules, with minor changes, formed the basis of the first edition of MISRA C.
  3. ^"Joint Strike Fighter Air Vehicle C++ Coding Standards"(PDF).Retrieved2019-07-16.
  4. ^"JPL Institutional Coding Standard for the C Programming Language"(PDF).Retrieved2019-07-16.
  5. ^"ISO 26262-6:2011 Road vehicles -- Functional safety -- Part 6: Product development at the software level".iso.org.ISO.Retrieved2019-07-16.
  6. ^"ISO 26262-6:2018 Road vehicles -- Functional safety -- Part 6: Product development at the software level".iso.org.ISO.Retrieved2019-07-16.
  7. ^"AUTOSAR 4.2 General Software Specification"(PDF).autosar.org.Retrieved2019-07-16.
  8. ^"AUTOSAR 4.3 General Specification of Basic Software Modules"(PDF).autosar.org.AutoSAR. 2016-11-30.Retrieved2019-07-16.
  9. ^MISRA publications
  10. ^ab"Fact Sheet: MISRA C:2012 (PDF)"(PDF).programmingresearch.Retrieved10 June2013.
  11. ^"MISRA Compliance:2016 (PDF)".MISRA.Retrieved22 July2016.
  12. ^"MISRA Compliance:2020 (PDF)"(PDF).MISRA.Retrieved8 April2020.
  13. ^"Achieving MISRA C:2012 Compliance".Parasoft.RetrievedMay 29,2017.
  14. ^"A brief history of MISRA C".MISRA. 2013-03-18.Retrieved2014-06-30.
  15. ^"MISRA C:2012 release date announced".MISRA. 26 February 2013.Retrieved10 June2013.
  16. ^"MISRA C:2012 - Amendment 1 (PDF)".MISRA. April 2016.Retrieved31 October2019.
  17. ^"MISRA C:2012 - Amendment 2 (PDF)".MISRA. February 2020.Retrieved6 January2021.
  18. ^"MISRA C:2012 - Addendum 1: Rule Mapping (PDF)".
  19. ^"MISRA C:2012 - Addendum 2: Coverage of MISRA C:2012 against ISO/IEC TS 17961:2013" C Secure "(PDF)".
  20. ^"MISRA C:2012 - Addendum 3: Coverage of MISRA C:2012 against CERT C (PDF)".
  21. ^"MISRA".
  22. ^MISRA GitLab repository
  23. ^"MISRA C FAQ list."MISRA Consortium
  24. ^"Helix QAC for C and C++ | Perforce".
  25. ^"Clearlake Capital-Backed Perforce Software to Acquire Rogue Wave Software | Perforce".
  26. ^"Klocwork for C, C++, C#, Java, and JavaScript | Perforce".
  27. ^"C/C++ Built-in Test Configurations".Parasoft. 17 October 2022.Retrieved9 March2023.
  28. ^MISRA conformance checking, PC-lint/FlexeLint, Gimpel Software.
  29. ^Languages and Standards; iar
  30. ^abLanguage subsetting in an industrial context: a comparison of MISRA C 1998 and MISRA C; Les Hatton; University of Kingston; 2004.
  31. ^Assessing the Value of Coding Standards: An Empirical Study; C.J. Boogerd and L. Moonen; Delft University of Technology; 2008.
[edit]