F´ Flight Software - C/C++ Documentation
A framework for building embedded system applications to NASA flight quality standards.
Loading...
Searching...
No Matches
UdpComponentImpl.hpp
Go to the documentation of this file.
1// ======================================================================
2// \title UdpComponentImpl.hpp
3// \author mstarch
4// \brief hpp file for UdpComponentImpl component implementation class
5//
6// \copyright
7// Copyright 2009-2020, by the California Institute of Technology.
8// ALL RIGHTS RESERVED. United States Government Sponsorship
9// acknowledged.
10//
11// ======================================================================
12
13#ifndef UdpComponentImpl_HPP
14#define UdpComponentImpl_HPP
15
16#include <Drv/Ip/IpSocket.hpp>
18#include <Drv/Ip/UdpSocket.hpp>
20
21namespace Drv {
22
24 public:
25 // ----------------------------------------------------------------------
26 // Construction, initialization, and destruction
27 // ----------------------------------------------------------------------
28
33 UdpComponentImpl(const char* const compName);
34
39
40 // ----------------------------------------------------------------------
41 // Helper methods to start and stop socket
42 // ----------------------------------------------------------------------
43
59 SocketIpStatus configureSend(const char* hostname,
60 const U16 port,
61 const U32 send_timeout_seconds = SOCKET_SEND_TIMEOUT_SECONDS,
62 const U32 send_timeout_microseconds = SOCKET_SEND_TIMEOUT_MICROSECONDS);
63
76 SocketIpStatus configureRecv(const char* hostname, const U16 port, FwSizeType buffer_size = 1024);
77
86 U16 getRecvPort();
87
88
89PROTECTED:
90 // ----------------------------------------------------------------------
91 // Implementations for socket read task virtual methods
92 // ----------------------------------------------------------------------
93
103
113
122 void sendBuffer(Fw::Buffer buffer, SocketIpStatus status);
123
127 void connected();
128
129 PRIVATE:
130
131 // ----------------------------------------------------------------------
132 // Handler implementations for user-defined typed input ports
133 // ----------------------------------------------------------------------
134
150 Drv::SendStatus send_handler(const NATIVE_INT_TYPE portNum, Fw::Buffer& fwBuffer);
151
152 Drv::UdpSocket m_socket;
153
154 FwSizeType m_allocation_size;
155};
156
157} // end namespace Drv
158
159#endif // end UdpComponentImpl
PlatformIntType NATIVE_INT_TYPE
Definition BasicTypes.h:55
PlatformSizeType FwSizeType
Definition FpConfig.h:35
@ SOCKET_SEND_TIMEOUT_SECONDS
Definition IpCfg.hpp:17
@ SOCKET_SEND_TIMEOUT_MICROSECONDS
Definition IpCfg.hpp:18
Helper base-class for setting up Berkeley sockets.
Definition IpSocket.hpp:55
Status returned by the send call.
supports a task to read a given socket adaptation
Auto-generated base for Udp component.
void sendBuffer(Fw::Buffer buffer, SocketIpStatus status)
sends a buffer to be filled with data
Fw::Buffer getBuffer()
returns a buffer to fill with data
IpSocket & getSocketHandler()
returns a reference to the socket handler
SocketIpStatus configureRecv(const char *hostname, const U16 port, FwSizeType buffer_size=1024)
Configures the Udp receive settings but does not open the connection.
void connected()
called when the IPv4 system has been connected
U16 getRecvPort()
get the port being received on
~UdpComponentImpl()
Destroy the component.
SocketIpStatus configureSend(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 Udp send settings but does not open the connection.
Helper for setting up Udp using Berkeley sockets as a client.
Definition UdpSocket.hpp:29
SocketIpStatus
Status enumeration for socket return values.
Definition IpSocket.hpp:29