From 96dc968f18c9a2273dc76cdc59dd5438df553b26 Mon Sep 17 00:00:00 2001 From: Fabrice Fontaine Date: Fri, 5 Nov 2010 14:28:50 +0100 Subject: [PATCH] Use SSDP_COPY to send multiple SSDP advertisements. Currently, SSDP_COPY is used only to send multiple M-SEARCH requests (in ssdp_ctrlpt.c). With this patch, SSDP_COPY is also used to send multiple copies of each advertisements packets (in ssdp_device.c). --- ChangeLog | 8 +++++ upnp/src/ssdp/ssdp_device.c | 60 ++++++++++++++++++++++++------------- 2 files changed, 48 insertions(+), 20 deletions(-) diff --git a/ChangeLog b/ChangeLog index 40fdc9f..a9869fb 100644 --- a/ChangeLog +++ b/ChangeLog @@ -2,6 +2,14 @@ Version 1.6.9 ******************************************************************************* +2010-11-05 Fabrice Fontaine + + Use SSDP_COPY to send multiple SSDP advertisements. + + Currently, SSDP_COPY is used only to send multiple M-SEARCH requests (in + ssdp_ctrlpt.c). With this patch, SSDP_COPY is also used to send multiple + copies of each advertisements packets (in ssdp_device.c). + 2010-11-01 Carl Benson Fix for Android build. diff --git a/upnp/src/ssdp/ssdp_device.c b/upnp/src/ssdp/ssdp_device.c index 86dcb1e..253d1ac 100644 --- a/upnp/src/ssdp/ssdp_device.c +++ b/upnp/src/ssdp/ssdp_device.c @@ -502,7 +502,7 @@ DeviceAdvertisement( IN char *DevType, //char Mil_Nt[LINE_SIZE] char Mil_Usn[LINE_SIZE]; char *msgs[3]; - int ret_code; + int ret_code = UPNP_E_SUCCESS; UpnpPrintf( UPNP_INFO, SSDP, __FILE__, __LINE__, "In function DeviceAdvertisement\n" ); @@ -554,13 +554,18 @@ DeviceAdvertisement( IN char *DevType, return UPNP_E_OUTOF_MEMORY; } // send packets - if( RootDev ) { - // send 3 msg types - ret_code = NewRequestHandler( (struct sockaddr*)&__ss, 3, &msgs[0] ); - } else // sub-device - { - // send 2 msg types - ret_code = NewRequestHandler( (struct sockaddr*)&__ss, 2, &msgs[1] ); + int NumCopy = 0; + while( ret_code == UPNP_E_SUCCESS && NumCopy < NUM_SSDP_COPY ) { + if( RootDev ) { + // send 3 msg types + ret_code = NewRequestHandler( (struct sockaddr*)&__ss, 3, &msgs[0] ); + } else // sub-device + { + // send 2 msg types + ret_code = NewRequestHandler( (struct sockaddr*)&__ss, 2, &msgs[1] ); + } + NumCopy++; + imillisleep(SSDP_PAUSE); } // free msgs @@ -751,7 +756,7 @@ ServiceAdvertisement( IN char *Udn, { char Mil_Usn[LINE_SIZE]; char *szReq[1]; - int RetVal; + int RetVal = UPNP_E_SUCCESS; struct sockaddr_storage __ss; struct sockaddr_in* DestAddr4 = (struct sockaddr_in*)&__ss; struct sockaddr_in6* DestAddr6 = (struct sockaddr_in6*)&__ss; @@ -783,7 +788,12 @@ ServiceAdvertisement( IN char *Udn, return UPNP_E_OUTOF_MEMORY; } - RetVal = NewRequestHandler( (struct sockaddr*)&__ss, 1, szReq ); + int NumCopy = 0; + while( RetVal == UPNP_E_SUCCESS && NumCopy < NUM_SSDP_COPY ) { + RetVal = NewRequestHandler( (struct sockaddr*)&__ss, 1, szReq ); + NumCopy++; + imillisleep(SSDP_PAUSE); + } free( szReq[0] ); return RetVal; @@ -860,7 +870,7 @@ ServiceShutdown( IN char *Udn, struct sockaddr_storage __ss; struct sockaddr_in* DestAddr4 = (struct sockaddr_in*)&__ss; struct sockaddr_in6* DestAddr6 = (struct sockaddr_in6*)&__ss; - int RetVal; + int RetVal = UPNP_E_SUCCESS; memset( &__ss, 0, sizeof(__ss) ); if( AddressFamily == AF_INET ) { @@ -888,7 +898,12 @@ ServiceShutdown( IN char *Udn, if( szReq[0] == NULL ) { return UPNP_E_OUTOF_MEMORY; } - RetVal = NewRequestHandler( (struct sockaddr*)&__ss, 1, szReq ); + int NumCopy = 0; + while( RetVal == UPNP_E_SUCCESS && NumCopy < NUM_SSDP_COPY ) { + RetVal = NewRequestHandler( (struct sockaddr*)&__ss, 1, szReq ); + NumCopy++; + imillisleep(SSDP_PAUSE); + } free( szReq[0] ); return RetVal; @@ -926,7 +941,7 @@ DeviceShutdown( IN char *DevType, struct sockaddr_in6* DestAddr6 = (struct sockaddr_in6*)&__ss; char *msgs[3]; char Mil_Usn[LINE_SIZE]; - int ret_code; + int ret_code = UPNP_E_SUCCESS; msgs[0] = NULL; msgs[1] = NULL; @@ -975,13 +990,18 @@ DeviceShutdown( IN char *DevType, return UPNP_E_OUTOF_MEMORY; } // send packets - if( RootDev ) { - // send 3 msg types - ret_code = NewRequestHandler( (struct sockaddr*)&__ss, 3, &msgs[0] ); - } else // sub-device - { - // send 2 msg types - ret_code = NewRequestHandler( (struct sockaddr*)&__ss, 2, &msgs[1] ); + int NumCopy = 0; + while( ret_code == UPNP_E_SUCCESS && NumCopy < NUM_SSDP_COPY ) { + if( RootDev ) { + // send 3 msg types + ret_code = NewRequestHandler( (struct sockaddr*)&__ss, 3, &msgs[0] ); + } else // sub-device + { + // send 2 msg types + ret_code = NewRequestHandler( (struct sockaddr*)&__ss, 2, &msgs[1] ); + } + NumCopy++; + imillisleep(SSDP_PAUSE); } // free msgs