

CubeSat Flight Software Workshop

# FSW Development Process

Aadil Rizvi Flight Software Engineer 6/3/2019



# **Agenda**

#### FSW Development Process Overview

#### FSW Subsystem Level Process

- Requirements Phase
- Prototyping
- Design Phase
- Implementation Phase
- Version Control
- Verification Phase
- Delivery Review
- Change Requests and Maintenance

#### Component Level Process

- Software Design Document
- Implementation
- Unit Testing
- Integrated Testing
- Code Analysis and Review
- Checklist

#### Status Reports

- Weekly Progress Summary
- Issue Tracking

# **FSW Development Process Overview**

Student CubeSat Project Timeline



### **FSW Development Process Overview**

Why is it important to have a development process?

#### Increases: -

- Reliability
- Testability
- Maintainability
- Portability
- Waterfall model fits in line with deadline driven development
- The right level of process is important
  - Too much process can bog you down
  - Too little process makes it impossible to manage a complex project
  - Either can lead to bad outcomes



Waterfall Model (Peter Kemp / Paul Smith [CC BY 3.0])

### **FSW Development Process Overview**

### **Development Phases**

Requirements

- Provide measurable constraints and characteristics from concept of operations

Design

- Provides blue print for software implementation given a set of requirements

Implementation

- Provides a testable product for verification

Verification

- Ensures implementation functionality and correctness

• Each phase has a review to ensure readiness for the next phase and address any issues

### Requirements Phase

- Why is it important to gather requirements: -
  - Map from concept of operations to specific capabilities that can be designed and implemented
  - Manages assumptions
  - Heads off disagreements/misunderstanding between designers/implementors and their stakeholders
    - "That's not what I wanted you to build!" Or
    - "That's not how I assumed it would work!"
  - Provides the structure for
    - Measuring progress of design and implementation
    - Verifying that we have built/delivered what is needed

### **Requirements Derivation**

- Understand project level requirements and concept of operations (ConOps) i.e. what is needed for the project
  - Decompose into various software components at high level
  - Functional breakdown rather than design
- Artifact: Requirements specification document
- Conduct review of requirements

#### Example requirement

| FSW Interfaces |                                       |                                                 |                                                |                      |              |                                                        |  |
|----------------|---------------------------------------|-------------------------------------------------|------------------------------------------------|----------------------|--------------|--------------------------------------------------------|--|
| REQ ID         | EQ ID Short Title Level 4 Requirement |                                                 | Rationale                                      | L3 Parent            | V&V Strategy | V&V Plan                                               |  |
|                |                                       |                                                 |                                                |                      |              |                                                        |  |
|                |                                       |                                                 |                                                |                      |              |                                                        |  |
|                |                                       |                                                 |                                                |                      |              | Test uplink frame formats with GDS. Both command       |  |
|                |                                       | The FSW shall interface with the XYZ radio over |                                                |                      |              | and file uplink frames will be tested for appropriate  |  |
|                |                                       | an SPI connection to perform uplink for ground  | FSW must provide software interface to receive |                      |              | decoding and execution. Part of FSW Rel-1.0 integrated |  |
| L4-FSW-1       | Radio Uplink Interface                | commands and files                              | uplinked data                                  | L3-FSW-34, L3-FSW-35 | Test         | testing.                                               |  |

What makes a good requirement?

### Proof of concept and Prototyping

- Target OS and hardware platform
- Compile and execute software on target
- Communicate over planned interfaces
- Data bandwidth and performance analysis



### **Design Phase**

- Trade studies and prototyping
- Component list
  - Services
  - Communication
  - Hardware managers
  - Hardware drivers
  - Guidance and control
  - Science
  - Fault protection and mode management
- Various design views
  - Block diagrams
  - Sequence diagrams
  - Data flow diagrams
  - State transition diagrams
  - Class diagrams
- Resource utilization, performance and concurrency issues discussion
- List of planned releases

Conduct design review
Artifact: software architecture and design documentation

### Implementation Phase

- Coding
  - With good design, this should not be too complicated
  - May require design updates
  - Majority of design expected to be completed in design phase
- Unit Testing
  - Component level
- Deployment
  - Functional integration of software components
- Conduct code reviews

### **Version Control**



#### Verification Phase

- Critical to overall software functionality and mission success
- Catching bugs early is cheaper and easier to fix
- Driven by requirements verification
  - · Performed using test scripts executed against a release deployment

#### Artifact: Requirements verification and validation matrix

| REQ ID                 | Short Title                  | Level 4<br>Requirement                                                                                                                        | Rationale                                                                                | L3<br>Parent          | V&V<br>Strategy | Status | V&V IDs                                          |
|------------------------|------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------|-----------------------|-----------------|--------|--------------------------------------------------|
| NEASC-<br>L4-<br>FSW-3 | Data<br>Storage<br>Interface | The FSW shall interface with the non-volatile data storace memory on board the flight CDH unit for read/write access for atleast 4 GB] bytes. | FSW needs<br>access to<br>this memory<br>to manage<br>science and<br>engineering<br>data | NEAS-<br>FS-L3-<br>32 | Test            | PASS   | jpl_ffs-VI-1 thru<br>jpl_ffs-VI-7,<br>prmDb-VI-1 |

