* SF Bug Tracker [ 1711325 ] Bad DestAddr in Upnp_Discovery structure
Submitted By: Bob Ciora The field DestAddr of the structure Upnp_Discovery is now a full SOCKADDRIN instead of a pointer to SOCKADDRIN. Commented code sugests that in a previous moment, the function ssdp_handle_ctrlpt_msg() did not use a postponed thread to call ctrlpt_callback(). Now the code uses a thread, and most probably the original data would get lost and the pointer would point to an invalid memory region. This fix caused an interface change in the library and the minor library version was bumped. Also, the libtool library numbers were changed accordingly. git-svn-id: https://pupnp.svn.sourceforge.net/svnroot/pupnp/trunk@203 119443c7-1b9e-41f8-b6fc-b9c35fce742c
This commit is contained in:
		
							
								
								
									
										14
									
								
								ChangeLog
									
									
									
									
									
								
							
							
						
						
									
										14
									
								
								ChangeLog
									
									
									
									
									
								
							| @@ -1,7 +1,19 @@ | |||||||
| ******************************************************************************* | ******************************************************************************* | ||||||
| Version 1.4.7 | Version 1.6.0 | ||||||
| ******************************************************************************* | ******************************************************************************* | ||||||
|  |  | ||||||
|  | 2007-05-26 Marcelo Jimenez <mroberto(at)users.sourceforge.net> | ||||||
|  | 	* SF Bug Tracker [ 1711325 ] Bad DestAddr in Upnp_Discovery structure | ||||||
|  | 	Submitted By: Bob Ciora | ||||||
|  | 	The field DestAddr of the structure Upnp_Discovery is now a full | ||||||
|  | 	SOCKADDRIN instead of a pointer to SOCKADDRIN. Commented code sugests | ||||||
|  | 	that in a previous moment, the function ssdp_handle_ctrlpt_msg() did | ||||||
|  | 	not use a postponed thread to call ctrlpt_callback(). Now the code | ||||||
|  | 	uses a thread, and most probably the original data would get lost and | ||||||
|  | 	the pointer would point to an invalid memory region. This fix caused | ||||||
|  | 	an interface change in the library and the minor library version was | ||||||
|  | 	bumped. Also, the libtool library numbers were changed accordingly. | ||||||
|  |  | ||||||
| 2007-05-26 Marcelo Jimenez <mroberto(at)users.sourceforge.net> | 2007-05-26 Marcelo Jimenez <mroberto(at)users.sourceforge.net> | ||||||
| 	* Added support for the Basic Device | 	* Added support for the Basic Device | ||||||
| 	(http://www.upnp.org/standardizeddcps/basic.asp) as suggested by | 	(http://www.upnp.org/standardizeddcps/basic.asp) as suggested by | ||||||
|   | |||||||
							
								
								
									
										1
									
								
								THANKS
									
									
									
									
									
								
							
							
						
						
									
										1
									
								
								THANKS
									
									
									
									
									
								
							| @@ -7,6 +7,7 @@ Here is a list of these people. Help us keep it complete and | |||||||
| exempt of errors. | exempt of errors. | ||||||
|  |  | ||||||
| - Arno Willig | - Arno Willig | ||||||
|  | - Bob Ciora | ||||||
| - Chaos | - Chaos | ||||||
| - Craig Nelson | - Craig Nelson | ||||||
| - David Maass | - David Maass | ||||||
|   | |||||||
							
								
								
									
										34
									
								
								configure.ac
									
									
									
									
									
								
							
							
						
						
									
										34
									
								
								configure.ac
									
									
									
									
									
								
							| @@ -9,7 +9,7 @@ | |||||||
|  |  | ||||||
| AC_PREREQ(2.60) | AC_PREREQ(2.60) | ||||||
|  |  | ||||||
| AC_INIT([libupnp], [1.4.7], [mroberto@users.sourceforge.net]) | AC_INIT([libupnp], [1.6.0], [mroberto@users.sourceforge.net]) | ||||||
| # *Independently* of the above libupnp package version, the libtool version | # *Independently* of the above libupnp package version, the libtool version | ||||||
| # of the 3 libraries need to be updated whenever there is a change released : | # of the 3 libraries need to be updated whenever there is a change released : | ||||||
| # "current:revision:age" (this is NOT the same as the package version), where: | # "current:revision:age" (this is NOT the same as the package version), where: | ||||||
| @@ -34,11 +34,35 @@ AC_INIT([libupnp], [1.4.7], [mroberto@users.sourceforge.net]) | |||||||
| #	current: 2 -> 3 | #	current: 2 -> 3 | ||||||
| #	revisiion: 3 -> 0 | #	revisiion: 3 -> 0 | ||||||
| #	age: 0 -> 1 | #	age: 0 -> 1 | ||||||
| # - Code has changed in upnp (revision 2 -> 3) | # - Code has changed in upnp | ||||||
| #	revision: 2 -> 3 | #	revision: 2 -> 3 | ||||||
| AC_SUBST([LT_VERSION_IXML],       [2:3:0]) | # | ||||||
| AC_SUBST([LT_VERSION_THREADUTIL], [3:0:1]) | # For release 1.4.6, we had: | ||||||
| AC_SUBST([LT_VERSION_UPNP],       [2:3:0]) | #AC_SUBST([LT_VERSION_IXML],       [2:3:0]) | ||||||
|  | #AC_SUBST([LT_VERSION_THREADUTIL], [3:0:1]) | ||||||
|  | #AC_SUBST([LT_VERSION_UPNP],       [2:3:0]) | ||||||
|  | # | ||||||
|  | # "current:revision:age" | ||||||
|  | # | ||||||
|  | # - Code has changed in ixml | ||||||
|  | #	revision: 3 -> 4 | ||||||
|  | # - Code has changed in threadutil | ||||||
|  | #	revision: 0 -> 1 | ||||||
|  | # - Code has changed in upnp | ||||||
|  | #	revision: 3 -> 4 | ||||||
|  | # - Interface changed in upnp | ||||||
|  | #	current: 2 -> 3 | ||||||
|  | #	revision: 4 -> 0 | ||||||
|  | # - Interface removed in upnp | ||||||
|  | #	age: 0 -> 0 | ||||||
|  | # | ||||||
|  | # For release 1.6.0, we had: | ||||||
|  | #AC_SUBST([LT_VERSION_IXML],       [2:4:0]) | ||||||
|  | #AC_SUBST([LT_VERSION_THREADUTIL], [3:1:1]) | ||||||
|  | #AC_SUBST([LT_VERSION_UPNP],       [3:0:0]) | ||||||
|  | AC_SUBST([LT_VERSION_IXML],       [2:4:0]) | ||||||
|  | AC_SUBST([LT_VERSION_THREADUTIL], [3:1:1]) | ||||||
|  | AC_SUBST([LT_VERSION_UPNP],       [3:0:0]) | ||||||
|  |  | ||||||
|  |  | ||||||
| AC_CONFIG_AUX_DIR(config.aux) | AC_CONFIG_AUX_DIR(config.aux) | ||||||
|   | |||||||
| @@ -828,13 +828,10 @@ struct Upnp_Event | |||||||
|  * Upnp_Discovery structure correctly. |  * Upnp_Discovery structure correctly. | ||||||
|  */ |  */ | ||||||
|  |  | ||||||
| typedef struct sockaddr_in SOCKADDRIN; |  | ||||||
|  |  | ||||||
| /** Returned in a {\bf UPNP_DISCOVERY_RESULT} callback. */ | /** Returned in a {\bf UPNP_DISCOVERY_RESULT} callback. */ | ||||||
|  |  | ||||||
| struct Upnp_Discovery | struct Upnp_Discovery | ||||||
| { | { | ||||||
|  |  | ||||||
| 	/** The result code of the {\bf UpnpSearchAsync} call. */ | 	/** The result code of the {\bf UpnpSearchAsync} call. */ | ||||||
| 	int  ErrCode;                   | 	int  ErrCode;                   | ||||||
| 				      | 				      | ||||||
| @@ -866,8 +863,7 @@ struct Upnp_Discovery | |||||||
| 	char Ext[LINE_SIZE];            | 	char Ext[LINE_SIZE];            | ||||||
| 				      | 				      | ||||||
| 	/** The host address of the device responding to the search. */ | 	/** The host address of the device responding to the search. */ | ||||||
|   SOCKADDRIN * DestAddr;  | 	struct sockaddr_in DestAddr;  | ||||||
|  |  | ||||||
| }; | }; | ||||||
|  |  | ||||||
| /** Returned along with a {\bf UPNP_EVENT_SUBSCRIBE_COMPLETE} or {\bf | /** Returned along with a {\bf UPNP_EVENT_SUBSCRIBE_COMPLETE} or {\bf | ||||||
|   | |||||||
| @@ -396,7 +396,7 @@ scanner_get_str( IN scanner_t * scanner ) | |||||||
| * Note : | * Note : | ||||||
| ************************************************************************/ | ************************************************************************/ | ||||||
| #warning The only use of the function 'scanner_pushback()' in the code is commented out. | #warning The only use of the function 'scanner_pushback()' in the code is commented out. | ||||||
| #warning 'scanner_pushback()' is a good candidate for removal. | #warning 'scanner_pushback()' is a candidate for removal. | ||||||
| static UPNP_INLINE void | static UPNP_INLINE void | ||||||
| scanner_pushback( INOUT scanner_t * scanner, | scanner_pushback( INOUT scanner_t * scanner, | ||||||
|                   IN size_t pushback_bytes ) |                   IN size_t pushback_bytes ) | ||||||
| @@ -966,7 +966,7 @@ read_until_crlf( INOUT scanner_t * scanner, | |||||||
| *   PARSE_INCOMPLETE | *   PARSE_INCOMPLETE | ||||||
| ************************************************************************/ | ************************************************************************/ | ||||||
| #warning There are currently no uses of the function 'skip_to_end_of_header()' in the code. | #warning There are currently no uses of the function 'skip_to_end_of_header()' in the code. | ||||||
| #warning 'skip_to_end_of_header()' is a good candidate for removal. | #warning 'skip_to_end_of_header()' is a candidate for removal. | ||||||
| static UPNP_INLINE int | static UPNP_INLINE int | ||||||
| skip_to_end_of_header( INOUT scanner_t * scanner ) | skip_to_end_of_header( INOUT scanner_t * scanner ) | ||||||
| { | { | ||||||
|   | |||||||
| @@ -159,7 +159,7 @@ ssdp_handle_ctrlpt_msg( IN http_message_t * hmsg, | |||||||
|     } |     } | ||||||
|  |  | ||||||
|     // dest addr |     // dest addr | ||||||
|     param.DestAddr = dest_addr; |     memcpy(¶m.DestAddr, dest_addr, sizeof(struct sockaddr_in) ); | ||||||
|  |  | ||||||
|     // EXT |     // EXT | ||||||
|     param.Ext[0] = '\0'; |     param.Ext[0] = '\0'; | ||||||
| @@ -366,7 +366,7 @@ ssdp_handle_ctrlpt_msg( IN http_message_t * hmsg, | |||||||
| * | * | ||||||
| ***************************************************************************/ | ***************************************************************************/ | ||||||
| #warning There are currently no uses of the function 'process_reply()' in the code. | #warning There are currently no uses of the function 'process_reply()' in the code. | ||||||
| #warning 'process_reply()' is a good candidate for removal. | #warning 'process_reply()' is a candidate for removal. | ||||||
| static UPNP_INLINE void | static UPNP_INLINE void | ||||||
| process_reply( IN char *request_buf, | process_reply( IN char *request_buf, | ||||||
|                IN int buf_len, |                IN int buf_len, | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 Marcelo Roberto Jimenez
					Marcelo Roberto Jimenez