Skip to content

Communication Adapter Interface

Any communication component (e.g. a radio component) that is intended for use with the standard F´ uplink and downlink stack should implement the Communication Adapter Interface ComInterface.fppi. This interface specifies both the ports and protocols used to operate with the standard F´ uplink and downlink components.

Implementors of this interface are referred to as Communication Adapters.

Communication Adapter Interface

The communication adapter interface protocol is designed to work alongside the framer status protocol and the com queue protocol to ensure that data messages do not overload a communication interface. These protocols are discussed below.

Ports

The Svc.ComDataWithContext port type is used to transmit comms data between components of the F´ system. This port type is composed of a Fw::Buffer object and a ComCfg::FrameContext object. The Fw::Buffer object is used to transmit the data, while the ComCfg::FrameContext object is used to provide context for the data being transmitted, such as header information once the header has been consumed.

The communication adapter interface is composed of five ports. These ports are used to transmit outgoing data through some communication hardware and receive incoming data from that same hardware. These ports share types with the byte stream driver model for backwards compatibility.

Kind Suggested Name Port Type Description
input dataIn Svc.ComDataWithContext Port receiving data for outgoing transmission (to be sent on the wire)
output dataOut Svc.ComDataWithContext Port producing data from incoming transmissions (received on the wire)
output dataReturnOut Svc.ComDataWithContext Port for sending back ownership of the Fw::Buffer received on the dataIn port
input dataReturnIn Svc.ComDataWithContext Port for receiving back ownership of the Fw::Buffer sent on the dataOut port
output comStatusOut Fw.SuccessCondition Port indicating status of outgoing transmission. See protocol.

Note

About buffer management: after receiving a buffer on the dataIn port, the communication component must return ownership of said buffer through the dataReturnOut port. The common scenario is to connect dataIn and dataReturnOut to the same component, so that the sender can handle deallocation. This is done with a callback so that dataIn can be an asynchronous port if needed. Similarly, the buffer sent out on dataOut is expected to be returned through the dataReturnIn port.

dataIn Description

This port receives data from an F´ application in the form of an argument of Fw::Buffer type and a ComCfg::FrameContext context. This data is intended to be sent out the communications interface managed by this component (often referred to as the wire). From the perspective of the application this is the outgoing data port.

dataOut Description

This port produces data to the F´ application once it is received on the wire. From the perspective of the application this is the incoming data port.

dataReturnOut Description

This port is used to send a callback returning ownership of the Fw::Buffer object that was received on the dataIn port. Ownership is typically returned to the sender. A callback is used so that dataIn may be an asynchronous port if needed.

dataReturnIn Description

This port is used to receive a callback returning ownership of the Fw::Buffer object that was sent on the dataOut port. Ownership is typically returned from the receiver of dataOut. A callback is used so that dataOut may be an asynchronous call if needed.

comStatusOut Description

This port carries a status of Fw::Success::SUCCESS or Fw::Success::FAILURE typically in response to a call to the dataIn port described above.

Note

it is critical to obey the protocol as described in the protocol section below.

Communication Queue Protocol

Svc::ComQueue queues messages until the communication adapter is ready to receive these messages. For each Fw::Success::SUCCESS message received, Svc::ComQueue will emit one message. Svc::ComQueue will not emit messages at any other time. This implies several things:

  1. An initial Fw::Success::SUCCESS message must be sent to Svc::ComQueue to initiate data flow
  2. A Fw::Success::SUCCESS must be eventually received in response to each message for data to continue to flow

These implications are discussed in more depth in the appropriate protocol sections.

Framer Status Protocol

Framing typically happens between Svc::ComQueue and a communications adapter. The action taken by this protocol is dependent on the number of framed messages (frames) sent to the communication adapter in response to each message received from Svc::ComQueue.

The Svc::FprimeFramer implements the Framer status protocol by emitting a frame for each message received from Svc::ComQueue. Therefore, the Svc::FprimeFramer receives a status from the communication adapter on each sent frame and forwards it back to Svc::ComQueue. This allows the data flow to continue, or pause if the communication adapter is unable to receive more data.

Framer implementations may choose to implement a different behavior. For example, a framer may choose to accept multiple messages from Svc::ComQueue and concatenate them in a single frame. In this case, the framer implementation must manage the flow of statuses accordingly. This is summarized in the table below.

Produced Frames Action Rationale
0 Send one Fw::Success::SUCCESS status Data must continue to flow to produce a frame
1 Pass through received status from ComQueue Frame produced and communication adapter produces status

Important

All framer implementations must pass through the initiation message from the communication adapter to start data flow.

Communication Adapter Protocol

The communication adapter must obey a specific protocol to indicate to F´ application components the status of outgoing transmissions. This is done with the comStatus port. A communication status is one of two possibilities:

Status Description
Fw::Success::SUCCESS Communication adapter transmission succeeded and is ready for more data.
Fw::Success::FAILURE Last transmission failed; communication adapter is unable to receive more data.
  • Fw::Success::SUCCESS may also indicate a connection/reconnection success when data flow must be initiated.

A Communication Adapter shall emit either Fw::Success::SUCCESS or Fw::Success::FAILURE via the comStatusOut port once for each call received on dataIn. Additionally, a Communication Adapter shall emit Fw::Success::SUCCESS once at startup to indicate communication is initially ready and once after each Fw::Success::FAILURE event to indicate that communication has been restored. By emitting Fw::Success::SUCCESS after any failure, the communication adapter ensures that each received message eventually results in a Fw::Success::SUCCESS.

Note

It is imperative that Communication Adapters implement the comStatusOut protocol correctly.