From ce7922e830ef693752b1177c42c29499dbc42001 Mon Sep 17 00:00:00 2001 From: Jeff Hill Date: Thu, 7 Mar 2002 19:06:00 +0000 Subject: [PATCH] removed broadcast overlap testing --- src/ca/iocinf.cpp | 33 ++++++++++++++++----------------- 1 file changed, 16 insertions(+), 17 deletions(-) diff --git a/src/ca/iocinf.cpp b/src/ca/iocinf.cpp index b25573cab..3f10f1c61 100644 --- a/src/ca/iocinf.cpp +++ b/src/ca/iocinf.cpp @@ -34,25 +34,29 @@ */ static char *getToken ( const char **ppString, char *pBuf, unsigned bufSIze ) { + bool tokenFound = false; const char *pToken; unsigned i; pToken = *ppString; - while(isspace(*pToken)&&*pToken){ + while ( isspace (*pToken) && *pToken ){ pToken++; } for ( i=0u; iaddr.ia = addr; - memset ( &pNewNode->netMask, '\0', sizeof ( pNewNode->netMask ) ); /* * LOCK applied externally @@ -103,9 +106,9 @@ extern "C" void epicsShareAPI addAddrToChannelAccessAddressList } /* - * removeDuplicatesAddresses () + * removeDuplicateAddresses () */ -extern "C" void epicsShareAPI removeDuplicatesAddresses +extern "C" void epicsShareAPI removeDuplicateAddresses ( ELLLIST *pDestList, ELLLIST *pSrcList, int silent ) { ELLNODE *pRawNode; @@ -120,14 +123,11 @@ extern "C" void epicsShareAPI removeDuplicatesAddresses pTmpNode = (osiSockAddrNode *) ellFirst (pDestList); // X aCC 749 while ( pTmpNode ) { if (pTmpNode->addr.sa.sa_family == AF_INET) { - unsigned netMask = pNode->netMask.ia.sin_addr.s_addr | - pTmpNode->netMask.ia.sin_addr.s_addr; - unsigned exorAddr = pNode->addr.ia.sin_addr.s_addr ^ pTmpNode->addr.ia.sin_addr.s_addr; - exorAddr &= netMask; - if ( exorAddr == 0u && pNode->addr.ia.sin_port == pTmpNode->addr.ia.sin_port) { - char buf[64]; - ipAddrToDottedIP ( &pNode->addr.ia, buf, sizeof (buf) ); + if ( pNode->addr.ia.sin_addr.s_addr == pTmpNode->addr.ia.sin_addr.s_addr && + pNode->addr.ia.sin_port == pTmpNode->addr.ia.sin_port ) { if ( ! silent ) { + char buf[64]; + ipAddrToDottedIP ( &pNode->addr.ia, buf, sizeof (buf) ); fprintf ( stderr, "Warning: Duplicate EPICS CA Address list entry \"%s\" discarded\n", buf ); } @@ -207,7 +207,7 @@ extern "C" void epicsShareAPI configureChannelAccessAddressList ellInit ( &bcastList ); // X aCC 392 addr.ia.sin_family = AF_UNSPEC; osiSockDiscoverBroadcastAddresses ( &bcastList, sock, &addr ); - removeDuplicatesAddresses ( &tmpList, &bcastList, 1 ); + removeDuplicateAddresses ( &tmpList, &bcastList, 1 ); if ( ellCount ( &tmpList ) == 0 ) { // X aCC 392 osiSockAddrNode *pNewNode; pNewNode = (osiSockAddrNode *) calloc ( 1, sizeof (*pNewNode) ); @@ -219,7 +219,6 @@ extern "C" void epicsShareAPI configureChannelAccessAddressList pNewNode->addr.ia.sin_family = AF_INET; pNewNode->addr.ia.sin_addr.s_addr = epicsHTON32 ( INADDR_LOOPBACK ); pNewNode->addr.ia.sin_port = epicsHTON16 ( port ); - memset ( &pNewNode->netMask, '\0', sizeof ( pNewNode->netMask ) ); ellAdd ( &tmpList, &pNewNode->node ); } else { @@ -232,7 +231,7 @@ extern "C" void epicsShareAPI configureChannelAccessAddressList } addAddrToChannelAccessAddressList ( &tmpList, &EPICS_CA_ADDR_LIST, port ); - removeDuplicatesAddresses ( pList, &tmpList, 0 ); + removeDuplicateAddresses ( pList, &tmpList, 0 ); }