diff src/g23m-fad/tcpip/rnet/rnet_rt/rnet_rt_api_send.c @ 1:d393cd9bb723

src/g23m-*: initial import from Magnetite
author Mychaela Falconia <falcon@freecalypso.org>
date Sun, 15 Jul 2018 04:40:46 +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_rt/rnet_rt_api_send.c	Sun Jul 15 04:40:46 2018 +0000
@@ -0,0 +1,107 @@
+/**
+ * @file    rnet_rt_api_send.c
+ *
+ * RNET_RT API
+ *
+ * @author  Regis Feneon
+ * @version 0.1
+ */
+
+/*
+ * $Id: rnet_rt_api_send.c,v 1.4 2002/10/30 15:23:34 rf Exp $
+ * $Name: ti_20021030 $
+ *
+ * History:
+ *
+ *  Date        Author        Modification
+ *  --------------------------------------------------
+ *  3/22/2002   Regis Feneon  Create
+ *
+ * (C) Copyright 2002 by TI, All Rights Reserved
+ *
+ */
+
+#include "rnet_cfg.h"
+#ifdef RNET_CFG_REAL_TRANSPORT
+
+#include "rnet_rt_i.h"
+#include "rnet_rt_env.h"
+
+/**
+ * Enqueues the data for sending.
+ *
+ * Data is sent by enqueueing the data with a call to rnet_send().
+ * The function is not-blocking.
+ *
+ * In case of TCP, when the data is successfully transmitted to the remote
+ * host, the application will be notified with a RNET_SEND_CFM message.
+ *
+ * Returns RNET_PARTIAL_SENT if not all data could be sent and the function
+ * needs to be called again later to send the rest of the data. In that case,
+ * the out value of len_p is the number of bytes effectively sent.
+ *
+ * The buffer is copied by RNET, so the application can free the data buffer
+ * when the function returns.
+ *
+ * TODO: The proper way to use this function.
+ *
+ * @param  desc  Connection identifier [IN].
+ * @param  buff  Pointer on the data to send [IN].
+ * @param  len_p  Pointer on the length of the data to send [IN].
+ *          Pointer on the length of the data effectively sent [OUT].
+ * @return  RNET_MEMORY_ERR      Not enough memory is available
+ *      RNET_NOT_INITIALIZED  NET subsystem not initialized (internal error).
+ *      RNET_INTERNAL_ERR    Network subsystem failed.
+ *                or  Requested address is a broadcast address.
+ *      RNET_INVALID_PARAMETER  The connection ID is invalid.
+ *                or  The ID is not connected.
+ *                or  Invalid buff parameter.
+ *                or  Connection not bound with bind.
+ *      RNET_CONN_ABORTED    Connection broken due to the "keep-alive" activity
+ *                  detecting a failure while the operation was in progress.
+ *                or  Virtual circuit terminated due to a time-out or other failure.
+ *      RNET_MSG_SIZE      Message oriented connection (UDP), and the message
+ *                  is larger than the maximum supported by the underlying transport.
+ *      RNET_NET_UNREACHABLE  Remote host cannot be reached from this host at this time.
+ *      RNET_CONN_RESET      The virtual circuit was reset by the remote side executing a "hard"
+ *                  or "abortive" close.
+ *      RNET_TIMEOUT      The connection has been dropped, because of a
+ *                  network failure or because the system on the other end went down
+ *                  without notice.
+ *      RNET_NOT_READY      Still processing a callback function.
+ *      RNET_OK          Sending in progress
+ *                  RNET_SEND_CFM will be sent when the sending
+ *                  has been successfully completed.
+ */
+
+T_RNET_RET rnet_rt_send (T_RNET_DESC * desc,
+            T_RVF_BUFFER * buff,
+            UINT16 * len_p)
+{
+  int ret;
+
+  rvf_lock_mutex( &rnet_rt_env_ctrl_blk_p->mutex);
+  ret = ngSAIOSend( (NGsock *) desc, buff, *len_p, 0, NULL);
+  if( (ret == NG_EWOULDBLOCK) || ((ret > 0) && (ret != *len_p))) {
+    /* send RNET_SEND_RDY message when data will be acknowledged */
+    ((T_RNET_RT_SOCK *) desc)->flags |= RNET_RT_SOCKF_NOTIFY_SEND;
+  }
+  rvf_unlock_mutex( &rnet_rt_env_ctrl_blk_p->mutex);
+
+  if( ret == NG_EWOULDBLOCK) {
+    ret = 0;
+  }
+  if( ret >= 0) {
+    if( ret != *len_p) {
+      /* not all data has been sent */
+      *len_p = ret;
+      return( RNET_PARTIAL_SENT);
+    }
+    return( RNET_OK);
+  }
+
+  return( rnet_rt_ngip_error( ret));
+}
+
+#endif /* ifdef RNET_CFG_REAL_TRANSPORT */
+