### **Delivery Review**

- Release description document (RDD)
  - Change log
  - Version Identification
  - Project Overview and Release Description
  - Controlling Documents
  - Test Reports
  - Requirements Verification Summary
  - Idiosyncrasies and Known Issues
  - Problem Disposition
  - Detailed Contents
- Users guide
  - Operational constraints
  - Usage guidelines
- Software design documents

### Change Requests and Maintenance



### Software Design Document

- Component overview
- Component level requirements
- Design
  - Component block diagram
  - Sequence, dataflow, state transition, class diagrams
  - Port List
  - Custom data types
  - State
  - Port Behaviors
  - Commands
  - Telemetry
  - Events
- Unit Test Output and Coverage Results
- Reference datasheets and other technical documents as applicable

### **Implementation**

- Port handler behaviors
- State management
- Command handlers
- Telemetry & events
- Topology integration
- Build with deployment

### **Unit Testing**

- F Prime unit test harness
- Traceability to component level requirements
- Code coverage analysis
- Unit test output and coverage results

### **Integrated Testing**

- Test venue
- Test scripts
- Test reports
- Requirements V&V





### Code Analysis and Review

- Static analysis tools
  - Coverity
  - Semmle
  - Power of 10 rules
  - GCC (compiler)
- Code peer review
- GitHub pull request

### Checklist

| Component: FSW/Components/FSWImageManager                                                    |        |              |
|----------------------------------------------------------------------------------------------|--------|--------------|
| Component Owner: John                                                                        |        |              |
| Component Contributors: Mike, Peter                                                          |        |              |
|                                                                                              | Status | Notes        |
| Modeling                                                                                     |        |              |
| Model generated in MagicDraw with interfaces defined                                         | YES    |              |
| Component auto-coded using component autocoder                                               | YES    |              |
| Auto-coded component builds successfully for SPHINX platform                                 | YES    |              |
| Implementation                                                                               |        |              |
| Behaviors, states, commands, telemetry, and events implemented                               | YES    |              |
| Component builds with the topology                                                           | YES    |              |
| Deployment                                                                                   |        |              |
| Static analysis of code performed using SCRUB                                                | YES    |              |
| Component Unit Tested                                                                        | YES    |              |
| Executes with topology on SPHINX platform without any issues                                 | YES    |              |
| Close-Out                                                                                    |        |              |
| SDD generated                                                                                | YES    |              |
| Component reviewed by peer(s)                                                                | YES    | Peers: David |
|                                                                                              |        |              |
| All open issues and action items related to the component have been addressed and closed out | YES    |              |

# **Status Reports**

### Weekly Progress Summary

- Highlight accomplishments and progress
- Indicate delays in receivables
- Describe pending items
- Estimated upcoming release delivery date
- Describe current progress against development plan schedule
- Communicate problems to stakeholders early on to facilitate timely action

### **Status Reports**

### **Issue Tracking**

- Track current progress to know how we're doing
- Estimate delivery dates and forecast delivery slips early on

