2.2.11 When a project is determined to have safety-critical software, the project shall ensure that the safety requirements of NASA-STD-8719.13, NASA Software Safety Standard, are implemented by the project. Engineering and software assurance initially determine software safety criticality in the formulation phase per NASA-STD-8739.8, Software Assurance Standard; the results are compared and any differences are resolved. As the software is developed or changed and the software components, software models, and software simulations are identified, the safety-critical software determination can be reassessed and applied at lower levels. Further scoping and tailoring of the safety effort is found in NASA-STD-8719.13, Software Safety Standard 271 and NASA-GB-8719.13, NASA Software Safety Guidebook. 276 Class A_SC A_NSC B_SC B_NSC C_SC C_NSC D_SC D_NSC E_SC E_NSC F G H Applicable? Key: A_SC = Class A Software, Safety-Critical | A_NSC = Class A Software, Not Safety-Critical | ... | In our modern world, software controls much of the hardware (equipment, electronics, and instruments). Sometimes hardware failure can lead to a loss of human life. When software controls, operates, or interacts with such hardware, software safety becomes a vital concern. Per NASA-STD-8719.13, "The task of developing safe software falls squarely on the shoulders of the software developer (also referred to as the software engineer), who creates the 'code' that must be safe." It is important to have a systematic, planned approach for ensuring that safety is designed into developed or acquired software, and that safety is maintained throughout the software and system life cycle. NASA-STD-8719.13 "specifies the software safety activities, data, and documentation necessary for the acquisition or development of software in a safety-critical system. Safety-critical systems that include software must be evaluated for software's contribution to the safety of the system during the concept phase, and prior to the start, or in the early phases, of the acquisition or planning for the given software." 271 Topic 7.16 - Traceability of 7150.2 to other NPRs, NASA-STDs of this Handbook includes a table, "Mapping Spreadsheet 2" that shows the relationship between the software engineering practices described in the NPR 7150.2 requirements and the software safety requirements documented in NASA-STD-8719.13. 271 Understanding these relationships can help project personnel see requests regarding software safety analysis as reasonable and know what to expect when software safety criticality assessments are conducted or repeated as the project evolves. Note that the requirements within NASA-STD-8719.13 271 must be met, how they are met is negotiable based on project criticality, size, complexity, etc. When implementing the requirements of NASA-STD-8719.13 271, follow the basic steps, with guidance provided in NASA-GB-8719.13 276, which is summarized here: The appropriate project personnel perform the following development activities to fulfill the software safety requirements: The following roles are involved in fulfilling the software safety requirements, as described in NASA-GB-8719.13. 276 Note that where independence is not required, one person may fill multiple roles; alternatively, more than one person may cooperatively fill a single role such as that of the software safety engineer. Role Responsibility Summary Project manager Maintains high-level overview of process, handles scheduling and budgeting of safety activities, assists with negotiations among team members. System engineer Designs system and partition elements between hardware and software, have "big picture" view of system and can make sure safety-critical elements are not overlooked. System safety engineer Determines which system components are hazardous, makes sure appropriate controls and mitigations are in place and verified. Software safety engineer Verifies software safety is addressed in the requirements and is designed into the software; and verifies the safety of the software. Software developer Designs, codes, tests the system, and implements defensive programming techniques. Software assurance Works with developers and safety engineers to assure safe software is created. IV&V May perform their own review of project software and present findings to project manager; IV&V occurs in addition to, not a replacement for, software assurance and software safety. When identifying software safety requirements applicable to a project, consult existing lists of software safety requirements to identify generic safety requirements. In addition, use techniques such as hazards analyses and design analyses to identify safety requirements specific to a particular project. NASA-GB-8719.13 276 provides a list of sources for generic requirements. Appendix H of that guidebook includes a checklist of generic software safety requirements from Marshall Space Flight Center (MSFC). Remember to include risk as a factor when determining which requirements are more critical than others. When developing safety-critical software, the project needs to: If the project involves programmable logic devices, consult NASA-HDBK-8739.23, NASA Complex Electronics Handbook for Assurance Professionals. 034 For tools that are used in the development of safety-critical software, including compilers, linkers, debuggers, test environments, simulators, code generators, etc., consider the following: If the project involves off-the-shelf (OTS) or reused software, the project needs to: For other OTS considerations that could affect safety, see SWE-027. For contractor-developed software, the project: MSFC's Software Development Process Description Document 001 on the NASA PAL notes in section 8.10.3: If the product is classified as 'safety critical' per NASA-STD-8719.13, then the supplier agreement must include safety requirements. In addition, a process is established to monitor that the safety requirements are traced and satisfied. Note: The safety requirements can be included with the other supplier requirements, but must be annotated as safety critical. Software safety activities to be performed by a supplier (e.g., an outside specialist) are noted in the appropriate supplier agreement and approved by Senior Management. For additional considerations when acquiring safety-critical software, see Topic 7.03 - Acquisition Guidance. Training in software safety is available in the NASA SMA Technical Excellence Program (STEP). 294 These topics and more are expanded in NASA-GB-8719.13. 276Consult the guidebook for additional guidance, techniques, analysis, references, resources, and more for software developers creating safety-critical software as well as guidance for project managers, software assurance personnel, system engineers, and safety engineers. Knowledge of the software safety tasks performed by persons in roles outside of software engineering will help engineering personnel understand requests from these persons for software engineering products and processes. Additional guidance related to software safety may be found in the following related requirements in this Handbook: Coding Standards Develop a software safety plan Software Safety Determination Safety Critical Software Requirements Software Safety Plan Contents While the requirements of NASA-STD-8719.13B 271must be met, they can be modified to the project size and criticality. The specific activities and depth of analyses needed to meet the requirements can, and should, be modified to the software safety risk. In other words, while the requirements must be met, the implementation and approach to meeting those requirements may and should vary to reflect the system to which they are applied. Substantial differences may exist when the same software safety requirements are applied to dissimilar projects. Appendix A of NASA-STD-8719.13 271provides guidance for how a sample, medium-sized project might meet the requirements. For projects designated as small project based on personnel or budget, the following options may be considered to assist in the fulfillment of this requirement: Tools to aid in compliance with this SWE, if any, may be found in the Tools Library in the NASA Engineering Network (NEN). NASA users find this in the Tools Library in the Software Processes Across NASA (SPAN) site of the Software Engineering Community in NEN. The list is informational only and does not represent an “approved tool list”, nor does it represent an endorsement of any particular tool. The purpose is to provide examples of tools being used across the Agency and to help projects and centers decide what tools to consider. The NASA Lesson Learned database contains the following lessons learned related to software safety: View this section on the website
See edit history of this section
Post feedback on this section
1. Requirements
1.1 Notes
1.2 Applicability Across Classes
- Applicable |
- Not Applicable
X - Applicable with details, read above for more | P(C) - P(Center), follow center requirements or procedures
2. Rationale
3. Guidance
4. Small Projects
5. Resources
5.1 Tools
6. Lessons Learned
SWE-023 - Software Safety
Web Resources
Unknown macro: {page-info}