GLAST/LAT > DAQ and FSW > FSW > Doxygen Index > NMSG / V3-1-1

Constituent: nmsg     Tag: sun-gcc


Interface   Data Structures   File List   Data Fields   Globals  

nmsgLib.c File Reference

Routines for handling formatted network messages. More...

#include "NMSG/nmsgLib.h"
#include <stdlib.h>
#include <unistd.h>
#include <sys/types.h>
#include <sys/socket.h>
#include <netdb.h>
#include <netinet/in.h>
#include <pthread.h>
#include <errno.h>
#include <string.h>
#include <stdio.h>

Include dependency graph for nmsgLib.c:


Functions

int nmsgConnect (void **hndl, char *node, int port)
 Connect to a message server.
int nmsgConnectAsy (void **hndl, char *node, int port, nmsgConnCB_t connRtn, nmsgDiscCB_t discRtn, void *uParm)
 Connect asynchronously (robustly) to a message server.
int nmsgListen (void **hndl, int port, int maxConn, int maxData, nmsgConnCB_t connRtn, nmsgDiscCB_t discRtn, nmsgRcveCB_t rcveRtn, void *uParm)
 Establish a message server.
int nmsgClose (void *hndl, int force)
 Terminate a message client or server.
int nmsgSendW (void *hndl, nmsgBuff_t *msg, nmsgBuff_t **replyP, nmsgBuff_t *reply, int maxData)
 Send a message and receive reply.
int nmsgSend (void *hndl, nmsgBuff_t *msg)
 Send a message and return immediately.
int nmsgWait (void *hndl, nmsgBuff_t **replyP, nmsgBuff_t *reply, int maxData)
 Wait for a reply to a sent message.
int nmsgRemoteIP (void *hndl)
 Get the IP address of the remote end.
int nmsgStats (void *hndl, nmsgStats_t *stats)
 Get connection statistics.
int nmsgCheck (void *hndl)
 Check a network connection handle.

Detailed Description

Routines for handling formatted network messages.

Author:
Owen H Saxton
Id
nmsgLib.c,v 1.9 2007/11/30 01:37:24 saxton Exp

Function Documentation

int nmsgCheck void *  hndl  ) 
 

Check a network connection handle.

This routine checks whether a network handle is valid or not.

Parameters:
hndl The handle for the connection.
Return values:
1 The handle is valid.
0 The handle is invalid.

int nmsgClose void *  hndl,
int  force
 

Terminate a message client or server.

This routine closes a network connection or stops a network server.

Parameters:
hndl The handle of the connection or server.
force For a client connection, if TRUE, the connection is closed even if another task is in the process of sending a message. If FALSE, the closing waits until any activity has ceased. Not used for a server.
Return values:
0 Success.
-1 An error occurred.

int nmsgConnect void **  hndl,
char *  node,
int  port
 

Connect to a message server.

This routine establishes a network connection to a message server.

Parameters:
hndl The address of a pointer to receive the identifying handle for the network connection.
node The address of the name of the node containing the message server.
port The port number on which to establish the connection.
Return values:
0 The connection was established successfully.
-1 An error occurred.

int nmsgConnectAsy void **  hndl,
char *  node,
int  port,
nmsgConnCB_t  connRtn,
nmsgDiscCB_t  discRtn,
void *  uParm
 

Connect asynchronously (robustly) to a message server.

This routine establishes a robust network connection to a message server. The connection is done asynchronously, and the attempt is retried periodically if the initial attempt fails, or if the connection is broken.

Parameters:
hndl The address of a pointer to receive the identifying handle for the network connection.
node The address of the name of the node containing the message server.
port The port number on which to establish the connection.
connRtn The address of a routine to be called when the connection has been made.
discRtn The address of a routine to be called when the connection is broken.
uParm A parameter to be passed to the connect and disconnect callback routines.
Return values:
0 The connection process was started successfully.
-1 An error occurred.

int nmsgListen void **  hndl,
int  port,
int  maxConn,
int  maxData,
nmsgConnCB_t  connRtn,
nmsgDiscCB_t  discRtn,
nmsgRcveCB_t  rcveRtn,
void *  uParm
 

Establish a message server.

This routine establishes a network message server (listener).

Parameters:
hndl The address of a pointer to receive the identifying handle for the network listener.
port The port number on which to establish the server.
maxConn The maximum number of concurrent connections that the server will allow.
maxData The maximum number of data bytes that can be transferred in a single message.
connRtn The address of a routine to be called when a new connection has been made. The connection will be rejected if this routine returns ERROR status.
discRtn The address of a routine to be called when a connection is broken.
rcveRtn The address of a routine to be called whenever a message is received.
uParm A parameter to be passed to the connect, disconnect and receive callback routines.
Return values:
0 The message server was started successfully.
-1 An error occurred.

int nmsgRemoteIP void *  hndl  ) 
 

Get the IP address of the remote end.

This routine returns the IP address of the remote end of a connection. It can be used on either end of a connection.

Parameters:
hndl The handle for the connection.
Returns:
The IP address of the remote end of the connection, or -1 if the handle is invalid.

int nmsgSend void *  hndl,
nmsgBuff_t msg
 

Send a message and return immediately.

This routine sends a message on a network connection and returns without waiting for a reply.

Parameters:
hndl The handle for the connection.
msg The address of message to be sent. It must be formatted using the nmsgBuff_t structure type.
Return values:
0 Success.
-1 An error occurred.

int nmsgSendW void *  hndl,
nmsgBuff_t msg,
nmsgBuff_t **  replyP,
nmsgBuff_t reply,
int  maxData
 

Send a message and receive reply.

This routine sends a message on a network connection and waits for a reply.

Parameters:
hndl The handle for the connection.
msg The address of message to be sent. It must be formatted using the nmsgBuff_t structure type.
replyP The address of a pointer to receive the address of the reply. If a reply area is supplied and it is big enough, this will be the address of this area. Otherwise a sufficiently large reply area is allocated and its address returned here. In this latter case, the memory must be relinquished using free() after it is no longer needed.
reply The address of an area to receive the reply to the message, or NULL if no area is to be used.
maxData The maximum number of data bytes that can be put into the supplied reply area.
Return values:
0 Success.
-1 An error occurred.

int nmsgStats void *  hndl,
nmsgStats_t stats
 

Get connection statistics.

This routine returns a block of connection statistics containing the number of connects, disconnects, messages sent/received, bytes sent and bytes received.

Parameters:
hndl The handle for the connection.
stats The address of an area to receive the statistics block.
Return values:
0 Success.
-1 The handle is invalid.

int nmsgWait void *  hndl,
nmsgBuff_t **  replyP,
nmsgBuff_t reply,
int  maxData
 

Wait for a reply to a sent message.

This routine waits for a reply to a previously sent message.

Parameters:
hndl The handle for the connection.
replyP The address of a pointer to receive the address of the reply. If a reply area is supplied and it is big enough, this will be the address of this area. Otherwise a sufficiently large reply area is allocated and its address returned here. In this latter case, the memory must be relinquished using free() after it is no longer needed.
reply The address of an area to receive the reply to the message, or NULL if no area is to be used.
maxData The maximum number of data bytes that can be put into the supplied reply area.
Return values:
0 Success.
-1 An error occurred.


Generated on Wed Dec 5 04:59:13 2007 by  doxygen 1.4.4