diff src/g23m-fad/tcpip/rnet/rnet_message.h @ 1:fa8dc04885d8

src/g23m-*: import from Magnetite
author Mychaela Falconia <falcon@freecalypso.org>
date Fri, 16 Oct 2020 06:25:50 +0000
parents
children
line wrap: on
line diff
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/src/g23m-fad/tcpip/rnet/rnet_message.h	Fri Oct 16 06:25:50 2020 +0000
@@ -0,0 +1,228 @@
+/**
+ * @file  rnet_message.h
+ *
+ * Riviera NET.
+ *
+ * Messages that RNET can SEND.
+ *
+ * @author  Vincent Oberle (v-oberle@ti.com)
+ * @version 0.1
+ */
+
+/*
+ * History:
+ *
+ *   Date         Author        Modification
+ *  --------------------------------------------------
+ *  01/25/2002  Vincent Oberle    Create
+ *
+ * (C) Copyright 2002 by Texas Instruments Incorporated, All Rights Reserved
+ */
+
+#ifndef __RNET_MESSAGE_H_
+#define __RNET_MESSAGE_H_
+
+#include "rv_general.h"
+#include "rvm_use_id_list.h"
+
+#include "rnet_api.h"
+#include "rnet_cfg.h"
+#include "rnet_ip_addr.h"
+
+#ifdef __cplusplus
+extern "C"
+{
+#endif
+
+/**
+ * The message offset must differ for each SWE in order to have
+ * unique msg_id in the system.
+ */
+#define RNET_MESSAGE_OFFSET BUILD_MESSAGE_OFFSET(RNET_USE_ID)
+
+/**
+ * @name RNET_ERROR_IND
+ *
+ * Sent by RNET when an error occured in a connection.
+ *
+ * The following list indicates the values that the error code
+ * can take as well as their meaning depending on the processing
+ *
+ * Connecting:
+ * - RNET_MEMORY_ERR    No buffer space is available. The socket cannot be connected.
+ * - RNET_NET_UNREACHABLE  The network cannot be reached from this host at this time.
+ * - RNET_TIMEOUT      Attempt to connect timed out without establishing a connection
+ * - RNET_CONN_REFUSED    The attempt to connect was forcefully rejected.
+ * - RNET_NOT_SUPPORTED    Addresses in the specified family cannot be used with this socket.
+ * Closing:
+ * - RNET_INTERNAL_ERR    The network subsystem has failed.
+ * - RNET_CONN_RESET    The connection was reset by the remote side
+ * - RNET_CONN_ABORTED    The connection was terminated due to a time-out or other failure.
+ * - RNET_CONN_CLOSED    The connection was gracefully closed (not an error actually)..
+ *
+ * @param  desc  Connection identifier.
+ * @param  error  Error code.
+ */
+/*@{*/
+/** Message ID. */
+#define RNET_ERROR_IND (RNET_MESSAGE_OFFSET | 0x001)
+
+/** Message structure. */
+typedef struct
+{
+  T_RV_HDR hdr;
+
+  T_RNET_DESC * desc;
+  T_RNET_RET error;
+
+} T_RNET_ERROR_IND;
+/*@}*/
+
+/**
+ * @name RNET_CONNECT_IND
+ *
+ * Sent to the connection oriented server when a client requests a connection.
+ *
+ * The server gets in this message a new connection identifier that
+ * the one the server was listening with.
+ * The client address and port are also indicated.
+ *
+ * @param  new_desc  New connection identifier.
+ * @param  listen_desc  Indicates the descriptor of the connection that server
+ *            is using for listening.
+ * @param  peer_addr  Peer address.
+ * @param  peer_port  Peer port.
+ */
+/*@{*/
+/** Message ID. */
+#define RNET_CONNECT_IND (RNET_MESSAGE_OFFSET | 0x002)
+
+/** Message structure. */
+typedef struct
+{
+  T_RV_HDR hdr;
+
+  T_RNET_DESC * new_desc;
+  T_RNET_DESC * listen_desc;
+  T_RNET_IP_ADDR peer_addr;
+  T_RNET_PORT peer_port;
+
+} T_RNET_CONNECT_IND;
+/*@}*/
+
+/**
+ * @name RNET_CONNECT_CFM
+ *
+ * Indicates that a connection request was successfully completed.
+ *
+ * @param  desc  Connection identifier.
+ */
+/*@{*/
+/** Message ID. */
+#define RNET_CONNECT_CFM (RNET_MESSAGE_OFFSET | 0x003)
+
+/** Message structure. */
+typedef struct
+{
+  T_RV_HDR hdr;
+
+  T_RNET_DESC * desc;
+
+} T_RNET_CONNECT_CFM;
+/*@}*/
+
+/**
+ * @name RNET_SEND_RDY
+ *
+ * Indicates that the connection descriptor is ready for sending data.
+ * A first RNET_SEND_RDY message is sent when a connection ID is first
+ * connected (function rnet_connect) or accepted (message RNET_CONNECT_IND)
+ * and then when a call to the function rnet_send couldn't send all
+ * wanted data. The application should then try to send the data again
+ * when receiving RNET_SEND_RDY.
+ *
+ * @param  desc  Connection identifier.
+ */
+/*@{*/
+/** Message ID. */
+#define RNET_SEND_RDY (RNET_MESSAGE_OFFSET | 0x004)
+
+/** Message structure. */
+typedef struct
+{
+  T_RV_HDR hdr;
+
+  T_RNET_DESC * desc;
+
+} T_RNET_SEND_RDY;
+/*@}*/
+
+/**
+ * @name RNET_RECV_IND
+ *
+ * New data arrived on the connection.
+ *
+ * See the description of the related function rnet_recv.
+ *
+ * @param  desc    Connection identifier.
+ * @param  peer_addr  Peer address.
+ * @param  peer_port  Peer port.
+ */
+/*@{*/
+/** Message ID. */
+#define RNET_RECV_IND (RNET_MESSAGE_OFFSET | 0x005)
+
+/** Message structure. */
+typedef struct
+{
+  T_RV_HDR hdr;
+
+  T_RNET_DESC * desc;
+  T_RNET_IP_ADDR peer_addr;
+  T_RNET_PORT peer_port;
+
+} T_RNET_RECV_IND;
+/*@}*/
+
+/**
+ * @name RNET_HOST_INFO
+ *
+ * Information on a host, names and addresses.
+ *
+ * If error is RNET_OK, no error occured and the host_name, host_addr
+ * and user_data parameters are valid.
+ * If is different from RNET_OK, the host information could not be retrieved
+ * and only user_data is valid.
+ *
+ * @param  error      Indicates if the host information could be
+ *              retrieved or not.
+ * @param  host_name    Official name of host.
+ * @param  host_addr    One address for the host.
+ * @param  user_data    Application specific pointer set by the user
+ *              in rnet_get_host_info.
+ */
+/*@{*/
+/** Message ID. */
+#define RNET_HOST_INFO (RNET_MESSAGE_OFFSET | 0x006)
+
+/** Message structure. */
+typedef struct
+{
+  T_RV_HDR hdr;
+
+  T_RNET_RET error;
+
+  T_RNET_IP_ADDR host_addr;
+  char host_name[RNET_MAX_HOST_NAME_LEN];
+
+  void * user_data;
+
+} T_RNET_HOST_INFO;
+/*@}*/
+
+#ifdef __cplusplus
+}
+#endif
+
+#endif /* __RNET_MESSAGE_H_ */
+