FreeCalypso > hg > fc-selenite
diff src/g23m-fad/tcpip/rnet/rnet_rt/rnet_rt_api_connect.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_connect.c Sun Jul 15 04:40:46 2018 +0000 @@ -0,0 +1,98 @@ +/** + * @file rnet_rt_api_connect.c + * + * RNET_RT API + * + * @author Regis Feneon + * @version 0.1 + */ + +/* + * $Id: rnet_rt_api_connect.c,v 1.3 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" + +#include "rnet_trace_i.h" + +/** + * Sets up the connection ID to connect to the remote host. + * + * For the connection-oriented client (TCP), it prepares a connection from the local + * to the peer system. The connection oriented client does not need + * to call rnet_bind() before rnet_connect(), since rnet_connect() would automatically + * use the local address of the client and allocate dynamically a free local port. + * + * rnet_connect() returns immediately, does not wait for the connection to be properly setup. + * The RNET_CONNECT_CFM message is sent when the connection is established. + * If the connection could not be properly established, a RNET_ERROR_IND + * message is sent. + * + * A connectionless client (UDP) would use rnet_connect() to locally specify + * the remote server, but no connection is open. But the remote address + * is then known and does not need to be specified again. + * rnet_connect() takes as parameter a fully initialized address structure, + * specifying server address and port. + * + * @param desc Connection identifier [IN]. + * @param peer_addr Peer address [IN]. + * @param peer_port Peer port [IN]. + * @return RNET_MEMORY_ERR No buffer space available. + * RNET_NOT_INITIALIZED NET subsystem not initialized (internal error). + * RNET_INTERNAL_ERR Network subsystem failed. + * or Attempt to connect forcefully rejected. + * or Attempt to connect datagram socket to broadcast address + * RNET_INVALID_PARAMETER Invalid connection ID. + * or Remote address not a valid address (such as ADDR_ANY). + * RNET_NOT_SUPPORTED Addresses in the specified family cannot be used with this socket. + * RNET_IN_USE Already connected (connection-oriented only). + * 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_NOT_READY Still processing a callback function. + * RNET_OK Connection in progress + * RNET_CONNECT_CFM will be sent when the connection + * has been successfully completed. + */ + +T_RNET_RET rnet_rt_connect (T_RNET_DESC * desc, + T_RNET_IP_ADDR peer_addr, + T_RNET_PORT peer_port) +{ + NGsockaddr addr; + int err; + + addr.sin_port = ngHTONS( peer_port); + addr.sin_addr = ngHTONL( peer_addr); + + /* connect to peer */ + rvf_lock_mutex( &rnet_rt_env_ctrl_blk_p->mutex); + err = ngSAIOConnect( (NGsock *) desc, &addr, 0); + + if( err == NG_EINPROGRESS) { + + /* send msg when connection completed */ + ((T_RNET_RT_SOCK *) desc)->flags |= RNET_RT_SOCKF_NOTIFY_CONNECT; + err = NG_EOK; + } + + rvf_unlock_mutex( &rnet_rt_env_ctrl_blk_p->mutex); + + return( rnet_rt_ngip_error( err)); +} + +#endif /* ifdef RNET_CFG_REAL_TRANSPORT */ +