You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
144 lines
6.9 KiB
144 lines
6.9 KiB
4 years ago
|
/***************************************************************************/
|
||
|
/* */
|
||
|
/* Project: OpenSLP - OpenSource implementation of Service Location */
|
||
|
/* Protocol */
|
||
|
/* */
|
||
|
/* File: slp_xcast.h */
|
||
|
/* */
|
||
|
/* Abstract: Functions used to multicast and broadcast SLP messages */
|
||
|
/* */
|
||
|
/*-------------------------------------------------------------------------*/
|
||
|
/* */
|
||
|
/* Please submit patches to http://www.openslp.org */
|
||
|
/* */
|
||
|
/*-------------------------------------------------------------------------*/
|
||
|
/* */
|
||
|
/* Copyright (C) 2000 Caldera Systems, Inc */
|
||
|
/* All rights reserved. */
|
||
|
/* */
|
||
|
/* Redistribution and use in source and binary forms, with or without */
|
||
|
/* modification, are permitted provided that the following conditions are */
|
||
|
/* met: */
|
||
|
/* */
|
||
|
/* Redistributions of source code must retain the above copyright */
|
||
|
/* notice, this list of conditions and the following disclaimer. */
|
||
|
/* */
|
||
|
/* Redistributions in binary form must reproduce the above copyright */
|
||
|
/* notice, this list of conditions and the following disclaimer in */
|
||
|
/* the documentation and/or other materials provided with the */
|
||
|
/* distribution. */
|
||
|
/* */
|
||
|
/* Neither the name of Caldera Systems nor the names of its */
|
||
|
/* contributors may be used to endorse or promote products derived */
|
||
|
/* from this software without specific prior written permission. */
|
||
|
/* */
|
||
|
/* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS */
|
||
|
/* `AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT */
|
||
|
/* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR */
|
||
|
/* A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE CALDERA */
|
||
|
/* SYSTEMS OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, */
|
||
|
/* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT */
|
||
|
/* LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, */
|
||
|
/* DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON */
|
||
|
/* ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT */
|
||
|
/* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE */
|
||
|
/* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */
|
||
|
/* */
|
||
|
/***************************************************************************/
|
||
|
|
||
|
#ifndef SLP_XCAST_H_INCLUDED
|
||
|
#define SLP_XCAST_H_INCLUDED
|
||
|
|
||
|
#include "slp_iface.h"
|
||
|
#include "slp_buffer.h"
|
||
|
|
||
|
typedef struct _SLPXcastSockets
|
||
|
{
|
||
|
int sock_count;
|
||
|
int sock[SLP_MAX_IFACES];
|
||
|
struct sockaddr_in peeraddr[SLP_MAX_IFACES];
|
||
|
}SLPXcastSockets;
|
||
|
|
||
|
|
||
|
/*========================================================================*/
|
||
|
int SLPBroadcastSend(const SLPIfaceInfo* ifaceinfo,
|
||
|
SLPBuffer msg,
|
||
|
SLPXcastSockets* socks);
|
||
|
/* Description:
|
||
|
* Broadcast a message.
|
||
|
*
|
||
|
* Parameters:
|
||
|
* ifaceinfo (IN) Pointer to the SLPIfaceInfo structure that contains
|
||
|
* information about the interfaces to send on
|
||
|
* msg (IN) Buffer to send
|
||
|
*
|
||
|
* socks (OUT) Sockets used broadcast multicast. May be used to
|
||
|
* recv() responses. MUST be close by caller using
|
||
|
* SLPXcastSocketsClose()
|
||
|
*
|
||
|
* Returns:
|
||
|
* Zero on sucess. Non-zero with errno set on error
|
||
|
*========================================================================*/
|
||
|
|
||
|
|
||
|
/*========================================================================*/
|
||
|
int SLPMulticastSend(const SLPIfaceInfo* ifaceinfo,
|
||
|
SLPBuffer msg,
|
||
|
SLPXcastSockets* socks);
|
||
|
/* Description:
|
||
|
* Multicast a message.
|
||
|
*
|
||
|
* Parameters:
|
||
|
* ifaceinfo (IN) Pointer to the SLPIfaceInfo structure that contains
|
||
|
* information about the interfaces to send on
|
||
|
* msg (IN) Buffer to send
|
||
|
*
|
||
|
* socks (OUT) Sockets used to multicast. May be used to recv()
|
||
|
* responses. MUST be close by caller using
|
||
|
* SLPXcastSocketsClose()
|
||
|
*
|
||
|
* Returns:
|
||
|
* Zero on sucess. Non-zero with errno set on error
|
||
|
*========================================================================*/
|
||
|
|
||
|
|
||
|
/*=========================================================================*/
|
||
|
int SLPXcastRecvMessage(const SLPXcastSockets* sockets,
|
||
|
SLPBuffer* buf,
|
||
|
struct sockaddr_in* peeraddr,
|
||
|
struct timeval* timeout);
|
||
|
/* Description:
|
||
|
* Receives datagram messages from one of the sockets in the specified
|
||
|
* SLPXcastsSockets structure
|
||
|
*
|
||
|
* Parameters:
|
||
|
* sockets (IN) Pointer to the SOPXcastSockets structure that describes
|
||
|
* which sockets to read messages from.
|
||
|
* buf (OUT) Pointer to SLPBuffer that will contain the message upon
|
||
|
* successful return.
|
||
|
* peeraddr (OUT) Pointer to struc sockaddr_in that will contain the
|
||
|
* address of the peer that sent the received message.
|
||
|
* timeout (IN/OUT) pointer to the struct timeval that indicates how much
|
||
|
* time to wait for a message to arrive
|
||
|
*
|
||
|
* Returns:
|
||
|
* Zero on success, errno on failure.
|
||
|
*========================================================================*/
|
||
|
|
||
|
|
||
|
/*========================================================================*/
|
||
|
int SLPXcastSocketsClose(SLPXcastSockets* socks);
|
||
|
/* Description:
|
||
|
* Closes sockets that were opened by calls to SLPMulticastSend() and
|
||
|
* SLPBroadcastSend()
|
||
|
*
|
||
|
* Parameters:
|
||
|
* socks (IN) Pointer to the SLPXcastSockets structure being close
|
||
|
*
|
||
|
* Returns:
|
||
|
* Zero on sucess. Non-zero with errno set on error
|
||
|
*========================================================================*/
|
||
|
|
||
|
|
||
|
#endif
|