bannera

Book A.
Introduction

Book B.
7150 Requirements Guidance

Book C.
Topics

Tools,
References, & Terms

SPAN
(NASA Only)

Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.
Wiki Markup
{alias:SWE-075}
{tabsetup:1. The Requirement|2. Rationale|3. Guidance|4. Small Projects|5. Resources|6. Lessons Learned}

{div3:id=tabs-1}

h1. 1. Requirements

3.5.2 The project shall plan software operations, maintenance, and retirement activities.      

h2. {color:#003366}{*}1.1 Notes{*}{color}

NPR 7150.2 does not include any notes for this requirement.

h2. 1.2 Applicability Across Classes

{applicable:asc=1|ansc=1|bsc=1|bnsc=1|csc=1|cnsc=1|dsc=1|dnsc=0|esc=1|ensc=0|f=1|g=p|h=0}

{div3}
{div3:id=tabs-2}

h1. 2. Rationale

Per Marshall Space Flight Center's "Software Development Process Description Document", "The Software Operation phase spans the time from execution of the software product in the target environment to software retirement. The Software Maintenance phase of the software life cycle begins after successful completion of formal test and delivery of the software product to the customer. This Software Maintenance phase overlaps the Software Operation phase and continues until software retirement or discontinuation of software support."^1^

As with any activity that builds on and relies on previous activities, software operations, maintenance, and retirement requires planning before implementation.  The team documents and review those plans before they are implemented to allow its members to consider all the tasks, personnel, methods, tools, facilities and related criteria needed to perform those activities.  


{div3}
{div3:id=tabs-3}

h1. 3. Guidance

The results of planning for operations, maintenance and retirement of software are captured in the Software Maintenance Plan for implementation.  In addition to the required contents for the Software Maintenance Plan ([SWE-105]) and the items listed in this handbook's guidance for requirement [SWE-074], consider the following items for each phase of planning:

+Operations+

* Software team support of operations, including help desk activities, as applicable
* Documentation required for operations support (e.g., as-built documentation, user's manual, source code, operations notes)
* Tools required for operations support (e.g., email systems, servers, issue tracking systems)
* Participation in mission debriefs, as appropriate{^}1^
* Capturing of lessons learned during operations
* Software assurance, including software safety, monitoring activities

+Maintenance+

* Modification of software after delivery
* Updates to system and software documentation to align with/reflect these modifications
* Documenting, reviewing, analyzing, and approving modifications (i.e., configuration management of changes) 
* Tools required for maintenance activities (e.g., issue tracking systems, analysis tools, configuration control systems, compilers) 
* Other resources required to perform maintenance activities such as documentation, development environment, test environment
* Testing of modifications
* Delivery and installation of modifications, including generation of associated documentation such as version description documents (VDD)
* Capture of maintenance metrics{^}1^
* Software assurance and software safety activities for updates

+Retirement+

* Archival of software products, including capture in a configuration management system{^}1^
* Retention period for retired software products{^}1^
* Tools needed to complete retirement activities (e.g., configuration management system) 
* Security measures for access to and use of retired software products
* Transition plans for functionality and data if software being retired is being replaced by another software product

The following personnel roles should be considered for involvement in the planning of operations, maintenance, and retirement activities:

* Software project lead
* Software team
* Project manager

Planning for maintenance activities, in particular, should begin very early in the software development life cycle so that the software is designed for maintainability{^}4^.  For NPR 7120.5 projects, this Handbook provides the recommended maturity of the Software Maintenance Plan at major milestone reviews (see [Maturity of Life cycle Products at Milestone Reviews|http://nasa7150.onconfluence.com/display/7150/7.4+-+Maturity+of+Life+Cycle+Products+at+Milestone+Reviews]). The lifetime of use for software is not always known, so maintenance becomes easier if the software is designed with maintenance in mind.  If there are specific design features that facilitate easier maintenance, those may be candidates for referencing in the Software Maintenance Plan. 

{panelnote} Consult Center Process Asset Libraries (PALs) for Center-specific guidance related to planning operations, maintenance, and retirement. {panelnote} 

Additionally, guidance related to operations, maintenance, and retirement planning may be found in the following requirements in this handbook:

|[SWE-074]|Document Maintenance Plan|
|[SWE-076]|Implement Operations, Maintenance, and Retirement Activities|
|[SWE-105]|Software Maintenance Plan|

{div3}
{div3:id=tabs-4}

h1. 4. Small Projects

No additional guidance is available for small projects.  The community of practice is encouraged to submit guidance candidates for this paragraph.

{div3}
{div3:id=tabs-5}

h1. 5. Resources

# Flight and Ground Software Division, MSFC, ["Software Development Process Description Document"|https://nen.nasa.gov/web/software/nasa-software-process-asset-library-pal?p_p_id=webconnector_WAR_webconnector_INSTANCE_PA7b&p_p_lifecycle=1&p_p_state=normal&p_p_mode=view&p_p_col_id=column-2&p_p_col_count=1&_webconnector_WAR_webconnector_INSTANCE_PA7b_edu.wisc.my.webproxy.URL=https%3A%2F%2Fnx.arc.nasa.gov%2Fnx%2Fdsweb%2FGet%2FDocument-499471%2FSDPDD_Rev%2BQ_080207.pdf], EI32-OI-001, Revision R, 2010 .
#	NASA Technical Standard, ["NASA Software Assurance Standard"|https://standards.nasa.gov/documents/detail/3315130], NASA-STD-8739.8, 2004.
#	NASA Technical Standard, ["NASA Software Safety Standard"|https://standards.nasa.gov/documents/detail/3314914], NASA-STD-8719.13B, 2004.
#	NASA Technical Standard, ["NASA Software Safety Guidebook"|https://standards.nasa.gov/documents/detail/3315126], NASA-GB-8719.13, 2004.
#	["Systems and software engineering - Software life cycle processes"|http://ieeexplore.ieee.org/stamp/stamp.jsp?tp=&arnumber=4475826&tag=1], ISO/IEC 12207, IEEE Std 12207-2008, 2008.  This link requires an account on the NASA START (AGCY NTSS) system [(http://standards.nasa.gov )|http://standards.nasa.gov/].  Once logged in, users can access Standards Organizations, IEEE and then search to get to authorized copies of IEEE standards. 
#	IEEE Computer Society, ["IEEE Standard for Software and System Test Documentation"|http://ieeexplore.ieee.org/stamp/stamp.jsp?tp=&arnumber=4578383&tag=1], IEEE Std 829-2008, 2008. This link requires an account on the NASA START (AGCY NTSS) system [(http://standards.nasa.gov)|http://standards.nasa.gov/].  Once logged in, users can access Standards Organizations, IEEE and then search to get to authorized copies of IEEE standards.
#	Software Engineering Division, Goddard Space Flight Center, ["In-house Software Development and Maintenance"|http://software.gsfc.nasa.gov/AssetsApproved/PA1.0.2.doc], GPR 7150.2, Version 20110110-1, 2009.
#	Software Engineering Institute, ["CMMI for Development, Version 1.3"|http://www.sei.cmu.edu/reports/10tr033.pdf], CMU/SEI-2010-TR-033, 2010.
#	International Standards Organization (ISO), ["Software Engineering - Software Life Cycle Processes - Maintenance"|http://ieeexplore.ieee.org/stamp/stamp.jsp?tp=&arnumber=1703974&tag=1], ISO/IEC 14764:2006, 2006. This link requires an account on the NASA START (AGCY NTSS) system [(http://standards.nasa.gov)|http://standards.nasa.gov/].  Once logged in, users can access Standards Organizations, IEEE and then search to get to authorized copies of IEEE standards.

{toolstable}

{div3}
{div3:id=tabs-6}

h2. 6. Lessons Learned

The NASA Lesson Learned database contains the following lessons learned related to maintenance planning:

*	*Benefits of Maintainability on NASA Programs*: Lesson Number: 0835 "Maintainability requirements for programs that require ground and/or in-space maintenance and anomaly resolution have to be established early in the program to be cost effective. Lack of management support to properly fund maintainability activities up-front can result in increased program risk. Including maintainability in the design process will greatly reduce the number of operational problems associated with system maintenance, improve the availability of the system, and reduce program costs." [(http://www.nasa.gov/offices/oce/llis/0835.html)|http://www.nasa.gov/offices/oce/llis/0835.html]
 
*	*Software Design for Maintainability*:  Lesson Number: 0838 "Because of increases in the size and complexity of software products, software maintenance tasks have become increasingly more difficult. Software maintenance should not be a design afterthought; it should be possible for software maintainers to enhance the product without tearing down and rebuilding the majority of code." [(http://www.nasa.gov/offices/oce/llis/0838.html)|http://www.nasa.gov/offices/oce/llis/0838.html]


{div3}
{tabclose}