F´ Flight Software - C/C++ Documentation NASA-v1.6.0
A framework for building embedded system applications to NASA flight quality standards.
|
The RateGroupDriver Component is used to take a single system tick and distribute it to multiple rate groups in a system. It takes the input Svc::Sched
port, then divides down the tick rate based on arguments to the constructor. Typically, the output ports would be connected to the asynchronous inputs of an ActiveRateGroup
.
The requirements for RateGroupDriver are as follows:
Requirement | Description | Verification Method |
---|---|---|
RGD-001 | The 'Svc::RateGroupDriver' component shall divide a primary system tick into the needed rate groups | Unit Test |
RCD-002 | The 'Svc::RateGroupDriver' component shall be able to run in ISR context | Inspection |
The Svc::RateGroupDriver component has the following component diagram:
The Svc::RateGroupDriver component uses the following port types:
Port Data Type | Name | Direction | Kind | Usage |
---|---|---|---|---|
Svc::Cycle | CycleIn | Input | Synchronous | Receive the system tick |
Svc::Cycle | CycleOut | Output | n/a | Used to drive rate groups |
The Svc::RateGroupDriver component has one input port that receives a system tick.
The configure()
function is passed an array of integer arguments that specifies the divisors for each output port. This should be called after the constructor but before any port calls are made. The contents of the array are copied during the call, so the array can be a temporary variable.
The input rate for each output port will be divided down by the value in the dividers[]
array corresponding to the output port number.
The implementation will be ISR compliant by avoiding the following:
For instance,
SchedIn Rate | divider[0] | SchedOut[0] | divider[1] | SchedOut[1] | divider[2] | SchedOut[2] |
---|---|---|---|---|---|---|
1Hz | 1 | 1Hz | 2 | 0.5Hz | 4 | 0.25Hz |
As described in the Functional Description section, the RateGroupDriver component accepts calls to the SchedIn and divides them down to the SchedOut ports:
RateGroupDriver has no state machines.
RateGroupDriver has no significant algorithms.
No dictionary for this module
Document | Link |
---|---|
Design Checklist | Link |
Code Review Checklist | Link |
Unit Test Checklist | Link |
To see unit test coverage run fprime-util check –coverage
Date | Description |
---|---|
6/19/2015 | Design review edits |
7/22/2015 | Design review actions |
9/2/2015 | Unit test updates |