Featured Webinar: Simplify Compliance Workflows With New C/C++test 2024.2 & AI-Driven Automation Watch Now
AUTOSAR C++14
AUTOSAR (AUTomotive Open System ARchitecture) is a worldwide development partnership of OEM manufacturers, Tier 1 automotive suppliers, semiconductor manufacturers, software suppliers, tool suppliers, and others that focus on establishing and standardizing automotive software architecture.
Adaptive AUTOSAR defines a platform for developing automotive control units, which provide sophisticated functionalities like advanced driving assistance systems, media streaming, or software updates via the internet. The platform contains the specification of interfaces that define services and APIs for building modern automotive systems.
A key component of AUTOSAR Adaptive Platform is AUTOSAR C++14 coding standard that defines guidelines for the use of the modern C++ language in critical and safety-related systems. This is the only standard on the market that supports modern C++. The standard is well documented and provides traceability to the other existing C++ standards, such as HIC++ 4.0, JSF, SEI CERT C++, C++ Core Guidelines, and to MISRA C++ 2008.
In Jan 2019, MISRA consortium announced the integration of AUTOSAR C++ 14 coding guidelines with MISRA. The MISRA Working Group will continue releasing new C++ industry standards and incorporate the latest version of C++ language, C++ 17, and its successor, C++20, later.
Parasoft C/C++test, a unified testing tool for C/C++ development, and Parasoft DTP, a reporting and analytics dashboard, provide a comprehensive solution to help organizations overcome the challenges associated with automotive software quality and compliance. C/C++test and DTP support AUTOSAR C++ 14 (19.03) with the most comprehensive coverage of static analysis checkers for the AUTOSAR C++14 guidelines and unique compliance reporting.
AUTOSAR C++14 Compliance
AUTOSAR C++14 does not provide explicit guidance on the process of achieving compliance. However, given that AUTOSAR C++ 14 guidelines are based on MISRA C++ 2008, it’s reasonable to refer to the MISRA compliance guidelines for guidance on achieving compliance.
The desired situation is to have a static analysis tool that covers as many guidelines as possible. The rules that cannot be enforced with static analysis will require manual reviews, which are expensive.
As with MISRA C compliance, a deviation handling procedure needs to be established. The deviation procedure formalizes the steps that need to be taken when development needs to deviate from a specific guideline. As MISRA prescribes, it’s expected that “…the procedure will be based around obtaining a sign-off for every deviation or class of deviations.”
This is a particularly important piece of the puzzle. It prevents abusing the deviation concept by developers deviating at will. Effectively, you’ll need formal tickets stored in your system that document every deviation in the source code. The same pertains to the compliance matrix and any additional configurations and process descriptions created to enforce compliance. MISRA C++2008 is truly clear here and requires “formalization within quality system.”
Finally, if all the procedures described in MISRA C++ 2008 point 4.3 are in place for AUTOSAR C++14, we can claim compliance by demonstrating:
- A compliance matrix has been completed that shows how compliance has been enforced.
- All the C++ code in the product is compliant with the rules of AUTOSAR C++ 14 document. If not, they are documented deviations.
- A list of all instances of the rules not being followed is maintained and for each instance, there is an appropriately signed-off deviation.
Support for AUTOSAR C++14 in Parasoft C/C++test
The only practical way to enforce compliance with a coding standard like AUTOSAR C++14 is with a static analysis tool, like Parasoft C/C++test, a code quality tool supporting multiple testing technologies. Parasoft C/C++test support for AUTOSAR C++14, provides a set of built-in checkers (rules) for verifying compliance with standards including MISRA C 2023, MISRA C++ 2023, MISRA C 2012, MISRA C++ 2008, JSF AV C++, SEI CERT C/C++, HIC++, CWE Top 25, CWE On the Cusp, OWASP, and more.
Parasoft compliance packs provide users with standard specific configurations, automatic generation of compliance documentation, risk assessment framework, and dynamic compliance reporting dashboards (DTP) to help stakeholders easily aggregate, correlate, and apply analytics to centralize reporting for each step along the complex software supply chain.
Elevate your software testing with Parasoft solutions.
Explore the Chapters
- Introduction »
- 1. Overview »
- 2. Static Analysis »
- 3. MISRA »
- 4. AUTOSAR C++ 14 »
- 5. SEI/CERT »
- 6. CWE »
- 7. Unit Testing »
- 8. Regression Testing »
- 9. Software Integration Testing »
- 10. Software System Testing »
- 11. Structural Code Coverage »
- 12. Requirements Traceability Matrix »
- 13. Tool Qualification »
- 14. Reporting & Analytics »