2.2.1.2 For safety-critical software, the project shall develop a software safety plan.
1.1 Notes
The requirement for the content of the software safety plan (whether stand-alone or condensed into one or more project level or software documents) is defined in Chapter 5 [section 5.1.9 of NPR 7150.2, NASA Software Engineering Requirements]. NASA-STD-8719.13 [NASA Software Safety Standard] contains detailed requirements
sweref
271
271
and guidance on development of software safety plans. Software engineering and the software safety disciplines jointly are responsible for providing project management with the optimal solution for software to meet the engineering, safety, quality, and reliability needs of the project.
Typically, Class F through H software is not considered safety critical; however, a piece of non-engineering software (Class F through H) could have a safety critical nature to it. One example is an emergency notification system for natural disasters. In this example, if the software did not work it could result in loss of life or injury or significant impact to assets. For this reason, this requirement includes applicability for safety critical Class F through H.
1.2 Applicability Across Classes
This requirement applies to all classes and safety criticalities includingsafety criticalClass F thru H, with exceptions noted in the following table:
applicable
f
1
g
1
h
1
asc
1
ansc
1
bnsc
1
csc
1
bsc
1
esc
1
cnsc
0
dsc
1
dnsc
0
ensc
0
Div
id
tabs-2
2. Rationale
The project team creates the Software Safety Plan to define the processes, risks, resources, stakeholders, interfaces, and safety design methodologies, necessary for the development of the software. The development of this plan allows for the review and agreement of the approach prior to implementation. NASA-STD-8719.13
sweref
271
271
defines the contents of the Software Safety Plan.
Effective planning assures that adequate safety features are included within the system and software. Developing a plan early in the project ensures that software safety will be an integral part of the software development or acquisition process.
Div
id
tabs-3
3. Guidance
NASA-STD-8719.13
sweref
271
271
defines the contents of the Software Safety Plan, and identifies who approves/concurs on it. The format for a Software Safety Plan is not mandated by this NPR or NASA-STD-8719.13. The project team checks with the Center's Safety and Mission Assurance (S&MA) organization for possible format requirements.
Based on the size and complexity of a project, the Software Safety Plan can be an independent document or part of another software document, such as a Software Assurance Plan, software development plan, or a software management plan.
If a project transitions from non-safety-critical to safety-critical, the project team will need to create the Software Safety Plan that includes the past, the transition, and the forward plan for meeting software safety requirements.
Best practices
Because the Software Safety Plan covers the life cycle of the project, it is periodically evaluated as the project matures, to verify accuracy and continued implementation approaches. Typically, the project and the responsible software assurance engineer perform the evaluation at major milestone reviews. See Topic 7.8 - Maturity of Life Cycle Products at Milestone Reviews to determine the state of maturity of the Software Safety Plan at the various Milestone Reviews.
Div
id
tabs-4
4. Small Projects
For small projects, the safety plan may be part of an overall project management plan.
Div
id
tabs-5
5. Resources
refstable
toolstable
Div
id
tabs-6
6. Lessons Learned
No lessons learned have currently been identified for this requirement.