| Toket Name                                                                     | Persont Complete (%) | Mischane              | Ectionate | Actual Completion Date | FYSS Replan VS Date | PY18 Region V2 Date | Original Man |
|--------------------------------------------------------------------------------|----------------------|-----------------------|-----------|------------------------|---------------------|---------------------|--------------|
| FSW Rel-1.0 Build, Execution and Integrated Testing                            | 300                  | 15W Ret-Lit Delivery  |           | 2 8/31/1               | 1                   |                     | 8/15/11      |
| SPI Interface Testing                                                          | 500                  | FSW Rel-2.0 Delivery  |           | 1 1/36/1               | 0.                  |                     | 1/1/10       |
| Power Switch Testing                                                           | 500                  | ISW Ball 2.0 Delivery |           | 3 13/4/1               |                     |                     | 11/4/12      |
| Propulsion interface                                                           | 300                  | 15W Rel-2.0 Delivery  |           | 4 1/29/1/              |                     |                     | 1/15/18      |
| Power EPS testing with FSW                                                     | 200                  | FSW Rel-2.0 Delivery  |           | 3 3/29/1               |                     |                     | 1/15/1       |
| Temp sensor testing with ADCs                                                  | 500                  | FSW Reli-2 O'Delivery |           | 1 11,49/1              | ,                   |                     | 10/11/1      |
| Update CridSequencer with AMPCS SOVF format.                                   | 500                  | 15W Rel-2.0 Delivery  |           | 3 3/36/1/              |                     |                     | 1/7/1        |
| Update GerMontar and EuConverter Database Files (Rel J.0)                      | 300                  | FSW Rel-LO Delivery   |           | 1 3/29/1               |                     |                     | 1/19/1       |
| Update bac block map for Sphinx (DM)                                           | 300                  | FSW Rel-1.0 Delivery  |           | 1 10/31/1              |                     |                     | 10/31/1      |
| Update and test file rystem with full BGB NAND flash                           | 500                  | TSW Rel-2.0 Delivery  |           | 1 11/9/1               |                     |                     | 11/1/1       |
| Tost XACT -Prop-Component with EOU                                             | 300                  | TSW Rel-1.0 Delivery  |           | 3 1/8/1                |                     |                     | 1/1/1        |
| F5W Rel-2.0 Build, Execution and Integrated Testing                            | 200                  | 150/ Rel-2.0 Delivery |           | 4 2/1/1                |                     |                     | 2/1/1        |
| FP Manager                                                                     | 500                  | FSW Rel-1.0 Delivery  |           | 2 3/6/11               |                     | 2/23/16             |              |
| Mode Manager                                                                   | 500                  | FEW Reli 3.0 Delivery |           | 2 3/13/10              | 0                   | 3/9/14              | K.           |
| FF State Manager                                                               | 300                  | 15W Ref-3.0 Delivery  |           | 2 4/12/10              |                     | 4/4/18              |              |
| FSW Rel-3.0 Build, Execution and integrated Testing                            | 300                  | FSW Rel-1.0 Delivery  |           | 4 4/17/11              |                     | 4/17/18             |              |
| Instrument Electronics Interface                                               | 300                  | ISW Rel-4.0 Delivery  |           | 4 8/7/1                |                     | 3/23/34             |              |
| F7 State Manager Updates                                                       | 300                  | 15W Rel-4.0 Delivery  |           | 2 8/7/1                |                     | 6/13/14             |              |
| Update GerMonitor and EuConverter Database Files for flight                    | 500                  | FSW Rel-4.0 Delivery  |           | 1 6/29/1/              |                     | 4/13/14             | k.           |
| Re-map power rwitches and ADC Channels                                         | 500                  | FSW Rel-4.0 Delivery  |           | 1 7/9/1                |                     | 6/79/16             | i)           |
| FSW Rel-4.0 Build, Execution and integrated Testing                            | 100                  | 15W Rel-4.0 Delivery  |           | 3 4/30/1               |                     | 7/6/14              | 1            |
| Payload Interface Updates                                                      | 300                  | ISW Rel-4.1 Delivery  |           | 1                      |                     | 3/12/18             | i .          |
| Bootloader for VvWorks+FSW                                                     | 500                  | PSW Rel-4.1 Delivery  |           | 3                      |                     | 9/19/18             | k.           |
| FIRST Rel-4.1 Build, Execution and integrated Testing (Psyload interface only) | 300                  | 15W Rel-4.3 Delivery  |           | 2 33/35/31             |                     | 9/26/18             |              |
| XACT interface updates for fault protection                                    | 300                  | FSW Rel-4.2 Delivery  |           | 4 4/8/15               | 4/8/                | 19 1/11/19          |              |
| PWM Duty Oxiling                                                               | 500                  | FSW Rel-4.2 Delivery  |           | 2 1/15/19              |                     | 1/17/18             |              |
| Iris Temperature Conversions                                                   | 500                  | FEW Rel: 4.2 Delivery |           | 1 4/10/1               | 4/11/               | 1/17/18             |              |
| HIS VZ.1 KeyC updates in FSW                                                   | 300                  | 15W Rel-4.2 Delivery  |           | 2 3/32/15              | 4/11/               | 29                  |              |
| Update Image Burn Process                                                      | 50                   | FSW Rel-4.2 Delivery  |           | 3 4/18/11              | 4/18/               | 19                  |              |
| FISH Rel-4.2 Build, Execution and Integrated Testing (KACT Interfaces only)    | 30                   | FSW Rel-4.2 Delivery  |           | 2                      | 5/23/               | 1/25/10             |              |
| Prop Interface updates for fault protection                                    | 32                   | 15W Rd-4.3 Delivery   |           | 4                      | 6/35/               | 19                  |              |
| FSW Rel-4.3 Build, Execution and Integrated Testing (Prop Interfaces only)     | 0                    | TSW Rel-4.3 Delivery  |           | 2                      | 7/26/               | 19                  |              |
| Bug Fixes, updates and change requests post FSW Rel-4.0                        | 0                    | 15W Rel-5.0 Delivery  |           | 1                      | 6/12/               | 16 2/9/16           |              |
| FSW Rel-5.0 Build. Execution and integrated Testing                            | . 0                  | 75W Rel-5.0 Delivery  |           | 1                      | 10/4/               | 19 8/12/19          |              |



**Completion Points** 

ZenHub Pipelines

# **Status Reports**

### Issue Tracking



Total Planned Completion
Points for Rel-1.0 = 17



jpl.nasa.gov