24 : ByteStreamDriverModelComponentBase(compName),
28 ByteStreamDriverModelComponentBase::init(instance);
33 const U32 send_timeout_seconds,
34 const U32 send_timeout_microseconds) {
35 return m_socket.
configure(hostname, port, send_timeout_seconds, send_timeout_microseconds);
41 return this->m_socket.
startup();
57 return allocate_out(0, 1024);
61 Drv::RecvStatus recvStatus = (status ==
SOCK_SUCCESS) ? RecvStatus::RECV_OK : RecvStatus::RECV_ERROR;
62 this->recv_out(0, buffer, recvStatus);
66 if (isConnected_ready_OutputPort(0)) {
80 return SendStatus::SEND_RETRY;
82 deallocate_out(0, fwBuffer);
83 return SendStatus::SEND_ERROR;
85 deallocate_out(0, fwBuffer);
86 return SendStatus::SEND_OK;
91 return PollStatus::POLL_ERROR;
PlatformIntType NATIVE_INT_TYPE
C++-compatible configuration header for fprime configuration.
Helper base-class for setting up Berkley sockets.
SocketIpStatus send(const U8 *const data, const U32 size)
send data out the IP socket from the given buffer
SocketIpStatus configure(const char *hostname, const U16 port, const U32 send_timeout_seconds, const U32 send_timeout_microseconds)
configure the ip socket with host and transmission timeouts
supports a task to read a given socket adaptation
~TcpServerComponentImpl()
Destroy the component.
SocketIpStatus startup()
startup the TcpServer
void init(const NATIVE_INT_TYPE instance=0)
Initialize this component.
Fw::Buffer getBuffer()
returns a buffer to fill with data
void shutdown()
shutdown the TcpServer
void sendBuffer(Fw::Buffer buffer, SocketIpStatus status)
sends a buffer to be filled with data
TcpServerComponentImpl(const char *const compName)
construct the TcpClient component.
IpSocket & getSocketHandler()
returns a reference to the socket handler
SocketIpStatus configure(const char *hostname, const U16 port, const U32 send_timeout_seconds=SOCKET_SEND_TIMEOUT_SECONDS, const U32 send_timeout_microseconds=SOCKET_SEND_TIMEOUT_MICROSECONDS)
Configures the TcpClient settings but does not open the connection.
void connected()
called when the IPv4 system has been connected
void shutdown()
Shutdown client socket, and listening server socket.
SocketIpStatus startup()
Opens the server socket and listens, does not block.
SocketIpStatus
Status enumeration for socket return values.
@ SOCK_SUCCESS
Socket operation successful.
@ SOCK_INTERRUPTED_TRY_AGAIN
Interrupted status for retries.