Skip to content

Drv::TcpClient TCP Client Component

The TCP client component bridges the byte stream driver model interface to a remote TCP server to which this tcp client connects and sends/receives bytes. It implements the callback formation (shown below) using a thread to receive data and producing the callback port call.

For more information on the supporting TCP implementation see: Drv::TcpClientSocket. For more information on the ByteStreamModelDriver see: Drv::ByteStreamDriverModel.

Design

The manager component (typically the ground interface) initiates the transfer of send data by calling the "send" port. The caller will provide a Fw::Buffer containing the data to send and the port call will return a status of that send. These responses are an enumeration whose values are described in the following table:

Value Description
Drv::SEND_OK Send functioned normally.
Drv::SEND_RETRY Send should be retried, but a subsequent send should return SEND_OK.
Drv::SEND_ERROR Send produced an error, future sends likely to fail.

This data is immediately sent out to the remote tcp server with a configured send timeout. See Usage described below.

Callback Formation

Callback

In the callback formation, the byte stream driver component initiates the transfer of received data by calling the "readCallback" output port. This port transfers any read data in a Fw::Buffer along with a status for the receive. This status is an enumeration whose values are described in the following table:

Value Description
Drv::RECV_OK Receive functioned normally buffer contains valid data.
Drv::RECV_ERROR Receive produced an error and buffer contains no valid data.

Usage

The Drv::TcpClientComponentImpl must be configured with the address of the remote connection using the configure method. The sockets must also be opened to send and receive data using open. When the component is set to automatically open, open is called via the first send or receive. Users declining to use automatic opening or who wish to control when open initially happens should call open before any send or receive.

Automatic opening is the default. Call setAutomaticOpen(false); to disable this behavior.

Users desiring to receive via TCP should start the receive thread using start, may stop the thread using stop and may wait for the thread to exit using join.

Drv::TcpClientComponentImpl comm = Drv::TcpClientComponentImpl("TCP Client");

bool constructApp(bool dump, U32 port_number, char* hostname) {
    ...
    comm.configure(hostname, port_number);
    ...
    if (hostname != nullptr && port_number != 0) {
        Os::TaskString name("ReceiveTask");
        comm.start(name);
    }
}

void exitTasks() {
    ...
    comm.stop();
    (void) comm.join();
}

Class Diagram

tcp client

Requirements

Name Description Validation
TCP-CLIENT-COMP-001 The tcp client component shall implement the ByteStreamDriverModel inspection
TCP-CLIENT-COMP-002 The tcp client component shall provide a read thread unit test
TCP-CLIENT-COMP-003 The tcp client component shall provide bidirectional communication with a tcp server unit test