Compare commits
	
		
			7 Commits
		
	
	
		
			release-1.
			...
			release-1.
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | eaaa721a15 | ||
|   | b09faaaec4 | ||
|   | 881952bd0d | ||
|   | ec93478a4f | ||
|   | a7ab0acfe8 | ||
|   | 85a8da77f2 | ||
|   | 25620c1967 | 
							
								
								
									
										264
									
								
								ChangeLog
									
									
									
									
									
								
							
							
						
						
									
										264
									
								
								ChangeLog
									
									
									
									
									
								
							| @@ -1,7 +1,191 @@ | |||||||
|  | ******************************************************************************* | ||||||
|  | Version 1.4.7 | ||||||
|  | ******************************************************************************* | ||||||
|  |  | ||||||
| ************************************************************************* | 2007-05-26 Marcelo Jimenez <mroberto(at)users.sourceforge.net> | ||||||
|  | 	* Added support for the Basic Device | ||||||
|  | 	(http://www.upnp.org/standardizeddcps/basic.asp) as suggested by | ||||||
|  | 	Titus Winters. | ||||||
|  |  | ||||||
|  | 2007-05-25 Marcelo Jimenez <mroberto(at)users.sourceforge.net> | ||||||
|  | 	* Fixed the file libupnp.pc.in to generate a correct path for the | ||||||
|  | 	include files. | ||||||
|  |  | ||||||
|  | 2007-05-25 Marcelo Jimenez <mroberto(at)users.sourceforge.net> | ||||||
|  | 	* Removing the Dbg_Level, InitLog, SetLogFileNames and CloseLog | ||||||
|  | 	defines. These were just aliases, no reason to keep them. | ||||||
|  |  | ||||||
|  | 2007-05-25 Marcelo Jimenez <mroberto(at)users.sourceforge.net> | ||||||
|  | 	* Changed the comments of the include files that expose the UPnP API | ||||||
|  | 	to use only C89 comments and no C99 comments. | ||||||
|  |  | ||||||
|  | 2007-05-24 Nektarios K. Papadopoulos <npapadop(at)inaccessnetworks.com> | ||||||
|  | 	* Added tvcombo sample that demonstrates coexistence of a device and a | ||||||
|  | 	control point in the same application. | ||||||
|  |  | ||||||
|  | 2007-05-24 Nektarios K. Papadopoulos <npapadop(at)inaccessnetworks.com> | ||||||
|  | 	* SF Tracker FR [ 1570020 ]. | ||||||
|  | 	* Enable both device and control point in the same application. Resolve | ||||||
|  | 	deadlock in the SSDP processing threads. | ||||||
|  | 	* Fix Threadpool expansion condition. | ||||||
|  | 	Thanks to Siva Chandran P. for the original patch. | ||||||
|  |  | ||||||
|  | 2007-05-24 Nektarios K. Papadopoulos <npapadop(at)inaccessnetworks.com> | ||||||
|  | 	* Modified tvdevice (control and picture) service descriptions to make | ||||||
|  | 	compatible with WinXP/IE control point. 'in' arguments must appear before | ||||||
|  | 	'out' arguments in argument list. | ||||||
|  | 	Thanks to Martin Tremblay for pointing out the solution originally provided | ||||||
|  | 	by MORIOKA Yasuhiro. | ||||||
|  |  | ||||||
|  | 2007-05-21 Marcelo Jimenez <mroberto(at)users.sourceforge.net> | ||||||
|  | 	* More MSVC fixes, using XINLINE instead of inline, MSVC has troubles | ||||||
|  | 	with inline. Thanks to David Maass for reporting. | ||||||
|  | 	* Changed XINLINE to UPNP_INLINE. | ||||||
|  |  | ||||||
|  | 2007-05-21 Marcelo Jimenez <mroberto(at)users.sourceforge.net> | ||||||
|  | 	* Added the file build/inc/msvc/inttypes.h. This file is for use with | ||||||
|  | 	MSVC only, because it does not provide C99 compatibility. | ||||||
|  |  | ||||||
|  | 2007-05-18 Marcelo Jimenez <mroberto(at)users.sourceforge.net> | ||||||
|  | 	* Removed all uses of the DEVICEONLY(x) macro. | ||||||
|  |  | ||||||
|  | 2007-05-17 Marcelo Jimenez <mroberto(at)users.sourceforge.net> | ||||||
|  | 	* Removed all uses of the DBGONLY(x) macro. A static inline empty | ||||||
|  | 	function now is used and the compiler takes care of optimizing it out. | ||||||
|  |  | ||||||
|  | 2007-05-17 Marcelo Jimenez <mroberto(at)users.sourceforge.net> | ||||||
|  | 	* Fixed a bug in UpnpPrintf, function could call va_start() and return | ||||||
|  | 	befor calling va_end(). | ||||||
|  |  | ||||||
|  | 2007-05-15 Marcelo Jimenez <mroberto(at)users.sourceforge.net> | ||||||
|  | 	* EXPORT_SPEC missing on some declarations in ixml/inc/ixml.h. | ||||||
|  | 	Thanks to David Maass. | ||||||
|  |  | ||||||
|  | 2007-05-15 Marcelo Jimenez <mroberto(at)users.sourceforge.net> | ||||||
|  | 	* sizeof is unsigned, so %zu is more adequate than %zd. | ||||||
|  |  | ||||||
|  | 2007-05-15 Marcelo Jimenez <mroberto(at)users.sourceforge.net> | ||||||
|  | 	* Using an invented printf directive PRIzu that on MSVC | ||||||
|  | 	expands to "lu", and on normal C99 compilers expands to "zu". | ||||||
|  |  | ||||||
|  | 2007-05-15 Marcelo Jimenez <mroberto(at)users.sourceforge.net> | ||||||
|  | 	* Rewrote raw_find_str. Now it no longer uses strcasestr(), but it | ||||||
|  | 	transforms the first input buffer into lowercase. | ||||||
|  |  | ||||||
|  | 2007-05-08 Marcelo Jimenez <mroberto(at)users.sourceforge.net> | ||||||
|  | 	* Fix for debug printf format strings. size_t are not expected | ||||||
|  | 	in a string format like "%.*s". | ||||||
|  |  | ||||||
|  | 2007-05-08 Marcelo Jimenez <mroberto(at)users.sourceforge.net> | ||||||
|  | 	* Added inttypes.h as a header requirement in configure.ac. | ||||||
|  |  | ||||||
|  | 2007-05-11 Marcelo Jimenez <mroberto(at)users.sourceforge.net> | ||||||
|  | 	* Moved upnp_tv_ctrlpt and upnp_tv_device executables from folder | ||||||
|  | 	upnp to folder upnp/sample. Moved folder upnp/sample/tvdevice/web | ||||||
|  | 	to folder upnp/sample/web. This way, if someone compiles the | ||||||
|  | 	tarball and executes upnp_tv_device from its creation directory, | ||||||
|  | 	there will be no error -108 for not finding directory web. | ||||||
|  |  | ||||||
|  | ******************************************************************************* | ||||||
|  | Version 1.4.6 | ||||||
|  | ******************************************************************************* | ||||||
|  |  | ||||||
|  | 2007-04-19 Marcelo Jimenez <mroberto(at)users.sourceforge.net> | ||||||
|  | 	* Fix for freebsd host_os in configure.ac. | ||||||
|  |  | ||||||
|  | ******************************************************************************* | ||||||
|  | Version 1.4.5 | ||||||
|  | ******************************************************************************* | ||||||
|  |  | ||||||
|  | 2007-04-19 Marcelo Jimenez <mroberto(at)users.sourceforge.net> | ||||||
|  | 	* Case insensitive comparison in raw_find_str() (httpparser.c) as | ||||||
|  | 	suggested by Craig Nelson in SF Tracker [ 1689382 ] DLINK DIR-625 | ||||||
|  | 	patch. | ||||||
|  |  | ||||||
|  | 2007-04-07 Nektarios K. Papadopoulos <npapadop(at)inaccessnetworks.com> | ||||||
|  | 	* Fix for a bug in makeAction where va_arg was beeing called one | ||||||
|  | 	extra time. | ||||||
|  |  | ||||||
|  | 2007-04-28 Marcelo Jimenez <mroberto(at)users.sourceforge.net> | ||||||
|  | 	* SF Tracker [ 1703533 ] Patch to make it compile under FreeBSD | ||||||
|  | 	Submitted By: Timothy Redaelli - drittz | ||||||
|  | 	I made some patches to make it compile under FreeBSD using | ||||||
|  | 	gethostbyaddr_r when supported. | ||||||
|  |  | ||||||
|  | 2007-04-28 Marcelo Jimenez <mroberto(at)users.sourceforge.net> | ||||||
|  | 	* [pupnp-devel] Type mixup on x86_64 causes UPNP_E_OUTOF_MEMORY | ||||||
|  | 	Submitted By: Glen Masgai | ||||||
|  | 	after an UpnpSendActionAsync() for example, i get UPNP_E_OUTOF_MEMORY | ||||||
|  | 	in the callback using 1.4.4 on a x86_64 system. This happens in | ||||||
|  | 	http_MakeMessage(), which in some cases get called with wrong types | ||||||
|  | 	(int instead of size_t) in combination with format "b" and "Q". | ||||||
|  | 	The attached patch should fix this. | ||||||
|  |  | ||||||
|  | ******************************************************************************* | ||||||
|  | Version 1.4.4 | ||||||
|  | ******************************************************************************* | ||||||
|  |  | ||||||
|  | 2007-04-06 Marcelo Jimenez <mroberto(at)users.sourceforge.net> | ||||||
|  | 	* SF Tracker [ 1695399 ] Typo in util.h | ||||||
|  | 	Submitted By: Luke Kim - nereusuj | ||||||
|  | 	Unix sleep is in seconds but WIN32 Sleep is in milliseconds. | ||||||
|  |  | ||||||
|  | 2007-04-17 Marcelo Jimenez <mroberto(at)users.sourceforge.net> | ||||||
|  | 	* SF Tracker [ 1652827 ] UpnpRegisterRootDevice returned -104 | ||||||
|  | 	Submitted By: Michael Andersen - miwer | ||||||
|  | 	 | ||||||
|  | 	Issue was found to be related to sizeof (size_t) != sizeof (int) | ||||||
|  | 	on AMD64 systems. Emil Ljungdahl's AMD64 patch has been applied along | ||||||
|  | 	with some other fixes. Original user report follows: | ||||||
|  |  | ||||||
|  | 	When I run upnpd I get the above mentioned error (UPNP_E_OUTOF_MEMORY). | ||||||
|  | 	I've tried with 1.4.1 and 1.4.2-RC3, it's the same. I don't understand why, | ||||||
|  | 	because I have plenty of RAM, and I even tried closing some applications, | ||||||
|  | 	but it didn't help. | ||||||
|  |  | ||||||
|  | 	$ upnpd eth1 br0 | ||||||
|  |  | ||||||
|  | 	The following is logged in the /var/log/messages: | ||||||
|  | 	Feb 6 01:33:47 server upnpd[6933]: Error registering the root device with | ||||||
|  | 	descDocUrl: http://192.168.0.1:49152/gatedesc.xml | ||||||
|  | 	Feb 6 01:33:47 server upnpd[6933]: UpnpRegisterRootDevice returned -104 | ||||||
|  |  | ||||||
|  |  | ||||||
|  | 	I tried enabling debugging and it looks like it cannot allocate memory | ||||||
|  | 	through the membuffer_append function. It's wierd because it's only a few | ||||||
|  | 	bytes. | ||||||
|  |  | ||||||
|  | 	Please note, that I enabled some extra debugging lines that were commented, | ||||||
|  | 	in order to get more information. See attached files. | ||||||
|  |  | ||||||
|  | ******************************************************************************* | ||||||
| Version 1.4.3 | Version 1.4.3 | ||||||
| ************************************************************************* | ******************************************************************************* | ||||||
|  |  | ||||||
|  | 2007-03-13 Marcelo Jimenez <mroberto(at)users.sourceforge.net> | ||||||
|  | 	* SF Tracker [ 1663004 ] Compile on Cygwin | ||||||
|  | 	Submitted By: Jon Foster - jongfoster | ||||||
|  | 	This patch gives basic support for building under Cygwin - it compiles, | ||||||
|  | 	links, and a simple UPnP device application can initialise. I'm not sure | ||||||
|  | 	if it actually works yet, but this is definitely a step in the right | ||||||
|  | 	direction. | ||||||
|  | 	 | ||||||
|  | 	Patch is against the 1.4.1 release. Changes are: | ||||||
|  | 	 | ||||||
|  | 	* threadutil/inc/ithread.h: Fix the ithread mutex support to use | ||||||
|  | 	documented, portable APIs (if present) rather than the Non-Portable (_NP) | ||||||
|  | 	ones it uses now. This is required because Cygwin implements only the | ||||||
|  | 	portable API. | ||||||
|  | 	 | ||||||
|  | 	* threadutil/src/ThreadPool.c: Fake SetPolicyType() to do nothing on Cygwin | ||||||
|  | 	because otherwise it fails. Should probably investigate why it fails and | ||||||
|  | 	add a proper implementation later. | ||||||
|  | 	 | ||||||
|  | 	* upnp/src/api/upnpapi.c: On Cygwin, zero out the GlobalHndMutex structure | ||||||
|  | 	before initialising it. Without this, the initialisation fails. This | ||||||
|  | 	appears to be a bug in Cygwin. | ||||||
|  | 	 | ||||||
|  | 	* upnp/src/genlib/net/uri/uri.c: Use gethostbyname() on Cygwin. | ||||||
| 	 | 	 | ||||||
| 2007-03-05 Oxy <oxygenic(at)users.sourceforge.net> | 2007-03-05 Oxy <oxygenic(at)users.sourceforge.net> | ||||||
| 	* Code adapted and typedefs added to compile cleanly under Windows | 	* Code adapted and typedefs added to compile cleanly under Windows | ||||||
| @@ -11,9 +195,9 @@ Version 1.4.3 | |||||||
| 	 | 	 | ||||||
| 	* Fixed nasty segmentation fault bug on membuffer.c. | 	* Fixed nasty segmentation fault bug on membuffer.c. | ||||||
| 	 | 	 | ||||||
| ************************************************************************* | ******************************************************************************* | ||||||
| Version 1.4.2 | Version 1.4.2 | ||||||
| ************************************************************************* | ******************************************************************************* | ||||||
|  |  | ||||||
| 2007-02-09 Marcelo Jimenez <mroberto(at)users.sourceforge.net> | 2007-02-09 Marcelo Jimenez <mroberto(at)users.sourceforge.net> | ||||||
|  |  | ||||||
| @@ -115,9 +299,9 @@ Version 1.4.2 | |||||||
| 	* support for large files (>2 GBytes) added | 	* support for large files (>2 GBytes) added | ||||||
|  |  | ||||||
|  |  | ||||||
| ************************************************************************* | ******************************************************************************* | ||||||
| Version 1.4.1 | Version 1.4.1 | ||||||
| ************************************************************************* | ******************************************************************************* | ||||||
|  |  | ||||||
| 2006-07-07 Oxy <virtual_worlds(at)gmx.de> | 2006-07-07 Oxy <virtual_worlds(at)gmx.de> | ||||||
|  |  | ||||||
| @@ -148,9 +332,9 @@ Version 1.4.1 | |||||||
| 	* Patch to fix memory leaks and reasons for crashes added (thanks | 	* Patch to fix memory leaks and reasons for crashes added (thanks | ||||||
| 	to loigu) | 	to loigu) | ||||||
|  |  | ||||||
| ************************************************************************* | ******************************************************************************* | ||||||
| Version 1.4.0 | Version 1.4.0 | ||||||
| ************************************************************************* | ******************************************************************************* | ||||||
|  |  | ||||||
| 2006-05-26 Oxy <virtual_worlds(at)gmx.de> | 2006-05-26 Oxy <virtual_worlds(at)gmx.de> | ||||||
|  |  | ||||||
| @@ -176,18 +360,18 @@ Version 1.4.0 | |||||||
| 	 | 	 | ||||||
| 	* Bugfix for M-Search packet | 	* Bugfix for M-Search packet | ||||||
|  |  | ||||||
| ************************************************************************* | ******************************************************************************* | ||||||
| FORK FROM DEAD libupnp | FORK FROM DEAD libupnp | ||||||
| ************************************************************************* | ******************************************************************************* | ||||||
|  |  | ||||||
| 2006-04-29  R<>mi Turboult  <r3mi(at)users.sourceforge.net> | 2006-04-29  R<>mi Turboult  <r3mi(at)users.sourceforge.net> | ||||||
|  |  | ||||||
| 	* THANKS: new file with list of contributors | 	* THANKS: new file with list of contributors | ||||||
|  |  | ||||||
| 	* upnp/src/gena/gena_device.c (respond_ok): add 'Content-Length: 0' | 	* upnp/src/gena/gena_device.c (respond_ok): add 'Content-Length: 0' | ||||||
| 	  in subscription response. Patch by Chaos (Bug # 1455367). | 	  in subscription response. Patch by Chaos (Bug # 1455367). | ||||||
|  |  | ||||||
| 2006-04-08  R<>mi Turboult  <r3mi(at)users.sourceforge.net> | 2006-04-08  R<>mi Turboult  <r3mi(at)users.sourceforge.net> | ||||||
|  |  | ||||||
| 	* upnp/doc/UPnP_Programming_Guide.pdf: replace this document with  | 	* upnp/doc/UPnP_Programming_Guide.pdf: replace this document with  | ||||||
| 	  the one in libupnp-doc-1.2.1 because current CVS version  | 	  the one in libupnp-doc-1.2.1 because current CVS version  | ||||||
| @@ -198,20 +382,20 @@ FORK FROM DEAD libupnp | |||||||
| 	* changes applied to several files to work under Sparc Solaris, temporarily | 	* changes applied to several files to work under Sparc Solaris, temporarily | ||||||
| 	  requiring a define SPARC_SOLARIS | 	  requiring a define SPARC_SOLARIS | ||||||
|  |  | ||||||
| 2006-04-03  R<>mi Turboult  <r3mi(at)users.sourceforge.net> | 2006-04-03  R<>mi Turboult  <r3mi(at)users.sourceforge.net> | ||||||
|  |  | ||||||
| 	* upnp/Makefile.am: install upnp samples in $(docdir)/examples | 	* upnp/Makefile.am: install upnp samples in $(docdir)/examples | ||||||
|  |  | ||||||
| 2006-03-28  R<>mi Turboult  <r3mi(at)users.sourceforge.net> | 2006-03-28  R<>mi Turboult  <r3mi(at)users.sourceforge.net> | ||||||
|  |  | ||||||
| 	* configure.ac: add --with-docdir option to choose where documentation | 	* configure.ac: add --with-docdir option to choose where documentation | ||||||
| 	  is installed (or -without-docdir to not install the documentation) | 	  is installed (or -without-docdir to not install the documentation) | ||||||
|  |  | ||||||
| 2006-03-27  R<>mi Turboult  <r3mi(at)users.sourceforge.net> | 2006-03-27  R<>mi Turboult  <r3mi(at)users.sourceforge.net> | ||||||
|  |  | ||||||
| 	* ixml/test: add simple test suite for xml parser | 	* ixml/test: add simple test suite for xml parser | ||||||
|  |  | ||||||
| 2006-03-26  R<>mi Turboult  <r3mi(at)users.sourceforge.net> | 2006-03-26  R<>mi Turboult  <r3mi(at)users.sourceforge.net> | ||||||
|  |  | ||||||
| 	* ixml/src/ixmlparser.c (Parser_processCDSect): fix bug which prevents | 	* ixml/src/ixmlparser.c (Parser_processCDSect): fix bug which prevents | ||||||
| 	  CDATA sections which contain a 0 (zero) to be parsed (instead the | 	  CDATA sections which contain a 0 (zero) to be parsed (instead the | ||||||
| @@ -222,18 +406,18 @@ FORK FROM DEAD libupnp | |||||||
| 	  option, and move samples compilation from check_PROGRAMS to | 	  option, and move samples compilation from check_PROGRAMS to | ||||||
| 	  noinst_PROGRAMS | 	  noinst_PROGRAMS | ||||||
|  |  | ||||||
| 2006-03-25  R<>mi Turboult  <r3mi(at)users.sourceforge.net> | 2006-03-25  R<>mi Turboult  <r3mi(at)users.sourceforge.net> | ||||||
|  |  | ||||||
| 	* upnp/src/genlib/miniserver/miniserver.c (get_miniserver_sockets):  | 	* upnp/src/genlib/miniserver/miniserver.c (get_miniserver_sockets):  | ||||||
| 	  fix bug if new socket created has fd 0 (can only occur when stdin | 	  fix bug if new socket created has fd 0 (can only occur when stdin | ||||||
| 	  has been closed). Patch by Oskar Liljeblad 2004-07-02 : | 	  has been closed). Patch by Oskar Liljeblad 2004-07-02 : | ||||||
| 	  http://sourceforge.net/mailarchive/message.php?msg_id=8870528 | 	  http://sourceforge.net/mailarchive/message.php?msg_id=8870528 | ||||||
| 	 | 	 | ||||||
| 2006-03-21  R<>mi Turboult  <r3mi(at)users.sourceforge.net> | 2006-03-21  R<>mi Turboult  <r3mi(at)users.sourceforge.net> | ||||||
|  |  | ||||||
| 	* upnp/test/test_init.c: add some version checks and exit if failure | 	* upnp/test/test_init.c: add some version checks and exit if failure | ||||||
|  |  | ||||||
| 2006-03-05  R<>mi Turboult  <r3mi(at)users.sourceforge.net> | 2006-03-05  R<>mi Turboult  <r3mi(at)users.sourceforge.net> | ||||||
|  |  | ||||||
| 	* libupnp version 1.3.1 | 	* libupnp version 1.3.1 | ||||||
|  |  | ||||||
| @@ -248,11 +432,11 @@ FORK FROM DEAD libupnp | |||||||
| 	  dependencies between upnp and ixml / threadutil, so that programs  | 	  dependencies between upnp and ixml / threadutil, so that programs  | ||||||
| 	  linking against upnp only still work. | 	  linking against upnp only still work. | ||||||
|  |  | ||||||
| 2006-03-04  R<>mi Turboult  <r3mi(at)users.sourceforge.net> | 2006-03-04  R<>mi Turboult  <r3mi(at)users.sourceforge.net> | ||||||
|  |  | ||||||
| 	* libupnp version 1.3.0 | 	* libupnp version 1.3.0 | ||||||
|  |  | ||||||
| 2006-03-03  R<>mi Turboult  <r3mi(at)users.sourceforge.net> | 2006-03-03  R<>mi Turboult  <r3mi(at)users.sourceforge.net> | ||||||
|  |  | ||||||
| 	* upnp/src/genlib/net/http/httpreadwrite.c (get_sdk_info): use | 	* upnp/src/genlib/net/http/httpreadwrite.c (get_sdk_info): use | ||||||
| 	  package version string from configure to set sdk info | 	  package version string from configure to set sdk info | ||||||
| @@ -260,7 +444,7 @@ FORK FROM DEAD libupnp | |||||||
| 	* upnp/Makefile.am: add sample/tvdevice/web/ files in EXTRA_DIST | 	* upnp/Makefile.am: add sample/tvdevice/web/ files in EXTRA_DIST | ||||||
| 	  + do not distribute generated upnpconfig.h file. | 	  + do not distribute generated upnpconfig.h file. | ||||||
|  |  | ||||||
| 2006-02-28  R<>mi Turboult  <r3mi(at)users.sourceforge.net> | 2006-02-28  R<>mi Turboult  <r3mi(at)users.sourceforge.net> | ||||||
|  |  | ||||||
| 	* upnp/src/inc/config.h, configure.ac: use only new defines | 	* upnp/src/inc/config.h, configure.ac: use only new defines | ||||||
| 	  UPNP_HAVE_xx instead of INCLUDE_yyy_APIS and INTERNAL_WEB_SERVER | 	  UPNP_HAVE_xx instead of INCLUDE_yyy_APIS and INTERNAL_WEB_SERVER | ||||||
| @@ -269,7 +453,7 @@ FORK FROM DEAD libupnp | |||||||
| 	  the librarie LDFLAGS in order to export only the symbols defined  | 	  the librarie LDFLAGS in order to export only the symbols defined  | ||||||
| 	  in the API | 	  in the API | ||||||
|  |  | ||||||
| 2006-02-27  R<>mi Turboult  <r3mi(at)users.sourceforge.net> | 2006-02-27  R<>mi Turboult  <r3mi(at)users.sourceforge.net> | ||||||
|  |  | ||||||
| 	* configure.ac: add libtool versions for the 3 libraries | 	* configure.ac: add libtool versions for the 3 libraries | ||||||
|  |  | ||||||
| @@ -277,7 +461,7 @@ FORK FROM DEAD libupnp | |||||||
|  |  | ||||||
| 	* threadutil/src/ThreadPool.c (SetSeed): add missing 'static'  | 	* threadutil/src/ThreadPool.c (SetSeed): add missing 'static'  | ||||||
|  |  | ||||||
| 2006-02-26  R<>mi Turboult  <r3mi(at)users.sourceforge.net> | 2006-02-26  R<>mi Turboult  <r3mi(at)users.sourceforge.net> | ||||||
|  |  | ||||||
| 	* threadutil/inc/iasnprintf.h: add gcc __printf__ format attribute | 	* threadutil/inc/iasnprintf.h: add gcc __printf__ format attribute | ||||||
| 	  to "iasnprintf" | 	  to "iasnprintf" | ||||||
| @@ -298,11 +482,11 @@ FORK FROM DEAD libupnp | |||||||
| 	  the configuration of the installed libraries (generates installed | 	  the configuration of the installed libraries (generates installed | ||||||
| 	  file <upnp/upnpconfig.h>) | 	  file <upnp/upnpconfig.h>) | ||||||
|  |  | ||||||
| 2006-02-22  R<>mi Turboult  <r3mi(at)users.sourceforge.net> | 2006-02-22  R<>mi Turboult  <r3mi(at)users.sourceforge.net> | ||||||
|  |  | ||||||
| 	* upnp/ : add missing include of config.h in some .c files | 	* upnp/ : add missing include of config.h in some .c files | ||||||
|  |  | ||||||
| 2006-02-21  R<>mi Turboult  <r3mi(at)users.sourceforge.net> | 2006-02-21  R<>mi Turboult  <r3mi(at)users.sourceforge.net> | ||||||
|  |  | ||||||
| 	* upnp/inc/upnp.h: move some definitions which should not be | 	* upnp/inc/upnp.h: move some definitions which should not be | ||||||
| 	  exported into "upnp/src/inc/util.h" | 	  exported into "upnp/src/inc/util.h" | ||||||
| @@ -310,12 +494,12 @@ FORK FROM DEAD libupnp | |||||||
| 	* import all modifications below from libupnp in djmount 0.51 | 	* import all modifications below from libupnp in djmount 0.51 | ||||||
| 	  into official libupnp | 	  into official libupnp | ||||||
| 	 | 	 | ||||||
| 2006-01-17  R<>mi Turboult  <r3mi(at)users.sourceforge.net> | 2006-01-17  R<>mi Turboult  <r3mi(at)users.sourceforge.net> | ||||||
|  |  | ||||||
| 	* threadutil/Makefile.am (libthreadutil_la_SOURCES): remove extraneous | 	* threadutil/Makefile.am (libthreadutil_la_SOURCES): remove extraneous | ||||||
| 	  file | 	  file | ||||||
|  |  | ||||||
| 2006-01-15  R<>mi Turboult  <r3mi(at)users.sourceforge.net> | 2006-01-15  R<>mi Turboult  <r3mi(at)users.sourceforge.net> | ||||||
|  |  | ||||||
| 	* configure.ac: add checks for large-file support | 	* configure.ac: add checks for large-file support | ||||||
|  |  | ||||||
| @@ -335,53 +519,53 @@ FORK FROM DEAD libupnp | |||||||
| 	* ixml/src/node.c (ixmlNode_getNodeType): fix compilation warning | 	* ixml/src/node.c (ixmlNode_getNodeType): fix compilation warning | ||||||
| 	  on const return type | 	  on const return type | ||||||
|  |  | ||||||
| 2006-01-12  R<>mi Turboult  <r3mi(at)users.sourceforge.net> | 2006-01-12  R<>mi Turboult  <r3mi(at)users.sourceforge.net> | ||||||
|  |  | ||||||
| 	* upnp/src/inc/readwrite.h : suppress unused C++ header file | 	* upnp/src/inc/readwrite.h : suppress unused C++ header file | ||||||
|  |  | ||||||
| 2006-01-11  R<>mi Turboult  <r3mi(at)users.sourceforge.net> | 2006-01-11  R<>mi Turboult  <r3mi(at)users.sourceforge.net> | ||||||
|  |  | ||||||
| 	* upnp/inc/config.h, upnp/src/inc/upnpapi.h,  | 	* upnp/inc/config.h, upnp/src/inc/upnpapi.h,  | ||||||
| 	  upnp/src/inc/httpreadwrite.h: remove internal configuration variable  | 	  upnp/src/inc/httpreadwrite.h: remove internal configuration variable  | ||||||
| 	  MINIMUM_DELAY (no clear purpose) | 	  MINIMUM_DELAY (no clear purpose) | ||||||
|  |  | ||||||
| 2005-12-05  R<>mi Turboult  <r3mi(at)users.sourceforge.net> | 2005-12-05  R<>mi Turboult  <r3mi(at)users.sourceforge.net> | ||||||
|  |  | ||||||
| 	* upnp/inc/upnp.h: re-declare obsolete method UpnpSetContentLength, | 	* upnp/inc/upnp.h: re-declare obsolete method UpnpSetContentLength, | ||||||
| 	  for binary compatibility with previous libupnp version. | 	  for binary compatibility with previous libupnp version. | ||||||
|  |  | ||||||
| 	* upnp/src/api/upnpapi.c: correct type of g_maxContentLength to size_t | 	* upnp/src/api/upnpapi.c: correct type of g_maxContentLength to size_t | ||||||
|  |  | ||||||
| 2005-11-01  R<>mi Turboult  <r3mi(at)users.sourceforge.net> | 2005-11-01  R<>mi Turboult  <r3mi(at)users.sourceforge.net> | ||||||
|  |  | ||||||
| 	* autoconfiscate library : replace all makefiles by Makefile.am | 	* autoconfiscate library : replace all makefiles by Makefile.am | ||||||
| 	  for automake support, + preliminary autoconf support | 	  for automake support, + preliminary autoconf support | ||||||
| 	  (generated config.h not yet used in source files) | 	  (generated config.h not yet used in source files) | ||||||
|  |  | ||||||
| 2005-10-18  R<>mi Turboult  <r3mi(at)users.sourceforge.net> | 2005-10-18  R<>mi Turboult  <r3mi(at)users.sourceforge.net> | ||||||
|  |  | ||||||
| 	* upnp/src/makefile: fix location of DEBUG STATIC libupnp library | 	* upnp/src/makefile: fix location of DEBUG STATIC libupnp library | ||||||
| 	 | 	 | ||||||
| 	* upnp/sample/tvctrlpt/linux/Makefile,  | 	* upnp/sample/tvctrlpt/linux/Makefile,  | ||||||
| 	  upnp/sample/tvdevice/linux/Makefile: fix STATIC library support | 	  upnp/sample/tvdevice/linux/Makefile: fix STATIC library support | ||||||
|  |  | ||||||
| 2005-10-16  R<>mi Turboult  <r3mi(at)users.sourceforge.net> | 2005-10-16  R<>mi Turboult  <r3mi(at)users.sourceforge.net> | ||||||
|  |  | ||||||
| 	* threadutil/src/Makefile (clean): remove built library | 	* threadutil/src/Makefile (clean): remove built library | ||||||
|  |  | ||||||
| 2005-08-28  R<>mi Turboult  <r3mi(at)users.sourceforge.net> | 2005-08-28  R<>mi Turboult  <r3mi(at)users.sourceforge.net> | ||||||
|  |  | ||||||
| 	* ixml/src/ixml.h, ixml/src/ixml.c (ixmlRelaxParser) : new function | 	* ixml/src/ixml.h, ixml/src/ixml.c (ixmlRelaxParser) : new function | ||||||
|  |  | ||||||
| 	* ixml/src/ixmlparser.h, ixml/src/ixmlparser.c (Parser_setErrorChar) : | 	* ixml/src/ixmlparser.h, ixml/src/ixmlparser.c (Parser_setErrorChar) : | ||||||
| 	  new function | 	  new function | ||||||
|  |  | ||||||
| 2005-08-02  R<>mi Turboult  <r3mi(at)users.sourceforge.net> | 2005-08-02  R<>mi Turboult  <r3mi(at)users.sourceforge.net> | ||||||
|  |  | ||||||
| 	* ixml/src/Makefile: correct bug for static library being incorrectly  | 	* ixml/src/Makefile: correct bug for static library being incorrectly  | ||||||
| 	  stripped when building non-debug | 	  stripped when building non-debug | ||||||
|  |  | ||||||
| 2005-06-09  R<>mi Turboult  <r3mi(at)users.sourceforge.net> | 2005-06-09  R<>mi Turboult  <r3mi(at)users.sourceforge.net> | ||||||
|  |  | ||||||
| 	* ixml/src/element.c (ixmlElement_removeAttributeNode):  | 	* ixml/src/element.c (ixmlElement_removeAttributeNode):  | ||||||
| 	  remove some compilation warning | 	  remove some compilation warning | ||||||
| @@ -392,7 +576,7 @@ FORK FROM DEAD libupnp | |||||||
| 	* upnp/inc/upnptools.h, upnp/src/api/upnptools.c :  | 	* upnp/inc/upnptools.h, upnp/src/api/upnptools.c :  | ||||||
| 	  add missing const's in public API | 	  add missing const's in public API | ||||||
|  |  | ||||||
| 2005-05-28  R<>mi Turboult  <r3mi(at)users.sourceforge.net> | 2005-05-28  R<>mi Turboult  <r3mi(at)users.sourceforge.net> | ||||||
|  |  | ||||||
| 	* upnp/inc/config.h: suppress HTTP_READ_BYTES (unused) | 	* upnp/inc/config.h: suppress HTTP_READ_BYTES (unused) | ||||||
| 	  and replace by DEFAULT_SOAP_CONTENT_LENGTH (previously in upnpapi.h) | 	  and replace by DEFAULT_SOAP_CONTENT_LENGTH (previously in upnpapi.h) | ||||||
| @@ -413,7 +597,7 @@ FORK FROM DEAD libupnp | |||||||
| 	* upnp/src/genlib/net/http/httpreadwrite.c : corrected an incorrect | 	* upnp/src/genlib/net/http/httpreadwrite.c : corrected an incorrect | ||||||
| 	  sprintf format | 	  sprintf format | ||||||
| 	 | 	 | ||||||
| 2005-05-27  R<>mi Turboult  <r3mi(at)users.sourceforge.net> | 2005-05-27  R<>mi Turboult  <r3mi(at)users.sourceforge.net> | ||||||
|  |  | ||||||
| 	* upnp/makefile, upnp/src/makefile,  | 	* upnp/makefile, upnp/src/makefile,  | ||||||
| 	  ixml/Makefile, ixml/src/Makefile,  | 	  ixml/Makefile, ixml/src/Makefile,  | ||||||
| @@ -421,7 +605,7 @@ FORK FROM DEAD libupnp | |||||||
| 	  implement STATIC library support (from patch at  | 	  implement STATIC library support (from patch at  | ||||||
| 	  http://sourceforge.net/tracker/?group_id=7189&atid=307189 ) | 	  http://sourceforge.net/tracker/?group_id=7189&atid=307189 ) | ||||||
|  |  | ||||||
| 2005-05-26  R<>mi Turboult  <r3mi(at)users.sourceforge.net> | 2005-05-26  R<>mi Turboult  <r3mi(at)users.sourceforge.net> | ||||||
|  |  | ||||||
| 	* upnp/src/api/upnpapi.c, upnp/src/soap/soap_device.c, | 	* upnp/src/api/upnpapi.c, upnp/src/soap/soap_device.c, | ||||||
| 	  upnp/src/soap/makefile :  | 	  upnp/src/soap/makefile :  | ||||||
|   | |||||||
							
								
								
									
										14
									
								
								Makefile.am
									
									
									
									
									
								
							
							
						
						
									
										14
									
								
								Makefile.am
									
									
									
									
									
								
							| @@ -1,15 +1,19 @@ | |||||||
| # $Id: Makefile.am,v 1.5 2006/04/29 20:12:50 r3mi Exp $ |  | ||||||
| # | # | ||||||
| # Top-level "Makefile.am" for libupnp | # Top-level "Makefile.am" for libupnp | ||||||
| # | # | ||||||
| # Copyright (C) 2005 R<>mi Turboult <r3mi@users.sourceforge.net> | # Copyright (C) 2005 R<>mi Turboult <r3mi@users.sourceforge.net> | ||||||
| # | # | ||||||
|  |  | ||||||
| ACLOCAL_AMFLAGS = -I m4 | ACLOCAL_AMFLAGS = -I m4 | ||||||
|  |  | ||||||
| DISTCHECK_CONFIGURE_FLAGS = --enable-debug --enable-samples | DISTCHECK_CONFIGURE_FLAGS = --enable-debug --enable-samples | ||||||
|  |  | ||||||
| SUBDIRS = ixml threadutil upnp docs/dist | SUBDIRS = \ | ||||||
|  | 	ixml \ | ||||||
|  | 	threadutil \ | ||||||
|  | 	upnp \ | ||||||
|  | 	docs/dist | ||||||
|  |  | ||||||
|  |  | ||||||
| EXTRA_DIST = \ | EXTRA_DIST = \ | ||||||
| @@ -23,7 +27,8 @@ EXTRA_DIST = \ | |||||||
| 	build/libupnp.dsw \ | 	build/libupnp.dsw \ | ||||||
| 	build/inc/autoconfig.h \ | 	build/inc/autoconfig.h \ | ||||||
| 	build/inc/config.h \ | 	build/inc/config.h \ | ||||||
| 	build/inc/upnpconfig.h | 	build/inc/upnpconfig.h \ | ||||||
|  | 	build/msvc/inttypes.h | ||||||
|  |  | ||||||
|  |  | ||||||
| # This variable must have 'exec' in its name, in order to be installed  | # This variable must have 'exec' in its name, in order to be installed  | ||||||
| @@ -31,6 +36,7 @@ EXTRA_DIST = \ | |||||||
| pkgconfigexecdir = $(libdir)/pkgconfig | pkgconfigexecdir = $(libdir)/pkgconfig | ||||||
| pkgconfigexec_DATA = libupnp.pc | pkgconfigexec_DATA = libupnp.pc | ||||||
|  |  | ||||||
|  |  | ||||||
| $(pkgconfigexec_DATA): config.status | $(pkgconfigexec_DATA): config.status | ||||||
|  |  | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										2
									
								
								README
									
									
									
									
									
								
							
							
						
						
									
										2
									
								
								README
									
									
									
									
									
								
							| @@ -1,7 +1,7 @@ | |||||||
| Portable SDK for UPnP* Devices (libupnp) | Portable SDK for UPnP* Devices (libupnp) | ||||||
|  |  | ||||||
| Copyright (c) 2000-2003 Intel Corporation - All Rights Reserved. | Copyright (c) 2000-2003 Intel Corporation - All Rights Reserved. | ||||||
| Copyright (c) 2005-2006 R<>mi Turboult <r3mi@users.sourceforge.net> | Copyright (c) 2005-2006 R<>mi Turboult <r3mi@users.sourceforge.net> | ||||||
| Copyright (c) 2006 Michel Pfeiffer and others <virtual_worlds@gmx.de> | Copyright (c) 2006 Michel Pfeiffer and others <virtual_worlds@gmx.de> | ||||||
|  |  | ||||||
| See LICENSE for details. | See LICENSE for details. | ||||||
|   | |||||||
							
								
								
									
										6
									
								
								THANKS
									
									
									
									
									
								
							
							
						
						
									
										6
									
								
								THANKS
									
									
									
									
									
								
							| @@ -8,16 +8,20 @@ exempt of errors. | |||||||
|  |  | ||||||
| - Arno Willig | - Arno Willig | ||||||
| - Chaos | - Chaos | ||||||
|  | - Craig Nelson | ||||||
| - David Maass | - David Maass | ||||||
|  | - Emil Ljungdahl | ||||||
| - Erik Johansson | - Erik Johansson | ||||||
| - Eric Tanguy | - Eric Tanguy | ||||||
| - Erwan Velu | - Erwan Velu | ||||||
| - Fredrik Svensson | - Fredrik Svensson | ||||||
|  | - Glen Masgai | ||||||
| - Jiri Zouhar | - Jiri Zouhar | ||||||
| - John Dennis | - John Dennis | ||||||
| - Jonathan (no_dice) | - Jonathan (no_dice) | ||||||
| - Leuk_He | - Leuk_He | ||||||
| - Loigu | - Loigu | ||||||
|  | - Luke Kim | ||||||
| - Marcelo Roberto Jimenez | - Marcelo Roberto Jimenez | ||||||
| - Markus Strobl | - Markus Strobl | ||||||
| - Nektarios K. Papadopoulos | - Nektarios K. Papadopoulos | ||||||
| @@ -25,4 +29,6 @@ exempt of errors. | |||||||
| - Michael (Oxy) | - Michael (Oxy) | ||||||
| - Paul Vixie | - Paul Vixie | ||||||
| - Siva Chandran | - Siva Chandran | ||||||
|  | - Timothy Redaelli | ||||||
|  | - Titus Winters | ||||||
|  |  | ||||||
|   | |||||||
| @@ -13,7 +13,3 @@ autoreconf --force --install -Wall -Wno-obsolete $* || exit 1 | |||||||
| echo "Now run ./configure and then make." | echo "Now run ./configure and then make." | ||||||
| exit 0 | exit 0 | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1,4 +1,4 @@ | |||||||
| /* autoconfig.h.  Generated by configure.  */ | /* autoconfig.h.  Generated from autoconfig.h.in by configure.  */ | ||||||
| /* autoconfig.h.in.  Generated from configure.ac by autoheader.  */ | /* autoconfig.h.in.  Generated from configure.ac by autoheader.  */ | ||||||
|  |  | ||||||
| /* Define to 1 to compile debug code */ | /* Define to 1 to compile debug code */ | ||||||
| @@ -19,15 +19,18 @@ | |||||||
| /* Define to 1 if fseeko (and presumably ftello) exists and is declared. */ | /* Define to 1 if fseeko (and presumably ftello) exists and is declared. */ | ||||||
| #define HAVE_FSEEKO 1 | #define HAVE_FSEEKO 1 | ||||||
|  |  | ||||||
|  | /* Define to 1 if you have the `ftime' function. */ | ||||||
|  | #define HAVE_FTIME 1 | ||||||
|  |  | ||||||
| /* Define to 1 if you have the <inttypes.h> header file. */ | /* Define to 1 if you have the <inttypes.h> header file. */ | ||||||
| #define HAVE_INTTYPES_H 1 | #define HAVE_INTTYPES_H 1 | ||||||
|  |  | ||||||
|  | /* Define to 1 if you have the `compat' library (-lcompat). */ | ||||||
|  | /* #undef HAVE_LIBCOMPAT */ | ||||||
|  |  | ||||||
| /* Define to 1 if you have the <limits.h> header file. */ | /* Define to 1 if you have the <limits.h> header file. */ | ||||||
| #define HAVE_LIMITS_H 1 | #define HAVE_LIMITS_H 1 | ||||||
|  |  | ||||||
| /* Define to 1 if you have the <malloc.h> header file. */ |  | ||||||
| #define HAVE_MALLOC_H 1 |  | ||||||
|  |  | ||||||
| /* Define to 1 if you have the <memory.h> header file. */ | /* Define to 1 if you have the <memory.h> header file. */ | ||||||
| #define HAVE_MEMORY_H 1 | #define HAVE_MEMORY_H 1 | ||||||
|  |  | ||||||
| @@ -92,19 +95,19 @@ | |||||||
| #define PACKAGE "libupnp" | #define PACKAGE "libupnp" | ||||||
|  |  | ||||||
| /* Define to the address where bug reports for this package should be sent. */ | /* Define to the address where bug reports for this package should be sent. */ | ||||||
| #define PACKAGE_BUGREPORT "virtual_worlds@gmx.de" | #define PACKAGE_BUGREPORT "mroberto@users.sourceforge.net" | ||||||
|  |  | ||||||
| /* Define to the full name of this package. */ | /* Define to the full name of this package. */ | ||||||
| #define PACKAGE_NAME "libupnp" | #define PACKAGE_NAME "libupnp" | ||||||
|  |  | ||||||
| /* Define to the full name and version of this package. */ | /* Define to the full name and version of this package. */ | ||||||
| #define PACKAGE_STRING "libupnp 1.4.0" | #define PACKAGE_STRING "libupnp 1.4.7" | ||||||
|  |  | ||||||
| /* Define to the one symbol short name of this package. */ | /* Define to the one symbol short name of this package. */ | ||||||
| #define PACKAGE_TARNAME "libupnp" | #define PACKAGE_TARNAME "libupnp" | ||||||
|  |  | ||||||
| /* Define to the version of this package. */ | /* Define to the version of this package. */ | ||||||
| #define PACKAGE_VERSION "1.4.0" | #define PACKAGE_VERSION "1.4.7" | ||||||
|  |  | ||||||
| /* Define to necessary symbol if this constant uses a non-standard name on | /* Define to necessary symbol if this constant uses a non-standard name on | ||||||
|    your system. */ |    your system. */ | ||||||
| @@ -135,27 +138,30 @@ | |||||||
| #define UPNP_VERSION_MINOR 4 | #define UPNP_VERSION_MINOR 4 | ||||||
|  |  | ||||||
| /* see upnpconfig.h */ | /* see upnpconfig.h */ | ||||||
| #define UPNP_VERSION_PATCH 0 | #define UPNP_VERSION_PATCH 7 | ||||||
|  |  | ||||||
| /* see upnpconfig.h */ | /* see upnpconfig.h */ | ||||||
| #define UPNP_VERSION_STRING "1.4.0" | #define UPNP_VERSION_STRING "1.4.7" | ||||||
|  |  | ||||||
| /* Version number of package */ | /* Version number of package */ | ||||||
| #define VERSION "1.4.0" | #define VERSION "1.4.7" | ||||||
|  |  | ||||||
| /* Number of bits in a file offset, on hosts where this is settable. */ | /* File Offset size */ | ||||||
| #define _FILE_OFFSET_BITS 64 | #define _FILE_OFFSET_BITS 64 | ||||||
|  |  | ||||||
| /* Define to 1 to make fseeko visible on some hosts (e.g. glibc 2.2). */ | /* Define to 1 to make fseeko visible on some hosts (e.g. glibc 2.2). */ | ||||||
| /* #undef _LARGEFILE_SOURCE */ | /* #undef _LARGEFILE_SOURCE */ | ||||||
|  |  | ||||||
| /* Define for large files, on AIX-style hosts. */ | /* Large files support */ | ||||||
| /* #undef _LARGE_FILES */ | #define _LARGE_FILE_SOURCE  | ||||||
|  |  | ||||||
| /* Define to empty if `const' does not conform to ANSI C. */ | /* Define to empty if `const' does not conform to ANSI C. */ | ||||||
| /* #undef const */ | /* #undef const */ | ||||||
|  |  | ||||||
| /* Define to `unsigned' if <sys/types.h> does not define. */ | /* Define to `long int' if <sys/types.h> does not define. */ | ||||||
|  | /* #undef off_t */ | ||||||
|  |  | ||||||
|  | /* Define to `unsigned int' if <sys/types.h> does not define. */ | ||||||
| /* #undef size_t */ | /* #undef size_t */ | ||||||
|  |  | ||||||
| /* Substitute for socklen_t */ | /* Substitute for socklen_t */ | ||||||
|   | |||||||
| @@ -34,7 +34,6 @@ | |||||||
|  |  | ||||||
| #include "autoconfig.h" | #include "autoconfig.h" | ||||||
|  |  | ||||||
| #define MAX_JOBS_TOTAL 10 |  | ||||||
|  |  | ||||||
| /** @name Compile time configuration options | /** @name Compile time configuration options | ||||||
|  *  The Linux SDK for UPnP Devices contains some compile-time parameters  |  *  The Linux SDK for UPnP Devices contains some compile-time parameters  | ||||||
| @@ -96,6 +95,17 @@ | |||||||
| #define MAX_THREADS 12  | #define MAX_THREADS 12  | ||||||
| //@} | //@} | ||||||
|  |  | ||||||
|  | /** @name MAX_JOBS_TOTAL | ||||||
|  |  *  The {\tt MAX_JOBS_TOTAL} constant determines the maximum number of jobs | ||||||
|  |  *  that can be queued. If this limit is reached further jobs will be thrown | ||||||
|  |  *  to avoid memory exhaustion. The default value 100. | ||||||
|  |  *  (Added by Axis.) | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | //@{ | ||||||
|  | #define MAX_JOBS_TOTAL 100 | ||||||
|  | //@} | ||||||
|  |  | ||||||
| /** @name DEFAULT_SOAP_CONTENT_LENGTH | /** @name DEFAULT_SOAP_CONTENT_LENGTH | ||||||
|  * SOAP messages will read at most {\tt DEFAULT_SOAP_CONTENT_LENGTH} bytes.   |  * SOAP messages will read at most {\tt DEFAULT_SOAP_CONTENT_LENGTH} bytes.   | ||||||
|  * This prevents devices that have a misbehaving web server to send  |  * This prevents devices that have a misbehaving web server to send  | ||||||
| @@ -294,68 +304,40 @@ | |||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| /** @name DBGONLY |  | ||||||
|           The {\bf DBGONLY} macro allows code to be marked so that it |  | ||||||
|           is only included in the DEBUG build and not the release.  To |  | ||||||
|           use this macro, put the code inside of the parentheses: |  | ||||||
|  |  | ||||||
|           {\tt DBGONLY(int i;)} |  | ||||||
|  |  | ||||||
|           This will cause a declaration of the integer {\tt i} only |  | ||||||
|           in the debug build. |  | ||||||
|   */ |  | ||||||
|  |  | ||||||
| //@{ |  | ||||||
| #ifdef DEBUG |  | ||||||
|  #define DBGONLY(x) x |  | ||||||
| #else |  | ||||||
|  #define DBGONLY(x) |  | ||||||
| #endif |  | ||||||
| //@} |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| #undef  EXCLUDE_WEB_SERVER  | #undef  EXCLUDE_WEB_SERVER  | ||||||
| #undef  EXCLUDE_MINISERVER  | #undef  EXCLUDE_MINISERVER  | ||||||
| #ifdef  INTERNAL_WEB_SERVER | #ifdef  INTERNAL_WEB_SERVER | ||||||
|  #define EXCLUDE_WEB_SERVER 0 | #	define EXCLUDE_WEB_SERVER 0 | ||||||
|  #define EXCLUDE_MINISERVER 0 | #	define EXCLUDE_MINISERVER 0 | ||||||
| #else | #else | ||||||
|  #define EXCLUDE_WEB_SERVER 1 | #	define EXCLUDE_WEB_SERVER 1 | ||||||
|  #define EXCLUDE_MINISERVER 1 | #	define EXCLUDE_MINISERVER 1 | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
| #if EXCLUDE_GENA == 1 && EXCLUDE_SOAP == 1 && EXCLUDE_WEB_SERVER == 1 | #if EXCLUDE_GENA == 1 && EXCLUDE_SOAP == 1 && EXCLUDE_WEB_SERVER == 1 | ||||||
|  #undef  EXCLUDE_MINISERVER | #	undef  EXCLUDE_MINISERVER  | ||||||
|  #define EXCLUDE_MINISERVER 1 | #	define EXCLUDE_MINISERVER 1 | ||||||
|  #if INTERNAL_WEB_SERVER | #	if INTERNAL_WEB_SERVER | ||||||
|   #	error "conflicting settings: use configure --disable-webserver" | #		error "conflicting settings: use configure --disable-webserver" | ||||||
|  #endif | #	endif | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
| #if EXCLUDE_GENA == 0 || EXCLUDE_SOAP == 0 || EXCLUDE_WEB_SERVER == 0 | #if EXCLUDE_GENA == 0 || EXCLUDE_SOAP == 0 || EXCLUDE_WEB_SERVER == 0 | ||||||
|  #undef  EXCLUDE_MINISERVER | #	undef  EXCLUDE_MINISERVER  | ||||||
|  #define EXCLUDE_MINISERVER 0 | #	define EXCLUDE_MINISERVER 0 | ||||||
|  #if EXCLUDE_WEB_SERVER == 0 && !defined INTERNAL_WEB_SERVER | #	if EXCLUDE_WEB_SERVER == 0 && !defined INTERNAL_WEB_SERVER | ||||||
|   #error "conflicting settings : use configure --enable-webserver" | #		error "conflicting settings : use configure --enable-webserver" | ||||||
|  #endif | #	endif | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| #ifdef INCLUDE_CLIENT_APIS | #ifdef INCLUDE_CLIENT_APIS | ||||||
|  #define CLIENTONLY(x) x | #	define CLIENTONLY(x) x | ||||||
| #else  | #else  | ||||||
|  #define CLIENTONLY(x) | #	define CLIENTONLY(x) | ||||||
| #endif |  | ||||||
|  |  | ||||||
| #ifdef INCLUDE_DEVICE_APIS |  | ||||||
|  #define DEVICEONLY(x) x |  | ||||||
| #else |  | ||||||
|  #define DEVICEONLY(x) |  | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
| //@} | //@} | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1,8 +1,8 @@ | |||||||
| /* upnp/inc/upnpconfig.h.  Generated by configure.  */ | /* upnp/inc/upnpconfig.h.  Generated from upnpconfig.h.in by configure.  */ | ||||||
| // -*- C -*- | // -*- C -*- | ||||||
| /////////////////////////////////////////////////////////////////////////// | /////////////////////////////////////////////////////////////////////////// | ||||||
| // | // | ||||||
| // Copyright (c) 2006 R<>mi Turboult <r3mi@users.sourceforge.net> | // Copyright (c) 2006 R<>mi Turboult <r3mi@users.sourceforge.net> | ||||||
| // All rights reserved.  | // All rights reserved.  | ||||||
| // | // | ||||||
| // Redistribution and use in source and binary forms, with or without  | // Redistribution and use in source and binary forms, with or without  | ||||||
| @@ -40,7 +40,7 @@ | |||||||
|  ***************************************************************************/  |  ***************************************************************************/  | ||||||
|  |  | ||||||
| /** The library version (string) e.g. "1.3.0" */ | /** The library version (string) e.g. "1.3.0" */ | ||||||
| #define UPNP_VERSION_STRING "1.4.0" | #define UPNP_VERSION_STRING "1.4.7" | ||||||
|  |  | ||||||
| /** Major version of the library */ | /** Major version of the library */ | ||||||
| #define UPNP_VERSION_MAJOR 1 | #define UPNP_VERSION_MAJOR 1 | ||||||
| @@ -49,7 +49,7 @@ | |||||||
| #define UPNP_VERSION_MINOR 4 | #define UPNP_VERSION_MINOR 4 | ||||||
|  |  | ||||||
| /** Patch version of the library */ | /** Patch version of the library */ | ||||||
| #define UPNP_VERSION_PATCH 0 | #define UPNP_VERSION_PATCH 7 | ||||||
|  |  | ||||||
| /** The library version (numeric) e.g. 10300 means version 1.3.0 */ | /** The library version (numeric) e.g. 10300 means version 1.3.0 */ | ||||||
| #define UPNP_VERSION	\ | #define UPNP_VERSION	\ | ||||||
| @@ -69,7 +69,7 @@ | |||||||
|  |  | ||||||
| /** Defined to 1 if the library has been compiled with DEBUG enabled  | /** Defined to 1 if the library has been compiled with DEBUG enabled  | ||||||
|  *  (i.e. configure --enable-debug) : <upnp/upnpdebug.h> file is available */ |  *  (i.e. configure --enable-debug) : <upnp/upnpdebug.h> file is available */ | ||||||
| #undef UPNP_HAVE_DEBUG | /* #undef UPNP_HAVE_DEBUG */ | ||||||
|  |  | ||||||
|  |  | ||||||
| /** Defined to 1 if the library has been compiled with client API enabled  | /** Defined to 1 if the library has been compiled with client API enabled  | ||||||
|   | |||||||
| @@ -5,17 +5,17 @@ | |||||||
| # TARGTYPE "Win32 (x86) Dynamic-Link Library" 0x0102 | # TARGTYPE "Win32 (x86) Dynamic-Link Library" 0x0102 | ||||||
|  |  | ||||||
| CFG=libupnp - Win32 Debug | CFG=libupnp - Win32 Debug | ||||||
| !MESSAGE Dies ist kein g<>ltiges Makefile. Zum Erstellen dieses Projekts mit NMAKE | !MESSAGE Dies ist kein g<>ltiges Makefile. Zum Erstellen dieses Projekts mit NMAKE | ||||||
| !MESSAGE verwenden Sie den Befehl "Makefile exportieren" und f<>hren Sie den Befehl | !MESSAGE verwenden Sie den Befehl "Makefile exportieren" und f<>hren Sie den Befehl | ||||||
| !MESSAGE  | !MESSAGE  | ||||||
| !MESSAGE NMAKE /f "libupnp.mak". | !MESSAGE NMAKE /f "libupnp.mak". | ||||||
| !MESSAGE  | !MESSAGE  | ||||||
| !MESSAGE Sie k<>nnen beim Ausf<73>hren von NMAKE eine Konfiguration angeben | !MESSAGE Sie k<>nnen beim Ausf<73>hren von NMAKE eine Konfiguration angeben | ||||||
| !MESSAGE durch Definieren des Makros CFG in der Befehlszeile. Zum Beispiel: | !MESSAGE durch Definieren des Makros CFG in der Befehlszeile. Zum Beispiel: | ||||||
| !MESSAGE  | !MESSAGE  | ||||||
| !MESSAGE NMAKE /f "libupnp.mak" CFG="libupnp - Win32 Debug" | !MESSAGE NMAKE /f "libupnp.mak" CFG="libupnp - Win32 Debug" | ||||||
| !MESSAGE  | !MESSAGE  | ||||||
| !MESSAGE F<>r die Konfiguration stehen zur Auswahl: | !MESSAGE F<>r die Konfiguration stehen zur Auswahl: | ||||||
| !MESSAGE  | !MESSAGE  | ||||||
| !MESSAGE "libupnp - Win32 Release" (basierend auf  "Win32 (x86) Dynamic-Link Library") | !MESSAGE "libupnp - Win32 Release" (basierend auf  "Win32 (x86) Dynamic-Link Library") | ||||||
| !MESSAGE "libupnp - Win32 Debug" (basierend auf  "Win32 (x86) Dynamic-Link Library") | !MESSAGE "libupnp - Win32 Debug" (basierend auf  "Win32 (x86) Dynamic-Link Library") | ||||||
|   | |||||||
							
								
								
									
										301
									
								
								build/msvc/inttypes.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										301
									
								
								build/msvc/inttypes.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,301 @@ | |||||||
|  | // ISO C9x  compliant inttypes.h for Microsoft Visual Studio | ||||||
|  | // Based on ISO/IEC 9899:TC2 Committee draft (May 6, 2005) WG14/N1124  | ||||||
|  | //  | ||||||
|  | //  Copyright (c) 2006 Alexander Chemeris | ||||||
|  | //  | ||||||
|  | // Redistribution and use in source and binary forms, with or without | ||||||
|  | // modification, are permitted provided that the following conditions are met: | ||||||
|  | //  | ||||||
|  | //   1. Redistributions of source code must retain the above copyright notice, | ||||||
|  | //      this list of conditions and the following disclaimer. | ||||||
|  | //  | ||||||
|  | //   2. 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. | ||||||
|  | //  | ||||||
|  | //   3. The name of the author may be used to endorse or promote products | ||||||
|  | //      derived from this software without specific prior written permission. | ||||||
|  | //  | ||||||
|  | // THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``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 AUTHOR 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 _MSC_VER // [ | ||||||
|  | #error "Use this header only with Microsoft Visual C++ compilers!" | ||||||
|  | #endif // _MSC_VER ] | ||||||
|  |  | ||||||
|  | #ifndef _MSC_INTTYPES_H_ // [ | ||||||
|  | #define _MSC_INTTYPES_H_ | ||||||
|  |  | ||||||
|  | #if _MSC_VER > 1000 | ||||||
|  | #pragma once | ||||||
|  | #endif | ||||||
|  |  | ||||||
|  | #include <stdint.h> | ||||||
|  |  | ||||||
|  | // 7.8 Format conversion of integer types | ||||||
|  |  | ||||||
|  | typedef struct { | ||||||
|  |    intmax_t quot; | ||||||
|  |    intmax_t rem; | ||||||
|  | } imaxdiv_t; | ||||||
|  |  | ||||||
|  | // 7.8.1 Macros for format specifiers | ||||||
|  |  | ||||||
|  | // The fprintf macros for signed integers are: | ||||||
|  | #define PRId8       "d" | ||||||
|  | #define PRIi8       "i" | ||||||
|  | #define PRIdLEAST8  "d" | ||||||
|  | #define PRIiLEAST8  "i" | ||||||
|  | #define PRIdFAST8   "d" | ||||||
|  | #define PRIiFAST8   "i" | ||||||
|  |  | ||||||
|  | #define PRId16       "hd" | ||||||
|  | #define PRIi16       "hi" | ||||||
|  | #define PRIdLEAST16  "hd" | ||||||
|  | #define PRIiLEAST16  "hi" | ||||||
|  | #define PRIdFAST16   "hd" | ||||||
|  | #define PRIiFAST16   "hi" | ||||||
|  |  | ||||||
|  | #define PRId32       "I32d" | ||||||
|  | #define PRIi32       "I32i" | ||||||
|  | #define PRIdLEAST32  "I32d" | ||||||
|  | #define PRIiLEAST32  "I32i" | ||||||
|  | #define PRIdFAST32   "I32d" | ||||||
|  | #define PRIiFAST32   "I32i" | ||||||
|  |  | ||||||
|  | #define PRId64       "I64d" | ||||||
|  | #define PRIi64       "I64i" | ||||||
|  | #define PRIdLEAST64  "I64d" | ||||||
|  | #define PRIiLEAST64  "I64i" | ||||||
|  | #define PRIdFAST64   "I64d" | ||||||
|  | #define PRIiFAST64   "I64i" | ||||||
|  |  | ||||||
|  | #define PRIdMAX     "I64d" | ||||||
|  | #define PRIiMAX     "I64i" | ||||||
|  |  | ||||||
|  | #define PRIdPTR     "Id" | ||||||
|  | #define PRIiPTR     "Ii" | ||||||
|  |  | ||||||
|  | // The fprintf macros for unsigned integers are: | ||||||
|  | #define PRIo8       "o" | ||||||
|  | #define PRIu8       "u" | ||||||
|  | #define PRIx8       "x" | ||||||
|  | #define PRIX8       "X" | ||||||
|  | #define PRIoLEAST8  "o" | ||||||
|  | #define PRIuLEAST8  "u" | ||||||
|  | #define PRIxLEAST8  "x" | ||||||
|  | #define PRIXLEAST8  "X" | ||||||
|  | #define PRIoFAST8   "o" | ||||||
|  | #define PRIuFAST8   "u" | ||||||
|  | #define PRIxFAST8   "x" | ||||||
|  | #define PRIXFAST8   "X" | ||||||
|  |  | ||||||
|  | #define PRIo16       "ho" | ||||||
|  | #define PRIu16       "hu" | ||||||
|  | #define PRIx16       "hx" | ||||||
|  | #define PRIX16       "hX" | ||||||
|  | #define PRIoLEAST16  "ho" | ||||||
|  | #define PRIuLEAST16  "hu" | ||||||
|  | #define PRIxLEAST16  "hx" | ||||||
|  | #define PRIXLEAST16  "hX" | ||||||
|  | #define PRIoFAST16   "ho" | ||||||
|  | #define PRIuFAST16   "hu" | ||||||
|  | #define PRIxFAST16   "hx" | ||||||
|  | #define PRIXFAST16   "hX" | ||||||
|  |  | ||||||
|  | #define PRIo32       "I32o" | ||||||
|  | #define PRIu32       "I32u" | ||||||
|  | #define PRIx32       "I32x" | ||||||
|  | #define PRIX32       "I32X" | ||||||
|  | #define PRIoLEAST32  "I32o" | ||||||
|  | #define PRIuLEAST32  "I32u" | ||||||
|  | #define PRIxLEAST32  "I32x" | ||||||
|  | #define PRIXLEAST32  "I32X" | ||||||
|  | #define PRIoFAST32   "I32o" | ||||||
|  | #define PRIuFAST32   "I32u" | ||||||
|  | #define PRIxFAST32   "I32x" | ||||||
|  | #define PRIXFAST32   "I32X" | ||||||
|  |  | ||||||
|  | #define PRIo64       "I64o" | ||||||
|  | #define PRIu64       "I64u" | ||||||
|  | #define PRIx64       "I64x" | ||||||
|  | #define PRIX64       "I64X" | ||||||
|  | #define PRIoLEAST64  "I64o" | ||||||
|  | #define PRIuLEAST64  "I64u" | ||||||
|  | #define PRIxLEAST64  "I64x" | ||||||
|  | #define PRIXLEAST64  "I64X" | ||||||
|  | #define PRIoFAST64   "I64o" | ||||||
|  | #define PRIuFAST64   "I64u" | ||||||
|  | #define PRIxFAST64   "I64x" | ||||||
|  | #define PRIXFAST64   "I64X" | ||||||
|  |  | ||||||
|  | #define PRIoMAX     "I64o" | ||||||
|  | #define PRIuMAX     "I64u" | ||||||
|  | #define PRIxMAX     "I64x" | ||||||
|  | #define PRIXMAX     "I64X" | ||||||
|  |  | ||||||
|  | #define PRIoPTR     "Io" | ||||||
|  | #define PRIuPTR     "Iu" | ||||||
|  | #define PRIxPTR     "Ix" | ||||||
|  | #define PRIXPTR     "IX" | ||||||
|  |  | ||||||
|  | // The fscanf macros for signed integers are: | ||||||
|  | #define SCNd8       "d" | ||||||
|  | #define SCNi8       "i" | ||||||
|  | #define SCNdLEAST8  "d" | ||||||
|  | #define SCNiLEAST8  "i" | ||||||
|  | #define SCNdFAST8   "d" | ||||||
|  | #define SCNiFAST8   "i" | ||||||
|  |  | ||||||
|  | #define SCNd16       "hd" | ||||||
|  | #define SCNi16       "hi" | ||||||
|  | #define SCNdLEAST16  "hd" | ||||||
|  | #define SCNiLEAST16  "hi" | ||||||
|  | #define SCNdFAST16   "hd" | ||||||
|  | #define SCNiFAST16   "hi" | ||||||
|  |  | ||||||
|  | #define SCNd32       "ld" | ||||||
|  | #define SCNi32       "li" | ||||||
|  | #define SCNdLEAST32  "ld" | ||||||
|  | #define SCNiLEAST32  "li" | ||||||
|  | #define SCNdFAST32   "ld" | ||||||
|  | #define SCNiFAST32   "li" | ||||||
|  |  | ||||||
|  | #define SCNd64       "I64d" | ||||||
|  | #define SCNi64       "I64i" | ||||||
|  | #define SCNdLEAST64  "I64d" | ||||||
|  | #define SCNiLEAST64  "I64i" | ||||||
|  | #define SCNdFAST64   "I64d" | ||||||
|  | #define SCNiFAST64   "I64i" | ||||||
|  |  | ||||||
|  | #define SCNdMAX     "I64d" | ||||||
|  | #define SCNiMAX     "I64i" | ||||||
|  |  | ||||||
|  | #ifdef _WIN64 // [ | ||||||
|  | #  define SCNdPTR     "I64d" | ||||||
|  | #  define SCNiPTR     "I64i" | ||||||
|  | #else  // _WIN64 ][ | ||||||
|  | #  define SCNdPTR     "ld" | ||||||
|  | #  define SCNiPTR     "li" | ||||||
|  | #endif  // _WIN64 ] | ||||||
|  |  | ||||||
|  | // The fscanf macros for unsigned integers are: | ||||||
|  | #define SCNo8       "o" | ||||||
|  | #define SCNu8       "u" | ||||||
|  | #define SCNx8       "x" | ||||||
|  | #define SCNX8       "X" | ||||||
|  | #define SCNoLEAST8  "o" | ||||||
|  | #define SCNuLEAST8  "u" | ||||||
|  | #define SCNxLEAST8  "x" | ||||||
|  | #define SCNXLEAST8  "X" | ||||||
|  | #define SCNoFAST8   "o" | ||||||
|  | #define SCNuFAST8   "u" | ||||||
|  | #define SCNxFAST8   "x" | ||||||
|  | #define SCNXFAST8   "X" | ||||||
|  |  | ||||||
|  | #define SCNo16       "ho" | ||||||
|  | #define SCNu16       "hu" | ||||||
|  | #define SCNx16       "hx" | ||||||
|  | #define SCNX16       "hX" | ||||||
|  | #define SCNoLEAST16  "ho" | ||||||
|  | #define SCNuLEAST16  "hu" | ||||||
|  | #define SCNxLEAST16  "hx" | ||||||
|  | #define SCNXLEAST16  "hX" | ||||||
|  | #define SCNoFAST16   "ho" | ||||||
|  | #define SCNuFAST16   "hu" | ||||||
|  | #define SCNxFAST16   "hx" | ||||||
|  | #define SCNXFAST16   "hX" | ||||||
|  |  | ||||||
|  | #define SCNo32       "lo" | ||||||
|  | #define SCNu32       "lu" | ||||||
|  | #define SCNx32       "lx" | ||||||
|  | #define SCNX32       "lX" | ||||||
|  | #define SCNoLEAST32  "lo" | ||||||
|  | #define SCNuLEAST32  "lu" | ||||||
|  | #define SCNxLEAST32  "lx" | ||||||
|  | #define SCNXLEAST32  "lX" | ||||||
|  | #define SCNoFAST32   "lo" | ||||||
|  | #define SCNuFAST32   "lu" | ||||||
|  | #define SCNxFAST32   "lx" | ||||||
|  | #define SCNXFAST32   "lX" | ||||||
|  |  | ||||||
|  | #define SCNo64       "I64o" | ||||||
|  | #define SCNu64       "I64u" | ||||||
|  | #define SCNx64       "I64x" | ||||||
|  | #define SCNX64       "I64X" | ||||||
|  | #define SCNoLEAST64  "I64o" | ||||||
|  | #define SCNuLEAST64  "I64u" | ||||||
|  | #define SCNxLEAST64  "I64x" | ||||||
|  | #define SCNXLEAST64  "I64X" | ||||||
|  | #define SCNoFAST64   "I64o" | ||||||
|  | #define SCNuFAST64   "I64u" | ||||||
|  | #define SCNxFAST64   "I64x" | ||||||
|  | #define SCNXFAST64   "I64X" | ||||||
|  |  | ||||||
|  | #define SCNoMAX     "I64o" | ||||||
|  | #define SCNuMAX     "I64u" | ||||||
|  | #define SCNxMAX     "I64x" | ||||||
|  | #define SCNXMAX     "I64X" | ||||||
|  |  | ||||||
|  | #ifdef _WIN64 // [ | ||||||
|  | #  define SCNoPTR     "I64o" | ||||||
|  | #  define SCNuPTR     "I64u" | ||||||
|  | #  define SCNxPTR     "I64x" | ||||||
|  | #  define SCNXPTR     "I64X" | ||||||
|  | #else  // _WIN64 ][ | ||||||
|  | #  define SCNoPTR     "lo" | ||||||
|  | #  define SCNuPTR     "lu" | ||||||
|  | #  define SCNxPTR     "lx" | ||||||
|  | #  define SCNXPTR     "lX" | ||||||
|  | #endif  // _WIN64 ] | ||||||
|  |  | ||||||
|  | // 7.8.2 Functions for greatest-width integer types | ||||||
|  |  | ||||||
|  | // 7.8.2.1 The imaxabs function | ||||||
|  | #define imaxabs _abs64 | ||||||
|  |  | ||||||
|  | // 7.8.2.2 The imaxdiv function | ||||||
|  |  | ||||||
|  | // This is modified version of div() function from Microsoft's div.c found | ||||||
|  | // in %MSVC.NET%\crt\src\div.c | ||||||
|  | #ifdef STATIC_IMAXDIV // [ | ||||||
|  | static | ||||||
|  | #else // STATIC_IMAXDIV ][ | ||||||
|  | _inline | ||||||
|  | #endif // STATIC_IMAXDIV ] | ||||||
|  | imaxdiv_t __cdecl imaxdiv(intmax_t numer, intmax_t denom) | ||||||
|  | { | ||||||
|  |    imaxdiv_t result; | ||||||
|  |  | ||||||
|  |    result.quot = numer / denom; | ||||||
|  |    result.rem = numer % denom; | ||||||
|  |  | ||||||
|  |    if (numer < 0 && result.rem > 0) { | ||||||
|  |       // did division wrong; must fix up | ||||||
|  |       ++result.quot; | ||||||
|  |       result.rem -= denom; | ||||||
|  |    } | ||||||
|  |  | ||||||
|  |    return result; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // 7.8.2.3 The strtoimax and strtoumax functions | ||||||
|  | #define strtoimax _strtoi64 | ||||||
|  | #define strtoumax _strtoui64 | ||||||
|  |  | ||||||
|  | // 7.8.2.4 The wcstoimax and wcstoumax functions | ||||||
|  | #define wcstoimax _wcstoi64 | ||||||
|  | #define wcstoumax _wcstoui64 | ||||||
|  |  | ||||||
|  |  | ||||||
|  | #endif // _MSC_INTTYPES_H_ ] | ||||||
							
								
								
									
										78
									
								
								configure.ac
									
									
									
									
									
								
							
							
						
						
									
										78
									
								
								configure.ac
									
									
									
									
									
								
							| @@ -1,16 +1,15 @@ | |||||||
| # -*- Autoconf -*- | # -*- Autoconf -*- | ||||||
| # $Id: configure.ac,v 1.11 2006/04/09 13:59:44 r3mi Exp $ |  | ||||||
| # | # | ||||||
| # Top-level configure.ac file for libupnp | # Top-level configure.ac file for libupnp | ||||||
| # | # | ||||||
| # Process this file with autoconf to produce a configure script. | # Process this file with autoconf to produce a configure script. | ||||||
| # | # | ||||||
| # (C) Copyright 2005-2006 R<>mi Turboult <r3mi@users.sourceforge.net> | # (C) Copyright 2005-2006 R<>mi Turboult <r3mi@users.sourceforge.net> | ||||||
| # | # | ||||||
|  |  | ||||||
| AC_PREREQ(2.60) | AC_PREREQ(2.60) | ||||||
|  |  | ||||||
| AC_INIT([libupnp], [1.4.2], [mroberto@users.sourceforge.net]) | AC_INIT([libupnp], [1.4.7], [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: | ||||||
| @@ -48,6 +47,11 @@ AC_CONFIG_SRCDIR(upnp/inc/upnp.h) | |||||||
|  |  | ||||||
| AM_INIT_AUTOMAKE([1.8 -Wall foreign subdir-objects dist-bzip2]) | AM_INIT_AUTOMAKE([1.8 -Wall foreign subdir-objects dist-bzip2]) | ||||||
|  |  | ||||||
|  | # | ||||||
|  | # Get canonical host names in host and host_os | ||||||
|  | # | ||||||
|  | AC_CANONICAL_HOST | ||||||
|  |  | ||||||
| # | # | ||||||
| # There are 3 configuration files : | # There are 3 configuration files : | ||||||
| # 1) "./autoconfig.h" is auto-generated and used only internally during build | # 1) "./autoconfig.h" is auto-generated and used only internally during build | ||||||
| @@ -131,11 +135,14 @@ RT_BOOL_ARG_ENABLE([samples], [yes], [compilation of upnp/sample/ code]) | |||||||
| # version on that. | # version on that. | ||||||
| docdir="${datadir}/doc/${PACKAGE_NAME}-${PACKAGE_VERSION}" | docdir="${datadir}/doc/${PACKAGE_NAME}-${PACKAGE_VERSION}" | ||||||
| AC_MSG_CHECKING([for documentation directory]) | AC_MSG_CHECKING([for documentation directory]) | ||||||
| AC_ARG_WITH([documentation],  | AC_ARG_WITH( | ||||||
| 	AS_HELP_STRING([--with-documentation=directory_name], | 	[documentation],  | ||||||
|  | 	AS_HELP_STRING( | ||||||
|  | 		[--with-documentation=directory_name], | ||||||
| 		[where documentation is installed  | 		[where documentation is installed  | ||||||
| 		 @<:@[DATADIR/doc/]AC_PACKAGE_NAME[-]AC_PACKAGE_VERSION@:>@]) | 		 @<:@[DATADIR/doc/]AC_PACKAGE_NAME[-]AC_PACKAGE_VERSION@:>@]) | ||||||
| AS_HELP_STRING([--without-documentation], | AS_HELP_STRING( | ||||||
|  | 		[--without-documentation], | ||||||
| 		[do not install the documentation]), | 		[do not install the documentation]), | ||||||
| 	[], | 	[], | ||||||
| 	[with_documentation=no]) | 	[with_documentation=no]) | ||||||
| @@ -159,25 +166,40 @@ AC_PROG_INSTALL | |||||||
| AC_PROG_MAKE_SET | AC_PROG_MAKE_SET | ||||||
| AC_PROG_EGREP | AC_PROG_EGREP | ||||||
|  |  | ||||||
|  |  | ||||||
| # | # | ||||||
| # Default compilation flags | # Default compilation flags | ||||||
| # | # | ||||||
| if test x"$enable_debug" = xyes; then | echo "--------------------- Default compilation flags -------------------------------" | ||||||
|  | echo host is $host | ||||||
|  | echo host_os is $host_os | ||||||
|  | case $host_os in | ||||||
|  | freebsd*) | ||||||
|  | 	echo "Using FreeBSD specific compiler settings" | ||||||
|  | 	# Put FreeBSD specific compiler flags here | ||||||
|  | 	;; | ||||||
|  | *) | ||||||
|  | 	echo "Using non-specific system compiler settings" | ||||||
|  | 	if test x"$enable_debug" = xyes; then | ||||||
| 		# AC_PROG_CC already sets CFLAGS to "-g -O2" by default | 		# AC_PROG_CC already sets CFLAGS to "-g -O2" by default | ||||||
| 		: | 		: | ||||||
| else | 	else | ||||||
| 		# add optimise for size | 		# add optimise for size | ||||||
| 		AX_CFLAGS_GCC_OPTION([-Os]) | 		AX_CFLAGS_GCC_OPTION([-Os]) | ||||||
| fi | 	fi | ||||||
|  | 	;; | ||||||
|  | esac | ||||||
|  |  | ||||||
| AX_CFLAGS_WARN_ALL | AX_CFLAGS_WARN_ALL | ||||||
|  | echo "-------------------------------------------------------------------------------" | ||||||
|  |  | ||||||
|  |  | ||||||
| # | # | ||||||
| # Lot's of stuff to ensure large file support | # Lot's of stuff to ensure large file support | ||||||
| # | # | ||||||
|  | AC_TYPE_SIZE_T | ||||||
| AC_TYPE_OFF_T | AC_TYPE_OFF_T | ||||||
| AC_DEFINE(_LARGE_FILE_SOURCE, [], [Large files support]) | AC_DEFINE([_LARGE_FILE_SOURCE], [], [Large files support]) | ||||||
| AC_DEFINE(_FILE_OFFSET_BITS, [64], [File Offset size]) | AC_DEFINE([_FILE_OFFSET_BITS], [64], [File Offset size]) | ||||||
|  |  | ||||||
|  |  | ||||||
| # | # | ||||||
| @@ -186,7 +208,25 @@ AC_DEFINE(_FILE_OFFSET_BITS, [64], [File Offset size]) | |||||||
| AC_HEADER_STDC | AC_HEADER_STDC | ||||||
| # libupnp code doesn't use autoconf variables yet, | # libupnp code doesn't use autoconf variables yet, | ||||||
| # so just abort if a header file is not found. | # so just abort if a header file is not found. | ||||||
| AC_CHECK_HEADERS([arpa/inet.h fcntl.h limits.h netdb.h netinet/in.h stdlib.h string.h sys/ioctl.h sys/socket.h sys/time.h sys/timeb.h syslog.h unistd.h],[],[AC_MSG_ERROR([required header file missing])]) | AC_CHECK_HEADERS( | ||||||
|  | 	[ \ | ||||||
|  | 	arpa/inet.h \ | ||||||
|  | 	fcntl.h \ | ||||||
|  | 	inttypes.h \ | ||||||
|  | 	limits.h \ | ||||||
|  | 	netdb.h \ | ||||||
|  | 	netinet/in.h \ | ||||||
|  | 	stdlib.h \ | ||||||
|  | 	string.h \ | ||||||
|  | 	sys/ioctl.h \ | ||||||
|  | 	sys/socket.h \ | ||||||
|  | 	sys/time.h \ | ||||||
|  | 	sys/timeb.h \ | ||||||
|  | 	syslog.h \ | ||||||
|  | 	unistd.h \ | ||||||
|  | 	], | ||||||
|  | 	[], | ||||||
|  | 	[AC_MSG_ERROR([required header file missing])]) | ||||||
|  |  | ||||||
|  |  | ||||||
| # | # | ||||||
| @@ -202,25 +242,29 @@ TYPE_SOCKLEN_T | |||||||
| # | # | ||||||
| AC_FUNC_VPRINTF | AC_FUNC_VPRINTF | ||||||
| AC_FUNC_FSEEKO | AC_FUNC_FSEEKO | ||||||
|  | AC_CHECK_FUNCS(ftime,, [AC_CHECK_LIB(compat, ftime)]) | ||||||
|  |  | ||||||
|  |  | ||||||
| # | # | ||||||
| # Checks for POSIX Threads | # Checks for POSIX Threads | ||||||
| # | # | ||||||
| ACX_PTHREAD([],[AC_MSG_ERROR([POSIX threads are required to build this program])]) | ACX_PTHREAD( | ||||||
|  | 	[], | ||||||
|  | 	[AC_MSG_ERROR([POSIX threads are required to build this program])]) | ||||||
|  |  | ||||||
|  |  | ||||||
|  | AC_CONFIG_FILES([ | ||||||
|  | 	Makefile | ||||||
| AC_CONFIG_FILES([Makefile |  | ||||||
| 	ixml/Makefile | 	ixml/Makefile | ||||||
| 	ixml/doc/Makefile | 	ixml/doc/Makefile | ||||||
| 	threadutil/Makefile | 	threadutil/Makefile | ||||||
| 	upnp/Makefile | 	upnp/Makefile | ||||||
| 	upnp/doc/Makefile | 	upnp/doc/Makefile | ||||||
|  | 	upnp/sample/Makefile | ||||||
| 	docs/dist/Makefile | 	docs/dist/Makefile | ||||||
| 	libupnp.pc | 	libupnp.pc | ||||||
| 	]) | 	]) | ||||||
|  |  | ||||||
|  |  | ||||||
| AC_OUTPUT | AC_OUTPUT | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										125
									
								
								ixml/inc/ixml.h
									
									
									
									
									
								
							
							
						
						
									
										125
									
								
								ixml/inc/ixml.h
									
									
									
									
									
								
							| @@ -1,46 +1,47 @@ | |||||||
| /////////////////////////////////////////////////////////////////////////// | /******************************************************************************* | ||||||
| // |  * | ||||||
| // Copyright (c) 2000-2003 Intel Corporation  |  * Copyright (c) 2000-2003 Intel Corporation  | ||||||
| // All rights reserved.  |  * All rights reserved.  | ||||||
| // |  * | ||||||
| // Redistribution and use in source and binary forms, with or without  |  * Redistribution and use in source and binary forms, with or without  | ||||||
| // modification, are permitted provided that the following conditions are met:  |  * modification, are permitted provided that the following conditions are met:  | ||||||
| // |  * | ||||||
| // * Redistributions of source code must retain the above copyright notice,  |  * * Redistributions of source code must retain the above copyright notice,  | ||||||
| // this list of conditions and the following disclaimer.  |  * this list of conditions and the following disclaimer.  | ||||||
| // * Redistributions in binary form must reproduce the above copyright notice,  |  * * Redistributions in binary form must reproduce the above copyright notice,  | ||||||
| // this list of conditions and the following disclaimer in the documentation  |  * this list of conditions and the following disclaimer in the documentation  | ||||||
| // and/or other materials provided with the distribution.  |  * and/or other materials provided with the distribution.  | ||||||
| // * Neither name of Intel Corporation nor the names of its contributors  |  * * Neither name of Intel Corporation nor the names of its contributors  | ||||||
| // may be used to endorse or promote products derived from this software  |  * may be used to endorse or promote products derived from this software  | ||||||
| // without specific prior written permission. |  * without specific prior written permission. | ||||||
| //  |  *  | ||||||
| // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS  |  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS  | ||||||
| // "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT  |  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT  | ||||||
| // LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR  |  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR  | ||||||
| // A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL INTEL OR  |  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL INTEL OR  | ||||||
| // CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,  |  * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,  | ||||||
| // EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,  |  * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,  | ||||||
| // PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR  |  * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR  | ||||||
| // PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY  |  * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY  | ||||||
| // OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING |  * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING | ||||||
| // NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS  |  * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS  | ||||||
| // SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |  * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||||
| // |  * | ||||||
| /////////////////////////////////////////////////////////////////////////// |  ******************************************************************************/ | ||||||
|  |  | ||||||
| #ifndef _IXML_H_ | #ifndef _IXML_H_ | ||||||
| #define _IXML_H_ | #define _IXML_H_ | ||||||
|  |  | ||||||
|  |  | ||||||
| #include <stdio.h> | #include <stdio.h> | ||||||
| #include <string.h> | #include <string.h> | ||||||
| //#include <malloc.h> |  | ||||||
| #include <assert.h> | #include <assert.h> | ||||||
|  |  | ||||||
|  |  | ||||||
| #ifdef WIN32 | #ifdef WIN32 | ||||||
| 	#ifndef UPNP_STATIC_LIB | 	#ifndef UPNP_STATIC_LIB | ||||||
| 		#ifdef LIBUPNP_EXPORTS | 		#ifdef LIBUPNP_EXPORTS | ||||||
|   // set up declspec for dll export to make functions visible to library users | 			/* set up declspec for dll export to make functions visible to library users */ | ||||||
| 			#define EXPORT_SPEC __declspec(dllexport) | 			#define EXPORT_SPEC __declspec(dllexport) | ||||||
| 		#else | 		#else | ||||||
| 			#define EXPORT_SPEC __declspec(dllimport) | 			#define EXPORT_SPEC __declspec(dllimport) | ||||||
| @@ -54,6 +55,7 @@ | |||||||
|  |  | ||||||
| typedef int BOOL; | typedef int BOOL; | ||||||
|  |  | ||||||
|  |  | ||||||
| #define DOMString   char * | #define DOMString   char * | ||||||
|  |  | ||||||
|  |  | ||||||
| @@ -88,7 +90,7 @@ typedef int BOOL; | |||||||
|  * etc., refer to section 1.1 of the DOM2-Core recommendation. |  * etc., refer to section 1.1 of the DOM2-Core recommendation. | ||||||
|  */ |  */ | ||||||
|  |  | ||||||
| //@{ | /*! @{ */ | ||||||
|  |  | ||||||
| /*================================================================ | /*================================================================ | ||||||
| * | * | ||||||
| @@ -121,7 +123,7 @@ typedef enum | |||||||
| * | * | ||||||
| *=================================================================*/ | *=================================================================*/ | ||||||
| typedef enum  | typedef enum  | ||||||
| {   // see DOM spec | {   /* see DOM spec */ | ||||||
|     IXML_INDEX_SIZE_ERR                 = 1, |     IXML_INDEX_SIZE_ERR                 = 1, | ||||||
|     IXML_DOMSTRING_SIZE_ERR             = 2, |     IXML_DOMSTRING_SIZE_ERR             = 2, | ||||||
|     IXML_HIERARCHY_REQUEST_ERR          = 3, |     IXML_HIERARCHY_REQUEST_ERR          = 3, | ||||||
| @@ -240,7 +242,7 @@ extern "C" { | |||||||
|  * its functionality.  For more information, refer to DOM2-Core page 34. |  * its functionality.  For more information, refer to DOM2-Core page 34. | ||||||
|  */ |  */ | ||||||
|  |  | ||||||
| //@{ | /*! @{ */ | ||||||
|  |  | ||||||
|   /** Returns the name of the {\bf Node}, depending on what type of  |   /** Returns the name of the {\bf Node}, depending on what type of  | ||||||
|    *  {\bf Node} it is, in a read-only string. Refer to the table in the  |    *  {\bf Node} it is, in a read-only string. Refer to the table in the  | ||||||
| @@ -620,7 +622,7 @@ ixmlNode_cloneNode(IXML_Node *nodeptr, | |||||||
|    */ |    */ | ||||||
|  |  | ||||||
| EXPORT_SPEC BOOL     | EXPORT_SPEC BOOL     | ||||||
| ixmlNode_hasAttributes(IXML_Node *node   | ixmlNode_hasAttributes(IXML_Node *nodeptr | ||||||
| 		         /** The {\bf Node} to query for attributes. */ | 		         /** The {\bf Node} to query for attributes. */ | ||||||
|                       ); |                       ); | ||||||
|  |  | ||||||
| @@ -630,11 +632,11 @@ ixmlNode_hasAttributes(IXML_Node *node | |||||||
|    */ |    */ | ||||||
|  |  | ||||||
| EXPORT_SPEC void     | EXPORT_SPEC void     | ||||||
| ixmlNode_free(IXML_Node *IXML_Node   | ixmlNode_free(IXML_Node *nodeptr | ||||||
| 		/** The {\bf Node} to free. */ | 		/** The {\bf Node} to free. */ | ||||||
|              ); |              ); | ||||||
|  |  | ||||||
| //@} | /*! @} */ | ||||||
|  |  | ||||||
| /*================================================================ | /*================================================================ | ||||||
| * | * | ||||||
| @@ -649,7 +651,7 @@ ixmlNode_free(IXML_Node *IXML_Node | |||||||
|  * allowable attributes and values for a particular element.  For more  |  * allowable attributes and values for a particular element.  For more  | ||||||
|  * information, refer to the {\it Interface Attr} section in the DOM2-Core. |  * information, refer to the {\it Interface Attr} section in the DOM2-Core. | ||||||
|  */ |  */ | ||||||
| //@{ | /*! @{ */ | ||||||
|  |  | ||||||
|  |  | ||||||
|   /** Frees an {\bf Attr} node. |   /** Frees an {\bf Attr} node. | ||||||
| @@ -662,7 +664,7 @@ ixmlAttr_free(IXML_Attr *attrNode | |||||||
| 		/** The {\bf Attr} node to free.  */ | 		/** The {\bf Attr} node to free.  */ | ||||||
|              ); |              ); | ||||||
|  |  | ||||||
| //@} | /*! @} */ | ||||||
|  |  | ||||||
|  |  | ||||||
| /*================================================================ | /*================================================================ | ||||||
| @@ -680,7 +682,7 @@ ixmlAttr_free(IXML_Attr *attrNode | |||||||
|  * information, refer to the {\it Interface CDATASection} section in the |  * information, refer to the {\it Interface CDATASection} section in the | ||||||
|  * DOM2-Core. |  * DOM2-Core. | ||||||
|  */ |  */ | ||||||
| //@{ | /*! @{ */ | ||||||
|  |  | ||||||
|  |  | ||||||
|   /** Initializes a {\bf CDATASection} node. |   /** Initializes a {\bf CDATASection} node. | ||||||
| @@ -704,7 +706,7 @@ ixmlCDATASection_free(IXML_CDATASection *nodeptr | |||||||
| 		        /** The {\bf CDATASection} node to free. */ | 		        /** The {\bf CDATASection} node to free. */ | ||||||
|                      ); |                      ); | ||||||
|  |  | ||||||
| //@} | /*! @} */ | ||||||
|  |  | ||||||
| /*================================================================ | /*================================================================ | ||||||
| * | * | ||||||
| @@ -719,7 +721,7 @@ ixmlCDATASection_free(IXML_CDATASection *nodeptr | |||||||
|  * primary interface to the elements of the document.  For more information, |  * primary interface to the elements of the document.  For more information, | ||||||
|  * refer to the {\it Interface Document} section in the DOM2Core. |  * refer to the {\it Interface Document} section in the DOM2Core. | ||||||
|  */ |  */ | ||||||
| //@{ | /*! @{ */ | ||||||
|  |  | ||||||
|   /** Initializes a {\bf Document} node. |   /** Initializes a {\bf Document} node. | ||||||
|    * |    * | ||||||
| @@ -947,7 +949,7 @@ ixmlDocument_getElementsByTagName(IXML_Document *doc, | |||||||
| 				    /** The tag name to find. */ | 				    /** The tag name to find. */ | ||||||
|                                  ); |                                  ); | ||||||
|  |  | ||||||
| // introduced in DOM level 2 | /* introduced in DOM level 2 */ | ||||||
|  |  | ||||||
|   /** Creates a new {\bf Element} node in the given qualified name and |   /** Creates a new {\bf Element} node in the given qualified name and | ||||||
|    *  namespace URI. |    *  namespace URI. | ||||||
| @@ -1128,7 +1130,7 @@ ixmlDocument_importNode(IXML_Document* doc, | |||||||
| 			  /** A pointer to a new {\bf Node} owned by {\bf  | 			  /** A pointer to a new {\bf Node} owned by {\bf  | ||||||
| 			      doc}. */ | 			      doc}. */ | ||||||
|                        ); |                        ); | ||||||
| //@} | /*! @} */ | ||||||
|  |  | ||||||
| /*================================================================ | /*================================================================ | ||||||
| * | * | ||||||
| @@ -1144,7 +1146,7 @@ ixmlDocument_importNode(IXML_Document* doc, | |||||||
|  * extends the {\bf Node} interface and adds more operations to manipulate |  * extends the {\bf Node} interface and adds more operations to manipulate | ||||||
|  * attributes. |  * attributes. | ||||||
|  */ |  */ | ||||||
| //@{ | /*! @{ */ | ||||||
|  |  | ||||||
|   /** Initializes a {\bf IXML_Element} node. |   /** Initializes a {\bf IXML_Element} node. | ||||||
|    * |    * | ||||||
| @@ -1314,7 +1316,7 @@ ixmlElement_getElementsByTagName(IXML_Element* element, | |||||||
| 				       search. */ | 				       search. */ | ||||||
|                                 ); |                                 ); | ||||||
|  |  | ||||||
| // introduced in DOM 2 | /* introduced in DOM 2 */ | ||||||
|  |  | ||||||
|   /** Retrieves an attribute value using the local name and namespace URI. |   /** Retrieves an attribute value using the local name and namespace URI. | ||||||
|    * |    * | ||||||
| @@ -1493,7 +1495,7 @@ ixmlElement_free(IXML_Element* element | |||||||
| 		   /** The {\bf Element} to free. */ | 		   /** The {\bf Element} to free. */ | ||||||
|                 ); |                 ); | ||||||
|  |  | ||||||
| //@} | /*! @} */ | ||||||
|  |  | ||||||
| /*================================================================ | /*================================================================ | ||||||
| * | * | ||||||
| @@ -1508,7 +1510,7 @@ ixmlElement_free(IXML_Element* element | |||||||
|  * no particular order.  The {\bf Node} interface uses a {\bf NamedNodeMap} |  * no particular order.  The {\bf Node} interface uses a {\bf NamedNodeMap} | ||||||
|  * to maintain the attributes of a node. |  * to maintain the attributes of a node. | ||||||
|  */ |  */ | ||||||
| //@{ | /*! @{ */ | ||||||
|  |  | ||||||
|   /** Returns the number of items contained in this {\bf NamedNodeMap}. |   /** Returns the number of items contained in this {\bf NamedNodeMap}. | ||||||
|    * |    * | ||||||
| @@ -1579,7 +1581,7 @@ ixmlNamedNodeMap_item(IXML_NamedNodeMap *nnMap, | |||||||
| 		        /** The index into the map to remove. */ | 		        /** The index into the map to remove. */ | ||||||
|                      ); |                      ); | ||||||
|  |  | ||||||
| // introduced in DOM level 2 | /* introduced in DOM level 2 */ | ||||||
|  |  | ||||||
|   /** Retrieves a {\bf Node} from a {\bf NamedNodeMap} specified by |   /** Retrieves a {\bf Node} from a {\bf NamedNodeMap} specified by | ||||||
|    *  namespace URI and local name. |    *  namespace URI and local name. | ||||||
| @@ -1646,7 +1648,7 @@ ixmlNamedNodeMap_free(IXML_NamedNodeMap *nnMap | |||||||
| 		        /** The {\bf NamedNodeMap to free}. */ | 		        /** The {\bf NamedNodeMap to free}. */ | ||||||
|                      ); |                      ); | ||||||
|  |  | ||||||
| //@} | /*! @} */ | ||||||
|  |  | ||||||
| /*================================================================ | /*================================================================ | ||||||
| * | * | ||||||
| @@ -1661,7 +1663,7 @@ ixmlNamedNodeMap_free(IXML_NamedNodeMap *nnMap | |||||||
|  * the nodes contained in a {\bf NodeList}.  The DOM2-Core refers to |  * the nodes contained in a {\bf NodeList}.  The DOM2-Core refers to | ||||||
|  * this as being {\it live}. |  * this as being {\it live}. | ||||||
|  */ |  */ | ||||||
| //@{ | /*! @{ */ | ||||||
|  |  | ||||||
|   /** Retrieves a {\bf Node} from a {\bf NodeList} specified by a  |   /** Retrieves a {\bf Node} from a {\bf NodeList} specified by a  | ||||||
|    *  numerical index. |    *  numerical index. | ||||||
| @@ -1701,8 +1703,8 @@ ixmlNodeList_free(IXML_NodeList *nList | |||||||
| 		    /** The {\bf NodeList} to free.  */ | 		    /** The {\bf NodeList} to free.  */ | ||||||
|                  ); |                  ); | ||||||
|  |  | ||||||
| //@} Interface NodeList | /*! @} */ /* Interface NodeList */ | ||||||
| //@} DOM Interfaces | /*! @} */ /* DOM Interfaces */ | ||||||
|  |  | ||||||
| /**@name IXML API | /**@name IXML API | ||||||
|  * The IXML API contains utility functions that are not part of the standard |  * The IXML API contains utility functions that are not part of the standard | ||||||
| @@ -1710,7 +1712,7 @@ ixmlNodeList_free(IXML_NodeList *nList | |||||||
|  * file or buffer, create an XML file from a DOM structure, and manipulate  |  * file or buffer, create an XML file from a DOM structure, and manipulate  | ||||||
|  * DOMString objects. |  * DOMString objects. | ||||||
|  */ |  */ | ||||||
| //@{ | /*! @{ */ | ||||||
|  |  | ||||||
| /*================================================================ | /*================================================================ | ||||||
| *  | *  | ||||||
| @@ -1738,7 +1740,7 @@ ixmlNodeList_free(IXML_NodeList *nList | |||||||
|    *                      of the DOM tree or {\tt NULL} on an error. |    *                      of the DOM tree or {\tt NULL} on an error. | ||||||
|    */ |    */ | ||||||
|  |  | ||||||
| DOMString | EXPORT_SPEC DOMString | ||||||
| ixmlPrintDocument(IXML_Document *doc); | ixmlPrintDocument(IXML_Document *doc); | ||||||
|  |  | ||||||
|   /** Renders a {\bf Node} and all sub-elements into an XML text |   /** Renders a {\bf Node} and all sub-elements into an XML text | ||||||
| @@ -1756,7 +1758,7 @@ ixmlPrintDocument(IXML_Document *doc); | |||||||
|    *                      of the DOM tree or {\tt NULL} on an error. |    *                      of the DOM tree or {\tt NULL} on an error. | ||||||
|    */ |    */ | ||||||
|  |  | ||||||
| DOMString    | EXPORT_SPEC DOMString    | ||||||
| ixmlPrintNode(IXML_Node *doc   | ixmlPrintNode(IXML_Node *doc   | ||||||
|                 /** The root of the {\bf Node} tree to render to XML text. */ |                 /** The root of the {\bf Node} tree to render to XML text. */ | ||||||
|              ); |              ); | ||||||
| @@ -1777,7 +1779,7 @@ ixmlPrintNode(IXML_Node *doc | |||||||
|    *                      of the DOM tree or {\tt NULL} on an error. |    *                      of the DOM tree or {\tt NULL} on an error. | ||||||
|    */ |    */ | ||||||
|  |  | ||||||
| DOMString | EXPORT_SPEC DOMString | ||||||
| ixmlDocumenttoString(IXML_Document *doc); | ixmlDocumenttoString(IXML_Document *doc); | ||||||
|  |  | ||||||
|   /** Renders a {\bf Node} and all sub-elements into an XML text |   /** Renders a {\bf Node} and all sub-elements into an XML text | ||||||
| @@ -1809,7 +1811,7 @@ ixmlNodetoString(IXML_Node *doc | |||||||
|    * characters are replaced by the {\bf errorChar}, and invalid "&" entities  |    * characters are replaced by the {\bf errorChar}, and invalid "&" entities  | ||||||
|    * are left untranslated. The parsing is then allowed to continue. |    * are left untranslated. The parsing is then allowed to continue. | ||||||
|    */ |    */ | ||||||
| void | EXPORT_SPEC void | ||||||
| ixmlRelaxParser(char errorChar); | ixmlRelaxParser(char errorChar); | ||||||
|  |  | ||||||
|  |  | ||||||
| @@ -1913,6 +1915,7 @@ ixmlFreeDOMString(DOMString buf | |||||||
| } | } | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
| //@} IXML API | /*! @} */ /* IXML API */ | ||||||
|  |  | ||||||
|  | #endif  /* _IXML_H_ */ | ||||||
|  |  | ||||||
| #endif  // _IXML_H_ |  | ||||||
|   | |||||||
| @@ -39,7 +39,7 @@ | |||||||
| #define MAXVAL( a, b ) ( (a) > (b) ? (a) : (b) ) | #define MAXVAL( a, b ) ( (a) > (b) ? (a) : (b) ) | ||||||
|  |  | ||||||
| #ifndef WIN32 | #ifndef WIN32 | ||||||
|  #define	XINLINE inline |  #define	UPNP_INLINE inline | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
| #define MEMBUF_DEF_SIZE_INC		20 | #define MEMBUF_DEF_SIZE_INC		20 | ||||||
|   | |||||||
| @@ -7,6 +7,6 @@ Name: libupnp | |||||||
| Description: Linux SDK for UPnP Devices | Description: Linux SDK for UPnP Devices | ||||||
| Version: @VERSION@ | Version: @VERSION@ | ||||||
| Libs: @PTHREAD_LIBS@ -L${libdir} -lupnp -lthreadutil -lixml  | Libs: @PTHREAD_LIBS@ -L${libdir} -lupnp -lthreadutil -lixml  | ||||||
| Cflags: @PTHREAD_CFLAGS@ -I${includedir} | Cflags: @PTHREAD_CFLAGS@ -I${includedir}/upnp | ||||||
|  |  | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1,4 +1,4 @@ | |||||||
| Version: 1.4.2 | Version: 1.4.7 | ||||||
| Summary: Universal Plug and Play (UPnP) SDK | Summary: Universal Plug and Play (UPnP) SDK | ||||||
| Name: libupnp | Name: libupnp | ||||||
| Release: 1%{?dist} | Release: 1%{?dist} | ||||||
| @@ -77,6 +77,9 @@ make install DESTDIR=$RPM_BUILD_ROOT | |||||||
| rm -rf %{buildroot} | rm -rf %{buildroot} | ||||||
|  |  | ||||||
| %changelog | %changelog | ||||||
|  | * Mon Nov 19 2007 Marcelo Jimenez <mroberto@users.sourceforge.net> - 1.4.7-1 | ||||||
|  | - Update to version 1.4.7 | ||||||
|  |  | ||||||
| * Fri Feb 02 2007 Eric Tanguy <eric.tanguy@univ-nantes.fr> - 1.4.2-1 | * Fri Feb 02 2007 Eric Tanguy <eric.tanguy@univ-nantes.fr> - 1.4.2-1 | ||||||
| - Update to version 1.4.2 | - Update to version 1.4.2 | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										14
									
								
								svnignore
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										14
									
								
								svnignore
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,14 @@ | |||||||
|  | .deps | ||||||
|  | .dirstamp | ||||||
|  | .libs | ||||||
|  | .*.swp | ||||||
|  | *~ | ||||||
|  | Makefile | ||||||
|  | Makefile.in | ||||||
|  | aclocal.m4 | ||||||
|  | autoconfig.h* | ||||||
|  | autom4te.cache | ||||||
|  | config* | ||||||
|  | libtool | ||||||
|  | libupnp.pc | ||||||
|  | stamp-h* | ||||||
| @@ -1,33 +1,33 @@ | |||||||
| /////////////////////////////////////////////////////////////////////////// | /******************************************************************************* | ||||||
| // |  * | ||||||
| // Copyright (c) 2000-2003 Intel Corporation  |  * Copyright (c) 2000-2003 Intel Corporation  | ||||||
| // All rights reserved.  |  * All rights reserved.  | ||||||
| // |  * | ||||||
| // Redistribution and use in source and binary forms, with or without  |  * Redistribution and use in source and binary forms, with or without  | ||||||
| // modification, are permitted provided that the following conditions are met:  |  * modification, are permitted provided that the following conditions are met:  | ||||||
| // |  * | ||||||
| // * Redistributions of source code must retain the above copyright notice,  |  * * Redistributions of source code must retain the above copyright notice,  | ||||||
| // this list of conditions and the following disclaimer.  |  * this list of conditions and the following disclaimer.  | ||||||
| // * Redistributions in binary form must reproduce the above copyright notice,  |  * * Redistributions in binary form must reproduce the above copyright notice,  | ||||||
| // this list of conditions and the following disclaimer in the documentation  |  * this list of conditions and the following disclaimer in the documentation  | ||||||
| // and/or other materials provided with the distribution.  |  * and/or other materials provided with the distribution.  | ||||||
| // * Neither name of Intel Corporation nor the names of its contributors  |  * * Neither name of Intel Corporation nor the names of its contributors  | ||||||
| // may be used to endorse or promote products derived from this software  |  * may be used to endorse or promote products derived from this software  | ||||||
| // without specific prior written permission. |  * without specific prior written permission. | ||||||
| //  |  *  | ||||||
| // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS  |  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS  | ||||||
| // "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT  |  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT  | ||||||
| // LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR  |  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR  | ||||||
| // A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL INTEL OR  |  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL INTEL OR  | ||||||
| // CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,  |  * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,  | ||||||
| // EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,  |  * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,  | ||||||
| // PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR  |  * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR  | ||||||
| // PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY  |  * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY  | ||||||
| // OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING |  * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING | ||||||
| // NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS  |  * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS  | ||||||
| // SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |  * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||||
| // |  * | ||||||
| /////////////////////////////////////////////////////////////////////////// |  ******************************************************************************/ | ||||||
|  |  | ||||||
| #ifndef FREE_LIST_H | #ifndef FREE_LIST_H | ||||||
| #define FREE_LIST_H | #define FREE_LIST_H | ||||||
| @@ -36,9 +36,6 @@ | |||||||
| extern "C" { | extern "C" { | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
| //#include <malloc.h> |  | ||||||
|  |  | ||||||
|  |  | ||||||
| #include "ithread.h" | #include "ithread.h" | ||||||
| #include <errno.h> | #include <errno.h> | ||||||
|  |  | ||||||
| @@ -52,7 +49,7 @@ extern "C" { | |||||||
|  *****************************************************************************/ |  *****************************************************************************/ | ||||||
| typedef struct FREELISTNODE | typedef struct FREELISTNODE | ||||||
| { | { | ||||||
| 	struct FREELISTNODE*next; //pointer to next free node | 	struct FREELISTNODE *next; | ||||||
| } FreeListNode; | } FreeListNode; | ||||||
|  |  | ||||||
|  |  | ||||||
| @@ -65,12 +62,10 @@ typedef struct FREELISTNODE | |||||||
|  *****************************************************************************/ |  *****************************************************************************/ | ||||||
| typedef struct FREELIST | typedef struct FREELIST | ||||||
| { | { | ||||||
| 	FreeListNode *head; //head of free list | 	FreeListNode *head; | ||||||
| 	size_t element_size;	//size of elements in free  | 	size_t element_size; | ||||||
|  							//list |  	int maxFreeListLength; | ||||||
|  	int maxFreeListLength; //max size of free structures  | 	int freeListLength; | ||||||
| 						 //to keep |  | ||||||
| 	int freeListLength; //current size of free list |  | ||||||
|          |          | ||||||
| }FreeList; | }FreeList; | ||||||
|  |  | ||||||
| @@ -141,4 +136,5 @@ int FreeListDestroy (FreeList *free_list); | |||||||
| } | } | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
| #endif // FREE_LIST_H | #endif /* FREE_LIST_H */ | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1,33 +1,33 @@ | |||||||
| /////////////////////////////////////////////////////////////////////////// | /******************************************************************************* | ||||||
| // |  * | ||||||
| // Copyright (c) 2000-2003 Intel Corporation  |  * Copyright (c) 2000-2003 Intel Corporation  | ||||||
| // All rights reserved.  |  * All rights reserved.  | ||||||
| // |  * | ||||||
| // Redistribution and use in source and binary forms, with or without  |  * Redistribution and use in source and binary forms, with or without  | ||||||
| // modification, are permitted provided that the following conditions are met:  |  * modification, are permitted provided that the following conditions are met:  | ||||||
| // |  * | ||||||
| // * Redistributions of source code must retain the above copyright notice,  |  * * Redistributions of source code must retain the above copyright notice,  | ||||||
| // this list of conditions and the following disclaimer.  |  * this list of conditions and the following disclaimer.  | ||||||
| // * Redistributions in binary form must reproduce the above copyright notice,  |  * * Redistributions in binary form must reproduce the above copyright notice,  | ||||||
| // this list of conditions and the following disclaimer in the documentation  |  * this list of conditions and the following disclaimer in the documentation  | ||||||
| // and/or other materials provided with the distribution.  |  * and/or other materials provided with the distribution.  | ||||||
| // * Neither name of Intel Corporation nor the names of its contributors  |  * * Neither name of Intel Corporation nor the names of its contributors  | ||||||
| // may be used to endorse or promote products derived from this software  |  * may be used to endorse or promote products derived from this software  | ||||||
| // without specific prior written permission. |  * without specific prior written permission. | ||||||
| //  |  *  | ||||||
| // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS  |  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS  | ||||||
| // "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT  |  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT  | ||||||
| // LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR  |  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR  | ||||||
| // A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL INTEL OR  |  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL INTEL OR  | ||||||
| // CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,  |  * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,  | ||||||
| // EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,  |  * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,  | ||||||
| // PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR  |  * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR  | ||||||
| // PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY  |  * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY  | ||||||
| // OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING |  * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING | ||||||
| // NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS  |  * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS  | ||||||
| // SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |  * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||||
| // |  * | ||||||
| /////////////////////////////////////////////////////////////////////////// |  ******************************************************************************/ | ||||||
|  |  | ||||||
| #ifndef LINKED_LIST_H | #ifndef LINKED_LIST_H | ||||||
| #define LINKED_LIST_H | #define LINKED_LIST_H | ||||||
| @@ -70,9 +70,9 @@ typedef int (*cmp_routine)(void *itemA,void *itemB); | |||||||
|  *****************************************************************************/ |  *****************************************************************************/ | ||||||
| typedef struct LISTNODE | typedef struct LISTNODE | ||||||
| { | { | ||||||
|   struct LISTNODE *prev; //previous node |   struct LISTNODE *prev; | ||||||
|   struct LISTNODE *next; //next node |   struct LISTNODE *next; | ||||||
|   void *item; //item |   void *item; | ||||||
| } ListNode; | } ListNode; | ||||||
|  |  | ||||||
| /**************************************************************************** | /**************************************************************************** | ||||||
| @@ -96,12 +96,12 @@ typedef struct LISTNODE | |||||||
|  *****************************************************************************/ |  *****************************************************************************/ | ||||||
| typedef struct LINKEDLIST | typedef struct LINKEDLIST | ||||||
| { | { | ||||||
|   ListNode head; //head, first item is stored at: head->next |   ListNode head; /* head, first item is stored at: head->next */ | ||||||
|   ListNode tail; //tail, last item is stored at: tail->prev |   ListNode tail; /* tail, last item is stored at: tail->prev  */ | ||||||
|   long size;      //size of list |   long size;     /* size of list */ | ||||||
|   FreeList freeNodeList; //free list to use |   FreeList freeNodeList;   /* free list to use */ | ||||||
|   free_function free_func; //free function to use |   free_function free_func; /* free function to use */ | ||||||
|   cmp_routine cmp_func; //compare function to use |   cmp_routine cmp_func;    /* compare function to use */ | ||||||
| } LinkedList; | } LinkedList; | ||||||
|  |  | ||||||
| /**************************************************************************** | /**************************************************************************** | ||||||
| @@ -327,4 +327,5 @@ int ListSize(LinkedList* list); | |||||||
| } | } | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
| #endif //LINKED_LIST_H | #endif /* LINKED_LIST_H */ | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1,33 +1,33 @@ | |||||||
| /////////////////////////////////////////////////////////////////////////// | /******************************************************************************* | ||||||
| // |  * | ||||||
| // Copyright (c) 2000-2003 Intel Corporation  |  * Copyright (c) 2000-2003 Intel Corporation  | ||||||
| // All rights reserved.  |  * All rights reserved.  | ||||||
| // |  * | ||||||
| // Redistribution and use in source and binary forms, with or without  |  * Redistribution and use in source and binary forms, with or without  | ||||||
| // modification, are permitted provided that the following conditions are met:  |  * modification, are permitted provided that the following conditions are met:  | ||||||
| // |  * | ||||||
| // * Redistributions of source code must retain the above copyright notice,  |  * * Redistributions of source code must retain the above copyright notice,  | ||||||
| // this list of conditions and the following disclaimer.  |  * this list of conditions and the following disclaimer.  | ||||||
| // * Redistributions in binary form must reproduce the above copyright notice,  |  * * Redistributions in binary form must reproduce the above copyright notice,  | ||||||
| // this list of conditions and the following disclaimer in the documentation  |  * this list of conditions and the following disclaimer in the documentation  | ||||||
| // and/or other materials provided with the distribution.  |  * and/or other materials provided with the distribution.  | ||||||
| // * Neither name of Intel Corporation nor the names of its contributors  |  * * Neither name of Intel Corporation nor the names of its contributors  | ||||||
| // may be used to endorse or promote products derived from this software  |  * may be used to endorse or promote products derived from this software  | ||||||
| // without specific prior written permission. |  * without specific prior written permission. | ||||||
| //  |  *  | ||||||
| // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS  |  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS  | ||||||
| // "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT  |  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT  | ||||||
| // LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR  |  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR  | ||||||
| // A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL INTEL OR  |  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL INTEL OR  | ||||||
| // CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,  |  * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,  | ||||||
| // EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,  |  * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,  | ||||||
| // PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR  |  * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR  | ||||||
| // PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY  |  * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY  | ||||||
| // OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING |  * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING | ||||||
| // NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS  |  * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS  | ||||||
| // SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |  * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||||
| // |  * | ||||||
| /////////////////////////////////////////////////////////////////////////// |  ******************************************************************************/ | ||||||
|  |  | ||||||
| #ifndef THREADPOOL_H | #ifndef THREADPOOL_H | ||||||
| #define THREADPOOL_H | #define THREADPOOL_H | ||||||
| @@ -36,17 +36,17 @@ | |||||||
| extern "C" { | extern "C" { | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
| //Size of job free list | /* Size of job free list */ | ||||||
| #define JOBFREELISTSIZE 100 | #define JOBFREELISTSIZE 100 | ||||||
|  |  | ||||||
| #define INFINITE_THREADS -1 | #define INFINITE_THREADS -1 | ||||||
|  |  | ||||||
| #define EMAXTHREADS (-8 & 1<<29) | #define EMAXTHREADS (-8 & 1<<29) | ||||||
|  |  | ||||||
| //Invalid Policy | /* Invalid Policy */ | ||||||
| #define INVALID_POLICY (-9 & 1<<29) | #define INVALID_POLICY (-9 & 1<<29) | ||||||
|  |  | ||||||
| //Invalid JOB Id | /* Invalid JOB Id */ | ||||||
| #define INVALID_JOB_ID (-2 & 1<<29) | #define INVALID_JOB_ID (-2 & 1<<29) | ||||||
|  |  | ||||||
| typedef enum duration {SHORT_TERM,PERSISTENT} Duration; | typedef enum duration {SHORT_TERM,PERSISTENT} Duration; | ||||||
| @@ -55,20 +55,20 @@ typedef enum priority {LOW_PRIORITY, | |||||||
| 		       MED_PRIORITY, | 		       MED_PRIORITY, | ||||||
| 		       HIGH_PRIORITY} ThreadPriority; | 		       HIGH_PRIORITY} ThreadPriority; | ||||||
|  |  | ||||||
| #define DEFAULT_PRIORITY MED_PRIORITY //default priority used by TPJobInit | #define DEFAULT_PRIORITY MED_PRIORITY /* default priority used by TPJobInit */ | ||||||
| #define DEFAULT_MIN_THREADS 1	      //default minimum used by TPAttrInit | #define DEFAULT_MIN_THREADS 1	      /* default minimum used by TPAttrInit */ | ||||||
| #define DEFAULT_MAX_THREADS 10	      //default max used by TPAttrInit	 | #define DEFAULT_MAX_THREADS 10	      /* default max used by TPAttrInit	*/ | ||||||
| #define DEFAULT_JOBS_PER_THREAD 10    //default jobs per thread used by TPAttrInit | #define DEFAULT_JOBS_PER_THREAD 10    /* default jobs per thread used by TPAttrInit */ | ||||||
| #define DEFAULT_STARVATION_TIME	500   //default starvation time used by TPAttrInit | #define DEFAULT_STARVATION_TIME	500   /* default starvation time used by TPAttrInit */ | ||||||
| #define DEFAULT_IDLE_TIME 10 * 1000   //default idle time used by TPAttrInit | #define DEFAULT_IDLE_TIME 10 * 1000   /* default idle time used by TPAttrInit */ | ||||||
| #define DEFAULT_FREE_ROUTINE NULL     //default free routine used TPJobInit | #define DEFAULT_FREE_ROUTINE NULL     /* default free routine used TPJobInit */ | ||||||
| #define DEFAULT_MAX_JOBS_TOTAL 100    //default max jobs used TPAttrInit | #define DEFAULT_MAX_JOBS_TOTAL 100    /* default max jobs used TPAttrInit */ | ||||||
|  |  | ||||||
| #define STATS 1 //always include stats because code change is minimal | #define STATS 1 /* always include stats because code change is minimal */ | ||||||
|  |  | ||||||
|  |  | ||||||
| //Statistics | /* Statistics */ | ||||||
| #ifdef WIN32 // todo: check why STATSONLY fails during compilation | #ifdef WIN32 /* TODO: check why STATSONLY fails during compilation */ | ||||||
| 	#undef STATS | 	#undef STATS | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
| @@ -82,15 +82,6 @@ typedef enum priority {LOW_PRIORITY, | |||||||
| 	#define DEBUG 1 | 	#define DEBUG 1 | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
| //DEBUGGING |  | ||||||
| #ifndef WIN32 |  | ||||||
|  #ifdef DEBUG |  | ||||||
|   #define DBGONLY(x) x |  | ||||||
|  #else |  | ||||||
|   #define DBGONLY(x) |  | ||||||
|  #endif |  | ||||||
| #endif |  | ||||||
|  |  | ||||||
| #include "LinkedList.h" | #include "LinkedList.h" | ||||||
| #include <sys/timeb.h> | #include <sys/timeb.h> | ||||||
| #include "FreeList.h" | #include "FreeList.h" | ||||||
| @@ -101,7 +92,7 @@ typedef enum priority {LOW_PRIORITY, | |||||||
| #define EXPORT | #define EXPORT | ||||||
| typedef int PolicyType; | typedef int PolicyType; | ||||||
| #define DEFAULT_POLICY SCHED_OTHER | #define DEFAULT_POLICY SCHED_OTHER | ||||||
| #define DEFAULT_SCHED_PARAM 0 //default priority | #define DEFAULT_SCHED_PARAM 0 /* default priority */ | ||||||
|  |  | ||||||
| /**************************************************************************** | /**************************************************************************** | ||||||
|  * Name: free_routine |  * Name: free_routine | ||||||
| @@ -120,25 +111,25 @@ typedef void (*free_routine)(void *arg); | |||||||
|  *****************************************************************************/ |  *****************************************************************************/ | ||||||
| typedef struct THREADPOOLATTR | typedef struct THREADPOOLATTR | ||||||
| { | { | ||||||
|   int minThreads;     // minThreads, ThreadPool will always maintain at least |   int minThreads;     /* minThreads, ThreadPool will always maintain at least | ||||||
|                       // this many threads |                          this many threads */ | ||||||
|  |  | ||||||
|   int maxThreads;     // maxThreads, ThreadPool will never have more than this |   int maxThreads;     /* maxThreads, ThreadPool will never have more than this | ||||||
|                       // number of threads |                          number of threads */ | ||||||
|  |  | ||||||
|   int maxIdleTime;    // maxIdleTime (in milliseconds) |   int maxIdleTime;    /* maxIdleTime (in milliseconds) | ||||||
|                       // this is the maximum time a thread will remain idle |                          this is the maximum time a thread will remain idle | ||||||
|                       // before dying |                          before dying */ | ||||||
|  |  | ||||||
|   int jobsPerThread;  // jobs per thread to maintain |   int jobsPerThread;  /* jobs per thread to maintain */ | ||||||
|  |  | ||||||
|   int maxJobsTotal;   // maximum number of jobs that can be queued totally. |   int maxJobsTotal;   /* maximum number of jobs that can be queued totally. */ | ||||||
|  |  | ||||||
|   int starvationTime; // the time a low priority or med priority |   int starvationTime; /* the time a low priority or med priority | ||||||
| 	              // job waits before getting bumped | 	                 job waits before getting bumped | ||||||
|                       // up a priority (in milliseconds) |                          up a priority (in milliseconds) */ | ||||||
|  |  | ||||||
|   PolicyType schedPolicy; // scheduling policy to use |   PolicyType schedPolicy; /* scheduling policy to use */ | ||||||
|  |  | ||||||
| } ThreadPoolAttr; | } ThreadPoolAttr; | ||||||
|  |  | ||||||
| @@ -150,12 +141,12 @@ typedef struct THREADPOOLATTR | |||||||
|  *****************************************************************************/ |  *****************************************************************************/ | ||||||
| typedef struct THREADPOOLJOB | typedef struct THREADPOOLJOB | ||||||
| { | { | ||||||
|   start_routine func; //function |   start_routine func; | ||||||
|   void *arg;          //arg |   void *arg; | ||||||
|   free_routine free_func; //free function |   free_routine free_func; | ||||||
|   struct timeb requestTime; //time of request |   struct timeb requestTime; | ||||||
|   int priority;       //priority of request |   int priority; | ||||||
|   int jobId;         //id |   int jobId; | ||||||
| } ThreadPoolJob; | } ThreadPoolJob; | ||||||
|  |  | ||||||
| /**************************************************************************** | /**************************************************************************** | ||||||
| @@ -165,32 +156,32 @@ typedef struct THREADPOOLJOB | |||||||
|  *     Structure to hold statistics |  *     Structure to hold statistics | ||||||
|  *****************************************************************************/ |  *****************************************************************************/ | ||||||
|  |  | ||||||
| STATSONLY( | #ifdef STATS | ||||||
|  |  | ||||||
| typedef struct TPOOLSTATS | typedef struct TPOOLSTATS | ||||||
| { | { | ||||||
|   double totalTimeHQ; //total time spent by all jobs in high priority Q |   double totalTimeHQ; | ||||||
|   int totalJobsHQ;    //total jobs in HQ run so far |   int totalJobsHQ; | ||||||
|   double avgWaitHQ;   //average wait in HQ |   double avgWaitHQ; | ||||||
|   double totalTimeMQ; //total time spent by all jobs in med priority Q |   double totalTimeMQ; | ||||||
|   int totalJobsMQ;    //total jobs in MQ run so far |   int totalJobsMQ; | ||||||
|   double avgWaitMQ;   //average wait in MQ |   double avgWaitMQ; | ||||||
|   double totalTimeLQ; //total time spent by all jobs in low priority Q |   double totalTimeLQ; | ||||||
|   int totalJobsLQ;    //total jobs in LQ run so far |   int totalJobsLQ; | ||||||
|   double avgWaitLQ;	//average wait in LQ |   double avgWaitLQ; | ||||||
|   double totalWorkTime; //total time spent working for all threads |   double totalWorkTime; | ||||||
|   double totalIdleTime; //total time spent idle for all threads |   double totalIdleTime; | ||||||
|   int workerThreads; //number of current workerThreads |   int workerThreads; | ||||||
|   int idleThreads;   //number of current idle threads |   int idleThreads; | ||||||
|   int persistentThreads; //number of persistent threads |   int persistentThreads; | ||||||
|   int totalThreads; //total number of current threads |   int totalThreads; | ||||||
|   int maxThreads; //max threads so far |   int maxThreads; | ||||||
|   int currentJobsHQ; // current jobs in Q |   int currentJobsHQ; | ||||||
|   int currentJobsLQ; //current jobs in Q |   int currentJobsLQ; | ||||||
|   int currentJobsMQ; //current jobs in Q |   int currentJobsMQ; | ||||||
| }ThreadPoolStats; | }ThreadPoolStats; | ||||||
|  |  | ||||||
| ) | #endif | ||||||
|  |  | ||||||
|  |  | ||||||
| /**************************************************************************** | /**************************************************************************** | ||||||
| @@ -215,24 +206,26 @@ typedef struct TPOOLSTATS | |||||||
|  |  | ||||||
| typedef struct THREADPOOL | typedef struct THREADPOOL | ||||||
| { | { | ||||||
|   ithread_mutex_t mutex; //mutex to protect job qs |   ithread_mutex_t mutex; /* mutex to protect job qs */ | ||||||
|   ithread_cond_t condition; //condition variable to signal Q |   ithread_cond_t condition; /* condition variable to signal Q */ | ||||||
|   ithread_cond_t start_and_shutdown; //condition variable for start  |   ithread_cond_t start_and_shutdown; /* condition variable for start  | ||||||
|                                      //and stop      |                                         and stop */ | ||||||
|   int lastJobId; //ids for jobs  |   int lastJobId; /* ids for jobs */ | ||||||
|   int shutdown;   //whether or not we are shutting down |   int shutdown;  /* whether or not we are shutting down */ | ||||||
|   int totalThreads;       //total number of threads	 |   int totalThreads;      /* total number of threads */ | ||||||
|   int persistentThreads; //number of persistent threads |   int persistentThreads; /* number of persistent threads */ | ||||||
|   FreeList jobFreeList; //free list of jobs |   FreeList jobFreeList;  /* free list of jobs */ | ||||||
|   LinkedList lowJobQ;    //low priority job Q |   LinkedList lowJobQ;    /* low priority job Q */ | ||||||
|   LinkedList medJobQ;    //med priority job Q |   LinkedList medJobQ;    /* med priority job Q */ | ||||||
|   LinkedList highJobQ;   //high priority job Q |   LinkedList highJobQ;   /* high priority job Q */ | ||||||
|   ThreadPoolJob *persistentJob; //persistent job |   ThreadPoolJob *persistentJob; /* persistent job */ | ||||||
|   |   | ||||||
|   ThreadPoolAttr attr; //thread pool attributes |   ThreadPoolAttr attr; /* thread pool attributes */ | ||||||
|    |    | ||||||
|   //statistics  | #ifdef STATS | ||||||
|   STATSONLY(ThreadPoolStats stats;) |   /* statistics */ | ||||||
|  |   ThreadPoolStats stats; | ||||||
|  | #endif | ||||||
|   |   | ||||||
| } ThreadPool; | } ThreadPool; | ||||||
|  |  | ||||||
| @@ -550,12 +543,15 @@ int TPAttrSetMaxJobsTotal(ThreadPoolAttr *attr, int maxJobsTotal); | |||||||
|  *  Returns: |  *  Returns: | ||||||
|  *      Always returns 0. |  *      Always returns 0. | ||||||
|  *****************************************************************************/ |  *****************************************************************************/ | ||||||
| STATSONLY( EXPORT int ThreadPoolGetStats(ThreadPool *tp, ThreadPoolStats *stats);); | #ifdef STATS | ||||||
|  | 	EXPORT int ThreadPoolGetStats(ThreadPool *tp, ThreadPoolStats *stats); | ||||||
|  |  | ||||||
| STATSONLY(EXPORT void ThreadPoolPrintStats(ThreadPoolStats *stats);); | 	EXPORT void ThreadPoolPrintStats(ThreadPoolStats *stats); | ||||||
|  | #endif | ||||||
|  |  | ||||||
| #ifdef __cplusplus | #ifdef __cplusplus | ||||||
| } | } | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
| #endif //ThreadPool | #endif /* ThreadPool */ | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1,33 +1,33 @@ | |||||||
| /////////////////////////////////////////////////////////////////////////// | /******************************************************************************* | ||||||
| // |  * | ||||||
| // Copyright (c) 2000-2003 Intel Corporation  |  * Copyright (c) 2000-2003 Intel Corporation  | ||||||
| // All rights reserved.  |  * All rights reserved.  | ||||||
| // |  * | ||||||
| // Redistribution and use in source and binary forms, with or without  |  * Redistribution and use in source and binary forms, with or without  | ||||||
| // modification, are permitted provided that the following conditions are met:  |  * modification, are permitted provided that the following conditions are met:  | ||||||
| // |  * | ||||||
| // * Redistributions of source code must retain the above copyright notice,  |  * * Redistributions of source code must retain the above copyright notice,  | ||||||
| // this list of conditions and the following disclaimer.  |  * this list of conditions and the following disclaimer.  | ||||||
| // * Redistributions in binary form must reproduce the above copyright notice,  |  * * Redistributions in binary form must reproduce the above copyright notice,  | ||||||
| // this list of conditions and the following disclaimer in the documentation  |  * this list of conditions and the following disclaimer in the documentation  | ||||||
| // and/or other materials provided with the distribution.  |  * and/or other materials provided with the distribution.  | ||||||
| // * Neither name of Intel Corporation nor the names of its contributors  |  * * Neither name of Intel Corporation nor the names of its contributors  | ||||||
| // may be used to endorse or promote products derived from this software  |  * may be used to endorse or promote products derived from this software  | ||||||
| // without specific prior written permission. |  * without specific prior written permission. | ||||||
| //  |  *  | ||||||
| // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS  |  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS  | ||||||
| // "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT  |  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT  | ||||||
| // LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR  |  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR  | ||||||
| // A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL INTEL OR  |  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL INTEL OR  | ||||||
| // CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,  |  * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,  | ||||||
| // EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,  |  * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,  | ||||||
| // PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR  |  * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR  | ||||||
| // PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY  |  * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY  | ||||||
| // OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING |  * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING | ||||||
| // NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS  |  * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS  | ||||||
| // SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |  * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||||
| // |  * | ||||||
| /////////////////////////////////////////////////////////////////////////// |  ******************************************************************************/ | ||||||
|  |  | ||||||
| #ifndef TIMERTHREAD_H | #ifndef TIMERTHREAD_H | ||||||
| #define TIMERTHREAD_H | #define TIMERTHREAD_H | ||||||
| @@ -43,9 +43,9 @@ extern "C" { | |||||||
|  |  | ||||||
| #define INVALID_EVENT_ID (-10 & 1<<29) | #define INVALID_EVENT_ID (-10 & 1<<29) | ||||||
|  |  | ||||||
| //Timeout Types | /* Timeout Types */ | ||||||
| //absolute means in seconds from Jan 1, 1970 | /* absolute means in seconds from Jan 1, 1970 */ | ||||||
| //relative means in seconds from current time | /* relative means in seconds from current time */ | ||||||
| typedef enum timeoutType {ABS_SEC,REL_SEC} TimeoutType; | typedef enum timeoutType {ABS_SEC,REL_SEC} TimeoutType; | ||||||
|  |  | ||||||
|  |  | ||||||
| @@ -63,13 +63,13 @@ typedef enum timeoutType {ABS_SEC,REL_SEC} TimeoutType; | |||||||
|  *****************************************************************************/ |  *****************************************************************************/ | ||||||
| typedef struct TIMERTHREAD | typedef struct TIMERTHREAD | ||||||
| { | { | ||||||
|   ithread_mutex_t mutex; //mutex to protect eventQ |   ithread_mutex_t mutex; | ||||||
|   ithread_cond_t condition; //condition variable |   ithread_cond_t condition; | ||||||
|   int lastEventId;	//last event id |   int lastEventId; | ||||||
|   LinkedList eventQ; //event q |   LinkedList eventQ; | ||||||
|   int shutdown;      //whether or not we are shutdown   |   int shutdown; | ||||||
|   FreeList freeEvents; //FreeList for events |   FreeList freeEvents; | ||||||
|   ThreadPool *tp;	 //ThreadPool to use |   ThreadPool *tp; | ||||||
| } TimerThread; | } TimerThread; | ||||||
|  |  | ||||||
|  |  | ||||||
| @@ -85,9 +85,9 @@ typedef struct TIMERTHREAD | |||||||
| typedef struct TIMEREVENT | typedef struct TIMEREVENT | ||||||
| { | { | ||||||
|   ThreadPoolJob job; |   ThreadPoolJob job; | ||||||
|   time_t eventTime; //absolute time for event in seconds since Jan 1, 1970 |   time_t eventTime; /* absolute time for event in seconds since Jan 1, 1970 */ | ||||||
|   Duration persistent;          //long term or short term job |   Duration persistent;  /* long term or short term job */ | ||||||
|   int id;                //id of job |   int id; | ||||||
| } TimerEvent; | } TimerEvent; | ||||||
|  |  | ||||||
|  |  | ||||||
| @@ -188,4 +188,5 @@ int TimerThreadShutdown(TimerThread *timer); | |||||||
| } | } | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
| #endif //TIMER_THREAD_H | #endif /* TIMER_THREAD_H */ | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1,33 +1,33 @@ | |||||||
| /////////////////////////////////////////////////////////////////////////// | /******************************************************************************* | ||||||
| // |  * | ||||||
| // Copyright (c) 2000-2003 Intel Corporation  |  * Copyright (c) 2000-2003 Intel Corporation  | ||||||
| // All rights reserved.  |  * All rights reserved.  | ||||||
| // |  * | ||||||
| // Redistribution and use in source and binary forms, with or without  |  * Redistribution and use in source and binary forms, with or without  | ||||||
| // modification, are permitted provided that the following conditions are met:  |  * modification, are permitted provided that the following conditions are met:  | ||||||
| // |  * | ||||||
| // * Redistributions of source code must retain the above copyright notice,  |  * * Redistributions of source code must retain the above copyright notice,  | ||||||
| // this list of conditions and the following disclaimer.  |  * this list of conditions and the following disclaimer.  | ||||||
| // * Redistributions in binary form must reproduce the above copyright notice,  |  * * Redistributions in binary form must reproduce the above copyright notice,  | ||||||
| // this list of conditions and the following disclaimer in the documentation  |  * this list of conditions and the following disclaimer in the documentation  | ||||||
| // and/or other materials provided with the distribution.  |  * and/or other materials provided with the distribution.  | ||||||
| // * Neither name of Intel Corporation nor the names of its contributors  |  * * Neither name of Intel Corporation nor the names of its contributors  | ||||||
| // may be used to endorse or promote products derived from this software  |  * may be used to endorse or promote products derived from this software  | ||||||
| // without specific prior written permission. |  * without specific prior written permission. | ||||||
| //  |  *  | ||||||
| // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS  |  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS  | ||||||
| // "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT  |  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT  | ||||||
| // LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR  |  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR  | ||||||
| // A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL INTEL OR  |  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL INTEL OR  | ||||||
| // CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,  |  * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,  | ||||||
| // EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,  |  * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,  | ||||||
| // PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR  |  * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR  | ||||||
| // PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY  |  * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY  | ||||||
| // OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING |  * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING | ||||||
| // NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS  |  * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS  | ||||||
| // SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |  * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||||
| // |  * | ||||||
| /////////////////////////////////////////////////////////////////////////// |  ******************************************************************************/ | ||||||
|  |  | ||||||
| #include <stdarg.h> | #include <stdarg.h> | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1,33 +1,33 @@ | |||||||
| /////////////////////////////////////////////////////////////////////////// | /******************************************************************************* | ||||||
| // |  * | ||||||
| // Copyright (c) 2000-2003 Intel Corporation  |  * Copyright (c) 2000-2003 Intel Corporation  | ||||||
| // All rights reserved.  |  * All rights reserved.  | ||||||
| // |  * | ||||||
| // Redistribution and use in source and binary forms, with or without  |  * Redistribution and use in source and binary forms, with or without  | ||||||
| // modification, are permitted provided that the following conditions are met:  |  * modification, are permitted provided that the following conditions are met:  | ||||||
| // |  * | ||||||
| // * Redistributions of source code must retain the above copyright notice,  |  * * Redistributions of source code must retain the above copyright notice,  | ||||||
| // this list of conditions and the following disclaimer.  |  * this list of conditions and the following disclaimer.  | ||||||
| // * Redistributions in binary form must reproduce the above copyright notice,  |  * * Redistributions in binary form must reproduce the above copyright notice,  | ||||||
| // this list of conditions and the following disclaimer in the documentation  |  * this list of conditions and the following disclaimer in the documentation  | ||||||
| // and/or other materials provided with the distribution.  |  * and/or other materials provided with the distribution.  | ||||||
| // * Neither name of Intel Corporation nor the names of its contributors  |  * * Neither name of Intel Corporation nor the names of its contributors  | ||||||
| // may be used to endorse or promote products derived from this software  |  * may be used to endorse or promote products derived from this software  | ||||||
| // without specific prior written permission. |  * without specific prior written permission. | ||||||
| //  |  *  | ||||||
| // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS  |  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS  | ||||||
| // "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT  |  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT  | ||||||
| // LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR  |  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR  | ||||||
| // A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL INTEL OR  |  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL INTEL OR  | ||||||
| // CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,  |  * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,  | ||||||
| // EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,  |  * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,  | ||||||
| // PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR  |  * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR  | ||||||
| // PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY  |  * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY  | ||||||
| // OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING |  * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING | ||||||
| // NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS  |  * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS  | ||||||
| // SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |  * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||||
| // |  * | ||||||
| /////////////////////////////////////////////////////////////////////////// |  ******************************************************************************/ | ||||||
|  |  | ||||||
| #ifndef ITHREADH | #ifndef ITHREADH | ||||||
| #define ITHREADH | #define ITHREADH | ||||||
| @@ -36,20 +36,28 @@ extern "C" { | |||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  |  | ||||||
| #ifdef DEBUG |  | ||||||
| #define DEBUG_ONLY(x) x |  | ||||||
| #else |  | ||||||
| #define DEBUG_ONLY(x) |  | ||||||
| #endif |  | ||||||
|  |  | ||||||
| #include <pthread.h> | #include <pthread.h> | ||||||
| #ifndef WIN32 | #ifndef WIN32 | ||||||
| 	#include <unistd.h> | 	#include <unistd.h> | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  | #ifdef __FreeBSD__ | ||||||
|  | #define PTHREAD_MUTEX_RECURSIVE_NP PTHREAD_MUTEX_RECURSIVE | ||||||
|  | #endif | ||||||
|  |  | ||||||
|  | #ifdef PTHREAD_MUTEX_RECURSIVE | ||||||
|  | /* This system has SuS2-compliant mutex attributes. | ||||||
|  |  * E.g. on Cygwin, where we don't have the old nonportable (NP) symbols | ||||||
|  |  */ | ||||||
|  | #define ITHREAD_MUTEX_FAST_NP PTHREAD_MUTEX_NORMAL | ||||||
|  | #define ITHREAD_MUTEX_RECURSIVE_NP PTHREAD_MUTEX_RECURSIVE | ||||||
|  | #define ITHREAD_MUTEX_ERRORCHECK_NP PTHREAD_MUTEX_ERRORCHECK | ||||||
|  | #else | ||||||
| #define ITHREAD_MUTEX_FAST_NP PTHREAD_MUTEX_FAST_NP | #define ITHREAD_MUTEX_FAST_NP PTHREAD_MUTEX_FAST_NP | ||||||
| #define ITHREAD_MUTEX_RECURSIVE_NP PTHREAD_MUTEX_RECURSIVE_NP | #define ITHREAD_MUTEX_RECURSIVE_NP PTHREAD_MUTEX_RECURSIVE_NP | ||||||
| #define ITHREAD_MUTEX_ERRORCHECK_NP PTHREAD_MUTEX_ERRORCHECK_NP | #define ITHREAD_MUTEX_ERRORCHECK_NP PTHREAD_MUTEX_ERRORCHECK_NP | ||||||
|  | #endif | ||||||
|  |  | ||||||
| #define ITHREAD_CANCELED PTHREAD_CANCELED | #define ITHREAD_CANCELED PTHREAD_CANCELED | ||||||
|  |  | ||||||
|    |    | ||||||
| @@ -181,8 +189,11 @@ extern "C" { | |||||||
|  *      Returns EINVAL if the kind is not supported. |  *      Returns EINVAL if the kind is not supported. | ||||||
|  *      See man page for pthread_mutexattr_setkind_np |  *      See man page for pthread_mutexattr_setkind_np | ||||||
|  *****************************************************************************/ |  *****************************************************************************/ | ||||||
|  | #ifdef PTHREAD_MUTEX_RECURSIVE | ||||||
|  | #define ithread_mutexattr_setkind_np pthread_mutexattr_settype | ||||||
|  | #else | ||||||
| #define ithread_mutexattr_setkind_np pthread_mutexattr_setkind_np | #define ithread_mutexattr_setkind_np pthread_mutexattr_setkind_np | ||||||
|  | #endif | ||||||
|  |  | ||||||
| /**************************************************************************** | /**************************************************************************** | ||||||
|  * Function: ithread_mutexattr_getkind_np |  * Function: ithread_mutexattr_getkind_np | ||||||
| @@ -203,7 +214,11 @@ extern "C" { | |||||||
|  *      Always returns 0. |  *      Always returns 0. | ||||||
|  *      See man page for pthread_mutexattr_getkind_np |  *      See man page for pthread_mutexattr_getkind_np | ||||||
|  *****************************************************************************/ |  *****************************************************************************/ | ||||||
|  | #ifdef PTHREAD_MUTEX_RECURSIVE | ||||||
|  | #define ithread_mutexattr_getkind_np pthread_mutexattr_gettype | ||||||
|  | #else | ||||||
| #define ithread_mutexattr_getkind_np pthread_mutexattr_getkind_np | #define ithread_mutexattr_getkind_np pthread_mutexattr_getkind_np | ||||||
|  | #endif | ||||||
|  |  | ||||||
|    |    | ||||||
| /**************************************************************************** | /**************************************************************************** | ||||||
| @@ -529,7 +544,7 @@ extern "C" { | |||||||
| #ifdef WIN32 | #ifdef WIN32 | ||||||
| 	#ifndef UPNP_STATIC_LIB | 	#ifndef UPNP_STATIC_LIB | ||||||
| 		#ifdef LIBUPNP_EXPORTS | 		#ifdef LIBUPNP_EXPORTS | ||||||
|    // set up declspec for dll export to make functions visible to library users | 			/* set up declspec for dll export to make functions visible to library users */ | ||||||
| 			#define EXPORT_SPEC __declspec(dllexport) | 			#define EXPORT_SPEC __declspec(dllexport) | ||||||
| 		#else | 		#else | ||||||
| 			#define EXPORT_SPEC __declspec(dllimport) | 			#define EXPORT_SPEC __declspec(dllimport) | ||||||
| @@ -542,11 +557,14 @@ extern "C" { | |||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  |  | ||||||
| //NK: Added for satisfying the gcc compiler   | #ifndef PTHREAD_MUTEX_RECURSIVE | ||||||
|  | /* NK: Added for satisfying the gcc compiler */ | ||||||
| EXPORT_SPEC int pthread_mutexattr_setkind_np(pthread_mutexattr_t *attr, int kind); | EXPORT_SPEC int pthread_mutexattr_setkind_np(pthread_mutexattr_t *attr, int kind); | ||||||
|  | #endif | ||||||
|  |  | ||||||
| #ifdef __cplusplus | #ifdef __cplusplus | ||||||
| } | } | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
| #endif //ITHREADH | #endif /* ITHREADH */ | ||||||
|  |  | ||||||
|   | |||||||
| @@ -90,6 +90,10 @@ FreeThreadPoolJob( ThreadPool * tp, | |||||||
| static int | static int | ||||||
| SetPolicyType( PolicyType in ) | SetPolicyType( PolicyType in ) | ||||||
| { | { | ||||||
|  |     #ifdef __CYGWIN__ | ||||||
|  |      /* TODO not currently working... */ | ||||||
|  |      return 0; | ||||||
|  |     #else | ||||||
|     #ifdef WIN32 |     #ifdef WIN32 | ||||||
|      return sched_setscheduler( 0, in); |      return sched_setscheduler( 0, in); | ||||||
|     #else |     #else | ||||||
| @@ -99,6 +103,7 @@ SetPolicyType( PolicyType in ) | |||||||
|      current.sched_priority = DEFAULT_SCHED_PARAM; |      current.sched_priority = DEFAULT_SCHED_PARAM; | ||||||
|      return sched_setscheduler( 0, in, ¤t ); |      return sched_setscheduler( 0, in, ¤t ); | ||||||
|     #endif |     #endif | ||||||
|  |     #endif | ||||||
| } | } | ||||||
|  |  | ||||||
| /**************************************************************************** | /**************************************************************************** | ||||||
| @@ -126,7 +131,7 @@ SetPriority( ThreadPriority priority ) | |||||||
|     int midPriority = 0; |     int midPriority = 0; | ||||||
|     struct sched_param newPriority; |     struct sched_param newPriority; | ||||||
|  |  | ||||||
|     pthread_getschedparam( ithread_self(  ), ¤tPolicy, |     pthread_getschedparam( ithread_self(), ¤tPolicy, | ||||||
|                            &newPriority ); |                            &newPriority ); | ||||||
|     minPriority = sched_get_priority_min( currentPolicy ); |     minPriority = sched_get_priority_min( currentPolicy ); | ||||||
|     maxPriority = sched_get_priority_max( currentPolicy ); |     maxPriority = sched_get_priority_max( currentPolicy ); | ||||||
| @@ -148,7 +153,7 @@ SetPriority( ThreadPriority priority ) | |||||||
|  |  | ||||||
|     newPriority.sched_priority = actPriority; |     newPriority.sched_priority = actPriority; | ||||||
|  |  | ||||||
|     return pthread_setschedparam( ithread_self(  ), currentPolicy, |     return pthread_setschedparam( ithread_self(), currentPolicy, | ||||||
|                                   &newPriority ); |                                   &newPriority ); | ||||||
|  |  | ||||||
| } | } | ||||||
| @@ -215,10 +220,8 @@ BumpPriority( ThreadPool * tp ) | |||||||
|                 //starvation time |                 //starvation time | ||||||
|                 //bump priority (add to higher priority Q) |                 //bump priority (add to higher priority Q) | ||||||
|  |  | ||||||
|                 STATSONLY( tp->stats.totalJobsMQ++; |                 STATSONLY( tp->stats.totalJobsMQ++; ) | ||||||
|                      ); |                 STATSONLY( tp->stats.totalTimeMQ += diffTime; ) | ||||||
|                 STATSONLY( tp->stats.totalTimeMQ += diffTime; |  | ||||||
|                      ); |  | ||||||
|  |  | ||||||
|                 ListDelNode( &tp->medJobQ, tp->medJobQ.head.next, 0 ); |                 ListDelNode( &tp->medJobQ, tp->medJobQ.head.next, 0 ); | ||||||
|                 ListAddTail( &tp->highJobQ, tempJob ); |                 ListAddTail( &tp->highJobQ, tempJob ); | ||||||
| @@ -236,10 +239,8 @@ BumpPriority( ThreadPool * tp ) | |||||||
|                 //starvation time |                 //starvation time | ||||||
|                 //bump priority (add to higher priority Q) |                 //bump priority (add to higher priority Q) | ||||||
|  |  | ||||||
|                 STATSONLY( tp->stats.totalJobsLQ++; |                 STATSONLY( tp->stats.totalJobsLQ++; ) | ||||||
|                      ); |                 STATSONLY( tp->stats.totalTimeLQ += diffTime; ) | ||||||
|                 STATSONLY( tp->stats.totalTimeLQ += diffTime; |  | ||||||
|                      ); |  | ||||||
|  |  | ||||||
|                 ListDelNode( &tp->lowJobQ, tp->lowJobQ.head.next, 0 ); |                 ListDelNode( &tp->lowJobQ, tp->lowJobQ.head.next, 0 ); | ||||||
|                 ListAddTail( &tp->medJobQ, tempJob ); |                 ListAddTail( &tp->medJobQ, tempJob ); | ||||||
| @@ -288,14 +289,26 @@ SetRelTimeout( struct timespec *time, | |||||||
|  *      ThreadPoolStats *stats must be valid non null stats structure |  *      ThreadPoolStats *stats must be valid non null stats structure | ||||||
|  *****************************************************************************/ |  *****************************************************************************/ | ||||||
| #ifdef STATS | #ifdef STATS | ||||||
| static void StatsInit( ThreadPoolStats * stats ) { | static void StatsInit( ThreadPoolStats * stats ) | ||||||
|            assert( stats != NULL ); stats->totalIdleTime = 0; stats->totalJobsHQ = 0; stats->totalJobsLQ = 0; stats->totalJobsMQ = 0; stats->totalTimeHQ = 0; stats->totalTimeMQ = 0; stats->totalTimeLQ = 0; stats->totalWorkTime = 0; stats->totalIdleTime = 0; stats->avgWaitHQ = 0; //average wait in HQ | { | ||||||
|            stats->avgWaitMQ = 0;    //average wait in MQ |            assert( stats != NULL ); | ||||||
|  | 	   stats->totalIdleTime = 0; | ||||||
|  | 	   stats->totalJobsHQ = 0; | ||||||
|  | 	   stats->totalJobsLQ = 0; | ||||||
|  | 	   stats->totalJobsMQ = 0; | ||||||
|  | 	   stats->totalTimeHQ = 0; | ||||||
|  | 	   stats->totalTimeMQ = 0; | ||||||
|  | 	   stats->totalTimeLQ = 0; | ||||||
|  | 	   stats->totalWorkTime = 0; | ||||||
|  | 	   stats->totalIdleTime = 0; | ||||||
|  | 	   stats->avgWaitHQ = 0; | ||||||
|  |            stats->avgWaitMQ = 0; | ||||||
|            stats->avgWaitLQ = 0; |            stats->avgWaitLQ = 0; | ||||||
|            stats->workerThreads = 0; |            stats->workerThreads = 0; | ||||||
|            stats->idleThreads = 0; |            stats->idleThreads = 0; | ||||||
|            stats->persistentThreads = 0; |            stats->persistentThreads = 0; | ||||||
|            stats->maxThreads = 0; stats->totalThreads = 0;} |            stats->maxThreads = 0; stats->totalThreads = 0; | ||||||
|  | } | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
| /**************************************************************************** | /**************************************************************************** | ||||||
| @@ -341,16 +354,16 @@ tp->stats.totalJobsLQ++; tp->stats.totalTimeLQ += diff; break; default: | |||||||
|  *  Parameters: |  *  Parameters: | ||||||
|  *       |  *       | ||||||
|  *****************************************************************************/ |  *****************************************************************************/ | ||||||
|     static void SetSeed(  ) { |     static void SetSeed() { | ||||||
|     struct timeb t; |     struct timeb t; | ||||||
|  |  | ||||||
|     ftime( &t ); |     ftime( &t ); | ||||||
| #if defined(WIN32) | #if defined(WIN32) | ||||||
|     srand( ( unsigned int )t.millitm + (unsigned int)ithread_get_current_thread_id(  ).p ); |     srand( ( unsigned int )t.millitm + (unsigned int)ithread_get_current_thread_id().p ); | ||||||
| #elif defined(__FreeBSD__) | #elif defined(__FreeBSD__) | ||||||
|     srand( ( unsigned int )t.millitm + (unsigned int)ithread_get_current_thread_id(  ) ); |     srand( ( unsigned int )t.millitm + (unsigned int)ithread_get_current_thread_id() ); | ||||||
| #else | #else | ||||||
|     srand( ( unsigned int )t.millitm + ithread_get_current_thread_id(  ) ); |     srand( ( unsigned int )t.millitm + ithread_get_current_thread_id() ); | ||||||
| #endif | #endif | ||||||
|     } |     } | ||||||
|  |  | ||||||
| @@ -370,8 +383,7 @@ tp->stats.totalJobsLQ++; tp->stats.totalTimeLQ += diff; break; default: | |||||||
|  *****************************************************************************/ |  *****************************************************************************/ | ||||||
|     static void *WorkerThread( void *arg ) { |     static void *WorkerThread( void *arg ) { | ||||||
|  |  | ||||||
|         STATSONLY( time_t start = 0; |         STATSONLY( time_t start = 0; ) | ||||||
|              ) |  | ||||||
|  |  | ||||||
|         ThreadPoolJob *job = NULL; |         ThreadPoolJob *job = NULL; | ||||||
|         ListNode *head = NULL; |         ListNode *head = NULL; | ||||||
| @@ -395,10 +407,9 @@ tp->stats.totalJobsLQ++; tp->stats.totalTimeLQ += diff; break; default: | |||||||
|         ithread_cond_broadcast( &tp->start_and_shutdown ); |         ithread_cond_broadcast( &tp->start_and_shutdown ); | ||||||
|         ithread_mutex_unlock( &tp->mutex ); |         ithread_mutex_unlock( &tp->mutex ); | ||||||
|  |  | ||||||
|         SetSeed(  ); |         SetSeed(); | ||||||
|  |  | ||||||
|         STATSONLY( time( &start ); |         STATSONLY( time( &start ); ) | ||||||
|              ); |  | ||||||
|  |  | ||||||
|         while( 1 ) { |         while( 1 ) { | ||||||
|  |  | ||||||
| @@ -413,12 +424,9 @@ tp->stats.totalJobsLQ++; tp->stats.totalTimeLQ += diff; break; default: | |||||||
|  |  | ||||||
|             retCode = 0; |             retCode = 0; | ||||||
|  |  | ||||||
|             STATSONLY( tp->stats.idleThreads++; |             STATSONLY( tp->stats.idleThreads++; ) | ||||||
|                  ); |             STATSONLY( tp->stats.totalWorkTime += ( time( NULL ) - start ); ) //work time | ||||||
|             STATSONLY( tp->stats.totalWorkTime += ( time( NULL ) - start ); |             STATSONLY( time( &start ); )  // idle time | ||||||
|                  );             //work time |  | ||||||
|             STATSONLY( time( &start ); |  | ||||||
|                  );             //idle time |  | ||||||
|  |  | ||||||
|             if( persistent == 1 ) { |             if( persistent == 1 ) { | ||||||
|                 //Persistent thread |                 //Persistent thread | ||||||
| @@ -426,8 +434,7 @@ tp->stats.totalJobsLQ++; tp->stats.totalTimeLQ += diff; break; default: | |||||||
|                 tp->persistentThreads--; |                 tp->persistentThreads--; | ||||||
|             } |             } | ||||||
|  |  | ||||||
|             STATSONLY( if( persistent == 0 ) |             STATSONLY( if( persistent == 0 ) tp->stats.workerThreads--; ) | ||||||
|                        tp->stats.workerThreads--; ); |  | ||||||
|  |  | ||||||
|             //Check for a job or shutdown |             //Check for a job or shutdown | ||||||
|             while( ( tp->lowJobQ.size == 0 ) |             while( ( tp->lowJobQ.size == 0 ) | ||||||
| @@ -448,7 +455,7 @@ tp->stats.totalJobsLQ++; tp->stats.totalTimeLQ += diff; break; default: | |||||||
|                          && ( ( tp->totalThreads ) > |                          && ( ( tp->totalThreads ) > | ||||||
|                               tp->attr.maxThreads ) ) ) { |                               tp->attr.maxThreads ) ) ) { | ||||||
|  |  | ||||||
|                     STATSONLY( tp->stats.idleThreads-- ); |                     STATSONLY( tp->stats.idleThreads--; ) | ||||||
|  |  | ||||||
|                     tp->totalThreads--; |                     tp->totalThreads--; | ||||||
|                     ithread_cond_broadcast( &tp->start_and_shutdown ); |                     ithread_cond_broadcast( &tp->start_and_shutdown ); | ||||||
| @@ -470,12 +477,9 @@ tp->stats.totalJobsLQ++; tp->stats.totalTimeLQ += diff; break; default: | |||||||
|  |  | ||||||
|             } |             } | ||||||
|  |  | ||||||
|             STATSONLY( tp->stats.idleThreads--; |             STATSONLY( tp->stats.idleThreads--; ) | ||||||
|                  ); |             STATSONLY( tp->stats.totalIdleTime += ( time( NULL ) - start ); )  // idle time | ||||||
|             STATSONLY( tp->stats.totalIdleTime += ( time( NULL ) - start ); |             STATSONLY( time( &start ); ) // work time | ||||||
|                  );             //idle time |  | ||||||
|             STATSONLY( time( &start ); |  | ||||||
|                  );             //work time |  | ||||||
|  |  | ||||||
|             //bump priority of starved jobs |             //bump priority of starved jobs | ||||||
|             BumpPriority( tp ); |             BumpPriority( tp ); | ||||||
| @@ -507,34 +511,33 @@ tp->stats.totalJobsLQ++; tp->stats.totalTimeLQ += diff; break; default: | |||||||
|                     ithread_cond_broadcast( &tp->start_and_shutdown ); |                     ithread_cond_broadcast( &tp->start_and_shutdown ); | ||||||
|  |  | ||||||
|                 } else { |                 } else { | ||||||
|                     STATSONLY( tp->stats.workerThreads++ ); |                     STATSONLY( tp->stats.workerThreads++; ) | ||||||
|                     persistent = 0; |                     persistent = 0; | ||||||
|  |  | ||||||
|                     //Pick the highest priority job |                     //Pick the highest priority job | ||||||
|                     if( tp->highJobQ.size > 0 ) { |                     if( tp->highJobQ.size > 0 ) { | ||||||
|                         head = ListHead( &tp->highJobQ ); |                         head = ListHead( &tp->highJobQ ); | ||||||
|                         job = ( ThreadPoolJob * ) head->item; |                         job = ( ThreadPoolJob * ) head->item; | ||||||
|                         STATSONLY( CalcWaitTime |                         STATSONLY( CalcWaitTime( tp, HIGH_PRIORITY, job ); ) | ||||||
|                                    ( tp, HIGH_PRIORITY, job ) ); |  | ||||||
|                         ListDelNode( &tp->highJobQ, head, 0 ); |                         ListDelNode( &tp->highJobQ, head, 0 ); | ||||||
|  |  | ||||||
|                     } else if( tp->medJobQ.size > 0 ) { |                     } else if( tp->medJobQ.size > 0 ) { | ||||||
|                         head = ListHead( &tp->medJobQ ); |                         head = ListHead( &tp->medJobQ ); | ||||||
|                         job = ( ThreadPoolJob * ) head->item; |                         job = ( ThreadPoolJob * ) head->item; | ||||||
|                         STATSONLY( CalcWaitTime( tp, MED_PRIORITY, job ) ); |                         STATSONLY( CalcWaitTime( tp, MED_PRIORITY, job ); ) | ||||||
|                         ListDelNode( &tp->medJobQ, head, 0 ); |                         ListDelNode( &tp->medJobQ, head, 0 ); | ||||||
|  |  | ||||||
|                     } else if( tp->lowJobQ.size > 0 ) { |                     } else if( tp->lowJobQ.size > 0 ) { | ||||||
|                         head = ListHead( &tp->lowJobQ ); |                         head = ListHead( &tp->lowJobQ ); | ||||||
|                         job = ( ThreadPoolJob * ) head->item; |                         job = ( ThreadPoolJob * ) head->item; | ||||||
|                         STATSONLY( CalcWaitTime( tp, LOW_PRIORITY, job ) ); |                         STATSONLY( CalcWaitTime( tp, LOW_PRIORITY, job ); ) | ||||||
|                         ListDelNode( &tp->lowJobQ, head, 0 ); |                         ListDelNode( &tp->lowJobQ, head, 0 ); | ||||||
|  |  | ||||||
|                     } else { |                     } else { | ||||||
|  |  | ||||||
|                         // Should never get here |                         // Should never get here | ||||||
|                         assert( 0 ); |                         assert( 0 ); | ||||||
|                         STATSONLY( tp->stats.workerThreads-- ); |                         STATSONLY( tp->stats.workerThreads--; ) | ||||||
|                         tp->totalThreads--; |                         tp->totalThreads--; | ||||||
|                         ithread_cond_broadcast( &tp->start_and_shutdown ); |                         ithread_cond_broadcast( &tp->start_and_shutdown ); | ||||||
|                         ithread_mutex_unlock( &tp->mutex ); |                         ithread_mutex_unlock( &tp->mutex ); | ||||||
| @@ -639,9 +642,11 @@ tp->stats.totalJobsLQ++; tp->stats.totalTimeLQ += diff; break; default: | |||||||
|  |  | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         STATSONLY( if( tp->stats.maxThreads < tp->totalThreads ) { | #ifdef STATS | ||||||
|                    tp->stats.maxThreads = tp->totalThreads;} |         if( tp->stats.maxThreads < tp->totalThreads ) { | ||||||
|          ) |                    tp->stats.maxThreads = tp->totalThreads; | ||||||
|  |         } | ||||||
|  | #endif | ||||||
|  |  | ||||||
|             return rc; |             return rc; | ||||||
|     } |     } | ||||||
| @@ -669,7 +674,7 @@ tp->stats.totalJobsLQ++; tp->stats.totalTimeLQ += diff; break; default: | |||||||
|         threads = tp->totalThreads - tp->persistentThreads; |         threads = tp->totalThreads - tp->persistentThreads; | ||||||
|  |  | ||||||
|         while( ( threads == 0 ) |         while( ( threads == 0 ) | ||||||
|                || ( ( jobs / threads ) > tp->attr.jobsPerThread ) ) { |                || ( ( jobs / threads ) >= tp->attr.jobsPerThread ) ) { | ||||||
|  |  | ||||||
|             if( CreateWorker( tp ) != 0 ) |             if( CreateWorker( tp ) != 0 ) | ||||||
|                 return; |                 return; | ||||||
| @@ -761,7 +766,7 @@ tp->stats.totalJobsLQ++; tp->stats.totalTimeLQ += diff; break; default: | |||||||
|                                  JOBFREELISTSIZE ); |                                  JOBFREELISTSIZE ); | ||||||
|         assert( retCode == 0 ); |         assert( retCode == 0 ); | ||||||
|  |  | ||||||
|         STATSONLY( StatsInit( &tp->stats ) ); |         STATSONLY( StatsInit( &tp->stats ); ) | ||||||
|  |  | ||||||
|         retCode += ListInit( &tp->highJobQ, CmpThreadPoolJob, NULL ); |         retCode += ListInit( &tp->highJobQ, CmpThreadPoolJob, NULL ); | ||||||
|         assert( retCode == 0 ); |         assert( retCode == 0 ); | ||||||
|   | |||||||
							
								
								
									
										139
									
								
								upnp/Makefile.am
									
									
									
									
									
								
							
							
						
						
									
										139
									
								
								upnp/Makefile.am
									
									
									
									
									
								
							| @@ -1,13 +1,14 @@ | |||||||
| # $Id: Makefile.am,v 1.10 2006/04/08 15:22:22 r3mi Exp $ |  | ||||||
| # | # | ||||||
| # "Makefile.am" for "libupnp/upnp" | # "Makefile.am" for "libupnp/upnp" | ||||||
| # | # | ||||||
| # Copyright (C) 2005 R<>mi Turboult <r3mi@users.sourceforge.net> | # Copyright (C) 2005 R<>mi Turboult <r3mi@users.sourceforge.net> | ||||||
| # | # | ||||||
|  |  | ||||||
| SUBDIRS 		= doc | SUBDIRS = doc . sample | ||||||
|  |  | ||||||
| AM_CPPFLAGS		= -I$(srcdir)/inc \ | AM_CPPFLAGS = \ | ||||||
|  | 	-I$(srcdir)/inc \ | ||||||
| 	-I$(top_srcdir)/threadutil/inc \ | 	-I$(top_srcdir)/threadutil/inc \ | ||||||
| 	-I$(top_srcdir)/ixml/inc | 	-I$(top_srcdir)/ixml/inc | ||||||
|  |  | ||||||
| @@ -15,7 +16,8 @@ AM_CFLAGS		= $(PTHREAD_CFLAGS) | |||||||
|  |  | ||||||
| AM_LDFLAGS = $(PTHREAD_LIBS) | AM_LDFLAGS = $(PTHREAD_LIBS) | ||||||
|  |  | ||||||
| LDADD			= libupnp.la \ | LDADD = \ | ||||||
|  | 	libupnp.la \ | ||||||
| 	$(top_builddir)/threadutil/libthreadutil.la \ | 	$(top_builddir)/threadutil/libthreadutil.la \ | ||||||
| 	$(top_builddir)/ixml/libixml.la | 	$(top_builddir)/ixml/libixml.la | ||||||
|  |  | ||||||
| @@ -30,40 +32,63 @@ if ENABLE_DEBUG | |||||||
| upnpinclude_HEADERS += inc/upnpdebug.h | upnpinclude_HEADERS += inc/upnpdebug.h | ||||||
| endif | endif | ||||||
|  |  | ||||||
|  |  | ||||||
| lib_LTLIBRARIES = libupnp.la | lib_LTLIBRARIES = libupnp.la | ||||||
|  |  | ||||||
| libupnp_la_CPPFLAGS = $(AM_CPPFLAGS) -I$(srcdir)/src/inc  | libupnp_la_CPPFLAGS = $(AM_CPPFLAGS) -I$(srcdir)/src/inc  | ||||||
| libupnp_la_LDFLAGS	= -version-info $(LT_VERSION_UPNP) \ |  | ||||||
|  | libupnp_la_LDFLAGS = \ | ||||||
|  | 	-version-info $(LT_VERSION_UPNP) \ | ||||||
| 	-export-symbols-regex '^Upnp.*' \ | 	-export-symbols-regex '^Upnp.*' \ | ||||||
| 	$(top_builddir)/threadutil/libthreadutil.la \ | 	$(top_builddir)/threadutil/libthreadutil.la \ | ||||||
| 	$(top_builddir)/ixml/libixml.la | 	$(top_builddir)/ixml/libixml.la | ||||||
|  |  | ||||||
| libupnp_la_SOURCES = \ | libupnp_la_SOURCES = \ | ||||||
| 	src/inc/config.h \ | 	src/inc/config.h \ | ||||||
| 			src/inc/client_table.h src/inc/global.h \ | 	src/inc/client_table.h \ | ||||||
| 			src/inc/md5.h src/inc/ssdplib.h \ | 	src/inc/gena.h \ | ||||||
| 			src/inc/unixutil.h src/inc/urlconfig.h \ | 	src/inc/gena_ctrlpt.h \ | ||||||
| 			src/inc/gmtdate.h src/inc/membuffer.h \ | 	src/inc/gena_device.h \ | ||||||
| 			src/inc/server.h src/inc/statcodes.h \ | 	src/inc/global.h \ | ||||||
| 			src/inc/upnpapi.h src/inc/utilall.h \ | 	src/inc/gmtdate.h \ | ||||||
| 			src/inc/gena_ctrlpt.h src/inc/http_client.h \ | 	src/inc/http_client.h \ | ||||||
| 			src/inc/miniserver.h src/inc/service_table.h \ | 	src/inc/httpparser.h \ | ||||||
| 			src/inc/statuscodes.h src/inc/upnpclosesocket.h \ | 	src/inc/httpreadwrite.h \ | ||||||
| 			src/inc/util.h src/inc/gena_device.h \ | 	src/inc/md5.h \ | ||||||
| 			src/inc/httpparser.h src/inc/netall.h \ | 	src/inc/membuffer.h \ | ||||||
| 			src/inc/soaplib.h src/inc/strintmap.h \ | 	src/inc/miniserver.h \ | ||||||
| 			src/inc/upnp_timeout.h src/inc/uuid.h \ | 	src/inc/netall.h \ | ||||||
| 			src/inc/gena.h src/inc/httpreadwrite.h \ | 	src/inc/parsetools.h \ | ||||||
| 			src/inc/parsetools.h src/inc/sock.h \ | 	src/inc/server.h \ | ||||||
| 			src/inc/sysdep.h src/inc/uri.h \ | 	src/inc/service_table.h \ | ||||||
|  | 	src/inc/soaplib.h \ | ||||||
|  | 	src/inc/sock.h \ | ||||||
|  | 	src/inc/statcodes.h \ | ||||||
|  | 	src/inc/statuscodes.h \ | ||||||
|  | 	src/inc/strintmap.h \ | ||||||
|  | 	src/inc/ssdplib.h \ | ||||||
|  | 	src/inc/sysdep.h \ | ||||||
|  | 	src/inc/unixutil.h \ | ||||||
|  | 	src/inc/upnpapi.h \ | ||||||
|  | 	src/inc/upnpclosesocket.h \ | ||||||
|  | 	src/inc/upnp_timeout.h \ | ||||||
|  | 	src/inc/uri.h \ | ||||||
|  | 	src/inc/urlconfig.h \ | ||||||
|  | 	src/inc/util.h \ | ||||||
|  | 	src/inc/utilall.h \ | ||||||
|  | 	src/inc/uuid.h \ | ||||||
| 	src/inc/webserver.h | 	src/inc/webserver.h | ||||||
|  |  | ||||||
| # ssdp | # ssdp | ||||||
| libupnp_la_SOURCES	+= src/ssdp/ssdp_device.c src/ssdp/ssdp_ctrlpt.c \ | libupnp_la_SOURCES += \ | ||||||
|  | 	src/ssdp/ssdp_device.c \ | ||||||
|  | 	src/ssdp/ssdp_ctrlpt.c \ | ||||||
| 	src/ssdp/ssdp_server.c | 	src/ssdp/ssdp_server.c | ||||||
|  |  | ||||||
| # soap | # soap | ||||||
| libupnp_la_SOURCES	+= src/soap/soap_device.c src/soap/soap_ctrlpt.c \ | libupnp_la_SOURCES += \ | ||||||
|  | 	src/soap/soap_device.c \ | ||||||
|  | 	src/soap/soap_ctrlpt.c \ | ||||||
| 	src/soap/soap_common.c | 	src/soap/soap_common.c | ||||||
|  |  | ||||||
| # genlib | # genlib | ||||||
| @@ -84,80 +109,46 @@ libupnp_la_SOURCES	+= \ | |||||||
| 	src/genlib/net/uri/uri.c | 	src/genlib/net/uri/uri.c | ||||||
|  |  | ||||||
| # gena | # gena | ||||||
| libupnp_la_SOURCES	+= src/gena/gena_device.c src/gena/gena_ctrlpt.c \ | libupnp_la_SOURCES += \ | ||||||
|  | 	src/gena/gena_device.c \ | ||||||
|  | 	src/gena/gena_ctrlpt.c \ | ||||||
| 	src/gena/gena_callback2.c | 	src/gena/gena_callback2.c | ||||||
|  |  | ||||||
| # api | # api | ||||||
| libupnp_la_SOURCES += src/api/upnpapi.c | libupnp_la_SOURCES += src/api/upnpapi.c | ||||||
| if ENABLE_TOOLS | if ENABLE_TOOLS | ||||||
|     libupnp_la_SOURCES	+= src/api/upnptools.c | libupnp_la_SOURCES += src/api/upnptools.c | ||||||
| endif | endif | ||||||
| if ENABLE_DEBUG | if ENABLE_DEBUG | ||||||
|     libupnp_la_SOURCES	+= src/api/upnpdebug.c  | libupnp_la_SOURCES += src/api/upnpdebug.c  | ||||||
| endif | endif | ||||||
|  |  | ||||||
|  |  | ||||||
| # uuid | # uuid | ||||||
| libupnp_la_SOURCES	+= src/uuid/md5.c src/uuid/sysdep.c src/uuid/uuid.c | libupnp_la_SOURCES += \ | ||||||
|  | 	src/uuid/md5.c \ | ||||||
|  | 	src/uuid/sysdep.c \ | ||||||
|  | 	src/uuid/uuid.c | ||||||
|  |  | ||||||
|  |  | ||||||
| # urlconfig | # urlconfig | ||||||
| libupnp_la_SOURCES += src/urlconfig/urlconfig.c | libupnp_la_SOURCES += src/urlconfig/urlconfig.c | ||||||
|  |  | ||||||
|  |  | ||||||
| # samples |  | ||||||
| noinst_PROGRAMS		= |  | ||||||
| if ENABLE_SAMPLES |  | ||||||
| if ENABLE_CLIENT |  | ||||||
|     noinst_PROGRAMS	+= upnp_tv_ctrlpt |  | ||||||
|     upnp_tv_ctrlpt_CPPFLAGS = $(AM_CPPFLAGS) \ |  | ||||||
| 			-I$(srcdir)/sample/common/ \ |  | ||||||
| 			-I$(srcdir)/sample/tvctrlpt |  | ||||||
| endif |  | ||||||
| if ENABLE_DEVICE |  | ||||||
|     noinst_PROGRAMS	+= upnp_tv_device  |  | ||||||
|     upnp_tv_device_CPPFLAGS = $(AM_CPPFLAGS) \ |  | ||||||
| 			-I$(srcdir)/sample/common/ \ |  | ||||||
| 			-I$(srcdir)/sample/tvdevice |  | ||||||
| endif |  | ||||||
| endif |  | ||||||
| upnp_tv_device_SOURCES = \ |  | ||||||
| 			sample/common/sample_util.c \ |  | ||||||
| 			sample/common/sample_util.h \ |  | ||||||
| 			sample/tvdevice/upnp_tv_device.c \ |  | ||||||
| 			sample/tvdevice/upnp_tv_device.h \ |  | ||||||
| 			sample/tvdevice/linux/upnp_tv_device_main.c |  | ||||||
| upnp_tv_ctrlpt_SOURCES = \ |  | ||||||
| 			sample/common/sample_util.c \ |  | ||||||
| 			sample/common/sample_util.h \ |  | ||||||
| 			sample/tvctrlpt/upnp_tv_ctrlpt.c \ |  | ||||||
| 			sample/tvctrlpt/upnp_tv_ctrlpt.h \ |  | ||||||
| 			sample/tvctrlpt/linux/upnp_tv_ctrlpt_main.c |  | ||||||
|  |  | ||||||
| if WITH_DOCUMENTATION |  | ||||||
|     examplesdir 	= $(docdir)/examples |  | ||||||
|     examples_DATA 	= $(upnp_tv_ctrlpt_SOURCES) $(upnp_tv_device_SOURCES) |  | ||||||
| endif |  | ||||||
|  |  | ||||||
|  |  | ||||||
| # check / distcheck tests | # check / distcheck tests | ||||||
| check_PROGRAMS = test_init | check_PROGRAMS = test_init | ||||||
| TESTS = test_init | TESTS = test_init | ||||||
|  |  | ||||||
| test_init_SOURCES = test/test_init.c | test_init_SOURCES = test/test_init.c | ||||||
|  |  | ||||||
|  |  | ||||||
| EXTRA_DIST 		= LICENSE \ | EXTRA_DIST = \ | ||||||
| 			sample/tvdevice/web/tvcontrolSCPD.xml \ | 	LICENSE \ | ||||||
| 			sample/tvdevice/web/tvdevicedesc.xml \ |  | ||||||
| 			sample/tvdevice/web/tvdevicepres.html \ |  | ||||||
| 			sample/tvdevice/web/tvpictureSCPD.xml \ |  | ||||||
| 	src/inc/inet_pton.h \ | 	src/inc/inet_pton.h \ | ||||||
| 	src/inet_pton.c \ | 	src/inet_pton.c \ | ||||||
| 	src/win_dll.c | 	src/win_dll.c | ||||||
|  |  | ||||||
|  |  | ||||||
|  | CLEANFILES = \ | ||||||
| CLEANFILES		= IUpnpErrFile.txt IUpnpInfoFile.txt | 	IUpnpErrFile.txt \ | ||||||
|  | 	IUpnpInfoFile.txt | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|   | |||||||
| @@ -2,7 +2,7 @@ | |||||||
| # | # | ||||||
| # "Makefile.am" for "libunp/upnp/doc"  | # "Makefile.am" for "libunp/upnp/doc"  | ||||||
| # | # | ||||||
| # (C) Copyright 2005 R<>mi Turboult <r3mi@users.sourceforge.net> | # (C) Copyright 2005 R<>mi Turboult <r3mi@users.sourceforge.net> | ||||||
| # | # | ||||||
| ########################################################################## | ########################################################################## | ||||||
| # | # | ||||||
|   | |||||||
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										389
									
								
								upnp/inc/upnp.h
									
									
									
									
									
								
							
							
						
						
									
										389
									
								
								upnp/inc/upnp.h
									
									
									
									
									
								
							| @@ -1,40 +1,41 @@ | |||||||
| /////////////////////////////////////////////////////////////////////////// | /******************************************************************************* | ||||||
| // |  * | ||||||
| // Copyright (c) 2000-2003 Intel Corporation  |  * Copyright (c) 2000-2003 Intel Corporation  | ||||||
| // All rights reserved.  |  * All rights reserved.  | ||||||
| // |  * | ||||||
| // Redistribution and use in source and binary forms, with or without  |  * Redistribution and use in source and binary forms, with or without  | ||||||
| // modification, are permitted provided that the following conditions are met:  |  * modification, are permitted provided that the following conditions are met:  | ||||||
| // |  * | ||||||
| // * Redistributions of source code must retain the above copyright notice,  |  * * Redistributions of source code must retain the above copyright notice,  | ||||||
| // this list of conditions and the following disclaimer.  |  * this list of conditions and the following disclaimer.  | ||||||
| // * Redistributions in binary form must reproduce the above copyright notice,  |  * * Redistributions in binary form must reproduce the above copyright notice,  | ||||||
| // this list of conditions and the following disclaimer in the documentation  |  * this list of conditions and the following disclaimer in the documentation  | ||||||
| // and/or other materials provided with the distribution.  |  * and/or other materials provided with the distribution.  | ||||||
| // * Neither name of Intel Corporation nor the names of its contributors  |  * * Neither name of Intel Corporation nor the names of its contributors  | ||||||
| // may be used to endorse or promote products derived from this software  |  * may be used to endorse or promote products derived from this software  | ||||||
| // without specific prior written permission. |  * without specific prior written permission. | ||||||
| //  |  *  | ||||||
| // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS  |  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS  | ||||||
| // "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT  |  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT  | ||||||
| // LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR  |  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR  | ||||||
| // A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL INTEL OR  |  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL INTEL OR  | ||||||
| // CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,  |  * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,  | ||||||
| // EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,  |  * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,  | ||||||
| // PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR  |  * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR  | ||||||
| // PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY  |  * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY  | ||||||
| // OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING |  * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING | ||||||
| // NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS  |  * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS  | ||||||
| // SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |  * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||||
| // |  * | ||||||
| /////////////////////////////////////////////////////////////////////////// |  ******************************************************************************/ | ||||||
|  |  | ||||||
| #ifndef UPNP_H | #ifndef UPNP_H | ||||||
| #define UPNP_H | #define UPNP_H | ||||||
|  |  | ||||||
| /** @name The API */ | /** @name The API */ | ||||||
|  |  | ||||||
| //@{ | /*! @{ */ | ||||||
|  |  | ||||||
|  |  | ||||||
| #if defined MYLIB_LARGEFILE_SENSITIVE && _FILE_OFFSET_BITS+0 != 64 | #if defined MYLIB_LARGEFILE_SENSITIVE && _FILE_OFFSET_BITS+0 != 64 | ||||||
| 	#if defined __GNUC__ | 	#if defined __GNUC__ | ||||||
| @@ -44,20 +45,19 @@ | |||||||
| 	#endif | 	#endif | ||||||
| #endif  | #endif  | ||||||
|  |  | ||||||
|  |  | ||||||
| #include <stdio.h> | #include <stdio.h> | ||||||
| #ifdef __FreeBSD__ | #ifdef __FreeBSD__ | ||||||
| #include <time.h> | 	#include <time.h> | ||||||
| #endif | #endif | ||||||
| #include "ixml.h" | #include "ixml.h" | ||||||
| #include "upnpconfig.h" | #include "upnpconfig.h" | ||||||
| #if UPNP_HAVE_DEBUG |  | ||||||
| #	include "upnpdebug.h" |  | ||||||
| #endif |  | ||||||
|  |  | ||||||
| #ifdef WIN32 | #ifdef WIN32 | ||||||
| 	#ifndef UPNP_STATIC_LIB | 	#ifndef UPNP_STATIC_LIB | ||||||
| 		#ifdef LIBUPNP_EXPORTS | 		#ifdef LIBUPNP_EXPORTS | ||||||
|    // set up declspec for dll export to make functions visible to library users | 			/* set up declspec for dll export to make functions visible to library users */ | ||||||
| 			#define EXPORT_SPEC __declspec(dllexport) | 			#define EXPORT_SPEC __declspec(dllexport) | ||||||
| 		#else | 		#else | ||||||
| 			#define EXPORT_SPEC __declspec(dllimport) | 			#define EXPORT_SPEC __declspec(dllimport) | ||||||
| @@ -65,16 +65,36 @@ | |||||||
| 	#else | 	#else | ||||||
| 		#define EXPORT_SPEC | 		#define EXPORT_SPEC | ||||||
| 	#endif | 	#endif | ||||||
|  #ifdef UPNP_USE_MSVCPP // define some things the M$ VC++ doesn't knows | 	#ifdef UPNP_USE_MSVCPP | ||||||
|  | 		/* define some things the M$ VC++ doesn't know */ | ||||||
|  | 		#define UPNP_INLINE | ||||||
| 		typedef __int64 int64_t; | 		typedef __int64 int64_t; | ||||||
|  | 		#define PRId64 "I64d" | ||||||
|  | 		#define PRIzu "lu" | ||||||
| 	#endif | 	#endif | ||||||
|  #ifdef UPNP_USE_BCBPP // define some things Borland Builder doesn't knows | 	#ifdef UPNP_USE_BCBPP | ||||||
|  | 		/* define some things Borland Builder doesn't know */ | ||||||
|  | 		#define UPNP_INLINE inline | ||||||
| 		typedef __int64 int64_t; | 		typedef __int64 int64_t; | ||||||
|  | #warning The Borland C compiler is probably broken on PRId64, please someone provide a proper fix here | ||||||
|  | 		#define PRId64 "I64d" | ||||||
|  | 		#define PRIzu "zu" | ||||||
| 	#endif | 	#endif | ||||||
| #else | #else | ||||||
| 	#define EXPORT_SPEC | 	#define EXPORT_SPEC | ||||||
|  | 	#define UPNP_INLINE inline | ||||||
|  | 	/* Invented this macro so that we can live a little longer with MSVC lack of C99. */ | ||||||
|  | 	#define PRIzu "zu" | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  | /* | ||||||
|  |  * Defining this macro here gives some interesting information about unused | ||||||
|  |  * functions in the code. Of course, this should never go uncommented on a | ||||||
|  |  * release. | ||||||
|  |  */ | ||||||
|  | /*#define inline*/ | ||||||
|  |  | ||||||
|  |  | ||||||
| #ifndef WIN32 | #ifndef WIN32 | ||||||
| 	#define UpnpCloseSocket close | 	#define UpnpCloseSocket close | ||||||
| #else | #else | ||||||
| @@ -87,6 +107,7 @@ | |||||||
| 	#define SOCKET int | 	#define SOCKET int | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  |  | ||||||
| #ifndef WIN32 | #ifndef WIN32 | ||||||
| 	#include <netinet/in.h> | 	#include <netinet/in.h> | ||||||
| #else | #else | ||||||
| @@ -94,8 +115,10 @@ | |||||||
| 	#include <time.h> | 	#include <time.h> | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  |  | ||||||
| #include <sys/types.h> | #include <sys/types.h> | ||||||
|  |  | ||||||
|  |  | ||||||
| #define NUM_HANDLE 200 | #define NUM_HANDLE 200 | ||||||
| #define LINE_SIZE  180 | #define LINE_SIZE  180 | ||||||
| #define NAME_SIZE  256 | #define NAME_SIZE  256 | ||||||
| @@ -104,7 +127,6 @@ | |||||||
| #define SERL_NUMR_SIZE  64 | #define SERL_NUMR_SIZE  64 | ||||||
| #define MODL_DESC_SIZE  64 | #define MODL_DESC_SIZE  64 | ||||||
| #define UPNP_INFINITE -1 | #define UPNP_INFINITE -1 | ||||||
|  |  | ||||||
| #define UPNP_USING_CHUNKED			-3 | #define UPNP_USING_CHUNKED			-3 | ||||||
| #define UPNP_UNTIL_CLOSE			-4 | #define UPNP_UNTIL_CLOSE			-4 | ||||||
|  |  | ||||||
| @@ -116,7 +138,7 @@ | |||||||
|  *  code means.  Refer to the documentation for each function for a  |  *  code means.  Refer to the documentation for each function for a  | ||||||
|  *  description of what an error code means in that context. |  *  description of what an error code means in that context. | ||||||
|  */ |  */ | ||||||
| //@{ | /*! @{ */ | ||||||
|  |  | ||||||
| /** @name UPNP_E_SUCCESS [0] | /** @name UPNP_E_SUCCESS [0] | ||||||
|  *  {\tt UPNP_E_SUCCESS} signifies that the operation completed successfully. |  *  {\tt UPNP_E_SUCCESS} signifies that the operation completed successfully. | ||||||
| @@ -124,35 +146,35 @@ | |||||||
|  *  the operation was successfully transmitted on the network.  The result of  |  *  the operation was successfully transmitted on the network.  The result of  | ||||||
|  *  the entire operation comes as part of the callback for that operation. |  *  the entire operation comes as part of the callback for that operation. | ||||||
|  */ |  */ | ||||||
| //@{ | /*! @{ */ | ||||||
| #define UPNP_E_SUCCESS          0 | #define UPNP_E_SUCCESS          0 | ||||||
| //@} | /*! @} */ | ||||||
|  |  | ||||||
| /** @name UPNP_E_INVALID_HANDLE [-100] | /** @name UPNP_E_INVALID_HANDLE [-100] | ||||||
|  *  {\tt UPNP_E_INVALID_HANDLE} signifies that the handle passed to a  |  *  {\tt UPNP_E_INVALID_HANDLE} signifies that the handle passed to a  | ||||||
|  *  function is not a recognized as a valid handle. |  *  function is not a recognized as a valid handle. | ||||||
|  */ |  */ | ||||||
| //@{ | /*! @{ */ | ||||||
| #define UPNP_E_INVALID_HANDLE   -100 | #define UPNP_E_INVALID_HANDLE   -100 | ||||||
| //@} | /*! @} */ | ||||||
|  |  | ||||||
| /** @name UPNP_E_INVALID_PARAM [-101] | /** @name UPNP_E_INVALID_PARAM [-101] | ||||||
|  *  {\tt UPNP_E_INVALID_PARAM} signifies that one or more of the parameters  |  *  {\tt UPNP_E_INVALID_PARAM} signifies that one or more of the parameters  | ||||||
|  *  passed to the function is not valid.  Refer to the documentation for each  |  *  passed to the function is not valid.  Refer to the documentation for each  | ||||||
|  *  function for more information on the valid ranges of the parameters. |  *  function for more information on the valid ranges of the parameters. | ||||||
|  */ |  */ | ||||||
| //@{ | /*! @{ */ | ||||||
| #define UPNP_E_INVALID_PARAM    -101 | #define UPNP_E_INVALID_PARAM    -101 | ||||||
| //@} | /*! @} */ | ||||||
|  |  | ||||||
| /** @name UPNP_E_OUTOF_HANDLE [-102] | /** @name UPNP_E_OUTOF_HANDLE [-102] | ||||||
|  *  {\tt UPNP_E_OUTOF_HANDLE} signifies that the SDK does not have any |  *  {\tt UPNP_E_OUTOF_HANDLE} signifies that the SDK does not have any | ||||||
|  *  more space for additional handles.  The SDK allocates space for only  |  *  more space for additional handles.  The SDK allocates space for only  | ||||||
|  *  a few handles in order to conserve memory. |  *  a few handles in order to conserve memory. | ||||||
|  */ |  */ | ||||||
| //@{ | /*! @{ */ | ||||||
| #define UPNP_E_OUTOF_HANDLE     -102 | #define UPNP_E_OUTOF_HANDLE     -102 | ||||||
| //@} | /*! @} */ | ||||||
|  |  | ||||||
| #define UPNP_E_OUTOF_CONTEXT    -103 | #define UPNP_E_OUTOF_CONTEXT    -103 | ||||||
|  |  | ||||||
| @@ -161,9 +183,9 @@ | |||||||
|  *  currently available to complete the operation.  Most operations require  |  *  currently available to complete the operation.  Most operations require  | ||||||
|  *  some free memory in order to complete their work. |  *  some free memory in order to complete their work. | ||||||
|  */ |  */ | ||||||
| //@{ | /*! @{ */ | ||||||
| #define UPNP_E_OUTOF_MEMORY     -104 | #define UPNP_E_OUTOF_MEMORY     -104 | ||||||
| //@} | /*! @} */ | ||||||
|  |  | ||||||
| /** @name UPNP_E_INIT [-105] | /** @name UPNP_E_INIT [-105] | ||||||
|  *  {\tt UPNP_E_INIT} signifies that the SDK has already been  |  *  {\tt UPNP_E_INIT} signifies that the SDK has already been  | ||||||
| @@ -171,9 +193,9 @@ | |||||||
|  *  Any additional initialization attempts simply return this error with |  *  Any additional initialization attempts simply return this error with | ||||||
|  *  no other ill effects. |  *  no other ill effects. | ||||||
|  */ |  */ | ||||||
| //@{ | /*! @{ */ | ||||||
| #define UPNP_E_INIT             -105 | #define UPNP_E_INIT             -105 | ||||||
| //@} | /*! @} */ | ||||||
|  |  | ||||||
| #define UPNP_E_BUFFER_TOO_SMALL -106 | #define UPNP_E_BUFFER_TOO_SMALL -106 | ||||||
|  |  | ||||||
| @@ -182,9 +204,9 @@ | |||||||
|  *  to {\bf UpnpRegisterRootDevice} or {\bf UpnpRegisterRootDevice2} is an  |  *  to {\bf UpnpRegisterRootDevice} or {\bf UpnpRegisterRootDevice2} is an  | ||||||
|  *  invalid description document.   |  *  invalid description document.   | ||||||
|  */ |  */ | ||||||
| //@{ | /*! @{ */ | ||||||
| #define UPNP_E_INVALID_DESC     -107 | #define UPNP_E_INVALID_DESC     -107 | ||||||
| //@} | /*! @} */ | ||||||
|  |  | ||||||
| /** @name UPNP_E_INVALID_URL [-108] | /** @name UPNP_E_INVALID_URL [-108] | ||||||
|  *  {\tt UPNP_E_INVALID_URL} signifies that a URL passed into the function |  *  {\tt UPNP_E_INVALID_URL} signifies that a URL passed into the function | ||||||
| @@ -192,9 +214,9 @@ | |||||||
|  *  URL itself might be malformed (e.g. have invalid characters in it) or |  *  URL itself might be malformed (e.g. have invalid characters in it) or | ||||||
|  *  the host might be unreachable. |  *  the host might be unreachable. | ||||||
|  */ |  */ | ||||||
| //@{ | /*! @{ */ | ||||||
| #define UPNP_E_INVALID_URL      -108 | #define UPNP_E_INVALID_URL      -108 | ||||||
| //@} | /*! @} */ | ||||||
|  |  | ||||||
| #define UPNP_E_INVALID_SID      -109 | #define UPNP_E_INVALID_SID      -109 | ||||||
| #define UPNP_E_INVALID_DEVICE   -110 | #define UPNP_E_INVALID_DEVICE   -110 | ||||||
| @@ -205,18 +227,18 @@ | |||||||
|  *  {\bf UpnpAcceptSubscriptionExt} to signify that the device ID/service |  *  {\bf UpnpAcceptSubscriptionExt} to signify that the device ID/service | ||||||
|  *  ID pair does not refer to a valid service. |  *  ID pair does not refer to a valid service. | ||||||
|  */ |  */ | ||||||
| //@{ | /*! @{ */ | ||||||
| #define UPNP_E_INVALID_SERVICE  -111 | #define UPNP_E_INVALID_SERVICE  -111 | ||||||
| //@} | /*! @} */ | ||||||
|  |  | ||||||
| /** @name UPNP_E_BAD_RESPONSE [-113] | /** @name UPNP_E_BAD_RESPONSE [-113] | ||||||
|  *  {\tt UPNP_E_BAD_RESPONSE} signifies that the response received from the  |  *  {\tt UPNP_E_BAD_RESPONSE} signifies that the response received from the  | ||||||
|  *  remote side of a connection is not correct for the protocol.  This applies |  *  remote side of a connection is not correct for the protocol.  This applies | ||||||
|  *  to the GENA, SOAP, and HTTP protocols. |  *  to the GENA, SOAP, and HTTP protocols. | ||||||
|  */ |  */ | ||||||
| //@{ | /*! @{ */ | ||||||
| #define UPNP_E_BAD_RESPONSE     -113 | #define UPNP_E_BAD_RESPONSE     -113 | ||||||
| //@} | /*! @} */ | ||||||
|  |  | ||||||
| #define UPNP_E_BAD_REQUEST      -114 | #define UPNP_E_BAD_REQUEST      -114 | ||||||
|  |  | ||||||
| @@ -225,26 +247,26 @@ | |||||||
|  *  invalid.  This can be because the DOM document passed to the function was |  *  invalid.  This can be because the DOM document passed to the function was | ||||||
|  *  malformed or the action message is not correct for the given action. |  *  malformed or the action message is not correct for the given action. | ||||||
|  */ |  */ | ||||||
| //@{ | /*! @{ */ | ||||||
| #define UPNP_E_INVALID_ACTION   -115 | #define UPNP_E_INVALID_ACTION   -115 | ||||||
| //@} | /*! @} */ | ||||||
|  |  | ||||||
| /** @name UPNP_E_FINISH [-116] | /** @name UPNP_E_FINISH [-116] | ||||||
|  *  {\tt UPNP_E_FINISH} signifies that {\bf UpnpInit} has not been called, or |  *  {\tt UPNP_E_FINISH} signifies that {\bf UpnpInit} has not been called, or | ||||||
|  *  that {\bf UpnpFinish} has already been called.  None of the API functions  |  *  that {\bf UpnpFinish} has already been called.  None of the API functions  | ||||||
|  *  operate until {\bf UpnpInit} successfully completes. |  *  operate until {\bf UpnpInit} successfully completes. | ||||||
|  */ |  */ | ||||||
| //@{ | /*! @{ */ | ||||||
| #define UPNP_E_FINISH           -116 | #define UPNP_E_FINISH           -116 | ||||||
| //@} | /*! @} */ | ||||||
|  |  | ||||||
| /** @name UPNP_E_INIT_FAILED [-117] | /** @name UPNP_E_INIT_FAILED [-117] | ||||||
|  *  {\tt UPNP_E_INIT_FAILED} signifies that {\bf UpnpInit} cannot complete.   |  *  {\tt UPNP_E_INIT_FAILED} signifies that {\bf UpnpInit} cannot complete.   | ||||||
|  *  The typical reason is failure to allocate sufficient resources. |  *  The typical reason is failure to allocate sufficient resources. | ||||||
|  */ |  */ | ||||||
| //@{ | /*! @{ */ | ||||||
| #define UPNP_E_INIT_FAILED      -117 | #define UPNP_E_INIT_FAILED      -117 | ||||||
| //@} | /*! @} */ | ||||||
|  |  | ||||||
| /** @name UPNP_E_URL_TOO_BIG [-118] | /** @name UPNP_E_URL_TOO_BIG [-118] | ||||||
|  *  {\tt UPNP_E_URL_TOO_BIG} signifies that the URL passed into a function  |  *  {\tt UPNP_E_URL_TOO_BIG} signifies that the URL passed into a function  | ||||||
| @@ -260,18 +282,18 @@ | |||||||
|  *  message (e.g. {\bf UpnpSubscribe}), GENA event notifications (e.g. {\bf |  *  message (e.g. {\bf UpnpSubscribe}), GENA event notifications (e.g. {\bf | ||||||
|  *  UpnpNotify}), and HTTP transfers (e.g. {\bf UpnpDownloadXmlDoc}). |  *  UpnpNotify}), and HTTP transfers (e.g. {\bf UpnpDownloadXmlDoc}). | ||||||
|  */ |  */ | ||||||
| //@{ | /*! @{ */ | ||||||
| #define UPNP_E_BAD_HTTPMSG      -119 | #define UPNP_E_BAD_HTTPMSG      -119 | ||||||
| //@} | /*! @} */ | ||||||
|  |  | ||||||
| /** @name UPNP_E_ALREADY_REGISTERED [-120] | /** @name UPNP_E_ALREADY_REGISTERED [-120] | ||||||
|  *  {\tt UPNP_E_ALREADY_REGISTERED} signifies that a client or a device is |  *  {\tt UPNP_E_ALREADY_REGISTERED} signifies that a client or a device is | ||||||
|  *  already registered.  The SDK currently has a limit of one registered  |  *  already registered.  The SDK currently has a limit of one registered  | ||||||
|  *  client and one registered device per process. |  *  client and one registered device per process. | ||||||
|  */ |  */ | ||||||
| //@{ | /*! @{ */ | ||||||
| #define UPNP_E_ALREADY_REGISTERED -120 | #define UPNP_E_ALREADY_REGISTERED -120 | ||||||
| //@} | /*! @} */ | ||||||
|  |  | ||||||
| /** @name UPNP_E_NETWORK_ERROR [-200] | /** @name UPNP_E_NETWORK_ERROR [-200] | ||||||
|  *  {\tt UPNP_E_NETWORK_ERROR} signifies that a network error occurred.  It  |  *  {\tt UPNP_E_NETWORK_ERROR} signifies that a network error occurred.  It  | ||||||
| @@ -280,9 +302,9 @@ | |||||||
|  *  failed to read the local IP address or had problems configuring one of |  *  failed to read the local IP address or had problems configuring one of | ||||||
|  *  the sockets. |  *  the sockets. | ||||||
|  */ |  */ | ||||||
| //@{ | /*! @{ */ | ||||||
| #define UPNP_E_NETWORK_ERROR    -200 | #define UPNP_E_NETWORK_ERROR    -200 | ||||||
| //@} | /*! @} */ | ||||||
|  |  | ||||||
| /** @name UPNP_E_SOCKET_WRITE [-201] | /** @name UPNP_E_SOCKET_WRITE [-201] | ||||||
|  *  {\tt UPNP_E_SOCKET_WRITE} signifies an error writing to a socket.  This |  *  {\tt UPNP_E_SOCKET_WRITE} signifies an error writing to a socket.  This | ||||||
| @@ -291,9 +313,9 @@ | |||||||
|  *  control (e.g. {\bf UpnpSendAction}), eventing (e.g. {\bf UpnpNotify}),  |  *  control (e.g. {\bf UpnpSendAction}), eventing (e.g. {\bf UpnpNotify}),  | ||||||
|  *  and HTTP functions (e.g. {\bf UpnpDownloadXmlDoc}). |  *  and HTTP functions (e.g. {\bf UpnpDownloadXmlDoc}). | ||||||
|  */ |  */ | ||||||
| //@{ | /*! @{ */ | ||||||
| #define UPNP_E_SOCKET_WRITE     -201 | #define UPNP_E_SOCKET_WRITE     -201 | ||||||
| //@} | /*! @} */ | ||||||
|  |  | ||||||
| /** @name UPNP_E_SOCKET_READ [-202] | /** @name UPNP_E_SOCKET_READ [-202] | ||||||
|  *  {\tt UPNP_E_SOCKET_READ} signifies an error reading from a socket.  This |  *  {\tt UPNP_E_SOCKET_READ} signifies an error reading from a socket.  This | ||||||
| @@ -302,9 +324,9 @@ | |||||||
|  *  control (e.g. {\bf UpnpSendAction}), eventing (e.g. {\bf UpnpNotify}),  |  *  control (e.g. {\bf UpnpSendAction}), eventing (e.g. {\bf UpnpNotify}),  | ||||||
|  *  and HTTP functions (e.g. {\bf UpnpDownloadXmlDoc}). |  *  and HTTP functions (e.g. {\bf UpnpDownloadXmlDoc}). | ||||||
|  */ |  */ | ||||||
| //@{ | /*! @{ */ | ||||||
| #define UPNP_E_SOCKET_READ      -202 | #define UPNP_E_SOCKET_READ      -202 | ||||||
| //@} | /*! @} */ | ||||||
|  |  | ||||||
| /** @name UPNP_E_SOCKET_BIND [-203] | /** @name UPNP_E_SOCKET_BIND [-203] | ||||||
|  *  {\tt UPNP_E_SOCKET_BIND} signifies that the SDK had a problem binding |  *  {\tt UPNP_E_SOCKET_BIND} signifies that the SDK had a problem binding | ||||||
| @@ -314,9 +336,9 @@ | |||||||
|  *  (e.g. {\bf UpnpNotify}), and HTTP functions (e.g.  |  *  (e.g. {\bf UpnpNotify}), and HTTP functions (e.g.  | ||||||
|  *  {\bf UpnpDownloadXmlDoc}). |  *  {\bf UpnpDownloadXmlDoc}). | ||||||
|  */ |  */ | ||||||
| //@{ | /*! @{ */ | ||||||
| #define UPNP_E_SOCKET_BIND      -203 | #define UPNP_E_SOCKET_BIND      -203 | ||||||
| //@} | /*! @} */ | ||||||
|  |  | ||||||
| /** @name UPNP_E_SOCKET_CONNECT [-204] | /** @name UPNP_E_SOCKET_CONNECT [-204] | ||||||
|  *  {\tt UPNP_E_SOCKET_CONNECT} signifies that the SDK had a problem |  *  {\tt UPNP_E_SOCKET_CONNECT} signifies that the SDK had a problem | ||||||
| @@ -326,9 +348,9 @@ | |||||||
|  *  (e.g. {\bf UpnpNotify}), and HTTP functions (e.g.  |  *  (e.g. {\bf UpnpNotify}), and HTTP functions (e.g.  | ||||||
|  *  {\bf UpnpDownloadXmlDoc}). |  *  {\bf UpnpDownloadXmlDoc}). | ||||||
|  */ |  */ | ||||||
| //@{ | /*! @{ */ | ||||||
| #define UPNP_E_SOCKET_CONNECT   -204 | #define UPNP_E_SOCKET_CONNECT   -204 | ||||||
| //@} | /*! @} */ | ||||||
|  |  | ||||||
| /** @name UPNP_E_OUTOF_SOCKET [-205] | /** @name UPNP_E_OUTOF_SOCKET [-205] | ||||||
|  *  {\tt UPNP_E_OUTOF_SOCKET} signifies that the SDK cannot create any |  *  {\tt UPNP_E_OUTOF_SOCKET} signifies that the SDK cannot create any | ||||||
| @@ -338,36 +360,36 @@ | |||||||
|  *  (e.g. {\bf UpnpNotify}), and HTTP functions (e.g.  |  *  (e.g. {\bf UpnpNotify}), and HTTP functions (e.g.  | ||||||
|  *  {\bf UpnpDownloadXmlDoc}). |  *  {\bf UpnpDownloadXmlDoc}). | ||||||
|  */ |  */ | ||||||
| //@{ | /*! @{ */ | ||||||
| #define UPNP_E_OUTOF_SOCKET     -205 | #define UPNP_E_OUTOF_SOCKET     -205 | ||||||
| //@} | /*! @} */ | ||||||
|  |  | ||||||
| /** @name UPNP_E_LISTEN [-206] | /** @name UPNP_E_LISTEN [-206] | ||||||
|  *  {\tt UPNP_E_LISTEN} signifies that the SDK had a problem setting the |  *  {\tt UPNP_E_LISTEN} signifies that the SDK had a problem setting the | ||||||
|  *  socket to listen for incoming connections.  This error only happens during |  *  socket to listen for incoming connections.  This error only happens during | ||||||
|  *  initialization (i.e. {\bf UpnpInit}). |  *  initialization (i.e. {\bf UpnpInit}). | ||||||
|  */ |  */ | ||||||
| //@{ | /*! @{ */ | ||||||
| #define UPNP_E_LISTEN           -206 | #define UPNP_E_LISTEN           -206 | ||||||
| //@} | /*! @} */ | ||||||
|  |  | ||||||
| /** @name UPNP_E_TIMEDOUT [-207] | /** @name UPNP_E_TIMEDOUT [-207] | ||||||
|  *  {\tt UPNP_E_TIMEDOUT} signifies that too much time elapsed before the |  *  {\tt UPNP_E_TIMEDOUT} signifies that too much time elapsed before the | ||||||
|  *  required number of bytes were sent or received over a socket.  This error |  *  required number of bytes were sent or received over a socket.  This error | ||||||
|  *  can be returned by any function that performs network operations. |  *  can be returned by any function that performs network operations. | ||||||
|  */ |  */ | ||||||
| //@{ | /*! @{ */ | ||||||
| #define UPNP_E_TIMEDOUT         -207 | #define UPNP_E_TIMEDOUT         -207 | ||||||
| //@} | /*! @} */ | ||||||
|  |  | ||||||
| /** @name UPNP_E_SOCKET_ERROR [-208] | /** @name UPNP_E_SOCKET_ERROR [-208] | ||||||
|  *  {\tt UPNP_E_SOCKET_ERROR} is the generic socket error code for |  *  {\tt UPNP_E_SOCKET_ERROR} is the generic socket error code for | ||||||
|  *  conditions not covered by other error codes.  This error can be returned |  *  conditions not covered by other error codes.  This error can be returned | ||||||
|  *  by any function that performs network operations. |  *  by any function that performs network operations. | ||||||
|  */ |  */ | ||||||
| //@{ | /*! @{ */ | ||||||
| #define UPNP_E_SOCKET_ERROR	    -208 | #define UPNP_E_SOCKET_ERROR	    -208 | ||||||
| //@} | /*! @} */ | ||||||
|  |  | ||||||
| #define UPNP_E_FILE_WRITE_ERROR -209 | #define UPNP_E_FILE_WRITE_ERROR -209 | ||||||
|  |  | ||||||
| @@ -376,9 +398,9 @@ | |||||||
|  *  error can be returned by any function that allows for external |  *  error can be returned by any function that allows for external | ||||||
|  *  cancelation. |  *  cancelation. | ||||||
|  */ |  */ | ||||||
| //@{ | /*! @{ */ | ||||||
| #define UPNP_E_CANCELED         -210 | #define UPNP_E_CANCELED         -210 | ||||||
| //@} | /*! @} */ | ||||||
|  |  | ||||||
| #define UPNP_E_EVENT_PROTOCOL         -300 | #define UPNP_E_EVENT_PROTOCOL         -300 | ||||||
|  |  | ||||||
| @@ -386,58 +408,58 @@ | |||||||
|  *  {\tt UPNP_E_SUBSCRIBE_UNACCEPTED} signifies that a subscription |  *  {\tt UPNP_E_SUBSCRIBE_UNACCEPTED} signifies that a subscription | ||||||
|  *  request was rejected from the remote side.   |  *  request was rejected from the remote side.   | ||||||
|  */ |  */ | ||||||
| //@{ | /*! @{ */ | ||||||
| #define UPNP_E_SUBSCRIBE_UNACCEPTED   -301 | #define UPNP_E_SUBSCRIBE_UNACCEPTED   -301 | ||||||
| //@} | /*! @} */ | ||||||
|  |  | ||||||
| /** @name UPNP_E_UNSUBSCRIBE_UNACCAPTED [-302] | /** @name UPNP_E_UNSUBSCRIBE_UNACCAPTED [-302] | ||||||
|  *  {\tt UPNP_E_UNSUBSCRIBE_UNACCEPTED} signifies that an unsubscribe |  *  {\tt UPNP_E_UNSUBSCRIBE_UNACCEPTED} signifies that an unsubscribe | ||||||
|  *  request was rejected from the remote side. |  *  request was rejected from the remote side. | ||||||
|  */ |  */ | ||||||
| //@{ | /*! @{ */ | ||||||
| #define UPNP_E_UNSUBSCRIBE_UNACCEPTED -302 | #define UPNP_E_UNSUBSCRIBE_UNACCEPTED -302 | ||||||
| //@} | /*! @} */ | ||||||
|  |  | ||||||
| /** @name UPNP_E_NOTIFY_UNACCEPTED [-303] | /** @name UPNP_E_NOTIFY_UNACCEPTED [-303] | ||||||
|  *  {\tt UPNP_E_NOTIFY_UNACCEPTED} signifies that the remote host did not |  *  {\tt UPNP_E_NOTIFY_UNACCEPTED} signifies that the remote host did not | ||||||
|  *  accept the notify sent from the local device. |  *  accept the notify sent from the local device. | ||||||
|  */ |  */ | ||||||
| //@{ | /*! @{ */ | ||||||
| #define UPNP_E_NOTIFY_UNACCEPTED      -303 | #define UPNP_E_NOTIFY_UNACCEPTED      -303 | ||||||
| //@} | /*! @} */ | ||||||
|  |  | ||||||
| /** @name UPNP_E_INVALID_ARGUMENT [-501] | /** @name UPNP_E_INVALID_ARGUMENT [-501] | ||||||
|  *  {\tt UPNP_E_INVALID_ARGUMENT} signifies that one or more of the parameters |  *  {\tt UPNP_E_INVALID_ARGUMENT} signifies that one or more of the parameters | ||||||
|  *  passed to a function is invalid.  Refer to the individual function |  *  passed to a function is invalid.  Refer to the individual function | ||||||
|  *  descriptions for the acceptable ranges for parameters. |  *  descriptions for the acceptable ranges for parameters. | ||||||
|  */ |  */ | ||||||
| //@{ | /*! @{ */ | ||||||
| #define UPNP_E_INVALID_ARGUMENT       -501 | #define UPNP_E_INVALID_ARGUMENT       -501 | ||||||
| //@} | /*! @} */ | ||||||
|  |  | ||||||
| /** @name UPNP_E_FILE_NOT_FOUND [-502] | /** @name UPNP_E_FILE_NOT_FOUND [-502] | ||||||
|  *  {\tt UPNP_E_FILE_NOT_FOUND} signifies that the filename passed |  *  {\tt UPNP_E_FILE_NOT_FOUND} signifies that the filename passed | ||||||
|  *  to one of the device registration functions was not found or was not |  *  to one of the device registration functions was not found or was not | ||||||
|  *  accessible. |  *  accessible. | ||||||
|  */ |  */ | ||||||
| //@{ | /*! @{ */ | ||||||
| #define UPNP_E_FILE_NOT_FOUND         -502 | #define UPNP_E_FILE_NOT_FOUND         -502 | ||||||
| //@} | /*! @} */ | ||||||
|  |  | ||||||
| /** @name UPNP_E_FILE_READ_ERROR [-503] | /** @name UPNP_E_FILE_READ_ERROR [-503] | ||||||
|  *  {\tt UPNP_E_FILE_READ_ERROR} signifies an error when reading a file. |  *  {\tt UPNP_E_FILE_READ_ERROR} signifies an error when reading a file. | ||||||
|  */ |  */ | ||||||
| //@{ | /*! @{ */ | ||||||
| #define UPNP_E_FILE_READ_ERROR        -503 | #define UPNP_E_FILE_READ_ERROR        -503 | ||||||
| //@} | /*! @} */ | ||||||
|  |  | ||||||
| /** @name UPNP_E_EXT_NOT_XML [-504] | /** @name UPNP_E_EXT_NOT_XML [-504] | ||||||
|  *  {\tt UPNP_E_EXT_NOT_XML} signifies that the file name of the description |  *  {\tt UPNP_E_EXT_NOT_XML} signifies that the file name of the description | ||||||
|  *  document passed to {\bf UpnpRegisterRootDevice2} does not end in ".xml". |  *  document passed to {\bf UpnpRegisterRootDevice2} does not end in ".xml". | ||||||
|  */ |  */ | ||||||
| //@{ | /*! @{ */ | ||||||
| #define UPNP_E_EXT_NOT_XML            -504 | #define UPNP_E_EXT_NOT_XML            -504 | ||||||
| //@} | /*! @} */ | ||||||
|  |  | ||||||
| #define UPNP_E_NO_WEB_SERVER          -505 | #define UPNP_E_NO_WEB_SERVER          -505 | ||||||
| #define UPNP_E_OUTOF_BOUNDS	      -506 | #define UPNP_E_OUTOF_BOUNDS	      -506 | ||||||
| @@ -446,26 +468,26 @@ | |||||||
|  *  {\tt UPNP_E_NOT_FOUND} signifies that the response to a SOAP request |  *  {\tt UPNP_E_NOT_FOUND} signifies that the response to a SOAP request | ||||||
|  *  did not contain the required XML constructs.   |  *  did not contain the required XML constructs.   | ||||||
|  */ |  */ | ||||||
| //@{ | /*! @{ */ | ||||||
| #define UPNP_E_NOT_FOUND	      -507 | #define UPNP_E_NOT_FOUND	      -507 | ||||||
| //@} | /*! @} */ | ||||||
|  |  | ||||||
| /** @name UPNP_E_INTERNAL_ERROR [-911] | /** @name UPNP_E_INTERNAL_ERROR [-911] | ||||||
|  *  {\tt UPNP_E_INTERNAL_ERROR} is the generic error code for internal |  *  {\tt UPNP_E_INTERNAL_ERROR} is the generic error code for internal | ||||||
|  *  conditions not covered by other error codes. |  *  conditions not covered by other error codes. | ||||||
|  */ |  */ | ||||||
| //@{ | /*! @{ */ | ||||||
| #define UPNP_E_INTERNAL_ERROR         -911 | #define UPNP_E_INTERNAL_ERROR         -911 | ||||||
| //@} | /*! @} */ | ||||||
|  |  | ||||||
| // SOAP-related error codes | /* SOAP-related error codes */ | ||||||
| #define UPNP_SOAP_E_INVALID_ACTION    401 | #define UPNP_SOAP_E_INVALID_ACTION    401 | ||||||
| #define UPNP_SOAP_E_INVALID_ARGS      402 | #define UPNP_SOAP_E_INVALID_ARGS      402 | ||||||
| #define UPNP_SOAP_E_OUT_OF_SYNC       403 | #define UPNP_SOAP_E_OUT_OF_SYNC       403 | ||||||
| #define UPNP_SOAP_E_INVALID_VAR       404 | #define UPNP_SOAP_E_INVALID_VAR       404 | ||||||
| #define UPNP_SOAP_E_ACTION_FAILED     501 | #define UPNP_SOAP_E_ACTION_FAILED     501 | ||||||
|  |  | ||||||
| //@} | /*! @} */ | ||||||
|  |  | ||||||
| #ifndef OUT | #ifndef OUT | ||||||
| #define OUT | #define OUT | ||||||
| @@ -479,10 +501,12 @@ | |||||||
| #define INOUT | #define INOUT | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  | #include "upnpdebug.h" | ||||||
|  |  | ||||||
| enum UpnpOpenFileMode{UPNP_READ, UPNP_WRITE}; | enum UpnpOpenFileMode{UPNP_READ, UPNP_WRITE}; | ||||||
|  |  | ||||||
| /// @name Constants, Structures, and Types | /*! @name Constants, Structures, and Types */ | ||||||
| //@{ | /*! @{ */ | ||||||
|  |  | ||||||
| /** Returned when a control point application registers with {\bf | /** Returned when a control point application registers with {\bf | ||||||
|  *  UpnpRegisterClient}.  Client handles can only be used with  |  *  UpnpRegisterClient}.  Client handles can only be used with  | ||||||
| @@ -505,9 +529,9 @@ typedef int  UpnpDevice_Handle; | |||||||
|  |  | ||||||
| enum Upnp_EventType_e { | enum Upnp_EventType_e { | ||||||
|  |  | ||||||
|   // |   /* | ||||||
|   // Control callbacks |    * Control callbacks | ||||||
|   // |    */ | ||||||
|  |  | ||||||
|   /** Received by a device when a control point issues a control |   /** Received by a device when a control point issues a control | ||||||
|    *  request.  The {\bf Event} parameter contains a pointer to a {\bf |    *  request.  The {\bf Event} parameter contains a pointer to a {\bf | ||||||
| @@ -535,9 +559,9 @@ enum Upnp_EventType_e { | |||||||
|  |  | ||||||
|   UPNP_CONTROL_GET_VAR_COMPLETE, |   UPNP_CONTROL_GET_VAR_COMPLETE, | ||||||
|  |  | ||||||
|   // |   /* | ||||||
|   // Discovery callbacks |    * Discovery callbacks | ||||||
|   // |    */ | ||||||
|  |  | ||||||
|   /** Received by a control point when a new device or service is available.   |   /** Received by a control point when a new device or service is available.   | ||||||
|    *  The {\bf Event} parameter contains a pointer to a {\bf |    *  The {\bf Event} parameter contains a pointer to a {\bf | ||||||
| @@ -566,9 +590,9 @@ enum Upnp_EventType_e { | |||||||
|  |  | ||||||
|   UPNP_DISCOVERY_SEARCH_TIMEOUT, |   UPNP_DISCOVERY_SEARCH_TIMEOUT, | ||||||
|  |  | ||||||
|   // |   /* | ||||||
|   // Eventing callbacks |    * Eventing callbacks | ||||||
|   // |    */ | ||||||
|  |  | ||||||
|   /** Received by a device when a subscription arrives. |   /** Received by a device when a subscription arrives. | ||||||
|    *  The {\bf Event} parameter contains a pointer to a {\bf |    *  The {\bf Event} parameter contains a pointer to a {\bf | ||||||
| @@ -799,10 +823,10 @@ struct Upnp_Event | |||||||
|  |  | ||||||
| }; | }; | ||||||
|  |  | ||||||
| // | /* | ||||||
| // This typedef is required by Doc++ to parse the last entry of the  |  * This typedef is required by Doc++ to parse the last entry of the  | ||||||
| // Upnp_Discovery structure correctly. |  * Upnp_Discovery structure correctly. | ||||||
| // |  */ | ||||||
|  |  | ||||||
| typedef struct sockaddr_in SOCKADDRIN; | typedef struct sockaddr_in SOCKADDRIN; | ||||||
|  |  | ||||||
| @@ -1047,14 +1071,14 @@ typedef int  (*Upnp_FunPtr) ( | |||||||
|     IN void *Cookie |     IN void *Cookie | ||||||
|     ); |     ); | ||||||
|  |  | ||||||
| //@} // Constants, Structures, and Types | /*! @} */ /* Constants, Structures, and Types */ | ||||||
|  |  | ||||||
| #ifdef __cplusplus | #ifdef __cplusplus | ||||||
| extern "C" { | extern "C" { | ||||||
| #endif // __cplusplus | #endif /* __cplusplus */ | ||||||
|  |  | ||||||
| ///@name Initialization and Registration | /*! @name Initialization and Registration */ | ||||||
| //@{ | /*! @{ */ | ||||||
| /** Initializes the Linux SDK for UPnP Devices. This function must be called | /** Initializes the Linux SDK for UPnP Devices. This function must be called | ||||||
|  *  before any other API function can be called.  It should be called |  *  before any other API function can be called.  It should be called | ||||||
|  *  only once.  Subsequent calls to this API return a {\tt UPNP_E_INIT} |  *  only once.  Subsequent calls to this API return a {\tt UPNP_E_INIT} | ||||||
| @@ -1365,18 +1389,18 @@ EXPORT_SPEC int UpnpSetMaxContentLength( | |||||||
| 			           for incoming SOAP actions, in bytes. */ | 			           for incoming SOAP actions, in bytes. */ | ||||||
|     ); |     ); | ||||||
|  |  | ||||||
| //@} // Initialization and Registration | /*! @} */ /* Initialization and Registration */ | ||||||
|  |  | ||||||
| //////////////////////////////////////////////////////////////////////// | /****************************************************************************** | ||||||
| //////////////////////////////////////////////////////////////////////// |  ****************************************************************************** | ||||||
| //                                                                    // |  *                                                                            * | ||||||
| //                        D I S C O V E R Y                           // |  *                        D I S C O V E R Y                                   * | ||||||
| //                                                                    // |  *                                                                            * | ||||||
| //////////////////////////////////////////////////////////////////////// |  ****************************************************************************** | ||||||
| //////////////////////////////////////////////////////////////////////// |  ******************************************************************************/ | ||||||
|  |  | ||||||
| ///@name Discovery | /*! @name Discovery */ | ||||||
| //@{ | /*! @{ */ | ||||||
|  |  | ||||||
| /** {\bf UpnpSearchAsync} searches for devices matching the given | /** {\bf UpnpSearchAsync} searches for devices matching the given | ||||||
|  *  search target.  The function returns immediately and the SDK  |  *  search target.  The function returns immediately and the SDK  | ||||||
| @@ -1435,18 +1459,18 @@ EXPORT_SPEC int UpnpSendAdvertisement( | |||||||
|                                   the announcements. */ |                                   the announcements. */ | ||||||
|     ); |     ); | ||||||
|  |  | ||||||
| //@} // Discovery | /*! @} */ /* Discovery */ | ||||||
|  |  | ||||||
| //////////////////////////////////////////////////////////////////////// | /****************************************************************************** | ||||||
| //////////////////////////////////////////////////////////////////////// |  ****************************************************************************** | ||||||
| //                                                                    // |  *                                                                            * | ||||||
| //                            C O N T R O L                           // |  *                            C O N T R O L                                   * | ||||||
| //                                                                    // |  *                                                                            * | ||||||
| //////////////////////////////////////////////////////////////////////// |  ****************************************************************************** | ||||||
| //////////////////////////////////////////////////////////////////////// |  ******************************************************************************/ | ||||||
|  |  | ||||||
| ///@name Control | /*! @name Control */ | ||||||
| //@{ | /*! @{ */ | ||||||
|  |  | ||||||
| /** {\bf UpnpGetServiceVarStatus} queries the state of a state  | /** {\bf UpnpGetServiceVarStatus} queries the state of a state  | ||||||
|  *  variable of a service on another device.  This is a synchronous call. |  *  variable of a service on another device.  This is a synchronous call. | ||||||
| @@ -1669,18 +1693,18 @@ EXPORT_SPEC int UpnpSendActionExAsync( | |||||||
|                                     passed to the callback when invoked. */ |                                     passed to the callback when invoked. */ | ||||||
|     ); |     ); | ||||||
|  |  | ||||||
| //@} // Control | /*! @} */ /* Control */ | ||||||
|  |  | ||||||
| //////////////////////////////////////////////////////////////////////// | /****************************************************************************** | ||||||
| //////////////////////////////////////////////////////////////////////// |  ****************************************************************************** | ||||||
| //                                                                    // |  *                                                                            * | ||||||
| //                        E V E N T I N G                             // |  *                        E V E N T I N G                                     * | ||||||
| //                                                                    // |  *                                                                            * | ||||||
| //////////////////////////////////////////////////////////////////////// |  ****************************************************************************** | ||||||
| //////////////////////////////////////////////////////////////////////// |  ******************************************************************************/ | ||||||
|  |  | ||||||
| ///@name Eventing | /*! @name Eventing */ | ||||||
| //@{ | /*! @{ */ | ||||||
|  |  | ||||||
| /** {\bf UpnpAcceptSubscription} accepts a subscription request and sends | /** {\bf UpnpAcceptSubscription} accepts a subscription request and sends | ||||||
|  *  out the current state of the eventable variables for a service.   |  *  out the current state of the eventable variables for a service.   | ||||||
| @@ -2183,19 +2207,19 @@ EXPORT_SPEC int UpnpUnSubscribeAsync( | |||||||
|                                   callback function when invoked. */ |                                   callback function when invoked. */ | ||||||
|     ); |     ); | ||||||
|  |  | ||||||
| //@} // Eventing | /*! @} */ /* Eventing */ | ||||||
|  |  | ||||||
|  |  | ||||||
| //////////////////////////////////////////////////////////////////////// | /****************************************************************************** | ||||||
| //////////////////////////////////////////////////////////////////////// |  ****************************************************************************** | ||||||
| //                                                                    // |  *                                                                            * | ||||||
| //                        C L I E N T - A P I                         // |  *                        C L I E N T - A P I                                 * | ||||||
| //                                                                    // |  *                                                                            * | ||||||
| //////////////////////////////////////////////////////////////////////// |  ****************************************************************************** | ||||||
| //////////////////////////////////////////////////////////////////////// |  ******************************************************************************/ | ||||||
|  |  | ||||||
| ///@name Control Point HTTP API | /*! @name Control Point HTTP API */ | ||||||
| //@{ | /*! @{ */ | ||||||
|  |  | ||||||
| /** {\bf UpnpDownloadUrlItem} downloads a file specified in a URL. | /** {\bf UpnpDownloadUrlItem} downloads a file specified in a URL. | ||||||
|  *  The SDK allocates the memory for {\bf outBuf} and the  |  *  The SDK allocates the memory for {\bf outBuf} and the  | ||||||
| @@ -2588,18 +2612,18 @@ EXPORT_SPEC int UpnpDownloadXmlDoc( | |||||||
| 				     XML document. */ | 				     XML document. */ | ||||||
|     ); |     ); | ||||||
|  |  | ||||||
| //@} // Control Point HTTP API | /*! @} */ /* Control Point HTTP API */ | ||||||
|  |  | ||||||
| //////////////////////////////////////////////////////////////////////// | /****************************************************************************** | ||||||
| //////////////////////////////////////////////////////////////////////// |  ****************************************************************************** | ||||||
| //                                                                    // |  *                                                                            * | ||||||
| //                    W E B  S E R V E R  A P I                       // |  *                    W E B  S E R V E R  A P I                               * | ||||||
| //                                                                    // |  *                                                                            * | ||||||
| //////////////////////////////////////////////////////////////////////// |  ****************************************************************************** | ||||||
| //////////////////////////////////////////////////////////////////////// |  ******************************************************************************/ | ||||||
|  |  | ||||||
| ///@name Web Server API | /*! @name Web Server API */ | ||||||
| //@{ | /*! @{ */ | ||||||
|  |  | ||||||
| /** {\bf UpnpSetWebServerRootDir} sets the document root directory for | /** {\bf UpnpSetWebServerRootDir} sets the document root directory for | ||||||
|  *  the internal web server. This directory is considered the |  *  the internal web server. This directory is considered the | ||||||
| @@ -2715,12 +2739,13 @@ EXPORT_SPEC void UpnpFree( | |||||||
|     IN void *item /* The item to free. */ |     IN void *item /* The item to free. */ | ||||||
|     ); |     ); | ||||||
|  |  | ||||||
| //@} // Web Server API | /*! @} */ /* Web Server API */ | ||||||
|  |  | ||||||
| #ifdef __cplusplus | #ifdef __cplusplus | ||||||
| } | } | ||||||
| #endif // __cplusplus | #endif /* __cplusplus */ | ||||||
|  |  | ||||||
| //@} The API | /*! @} */ /* The API */ | ||||||
|  |  | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1,34 +1,34 @@ | |||||||
| // -*- C -*- | /* -*- C -*- */ | ||||||
| /////////////////////////////////////////////////////////////////////////// | /******************************************************************************* | ||||||
| // |  * | ||||||
| // Copyright (c) 2006 R<>mi Turboult <r3mi@users.sourceforge.net> |  * Copyright (c) 2006 R<>mi Turboult <r3mi@users.sourceforge.net> | ||||||
| // All rights reserved.  |  * All rights reserved.  | ||||||
| // |  * | ||||||
| // Redistribution and use in source and binary forms, with or without  |  * Redistribution and use in source and binary forms, with or without  | ||||||
| // modification, are permitted provided that the following conditions are met:  |  * modification, are permitted provided that the following conditions are met:  | ||||||
| // |  * | ||||||
| // * Redistributions of source code must retain the above copyright notice,  |  * * Redistributions of source code must retain the above copyright notice,  | ||||||
| // this list of conditions and the following disclaimer.  |  * this list of conditions and the following disclaimer.  | ||||||
| // * Redistributions in binary form must reproduce the above copyright notice,  |  * * Redistributions in binary form must reproduce the above copyright notice,  | ||||||
| // this list of conditions and the following disclaimer in the documentation  |  * this list of conditions and the following disclaimer in the documentation  | ||||||
| // and/or other materials provided with the distribution.  |  * and/or other materials provided with the distribution.  | ||||||
| // * Neither name of Intel Corporation nor the names of its contributors  |  * * Neither name of Intel Corporation nor the names of its contributors  | ||||||
| // may be used to endorse or promote products derived from this software  |  * may be used to endorse or promote products derived from this software  | ||||||
| // without specific prior written permission. |  * without specific prior written permission. | ||||||
| //  |  *  | ||||||
| // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS  |  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS  | ||||||
| // "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT  |  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT  | ||||||
| // LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR  |  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR  | ||||||
| // A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL INTEL OR  |  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL INTEL OR  | ||||||
| // CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,  |  * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,  | ||||||
| // EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,  |  * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,  | ||||||
| // PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR  |  * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR  | ||||||
| // PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY  |  * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY  | ||||||
| // OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING |  * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING | ||||||
| // NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS  |  * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS  | ||||||
| // SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |  * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||||
| // |  * | ||||||
| /////////////////////////////////////////////////////////////////////////// |  ******************************************************************************/ | ||||||
|  |  | ||||||
| #ifndef UPNP_CONFIG_H | #ifndef UPNP_CONFIG_H | ||||||
| #define UPNP_CONFIG_H  | #define UPNP_CONFIG_H  | ||||||
| @@ -91,6 +91,5 @@ | |||||||
| #undef UPNP_HAVE_TOOLS | #undef UPNP_HAVE_TOOLS | ||||||
|  |  | ||||||
|  |  | ||||||
| #endif // UPNP_CONFIG_H | #endif /* UPNP_CONFIG_H */ | ||||||
|  |  | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1,43 +1,41 @@ | |||||||
| /////////////////////////////////////////////////////////////////////////// | /******************************************************************************* | ||||||
| // |  * | ||||||
| // Copyright (c) 2000-2003 Intel Corporation  |  * Copyright (c) 2000-2003 Intel Corporation  | ||||||
| // Copyright (c) 2006 R<>mi Turboult <r3mi@users.sourceforge.net> |  * Copyright (c) 2006 R<>mi Turboult <r3mi@users.sourceforge.net> | ||||||
| // All rights reserved.  |  * All rights reserved.  | ||||||
| // |  * | ||||||
| // Redistribution and use in source and binary forms, with or without  |  * Redistribution and use in source and binary forms, with or without  | ||||||
| // modification, are permitted provided that the following conditions are met:  |  * modification, are permitted provided that the following conditions are met:  | ||||||
| // |  * | ||||||
| // * Redistributions of source code must retain the above copyright notice,  |  * * Redistributions of source code must retain the above copyright notice,  | ||||||
| // this list of conditions and the following disclaimer.  |  * this list of conditions and the following disclaimer.  | ||||||
| // * Redistributions in binary form must reproduce the above copyright notice,  |  * * Redistributions in binary form must reproduce the above copyright notice,  | ||||||
| // this list of conditions and the following disclaimer in the documentation  |  * this list of conditions and the following disclaimer in the documentation  | ||||||
| // and/or other materials provided with the distribution.  |  * and/or other materials provided with the distribution.  | ||||||
| // * Neither name of Intel Corporation nor the names of its contributors  |  * * Neither name of Intel Corporation nor the names of its contributors  | ||||||
| // may be used to endorse or promote products derived from this software  |  * may be used to endorse or promote products derived from this software  | ||||||
| // without specific prior written permission. |  * without specific prior written permission. | ||||||
| //  |  *  | ||||||
| // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS  |  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS  | ||||||
| // "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT  |  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT  | ||||||
| // LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR  |  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR  | ||||||
| // A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL INTEL OR  |  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL INTEL OR  | ||||||
| // CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,  |  * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,  | ||||||
| // EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,  |  * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,  | ||||||
| // PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR  |  * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR  | ||||||
| // PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY  |  * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY  | ||||||
| // OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING |  * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING | ||||||
| // NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS  |  * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS  | ||||||
| // SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |  * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||||
| // |  * | ||||||
| /////////////////////////////////////////////////////////////////////////// |  ******************************************************************************/ | ||||||
|  |  | ||||||
| #ifndef UPNP_DEBUG_H | #ifndef UPNP_DEBUG_H | ||||||
| #define UPNP_DEBUG_H  | #define UPNP_DEBUG_H  | ||||||
|  |  | ||||||
|  | #include "upnp.h" | ||||||
| #include "upnpconfig.h" | #include "upnpconfig.h" | ||||||
|  |  | ||||||
| // Function declarations only if debug compiled into the library |  | ||||||
| #if UPNP_HAVE_DEBUG |  | ||||||
|  |  | ||||||
| #include <stdio.h> | #include <stdio.h> | ||||||
|  |  | ||||||
| #ifdef __cplusplus | #ifdef __cplusplus | ||||||
| @@ -49,7 +47,7 @@ extern "C" { | |||||||
|           The UPnP SDK contains other features to aid in debugging. |           The UPnP SDK contains other features to aid in debugging. | ||||||
|  */ |  */ | ||||||
|  |  | ||||||
| //@{ | /*! @{ */ | ||||||
|  |  | ||||||
| /** @name Upnp_LogLevel | /** @name Upnp_LogLevel | ||||||
|  *  The user has the option to select 4 different types of debugging levels, |  *  The user has the option to select 4 different types of debugging levels, | ||||||
| @@ -70,18 +68,25 @@ extern "C" { | |||||||
|  *  \end{itemize} |  *  \end{itemize} | ||||||
|  */ |  */ | ||||||
|  |  | ||||||
| typedef enum Upnp_Module {SSDP,SOAP,GENA,TPOOL,MSERV,DOM,API, HTTP} Dbg_Module; | typedef enum Upnp_Module { | ||||||
| //@{ | 	SSDP, | ||||||
|  | 	SOAP, | ||||||
|  | 	GENA, | ||||||
|  | 	TPOOL, | ||||||
|  | 	MSERV, | ||||||
|  | 	DOM, | ||||||
|  | 	API, | ||||||
|  | 	HTTP | ||||||
|  | } Dbg_Module; | ||||||
|  |  | ||||||
|  | /*! @{ */ | ||||||
| typedef enum Upnp_LogLevel_e { | typedef enum Upnp_LogLevel_e { | ||||||
| 	UPNP_CRITICAL, | 	UPNP_CRITICAL, | ||||||
| 	UPNP_PACKET, | 	UPNP_PACKET, | ||||||
| 	UPNP_INFO, | 	UPNP_INFO, | ||||||
| 	UPNP_ALL | 	UPNP_ALL | ||||||
| } Upnp_LogLevel; | } Upnp_LogLevel; | ||||||
| //@} | /*! @} */ | ||||||
|  |  | ||||||
| // for backward compatibility |  | ||||||
| #define Dbg_Level	Upnp_LogLevel |  | ||||||
|  |  | ||||||
|  |  | ||||||
| /** | /** | ||||||
| @@ -98,26 +103,32 @@ typedef enum Upnp_LogLevel_e { | |||||||
|  * |  * | ||||||
|  * Description: |  * Description: | ||||||
|  *	This functions initializes the log files |  *	This functions initializes the log files | ||||||
|  |  * | ||||||
|  * Returns: int |  * Returns: int | ||||||
|  *	-1 : If fails |  *	-1 : If fails | ||||||
|  *	UPNP_E_SUCCESS : if success |  *	UPNP_E_SUCCESS : if success | ||||||
|  ***************************************************************************/ |  ***************************************************************************/ | ||||||
|  | #ifdef DEBUG | ||||||
| int UpnpInitLog(); | int UpnpInitLog(); | ||||||
|  | #else | ||||||
| // for backward compatibility | static UPNP_INLINE int UpnpInitLog() { return UPNP_E_SUCCESS; } | ||||||
| #define InitLog		UpnpInitLog | #endif | ||||||
|  |  | ||||||
|  |  | ||||||
| /*************************************************************************** | /*************************************************************************** | ||||||
|  * Function : UpnpSetLogLevel |  * Function : UpnpSetLogLevel | ||||||
|  *				 |  *				 | ||||||
|  * Parameters:	void |  * Parameters: Upnp_LogLevel log_level | ||||||
|  * |  * | ||||||
|  * Description:							 |  * Description:							 | ||||||
|  *	This functions set the log level (see {\tt Upnp_LogLevel} |  *	This functions set the log level (see {\tt Upnp_LogLevel} | ||||||
|  * Returns: void |  * Returns: void | ||||||
|  ***************************************************************************/ |  ***************************************************************************/ | ||||||
| void UpnpSetLogLevel (Upnp_LogLevel); | #ifdef DEBUG | ||||||
|  | void UpnpSetLogLevel(Upnp_LogLevel log_level); | ||||||
|  | #else | ||||||
|  | static UPNP_INLINE void UpnpSetLogLevel(Upnp_LogLevel log_level) {} | ||||||
|  | #endif | ||||||
|  |  | ||||||
|  |  | ||||||
| /*************************************************************************** | /*************************************************************************** | ||||||
| @@ -129,10 +140,11 @@ void UpnpSetLogLevel (Upnp_LogLevel); | |||||||
|  *	This functions closes the log files |  *	This functions closes the log files | ||||||
|  * Returns: void |  * Returns: void | ||||||
|  ***************************************************************************/ |  ***************************************************************************/ | ||||||
|  | #ifdef DEBUG | ||||||
| void UpnpCloseLog(); | void UpnpCloseLog(); | ||||||
|  | #else | ||||||
| // for backward compatibility | static UPNP_INLINE void UpnpCloseLog() {} | ||||||
| #define CloseLog	UpnpCloseLog | #endif | ||||||
|  |  | ||||||
|  |  | ||||||
| /*************************************************************************** | /*************************************************************************** | ||||||
| @@ -149,17 +161,22 @@ void UpnpCloseLog(); | |||||||
|  *	per the requested banner	 |  *	per the requested banner	 | ||||||
|  * Returns: void |  * Returns: void | ||||||
|  ***************************************************************************/ |  ***************************************************************************/ | ||||||
| void UpnpSetLogFileNames (const char* ErrFileName, const char* InfoFileName); | #ifdef DEBUG | ||||||
|  | void UpnpSetLogFileNames( | ||||||
| // for backward compatibility | 	const char *ErrFileName, | ||||||
| #define SetLogFileNames		UpnpSetLogFileNames | 	const char *InfoFileName); | ||||||
|  | #else | ||||||
|  | static UPNP_INLINE void UpnpSetLogFileNames( | ||||||
|  | 	const char *ErrFileName, | ||||||
|  | 	const char *InfoFileName) {} | ||||||
|  | #endif | ||||||
|  |  | ||||||
|  |  | ||||||
| /*************************************************************************** | /*************************************************************************** | ||||||
|  * Function : UpnpGetDebugFile		 |  * Function : UpnpGetDebugFile		 | ||||||
|  *						 |  *						 | ||||||
|  * Parameters:					 |  * Parameters:					 | ||||||
|  *	IN Dbg_Level DLevel: The level of the debug logging. It will decide  |  *	IN Upnp_LogLevel DLevel: The level of the debug logging. It will decide  | ||||||
|  *		whether debug statement will go to standard output,  |  *		whether debug statement will go to standard output,  | ||||||
|  *		or any of the log files. |  *		or any of the log files. | ||||||
|  *	IN Dbg_Module Module: debug will go in the name of this module |  *	IN Dbg_Module Module: debug will go in the name of this module | ||||||
| @@ -171,17 +188,47 @@ void UpnpSetLogFileNames (const char* ErrFileName, const char* InfoFileName); | |||||||
|  *	NULL : if the module is turn off for debug  |  *	NULL : if the module is turn off for debug  | ||||||
|  *	else returns the right file descriptor |  *	else returns the right file descriptor | ||||||
|  ***************************************************************************/ |  ***************************************************************************/ | ||||||
| FILE* UpnpGetDebugFile (Upnp_LogLevel level, Dbg_Module module); | #ifdef DEBUG | ||||||
|  | FILE *UpnpGetDebugFile(Upnp_LogLevel level, Dbg_Module module); | ||||||
|  | #else | ||||||
|  | static UPNP_INLINE FILE *UpnpGetDebugFile(Upnp_LogLevel level, Dbg_Module module) | ||||||
|  | { | ||||||
|  | 	return NULL; | ||||||
|  | } | ||||||
|  | #endif | ||||||
|  |  | ||||||
| // for backward compatibility |  | ||||||
| #define GetDebugFile	UpnpGetDebugFile | /*************************************************************************** | ||||||
|  |  * Function : DebugAtThisLevel					 | ||||||
|  |  *									 | ||||||
|  |  * Parameters:			 | ||||||
|  |  *	IN Upnp_LogLevel DLevel: The level of the debug logging. It will decide  | ||||||
|  |  *		whether debug statement will go to standard output,  | ||||||
|  |  *		or any of the log files. | ||||||
|  |  *	IN Dbg_Module Module: debug will go in the name of this module | ||||||
|  |  *					 | ||||||
|  |  * Description:					 | ||||||
|  |  *	This functions returns true if debug output should be done in this | ||||||
|  |  *	module. | ||||||
|  |  * | ||||||
|  |  * Returns: int | ||||||
|  |  ***************************************************************************/ | ||||||
|  | #ifdef DEBUG | ||||||
|  | int DebugAtThisLevel( | ||||||
|  | 	IN Upnp_LogLevel DLevel, | ||||||
|  | 	IN Dbg_Module Module); | ||||||
|  | #else | ||||||
|  | static UPNP_INLINE int DebugAtThisLevel( | ||||||
|  | 	IN Upnp_LogLevel DLevel, | ||||||
|  | 	IN Dbg_Module Module) { return 0; } | ||||||
|  | #endif | ||||||
|  |  | ||||||
|  |  | ||||||
| /*************************************************************************** | /*************************************************************************** | ||||||
|  * Function : UpnpPrintf				 |  * Function : UpnpPrintf				 | ||||||
|  *									 |  *									 | ||||||
|  * Parameters:								 |  * Parameters:								 | ||||||
|  *	IN Dbg_Level DLevel: The level of the debug logging. It will decide  |  *	IN Upnp_LogLevel DLevel: The level of the debug logging. It will decide  | ||||||
|  *		whether debug statement will go to standard output,  |  *		whether debug statement will go to standard output,  | ||||||
|  *		or any of the log files. |  *		or any of the log files. | ||||||
|  *	IN Dbg_Module Module: debug will go in the name of this module |  *	IN Dbg_Module Module: debug will go in the name of this module | ||||||
| @@ -198,6 +245,7 @@ FILE* UpnpGetDebugFile (Upnp_LogLevel level, Dbg_Module module); | |||||||
|  *	debug statement is coming |  *	debug statement is coming | ||||||
|  * Returns: void |  * Returns: void | ||||||
|  ***************************************************************************/  |  ***************************************************************************/  | ||||||
|  | #ifdef DEBUG | ||||||
| void UpnpPrintf (Upnp_LogLevel DLevel, Dbg_Module Module, | void UpnpPrintf (Upnp_LogLevel DLevel, Dbg_Module Module, | ||||||
| 		 const char* DbgFileName, int DbgLineNo, | 		 const char* DbgFileName, int DbgLineNo, | ||||||
| 		 const char* FmtStr, | 		 const char* FmtStr, | ||||||
| @@ -206,6 +254,15 @@ void UpnpPrintf (Upnp_LogLevel DLevel, Dbg_Module Module, | |||||||
| 	__attribute__((format (__printf__, 5, 6))) | 	__attribute__((format (__printf__, 5, 6))) | ||||||
| #endif | #endif | ||||||
| ; | ; | ||||||
|  | #else | ||||||
|  | static UPNP_INLINE void UpnpPrintf( | ||||||
|  | 	Upnp_LogLevel DLevel, | ||||||
|  | 	Dbg_Module Module, | ||||||
|  | 	const char* DbgFileName, | ||||||
|  | 	int DbgLineNo, | ||||||
|  | 	const char* FmtStr, | ||||||
|  | 	...) {} | ||||||
|  | #endif | ||||||
|  |  | ||||||
|  |  | ||||||
| /*************************************************************************** | /*************************************************************************** | ||||||
| @@ -222,8 +279,19 @@ void UpnpPrintf (Upnp_LogLevel DLevel, Dbg_Module Module, | |||||||
|  *	per the requested banner			 |  *	per the requested banner			 | ||||||
|  * Returns: void |  * Returns: void | ||||||
|  ***************************************************************************/ |  ***************************************************************************/ | ||||||
| void UpnpDisplayBanner (FILE *fd, | #ifdef DEBUG | ||||||
| 			const char** lines, size_t size, int starlength); | void UpnpDisplayBanner( | ||||||
|  | 	FILE *fd, | ||||||
|  | 	const char **lines, | ||||||
|  | 	size_t size, | ||||||
|  | 	int starlength); | ||||||
|  | #else | ||||||
|  | static UPNP_INLINE void UpnpDisplayBanner( | ||||||
|  | 	FILE *fd, | ||||||
|  | 	const char **lines, | ||||||
|  | 	size_t size, | ||||||
|  | 	int starlength) {} | ||||||
|  | #endif | ||||||
|  |  | ||||||
|  |  | ||||||
| /*************************************************************************** | /*************************************************************************** | ||||||
| @@ -240,19 +308,23 @@ void UpnpDisplayBanner (FILE *fd, | |||||||
|  *		debug statement is coming to the log file |  *		debug statement is coming to the log file | ||||||
|  * Returns: void |  * Returns: void | ||||||
|  ***************************************************************************/ |  ***************************************************************************/ | ||||||
| void UpnpDisplayFileAndLine (FILE *fd, const char *DbgFileName, int DbgLineNo); | #ifdef DEBUG | ||||||
|  | void UpnpDisplayFileAndLine( | ||||||
|  | 	FILE *fd, | ||||||
| //@} | 	const char *DbgFileName, | ||||||
|  | 	int DbgLineNo); | ||||||
|  | #else | ||||||
|  | static UPNP_INLINE void UpnpDisplayFileAndLine( | ||||||
|  | 	FILE *fd, | ||||||
|  | 	const char *DbgFileName, | ||||||
|  | 	int DbgLineNo) {} | ||||||
|  | #endif | ||||||
|  |  | ||||||
|  | /*! @} */ | ||||||
|  |  | ||||||
| #ifdef __cplusplus | #ifdef __cplusplus | ||||||
| } | } | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
| #endif // UPNP_HAVE_DEBUG | #endif /* UPNP_DEBUG_H */ | ||||||
|  |  | ||||||
| #endif // UPNP_DEBUG_H |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1,33 +1,33 @@ | |||||||
| /////////////////////////////////////////////////////////////////////////// | /******************************************************************************* | ||||||
| // |  * | ||||||
| // Copyright (c) 2000-2003 Intel Corporation  |  * Copyright (c) 2000-2003 Intel Corporation  | ||||||
| // All rights reserved.  |  * All rights reserved.  | ||||||
| // |  * | ||||||
| // Redistribution and use in source and binary forms, with or without  |  * Redistribution and use in source and binary forms, with or without  | ||||||
| // modification, are permitted provided that the following conditions are met:  |  * modification, are permitted provided that the following conditions are met:  | ||||||
| // |  * | ||||||
| // * Redistributions of source code must retain the above copyright notice,  |  * * Redistributions of source code must retain the above copyright notice,  | ||||||
| // this list of conditions and the following disclaimer.  |  * this list of conditions and the following disclaimer.  | ||||||
| // * Redistributions in binary form must reproduce the above copyright notice,  |  * * Redistributions in binary form must reproduce the above copyright notice,  | ||||||
| // this list of conditions and the following disclaimer in the documentation  |  * this list of conditions and the following disclaimer in the documentation  | ||||||
| // and/or other materials provided with the distribution.  |  * and/or other materials provided with the distribution.  | ||||||
| // * Neither name of Intel Corporation nor the names of its contributors  |  * * Neither name of Intel Corporation nor the names of its contributors  | ||||||
| // may be used to endorse or promote products derived from this software  |  * may be used to endorse or promote products derived from this software  | ||||||
| // without specific prior written permission. |  * without specific prior written permission. | ||||||
| //  |  *  | ||||||
| // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS  |  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS  | ||||||
| // "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT  |  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT  | ||||||
| // LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR  |  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR  | ||||||
| // A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL INTEL OR  |  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL INTEL OR  | ||||||
| // CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,  |  * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,  | ||||||
| // EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,  |  * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,  | ||||||
| // PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR  |  * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR  | ||||||
| // PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY  |  * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY  | ||||||
| // OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING |  * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING | ||||||
| // NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS  |  * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS  | ||||||
| // SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |  * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||||
| // |  * | ||||||
| /////////////////////////////////////////////////////////////////////////// |  ******************************************************************************/ | ||||||
|  |  | ||||||
| /** @name Optional Tool APIs | /** @name Optional Tool APIs | ||||||
|  *  The Linux SDK for UPnP Devices contains some additional, optional  |  *  The Linux SDK for UPnP Devices contains some additional, optional  | ||||||
| @@ -36,14 +36,14 @@ | |||||||
|  *  size in the SDK. Refer to the README for details. |  *  size in the SDK. Refer to the README for details. | ||||||
|  */ |  */ | ||||||
|  |  | ||||||
| //@{ | /*! @{ */ | ||||||
|  |  | ||||||
| #ifndef UPNP_TOOLS_H | #ifndef UPNP_TOOLS_H | ||||||
| #define UPNP_TOOLS_H | #define UPNP_TOOLS_H | ||||||
|  |  | ||||||
| #include "upnp.h" | #include "upnp.h" | ||||||
|  |  | ||||||
| // Function declarations only if tools compiled into the library | /* Function declarations only if tools compiled into the library */ | ||||||
| #if UPNP_HAVE_TOOLS | #if UPNP_HAVE_TOOLS | ||||||
|  |  | ||||||
| #ifdef __cplusplus | #ifdef __cplusplus | ||||||
| @@ -217,14 +217,13 @@ EXPORT_SPEC const char * UpnpGetErrorMessage( | |||||||
|         int errorcode  /** The SDK error code to convert. */ |         int errorcode  /** The SDK error code to convert. */ | ||||||
|         ); |         ); | ||||||
|  |  | ||||||
| //@} | /*! @} */ | ||||||
|  |  | ||||||
| #ifdef __cplusplus | #ifdef __cplusplus | ||||||
| } | } | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
| #endif // UPNP_HAVE_TOOLS | #endif /* UPNP_HAVE_TOOLS */ | ||||||
|  |  | ||||||
| #endif // UPNP_TOOLS_H |  | ||||||
|  |  | ||||||
|  | #endif /* UPNP_TOOLS_H */ | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										86
									
								
								upnp/sample/Makefile.am
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										86
									
								
								upnp/sample/Makefile.am
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,86 @@ | |||||||
|  | # | ||||||
|  | # "Makefile.am" for "libupnp/upnp/sample" | ||||||
|  | # | ||||||
|  | # Copyright (C) 2007 Marcelo Roberto Jimenez <mroberto@users.sourceforge.net> | ||||||
|  | # | ||||||
|  |  | ||||||
|  | AM_CPPFLAGS = \ | ||||||
|  | 	-I$(top_srcdir)/upnp/inc \ | ||||||
|  | 	-I$(top_srcdir)/threadutil/inc \ | ||||||
|  | 	-I$(top_srcdir)/ixml/inc | ||||||
|  |  | ||||||
|  | AM_CFLAGS = $(PTHREAD_CFLAGS) | ||||||
|  |  | ||||||
|  | AM_LDFLAGS = $(PTHREAD_LIBS) | ||||||
|  |  | ||||||
|  | LDADD = \ | ||||||
|  | 	$(top_builddir)/upnp/libupnp.la \ | ||||||
|  | 	$(top_builddir)/threadutil/libthreadutil.la \ | ||||||
|  | 	$(top_builddir)/ixml/libixml.la | ||||||
|  |  | ||||||
|  |  | ||||||
|  | # samples | ||||||
|  | noinst_PROGRAMS = | ||||||
|  | if ENABLE_SAMPLES | ||||||
|  | if ENABLE_CLIENT | ||||||
|  | noinst_PROGRAMS += upnp_tv_ctrlpt | ||||||
|  | upnp_tv_ctrlpt_CPPFLAGS = \ | ||||||
|  | 	$(AM_CPPFLAGS) \ | ||||||
|  | 	-I$(srcdir)/common/ \ | ||||||
|  | 	-I$(srcdir)/tvctrlpt | ||||||
|  | if ENABLE_DEVICE | ||||||
|  | noinst_PROGRAMS += upnp_tv_combo | ||||||
|  | upnp_tv_combo_CPPFLAGS = $(AM_CPPFLAGS) \ | ||||||
|  | 	-I$(srcdir)/common/ \ | ||||||
|  | 	-I$(srcdir)/tvcombo | ||||||
|  | endif | ||||||
|  | endif | ||||||
|  | if ENABLE_DEVICE | ||||||
|  | noinst_PROGRAMS += upnp_tv_device | ||||||
|  | upnp_tv_device_CPPFLAGS = \ | ||||||
|  | 	$(AM_CPPFLAGS) \ | ||||||
|  | 	-I$(srcdir)/common/ \ | ||||||
|  | 	-I$(srcdir)/tvdevice | ||||||
|  | endif | ||||||
|  | endif | ||||||
|  |  | ||||||
|  |  | ||||||
|  | upnp_tv_device_SOURCES = \ | ||||||
|  | 	common/sample_util.c \ | ||||||
|  | 	common/sample_util.h \ | ||||||
|  | 	tvdevice/upnp_tv_device.c \ | ||||||
|  | 	tvdevice/upnp_tv_device.h \ | ||||||
|  | 	tvdevice/linux/upnp_tv_device_main.c | ||||||
|  |  | ||||||
|  |  | ||||||
|  | upnp_tv_ctrlpt_SOURCES = \ | ||||||
|  | 	common/sample_util.c \ | ||||||
|  | 	common/sample_util.h \ | ||||||
|  | 	tvctrlpt/upnp_tv_ctrlpt.c \ | ||||||
|  | 	tvctrlpt/upnp_tv_ctrlpt.h \ | ||||||
|  | 	tvctrlpt/linux/upnp_tv_ctrlpt_main.c | ||||||
|  |  | ||||||
|  | upnp_tv_combo_SOURCES = \ | ||||||
|  | 	common/sample_util.c \ | ||||||
|  | 	common/sample_util.h \ | ||||||
|  | 	tvcombo/upnp_tv_ctrlpt.c \ | ||||||
|  | 	tvcombo/upnp_tv_ctrlpt.h \ | ||||||
|  | 	tvcombo/upnp_tv_device.c \ | ||||||
|  | 	tvcombo/upnp_tv_device.h \ | ||||||
|  | 	tvcombo/linux/upnp_tv_combo_main.c | ||||||
|  |  | ||||||
|  |  | ||||||
|  | if WITH_DOCUMENTATION | ||||||
|  | examplesdir = $(docdir)/examples | ||||||
|  | examples_DATA = \ | ||||||
|  | 		$(upnp_tv_ctrlpt_SOURCES) \ | ||||||
|  | 		$(upnp_tv_device_SOURCES) | ||||||
|  | endif | ||||||
|  |  | ||||||
|  |  | ||||||
|  | EXTRA_DIST = \ | ||||||
|  | 	tvdevice/web/tvcontrolSCPD.xml \ | ||||||
|  | 	tvdevice/web/tvdevicedesc.xml \ | ||||||
|  | 	tvdevice/web/tvdevicepres.html \ | ||||||
|  | 	tvdevice/web/tvpictureSCPD.xml | ||||||
|  |  | ||||||
							
								
								
									
										489
									
								
								upnp/sample/tvcombo/linux/upnp_tv_combo_main.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										489
									
								
								upnp/sample/tvcombo/linux/upnp_tv_combo_main.c
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,489 @@ | |||||||
|  | /////////////////////////////////////////////////////////////////////////// | ||||||
|  | // | ||||||
|  | // Copyright (c) 2000-2003 Intel Corporation  | ||||||
|  | // 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 name of Intel Corporation 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 INTEL 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. | ||||||
|  | // | ||||||
|  | /////////////////////////////////////////////////////////////////////////// | ||||||
|  |  | ||||||
|  |  | ||||||
|  | #include "sample_util.h" | ||||||
|  | #include "upnp_tv_ctrlpt.h" | ||||||
|  | #include "upnp_tv_device.h" | ||||||
|  |  | ||||||
|  |  | ||||||
|  | #include <stdio.h> | ||||||
|  | #include <string.h> | ||||||
|  |  | ||||||
|  | /* | ||||||
|  |    Tags for valid commands issued at the command prompt  | ||||||
|  |  */ | ||||||
|  | enum cmdloop_tvcmds { | ||||||
|  |     PRTHELP = 0, PRTFULLHELP, POWON, POWOFF, | ||||||
|  |     SETCHAN, SETVOL, SETCOL, SETTINT, SETCONT, SETBRT, | ||||||
|  |     CTRLACTION, PICTACTION, CTRLGETVAR, PICTGETVAR, | ||||||
|  |     PRTDEV, LSTDEV, REFRESH, EXITCMD | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | /* | ||||||
|  |    Data structure for parsing commands from the command line  | ||||||
|  |  */ | ||||||
|  | struct cmdloop_commands { | ||||||
|  |     char *str;                  // the string  | ||||||
|  |     int cmdnum;                 // the command | ||||||
|  |     int numargs;                // the number of arguments | ||||||
|  |     char *args;                 // the args | ||||||
|  | } cmdloop_commands; | ||||||
|  |  | ||||||
|  | /* | ||||||
|  |    Mappings between command text names, command tag, | ||||||
|  |    and required command arguments for command line | ||||||
|  |    commands  | ||||||
|  |  */ | ||||||
|  | static struct cmdloop_commands cmdloop_cmdlist[] = { | ||||||
|  |     {"Help", PRTHELP, 1, ""}, | ||||||
|  |     {"HelpFull", PRTFULLHELP, 1, ""}, | ||||||
|  |     {"ListDev", LSTDEV, 1, ""}, | ||||||
|  |     {"Refresh", REFRESH, 1, ""}, | ||||||
|  |     {"PrintDev", PRTDEV, 2, "<devnum>"}, | ||||||
|  |     {"PowerOn", POWON, 2, "<devnum>"}, | ||||||
|  |     {"PowerOff", POWOFF, 2, "<devnum>"}, | ||||||
|  |     {"SetChannel", SETCHAN, 3, "<devnum> <channel (int)>"}, | ||||||
|  |     {"SetVolume", SETVOL, 3, "<devnum> <volume (int)>"}, | ||||||
|  |     {"SetColor", SETCOL, 3, "<devnum> <color (int)>"}, | ||||||
|  |     {"SetTint", SETTINT, 3, "<devnum> <tint (int)>"}, | ||||||
|  |     {"SetContrast", SETCONT, 3, "<devnum> <contrast (int)>"}, | ||||||
|  |     {"SetBrightness", SETBRT, 3, "<devnum> <brightness (int)>"}, | ||||||
|  |     {"CtrlAction", CTRLACTION, 2, "<devnum> <action (string)>"}, | ||||||
|  |     {"PictAction", PICTACTION, 2, "<devnum> <action (string)>"}, | ||||||
|  |     {"CtrlGetVar", CTRLGETVAR, 2, "<devnum> <varname (string)>"}, | ||||||
|  |     {"PictGetVar", PICTGETVAR, 2, "<devnum> <varname (string)>"}, | ||||||
|  |     {"Exit", EXITCMD, 1, ""} | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | void | ||||||
|  | linux_print( const char *string ) | ||||||
|  | { | ||||||
|  |     puts( string ); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | /******************************************************************************** | ||||||
|  |  * TvCtrlPointPrintHelp | ||||||
|  |  * | ||||||
|  |  * Description:  | ||||||
|  |  *       Print help info for this application. | ||||||
|  |  ********************************************************************************/ | ||||||
|  | void | ||||||
|  | TvCtrlPointPrintShortHelp( void ) | ||||||
|  | { | ||||||
|  |     SampleUtil_Print( "Commands:" ); | ||||||
|  |     SampleUtil_Print( "  Help" ); | ||||||
|  |     SampleUtil_Print( "  HelpFull" ); | ||||||
|  |     SampleUtil_Print( "  ListDev" ); | ||||||
|  |     SampleUtil_Print( "  Refresh" ); | ||||||
|  |     SampleUtil_Print( "  PrintDev      <devnum>" ); | ||||||
|  |     SampleUtil_Print( "  PowerOn       <devnum>" ); | ||||||
|  |     SampleUtil_Print( "  PowerOff      <devnum>" ); | ||||||
|  |     SampleUtil_Print( "  SetChannel    <devnum> <channel>" ); | ||||||
|  |     SampleUtil_Print( "  SetVolume     <devnum> <volume>" ); | ||||||
|  |     SampleUtil_Print( "  SetColor      <devnum> <color>" ); | ||||||
|  |     SampleUtil_Print( "  SetTint       <devnum> <tint>" ); | ||||||
|  |     SampleUtil_Print( "  SetContrast   <devnum> <contrast>" ); | ||||||
|  |     SampleUtil_Print( "  SetBrightness <devnum> <brightness>" ); | ||||||
|  |     SampleUtil_Print( "  CtrlAction    <devnum> <action>" ); | ||||||
|  |     SampleUtil_Print( "  PictAction    <devnum> <action>" ); | ||||||
|  |     SampleUtil_Print( "  CtrlGetVar    <devnum> <varname>" ); | ||||||
|  |     SampleUtil_Print( "  PictGetVar    <devnum> <action>" ); | ||||||
|  |     SampleUtil_Print( "  Exit" ); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | void | ||||||
|  | TvCtrlPointPrintLongHelp( void ) | ||||||
|  | { | ||||||
|  |     SampleUtil_Print( "" ); | ||||||
|  |     SampleUtil_Print( "******************************" ); | ||||||
|  |     SampleUtil_Print( "* TV Control Point Help Info *" ); | ||||||
|  |     SampleUtil_Print( "******************************" ); | ||||||
|  |     SampleUtil_Print( "" ); | ||||||
|  |     SampleUtil_Print( "This sample control point application automatically searches" ); | ||||||
|  |     SampleUtil_Print( "for and subscribes to the services of television device emulator" ); | ||||||
|  |     SampleUtil_Print( "devices. While registers a tv device itself." ); | ||||||
|  |     SampleUtil_Print( "" ); | ||||||
|  |     SampleUtil_Print( "Commands:" ); | ||||||
|  |     SampleUtil_Print( "  Help" ); | ||||||
|  |     SampleUtil_Print( "       Print this help info." ); | ||||||
|  |     SampleUtil_Print( "  ListDev" ); | ||||||
|  |     SampleUtil_Print( "       Print the current list of TV Device Emulators that this" ); | ||||||
|  |     SampleUtil_Print( "         control point is aware of.  Each device is preceded by a" ); | ||||||
|  |     SampleUtil_Print( "         device number which corresponds to the devnum argument of" ); | ||||||
|  |     SampleUtil_Print( "         commands listed below." ); | ||||||
|  |     SampleUtil_Print( "  Refresh" ); | ||||||
|  |     SampleUtil_Print( "       Delete all of the devices from the device list and issue new" ); | ||||||
|  |     SampleUtil_Print( "         search request to rebuild the list from scratch." ); | ||||||
|  |     SampleUtil_Print( "  PrintDev       <devnum>" ); | ||||||
|  |     SampleUtil_Print( "       Print the state table for the device <devnum>." ); | ||||||
|  |     SampleUtil_Print( "         e.g., 'PrintDev 1' prints the state table for the first" ); | ||||||
|  |     SampleUtil_Print( "         device in the device list." ); | ||||||
|  |     SampleUtil_Print( "  PowerOn        <devnum>" ); | ||||||
|  |     SampleUtil_Print( "       Sends the PowerOn action to the Control Service of" ); | ||||||
|  |     SampleUtil_Print( "         device <devnum>." ); | ||||||
|  |     SampleUtil_Print( "  PowerOff       <devnum>" ); | ||||||
|  |     SampleUtil_Print( "       Sends the PowerOff action to the Control Service of" ); | ||||||
|  |     SampleUtil_Print( "         device <devnum>." ); | ||||||
|  |     SampleUtil_Print( "  SetChannel     <devnum> <channel>" ); | ||||||
|  |     SampleUtil_Print( "       Sends the SetChannel action to the Control Service of" ); | ||||||
|  |     SampleUtil_Print( "         device <devnum>, requesting the channel to be changed" ); | ||||||
|  |     SampleUtil_Print( "         to <channel>." ); | ||||||
|  |     SampleUtil_Print( "  SetVolume      <devnum> <volume>" ); | ||||||
|  |     SampleUtil_Print( "       Sends the SetVolume action to the Control Service of" ); | ||||||
|  |     SampleUtil_Print( "         device <devnum>, requesting the volume to be changed" ); | ||||||
|  |     SampleUtil_Print( "         to <volume>." ); | ||||||
|  |     SampleUtil_Print( "  SetColor       <devnum> <color>" ); | ||||||
|  |     SampleUtil_Print( "       Sends the SetColor action to the Control Service of" ); | ||||||
|  |     SampleUtil_Print( "         device <devnum>, requesting the color to be changed" ); | ||||||
|  |     SampleUtil_Print( "         to <color>." ); | ||||||
|  |     SampleUtil_Print( "  SetTint        <devnum> <tint>" ); | ||||||
|  |     SampleUtil_Print( "       Sends the SetTint action to the Control Service of" ); | ||||||
|  |     SampleUtil_Print( "         device <devnum>, requesting the tint to be changed" ); | ||||||
|  |     SampleUtil_Print( "         to <tint>." ); | ||||||
|  |     SampleUtil_Print( "  SetContrast    <devnum> <contrast>" ); | ||||||
|  |     SampleUtil_Print( "       Sends the SetContrast action to the Control Service of" ); | ||||||
|  |     SampleUtil_Print( "         device <devnum>, requesting the contrast to be changed" ); | ||||||
|  |     SampleUtil_Print( "         to <contrast>." ); | ||||||
|  |     SampleUtil_Print( "  SetBrightness  <devnum> <brightness>" ); | ||||||
|  |     SampleUtil_Print( "       Sends the SetBrightness action to the Control Service of" ); | ||||||
|  |     SampleUtil_Print( "         device <devnum>, requesting the brightness to be changed" ); | ||||||
|  |     SampleUtil_Print( "         to <brightness>." ); | ||||||
|  |     SampleUtil_Print( "  CtrlAction     <devnum> <action>" ); | ||||||
|  |     SampleUtil_Print( "       Sends an action request specified by the string <action>" ); | ||||||
|  |     SampleUtil_Print( "         to the Control Service of device <devnum>.  This command" ); | ||||||
|  |     SampleUtil_Print( "         only works for actions that have no arguments." ); | ||||||
|  |     SampleUtil_Print( "         (e.g., \"CtrlAction 1 IncreaseChannel\")" ); | ||||||
|  |     SampleUtil_Print( "  PictAction     <devnum> <action>" ); | ||||||
|  |     SampleUtil_Print( "       Sends an action request specified by the string <action>" ); | ||||||
|  |     SampleUtil_Print( "         to the Picture Service of device <devnum>.  This command" ); | ||||||
|  |     SampleUtil_Print( "         only works for actions that have no arguments." ); | ||||||
|  |     SampleUtil_Print( "         (e.g., \"PictAction 1 DecreaseContrast\")" ); | ||||||
|  |     SampleUtil_Print( "  CtrlGetVar     <devnum> <varname>" ); | ||||||
|  |     SampleUtil_Print( "       Requests the value of a variable specified by the string <varname>" ); | ||||||
|  |     SampleUtil_Print( "         from the Control Service of device <devnum>." ); | ||||||
|  |     SampleUtil_Print( "         (e.g., \"CtrlGetVar 1 Volume\")" ); | ||||||
|  |     SampleUtil_Print( "  PictGetVar     <devnum> <action>" ); | ||||||
|  |     SampleUtil_Print( "       Requests the value of a variable specified by the string <varname>" ); | ||||||
|  |     SampleUtil_Print( "         from the Picture Service of device <devnum>." ); | ||||||
|  |     SampleUtil_Print( "         (e.g., \"PictGetVar 1 Tint\")" ); | ||||||
|  |     SampleUtil_Print( "  Exit" ); | ||||||
|  |     SampleUtil_Print( "       Exits the control point application." ); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | /******************************************************************************** | ||||||
|  |  * TvCtrlPointPrintCommands | ||||||
|  |  * | ||||||
|  |  * Description:  | ||||||
|  |  *       Print the list of valid command line commands to the user | ||||||
|  |  * | ||||||
|  |  * Parameters: | ||||||
|  |  *   None | ||||||
|  |  * | ||||||
|  |  ********************************************************************************/ | ||||||
|  | void | ||||||
|  | TvCtrlPointPrintCommands() | ||||||
|  | { | ||||||
|  |     int i; | ||||||
|  |     int numofcmds = sizeof( cmdloop_cmdlist ) / sizeof( cmdloop_commands ); | ||||||
|  |  | ||||||
|  |     SampleUtil_Print( "Valid Commands:" ); | ||||||
|  |     for( i = 0; i < numofcmds; i++ ) { | ||||||
|  |         SampleUtil_Print( "  %-14s %s", cmdloop_cmdlist[i].str, | ||||||
|  |                           cmdloop_cmdlist[i].args ); | ||||||
|  |     } | ||||||
|  |     SampleUtil_Print( "" ); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | /******************************************************************************** | ||||||
|  |  * TvCtrlPointCommandLoop | ||||||
|  |  * | ||||||
|  |  * Description:  | ||||||
|  |  *       Function that receives commands from the user at the command prompt | ||||||
|  |  *       during the lifetime of the control point, and calls the appropriate | ||||||
|  |  *       functions for those commands. | ||||||
|  |  * | ||||||
|  |  * Parameters: | ||||||
|  |  *    None | ||||||
|  |  * | ||||||
|  |  ********************************************************************************/ | ||||||
|  | void * | ||||||
|  | TvCtrlPointCommandLoop( void *args ) | ||||||
|  | { | ||||||
|  |     char cmdline[100]; | ||||||
|  |  | ||||||
|  |     while( 1 ) { | ||||||
|  |         SampleUtil_Print( "\n>> " ); | ||||||
|  |         fgets( cmdline, 100, stdin ); | ||||||
|  |         TvCtrlPointProcessCommand( cmdline ); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     return NULL; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | int | ||||||
|  | TvCtrlPointProcessCommand( char *cmdline ) | ||||||
|  | { | ||||||
|  |     char cmd[100]; | ||||||
|  |     char strarg[100]; | ||||||
|  |     int arg_val_err = -99999; | ||||||
|  |     int arg1 = arg_val_err; | ||||||
|  |     int arg2 = arg_val_err; | ||||||
|  |     int cmdnum = -1; | ||||||
|  |     int numofcmds = sizeof( cmdloop_cmdlist ) / sizeof( cmdloop_commands ); | ||||||
|  |     int cmdfound = 0; | ||||||
|  |     int i, | ||||||
|  |       rc; | ||||||
|  |     int invalidargs = 0; | ||||||
|  |     int validargs; | ||||||
|  |  | ||||||
|  |     validargs = sscanf( cmdline, "%s %d %d", cmd, &arg1, &arg2 ); | ||||||
|  |  | ||||||
|  |     for( i = 0; i < numofcmds; i++ ) { | ||||||
|  |         if( strcasecmp( cmd, cmdloop_cmdlist[i].str ) == 0 ) { | ||||||
|  |             cmdnum = cmdloop_cmdlist[i].cmdnum; | ||||||
|  |             cmdfound++; | ||||||
|  |             if( validargs != cmdloop_cmdlist[i].numargs ) | ||||||
|  |                 invalidargs++; | ||||||
|  |             break; | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     if( !cmdfound ) { | ||||||
|  |         SampleUtil_Print( "Command not found; try 'Help'" ); | ||||||
|  |         return TV_SUCCESS; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     if( invalidargs ) { | ||||||
|  |         SampleUtil_Print( "Invalid arguments; try 'Help'" ); | ||||||
|  |         return TV_SUCCESS; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     switch ( cmdnum ) { | ||||||
|  |         case PRTHELP: | ||||||
|  |             TvCtrlPointPrintShortHelp(); | ||||||
|  |             break; | ||||||
|  |  | ||||||
|  |         case PRTFULLHELP: | ||||||
|  |             TvCtrlPointPrintLongHelp(); | ||||||
|  |             break; | ||||||
|  |  | ||||||
|  |         case POWON: | ||||||
|  |             TvCtrlPointSendPowerOn( arg1 ); | ||||||
|  |             break; | ||||||
|  |  | ||||||
|  |         case POWOFF: | ||||||
|  |             TvCtrlPointSendPowerOff( arg1 ); | ||||||
|  |             break; | ||||||
|  |  | ||||||
|  |         case SETCHAN: | ||||||
|  |             TvCtrlPointSendSetChannel( arg1, arg2 ); | ||||||
|  |             break; | ||||||
|  |  | ||||||
|  |         case SETVOL: | ||||||
|  |             TvCtrlPointSendSetVolume( arg1, arg2 ); | ||||||
|  |             break; | ||||||
|  |  | ||||||
|  |         case SETCOL: | ||||||
|  |             TvCtrlPointSendSetColor( arg1, arg2 ); | ||||||
|  |             break; | ||||||
|  |  | ||||||
|  |         case SETTINT: | ||||||
|  |             TvCtrlPointSendSetTint( arg1, arg2 ); | ||||||
|  |             break; | ||||||
|  |  | ||||||
|  |         case SETCONT: | ||||||
|  |             TvCtrlPointSendSetContrast( arg1, arg2 ); | ||||||
|  |             break; | ||||||
|  |  | ||||||
|  |         case SETBRT: | ||||||
|  |             TvCtrlPointSendSetBrightness( arg1, arg2 ); | ||||||
|  |             break; | ||||||
|  |  | ||||||
|  |         case CTRLACTION: | ||||||
|  |             /* | ||||||
|  |                re-parse commandline since second arg is string  | ||||||
|  |              */ | ||||||
|  |             validargs = sscanf( cmdline, "%s %d %s", cmd, &arg1, strarg ); | ||||||
|  |             if( 3 == validargs ) | ||||||
|  |                 TvCtrlPointSendAction( TV_SERVICE_CONTROL, arg1, strarg, | ||||||
|  |                                        NULL, NULL, 0 ); | ||||||
|  |             else | ||||||
|  |                 invalidargs++; | ||||||
|  |             break; | ||||||
|  |  | ||||||
|  |         case PICTACTION: | ||||||
|  |             /* | ||||||
|  |                re-parse commandline since second arg is string  | ||||||
|  |              */ | ||||||
|  |             validargs = sscanf( cmdline, "%s %d %s", cmd, &arg1, strarg ); | ||||||
|  |             if( 3 == validargs ) | ||||||
|  |                 TvCtrlPointSendAction( TV_SERVICE_PICTURE, arg1, strarg, | ||||||
|  |                                        NULL, NULL, 0 ); | ||||||
|  |             else | ||||||
|  |                 invalidargs++; | ||||||
|  |             break; | ||||||
|  |  | ||||||
|  |         case CTRLGETVAR: | ||||||
|  |             /* | ||||||
|  |                re-parse commandline since second arg is string  | ||||||
|  |              */ | ||||||
|  |             validargs = sscanf( cmdline, "%s %d %s", cmd, &arg1, strarg ); | ||||||
|  |             if( 3 == validargs ) | ||||||
|  |                 TvCtrlPointGetVar( TV_SERVICE_CONTROL, arg1, strarg ); | ||||||
|  |             else | ||||||
|  |                 invalidargs++; | ||||||
|  |             break; | ||||||
|  |  | ||||||
|  |         case PICTGETVAR: | ||||||
|  |             /* | ||||||
|  |                re-parse commandline since second arg is string  | ||||||
|  |              */ | ||||||
|  |             validargs = sscanf( cmdline, "%s %d %s", cmd, &arg1, strarg ); | ||||||
|  |             if( 3 == validargs ) | ||||||
|  |                 TvCtrlPointGetVar( TV_SERVICE_PICTURE, arg1, strarg ); | ||||||
|  |             else | ||||||
|  |                 invalidargs++; | ||||||
|  |             break; | ||||||
|  |  | ||||||
|  |         case PRTDEV: | ||||||
|  |             TvCtrlPointPrintDevice( arg1 ); | ||||||
|  |             break; | ||||||
|  |  | ||||||
|  |         case LSTDEV: | ||||||
|  |             TvCtrlPointPrintList(); | ||||||
|  |             break; | ||||||
|  |  | ||||||
|  |         case REFRESH: | ||||||
|  |             TvCtrlPointRefresh(); | ||||||
|  |             break; | ||||||
|  |  | ||||||
|  |         case EXITCMD: | ||||||
|  |             rc = TvCtrlPointStop(); | ||||||
|  |             exit( rc ); | ||||||
|  |             break; | ||||||
|  |  | ||||||
|  |         default: | ||||||
|  |             SampleUtil_Print( "Command not implemented; see 'Help'" ); | ||||||
|  |             break; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     if( invalidargs ) | ||||||
|  |         SampleUtil_Print( "Invalid args in command; see 'Help'" ); | ||||||
|  |  | ||||||
|  |     return TV_SUCCESS; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | int | ||||||
|  | device_main( int argc, char **argv ) | ||||||
|  | { | ||||||
|  |  | ||||||
|  |     unsigned int portTemp = 0; | ||||||
|  |     char *ip_address = NULL, | ||||||
|  |      *desc_doc_name = NULL, | ||||||
|  |      *web_dir_path = NULL; | ||||||
|  |     unsigned int port = 0; | ||||||
|  |  | ||||||
|  |     int i = 0; | ||||||
|  |  | ||||||
|  |     SampleUtil_Initialize( linux_print ); | ||||||
|  |  | ||||||
|  |     // Parse options | ||||||
|  |     for( i = 1; i < argc; i++ ) { | ||||||
|  |         if( strcmp( argv[i], "-ip" ) == 0 ) { | ||||||
|  |             ip_address = argv[++i]; | ||||||
|  |         } else if( strcmp( argv[i], "-port" ) == 0 ) { | ||||||
|  |             sscanf( argv[++i], "%u", &portTemp ); | ||||||
|  |         } else if( strcmp( argv[i], "-desc" ) == 0 ) { | ||||||
|  |             desc_doc_name = argv[++i]; | ||||||
|  |         } else if( strcmp( argv[i], "-webdir" ) == 0 ) { | ||||||
|  |             web_dir_path = argv[++i]; | ||||||
|  |         } else if( strcmp( argv[i], "-help" ) == 0 ) { | ||||||
|  |             SampleUtil_Print( "Usage: %s -ip ipaddress -port port" | ||||||
|  |                               " -desc desc_doc_name -webdir web_dir_path" | ||||||
|  |                               " -help (this message)\n", argv[0] ); | ||||||
|  |             SampleUtil_Print( "\tipaddress:     IP address of the device" | ||||||
|  |                               " (must match desc. doc)\n" ); | ||||||
|  |             SampleUtil_Print( "\t\te.g.: 192.168.0.4\n" ); | ||||||
|  |             SampleUtil_Print( "\tport:          Port number to use for " | ||||||
|  |                               "receiving UPnP messages (must match desc. doc)\n" ); | ||||||
|  |             SampleUtil_Print( "\t\te.g.: 5431\n" ); | ||||||
|  |             SampleUtil_Print | ||||||
|  |                 ( "\tdesc_doc_name: name of device description document\n" ); | ||||||
|  |             SampleUtil_Print( "\t\te.g.: tvcombodesc.xml\n" ); | ||||||
|  |             SampleUtil_Print | ||||||
|  |                 ( "\tweb_dir_path: Filesystem path where web files " | ||||||
|  |                   "related to the device are stored\n" ); | ||||||
|  |             SampleUtil_Print( "\t\te.g.: /upnp/sample/web\n" ); | ||||||
|  |             return 1; | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     port = ( unsigned short )portTemp; | ||||||
|  |  | ||||||
|  |     return TvDeviceStart( | ||||||
|  |         ip_address, port, desc_doc_name, web_dir_path, linux_print ); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | int | ||||||
|  | main( int argc, char **argv ) | ||||||
|  | { | ||||||
|  |     int rc; | ||||||
|  |     ithread_t cmdloop_thread; | ||||||
|  |     int sig; | ||||||
|  |     sigset_t sigs_to_catch; | ||||||
|  |     int code; | ||||||
|  |  | ||||||
|  |     device_main(argc, argv); | ||||||
|  |     rc = TvCtrlPointStart( linux_print, NULL ); | ||||||
|  |     if( rc != TV_SUCCESS ) { | ||||||
|  |         SampleUtil_Print( "Error starting UPnP TV Control Point" ); | ||||||
|  |         return rc; | ||||||
|  |     } | ||||||
|  |     // start a command loop thread | ||||||
|  |     code = | ||||||
|  |         ithread_create( &cmdloop_thread, NULL, TvCtrlPointCommandLoop, | ||||||
|  |                         NULL ); | ||||||
|  |  | ||||||
|  |     /* | ||||||
|  |        Catch Ctrl-C and properly shutdown  | ||||||
|  |      */ | ||||||
|  |     sigemptyset( &sigs_to_catch ); | ||||||
|  |     sigaddset( &sigs_to_catch, SIGINT ); | ||||||
|  |     sigwait( &sigs_to_catch, &sig ); | ||||||
|  |  | ||||||
|  |     SampleUtil_Print( "Shutting down on signal %d...", sig ); | ||||||
|  |     TvDeviceStop(); | ||||||
|  |     rc = TvCtrlPointStop(); | ||||||
|  |      | ||||||
|  |     return rc; | ||||||
|  | } | ||||||
|  |  | ||||||
							
								
								
									
										1409
									
								
								upnp/sample/tvcombo/upnp_tv_ctrlpt.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1409
									
								
								upnp/sample/tvcombo/upnp_tv_ctrlpt.c
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										158
									
								
								upnp/sample/tvcombo/upnp_tv_ctrlpt.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										158
									
								
								upnp/sample/tvcombo/upnp_tv_ctrlpt.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,158 @@ | |||||||
|  | /////////////////////////////////////////////////////////////////////////// | ||||||
|  | // | ||||||
|  | // Copyright (c) 2000-2003 Intel Corporation  | ||||||
|  | // 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 name of Intel Corporation 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 INTEL 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 UPNP_TV_CTRLPT_H | ||||||
|  | #define UPNP_TV_CTRLPT_H | ||||||
|  |  | ||||||
|  | #ifdef __cplusplus | ||||||
|  | extern "C" { | ||||||
|  | #endif | ||||||
|  |  | ||||||
|  | #include <stdio.h> | ||||||
|  |  | ||||||
|  | #include "ithread.h" | ||||||
|  | #include <unistd.h> | ||||||
|  | #include <stdarg.h> | ||||||
|  | #include <stdlib.h> | ||||||
|  | #include <signal.h> | ||||||
|  | #include <string.h> | ||||||
|  |  | ||||||
|  | #include "upnp.h" | ||||||
|  | #include "upnptools.h" | ||||||
|  | #include "sample_util.h" | ||||||
|  |  | ||||||
|  | #define TV_SERVICE_SERVCOUNT	2 | ||||||
|  | #define TV_SERVICE_CONTROL		0 | ||||||
|  | #define TV_SERVICE_PICTURE		1 | ||||||
|  |  | ||||||
|  | #define TV_CONTROL_VARCOUNT		3 | ||||||
|  | #define TV_CONTROL_POWER		0 | ||||||
|  | #define TV_CONTROL_CHANNEL		1 | ||||||
|  | #define TV_CONTROL_VOLUME		2 | ||||||
|  |  | ||||||
|  | #define TV_PICTURE_VARCOUNT		4 | ||||||
|  | #define TV_PICTURE_COLOR		0 | ||||||
|  | #define TV_PICTURE_TINT			1 | ||||||
|  | #define TV_PICTURE_CONTRAST		2 | ||||||
|  | #define TV_PICTURE_BRIGHTNESS	3 | ||||||
|  |  | ||||||
|  | #define TV_MAX_VAL_LEN			5 | ||||||
|  |  | ||||||
|  | #define TV_SUCCESS				0 | ||||||
|  | #define TV_ERROR				(-1) | ||||||
|  | #define TV_WARNING				1 | ||||||
|  |  | ||||||
|  | /* This should be the maximum VARCOUNT from above */ | ||||||
|  | #define TV_MAXVARS				TV_PICTURE_VARCOUNT | ||||||
|  |  | ||||||
|  | extern char TvDeviceType[]; | ||||||
|  | extern char *TvServiceType[]; | ||||||
|  | extern char *TvServiceName[]; | ||||||
|  | extern char *TvVarName[TV_SERVICE_SERVCOUNT][TV_MAXVARS]; | ||||||
|  | extern char TvVarCount[]; | ||||||
|  |  | ||||||
|  | struct tv_service { | ||||||
|  |     char ServiceId[NAME_SIZE]; | ||||||
|  |     char ServiceType[NAME_SIZE]; | ||||||
|  |     char *VariableStrVal[TV_MAXVARS]; | ||||||
|  |     char EventURL[NAME_SIZE]; | ||||||
|  |     char ControlURL[NAME_SIZE]; | ||||||
|  |     char SID[NAME_SIZE]; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | extern struct TvDeviceNode *GlobalDeviceList; | ||||||
|  |  | ||||||
|  | struct TvDevice { | ||||||
|  |     char UDN[250]; | ||||||
|  |     char DescDocURL[250]; | ||||||
|  |     char FriendlyName[250]; | ||||||
|  |     char PresURL[250]; | ||||||
|  |     int  AdvrTimeOut; | ||||||
|  |     struct tv_service TvService[TV_SERVICE_SERVCOUNT]; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | struct TvDeviceNode { | ||||||
|  |     struct TvDevice device; | ||||||
|  |     struct TvDeviceNode *next; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | extern ithread_mutex_t DeviceListMutex; | ||||||
|  |  | ||||||
|  | extern UpnpClient_Handle ctrlpt_handle; | ||||||
|  |  | ||||||
|  | void	TvCtrlPointPrintHelp( void ); | ||||||
|  | int		TvCtrlPointDeleteNode(struct TvDeviceNode*); | ||||||
|  | int		TvCtrlPointRemoveDevice(char*); | ||||||
|  | int		TvCtrlPointRemoveAll( void ); | ||||||
|  | int		TvCtrlPointRefresh( void ); | ||||||
|  |  | ||||||
|  |  | ||||||
|  | int		TvCtrlPointSendAction(int, int, char *, char **, char **, int); | ||||||
|  | int		TvCtrlPointSendActionNumericArg(int devnum, int service, char *actionName, char *paramName, int paramValue); | ||||||
|  | int		TvCtrlPointSendPowerOn(int devnum); | ||||||
|  | int		TvCtrlPointSendPowerOff(int devnum); | ||||||
|  | int		TvCtrlPointSendSetChannel(int, int); | ||||||
|  | int		TvCtrlPointSendSetVolume(int, int); | ||||||
|  | int		TvCtrlPointSendSetColor(int, int); | ||||||
|  | int		TvCtrlPointSendSetTint(int, int); | ||||||
|  | int		TvCtrlPointSendSetContrast(int, int); | ||||||
|  | int		TvCtrlPointSendSetBrightness(int, int); | ||||||
|  |  | ||||||
|  | int		TvCtrlPointGetVar(int, int, char*); | ||||||
|  | int		TvCtrlPointGetPower(int devnum); | ||||||
|  | int		TvCtrlPointGetChannel(int); | ||||||
|  | int		TvCtrlPointGetVolume(int); | ||||||
|  | int		TvCtrlPointGetColor(int); | ||||||
|  | int		TvCtrlPointGetTint(int); | ||||||
|  | int		TvCtrlPointGetContrast(int); | ||||||
|  | int		TvCtrlPointGetBrightness(int); | ||||||
|  |  | ||||||
|  | int		TvCtrlPointGetDevice(int, struct TvDeviceNode **); | ||||||
|  | int		TvCtrlPointPrintList( void ); | ||||||
|  | int		TvCtrlPointPrintDevice(int); | ||||||
|  | void	TvCtrlPointAddDevice (IXML_Document *, char *, int);  | ||||||
|  | void    TvCtrlPointHandleGetVar(char *,char *,DOMString); | ||||||
|  | void	TvStateUpdate(char*,int, IXML_Document * , char **); | ||||||
|  | void	TvCtrlPointHandleEvent(Upnp_SID, int, IXML_Document *);  | ||||||
|  | void	TvCtrlPointHandleSubscribeUpdate(char *, Upnp_SID, int);  | ||||||
|  | int		TvCtrlPointCallbackEventHandler(Upnp_EventType, void *, void *); | ||||||
|  | void	TvCtrlPointVerifyTimeouts(int); | ||||||
|  | void	TvCtrlPointPrintCommands( void ); | ||||||
|  | void*	TvCtrlPointCommandLoop( void* ); | ||||||
|  | int		TvCtrlPointStart( print_string printFunctionPtr, state_update updateFunctionPtr ); | ||||||
|  | int		TvCtrlPointStop( void ); | ||||||
|  | int		TvCtrlPointProcessCommand( char *cmdline ); | ||||||
|  |  | ||||||
|  | #ifdef __cplusplus | ||||||
|  | }; | ||||||
|  | #endif | ||||||
|  |  | ||||||
|  | #endif //UPNP_TV_CTRLPT_H | ||||||
							
								
								
									
										2031
									
								
								upnp/sample/tvcombo/upnp_tv_device.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										2031
									
								
								upnp/sample/tvcombo/upnp_tv_device.c
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										638
									
								
								upnp/sample/tvcombo/upnp_tv_device.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										638
									
								
								upnp/sample/tvcombo/upnp_tv_device.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,638 @@ | |||||||
|  | /////////////////////////////////////////////////////////////////////////// | ||||||
|  | // | ||||||
|  | // Copyright (c) 2000-2003 Intel Corporation  | ||||||
|  | // 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 name of Intel Corporation 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 INTEL 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 UPNP_TV_DEVICE_H | ||||||
|  | #define UPNP_TV_DEVICE_H | ||||||
|  |  | ||||||
|  | #include <stdio.h> | ||||||
|  | #include <signal.h> | ||||||
|  |  | ||||||
|  | #ifdef __cplusplus | ||||||
|  | extern "C" { | ||||||
|  | #endif | ||||||
|  |  | ||||||
|  | #include "ithread.h" | ||||||
|  | #include <stdlib.h> | ||||||
|  | #include <unistd.h> | ||||||
|  | #include <string.h> | ||||||
|  | #include "upnp.h" | ||||||
|  | #include "sample_util.h" | ||||||
|  |  | ||||||
|  | //Color constants | ||||||
|  | #define MAX_COLOR 10 | ||||||
|  | #define MIN_COLOR 1 | ||||||
|  |  | ||||||
|  | //Brightness constants | ||||||
|  | #define MAX_BRIGHTNESS 10 | ||||||
|  | #define MIN_BRIGHTNESS 1 | ||||||
|  |  | ||||||
|  | //Power constants | ||||||
|  | #define POWER_ON 1 | ||||||
|  | #define POWER_OFF 0 | ||||||
|  |  | ||||||
|  | //Tint constants | ||||||
|  | #define MAX_TINT 10 | ||||||
|  | #define MIN_TINT 1 | ||||||
|  |  | ||||||
|  | //Volume constants | ||||||
|  | #define MAX_VOLUME 10 | ||||||
|  | #define MIN_VOLUME 1 | ||||||
|  |  | ||||||
|  | //Contrast constants | ||||||
|  | #define MAX_CONTRAST 10 | ||||||
|  | #define MIN_CONTRAST 1 | ||||||
|  |  | ||||||
|  | //Channel constants | ||||||
|  | #define MAX_CHANNEL 100 | ||||||
|  | #define MIN_CHANNEL 1 | ||||||
|  |  | ||||||
|  | //Number of services. | ||||||
|  | #define TV_SERVICE_SERVCOUNT  2 | ||||||
|  |  | ||||||
|  | //Index of control service | ||||||
|  | #define TV_SERVICE_CONTROL    0 | ||||||
|  |  | ||||||
|  | //Index of picture service | ||||||
|  | #define TV_SERVICE_PICTURE    1 | ||||||
|  |  | ||||||
|  | //Number of control variables | ||||||
|  | #define TV_CONTROL_VARCOUNT   3 | ||||||
|  |  | ||||||
|  | //Index of power variable | ||||||
|  | #define TV_CONTROL_POWER      0 | ||||||
|  |  | ||||||
|  | //Index of channel variable | ||||||
|  | #define TV_CONTROL_CHANNEL    1 | ||||||
|  |  | ||||||
|  | //Index of volume variable | ||||||
|  | #define TV_CONTROL_VOLUME     2 | ||||||
|  |  | ||||||
|  | //Number of picture variables | ||||||
|  | #define TV_PICTURE_VARCOUNT   4 | ||||||
|  |  | ||||||
|  | //Index of color variable | ||||||
|  | #define TV_PICTURE_COLOR      0 | ||||||
|  |  | ||||||
|  | //Index of tint variable | ||||||
|  | #define TV_PICTURE_TINT       1 | ||||||
|  |  | ||||||
|  | //Index of contrast variable | ||||||
|  | #define TV_PICTURE_CONTRAST   2 | ||||||
|  |  | ||||||
|  | //Index of brightness variable | ||||||
|  | #define TV_PICTURE_BRIGHTNESS 3 | ||||||
|  |  | ||||||
|  | //Max value length | ||||||
|  | #define TV_MAX_VAL_LEN 5 | ||||||
|  |  | ||||||
|  | //Max actions | ||||||
|  | #define TV_MAXACTIONS 12 | ||||||
|  |  | ||||||
|  | /* This should be the maximum VARCOUNT from above */ | ||||||
|  | #define TV_MAXVARS TV_PICTURE_VARCOUNT | ||||||
|  |  | ||||||
|  |  | ||||||
|  | extern char TvDeviceType[]; | ||||||
|  |  | ||||||
|  | extern char *TvServiceType[]; | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | /****************************************************************************** | ||||||
|  |  * upnp_action | ||||||
|  |  * | ||||||
|  |  * Description:  | ||||||
|  |  *       Prototype for all actions. For each action that a service  | ||||||
|  |  *       implements, there is a corresponding function with this prototype. | ||||||
|  |  *       Pointers to these functions, along with action names, are stored | ||||||
|  |  *       in the service table. When an action request comes in the action | ||||||
|  |  *       name is matched, and the appropriate function is called. | ||||||
|  |  *       Each function returns UPNP_E_SUCCESS, on success, and a nonzero  | ||||||
|  |  *       error code on failure. | ||||||
|  |  * | ||||||
|  |  * Parameters: | ||||||
|  |  * | ||||||
|  |  *    IXML_Document * request - document of action request | ||||||
|  |  *    IXML_Document **out - action result | ||||||
|  |  *    char **errorString - errorString (in case action was unsuccessful) | ||||||
|  |  * | ||||||
|  |  *****************************************************************************/ | ||||||
|  |  | ||||||
|  | typedef int (*upnp_action) (IXML_Document *request, IXML_Document **out,  | ||||||
|  | 			    char **errorString); | ||||||
|  |  | ||||||
|  | /* Structure for storing Tv Service | ||||||
|  |    identifiers and state table */ | ||||||
|  | struct TvService { | ||||||
|  |    | ||||||
|  |   char UDN[NAME_SIZE]; /* Universally Unique Device Name */ | ||||||
|  |   char ServiceId[NAME_SIZE]; | ||||||
|  |   char ServiceType[NAME_SIZE]; | ||||||
|  |   char *VariableName[TV_MAXVARS];  | ||||||
|  |   char *VariableStrVal[TV_MAXVARS]; | ||||||
|  |   char *ActionNames[TV_MAXACTIONS]; | ||||||
|  |   upnp_action actions[TV_MAXACTIONS]; | ||||||
|  |   unsigned int  VariableCount; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | //Array of service structures | ||||||
|  | extern struct TvService tv_service_table[]; | ||||||
|  |  | ||||||
|  | //Device handle returned from sdk | ||||||
|  | extern UpnpDevice_Handle device_handle; | ||||||
|  |  | ||||||
|  |  | ||||||
|  | /* Mutex for protecting the global state table data | ||||||
|  |    in a multi-threaded, asynchronous environment. | ||||||
|  |    All functions should lock this mutex before reading | ||||||
|  |    or writing the state table data. */ | ||||||
|  | extern ithread_mutex_t TVDevMutex; | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | /****************************************************************************** | ||||||
|  |  * SetActionTable | ||||||
|  |  * | ||||||
|  |  * Description:  | ||||||
|  |  *       Initializes the action table for the specified service. | ||||||
|  |  *       Note that  | ||||||
|  |  *       knowledge of the service description is | ||||||
|  |  *       assumed.  Action names are hardcoded. | ||||||
|  |  * Parameters: | ||||||
|  |  *   int serviceType - one of TV_SERVICE_CONTROL or, TV_SERVICE_PICTURE | ||||||
|  |  *   struct TvService *out - service containing action table to set. | ||||||
|  |  * | ||||||
|  |  *****************************************************************************/ | ||||||
|  | int SetActionTable(int serviceType, struct TvService * out); | ||||||
|  |  | ||||||
|  | /****************************************************************************** | ||||||
|  |  * TvDeviceStateTableInit | ||||||
|  |  * | ||||||
|  |  * Description:  | ||||||
|  |  *       Initialize the device state table for  | ||||||
|  |  * 	 this TvDevice, pulling identifier info | ||||||
|  |  *       from the description Document.  Note that  | ||||||
|  |  *       knowledge of the service description is | ||||||
|  |  *       assumed.  State table variables and default | ||||||
|  |  *       values are currently hardcoded in this file | ||||||
|  |  *       rather than being read from service description | ||||||
|  |  *       documents. | ||||||
|  |  * | ||||||
|  |  * Parameters: | ||||||
|  |  *   DescDocURL -- The description document URL | ||||||
|  |  * | ||||||
|  |  *****************************************************************************/ | ||||||
|  | int TvDeviceStateTableInit(char*); | ||||||
|  |  | ||||||
|  |  | ||||||
|  | /****************************************************************************** | ||||||
|  |  * TvDeviceHandleSubscriptionRequest | ||||||
|  |  * | ||||||
|  |  * Description:  | ||||||
|  |  *       Called during a subscription request callback.  If the | ||||||
|  |  *       subscription request is for this device and either its | ||||||
|  |  *       control service or picture service, then accept it. | ||||||
|  |  * | ||||||
|  |  * Parameters: | ||||||
|  |  *   sr_event -- The subscription request event structure | ||||||
|  |  * | ||||||
|  |  *****************************************************************************/ | ||||||
|  | int TvDeviceHandleSubscriptionRequest(struct Upnp_Subscription_Request *); | ||||||
|  |  | ||||||
|  | /****************************************************************************** | ||||||
|  |  * TvDeviceHandleGetVarRequest | ||||||
|  |  * | ||||||
|  |  * Description:  | ||||||
|  |  *       Called during a get variable request callback.  If the | ||||||
|  |  *       request is for this device and either its control service | ||||||
|  |  *       or picture service, then respond with the variable value. | ||||||
|  |  * | ||||||
|  |  * Parameters: | ||||||
|  |  *   cgv_event -- The control get variable request event structure | ||||||
|  |  * | ||||||
|  |  *****************************************************************************/ | ||||||
|  | int TvDeviceHandleGetVarRequest(struct Upnp_State_Var_Request *); | ||||||
|  |  | ||||||
|  | /****************************************************************************** | ||||||
|  |  * TvDeviceHandleActionRequest | ||||||
|  |  * | ||||||
|  |  * Description:  | ||||||
|  |  *       Called during an action request callback.  If the | ||||||
|  |  *       request is for this device and either its control service | ||||||
|  |  *       or picture service, then perform the action and respond. | ||||||
|  |  * | ||||||
|  |  * Parameters: | ||||||
|  |  *   ca_event -- The control action request event structure | ||||||
|  |  * | ||||||
|  |  *****************************************************************************/ | ||||||
|  | int TvDeviceHandleActionRequest(struct Upnp_Action_Request *); | ||||||
|  |  | ||||||
|  | /****************************************************************************** | ||||||
|  |  * TvDeviceCallbackEventHandler | ||||||
|  |  * | ||||||
|  |  * Description:  | ||||||
|  |  *       The callback handler registered with the SDK while registering | ||||||
|  |  *       root device.  Dispatches the request to the appropriate procedure | ||||||
|  |  *       based on the value of EventType. The four requests handled by the  | ||||||
|  |  *       device are:  | ||||||
|  |  *                   1) Event Subscription requests.   | ||||||
|  |  *                   2) Get Variable requests.  | ||||||
|  |  *                   3) Action requests. | ||||||
|  |  * | ||||||
|  |  * Parameters: | ||||||
|  |  * | ||||||
|  |  *   EventType -- The type of callback event | ||||||
|  |  *   Event -- Data structure containing event data | ||||||
|  |  *   Cookie -- Optional data specified during callback registration | ||||||
|  |  * | ||||||
|  |  *****************************************************************************/ | ||||||
|  | int TvDeviceCallbackEventHandler(Upnp_EventType, void*, void*); | ||||||
|  |  | ||||||
|  | /****************************************************************************** | ||||||
|  |  * TvDeviceSetServiceTableVar | ||||||
|  |  * | ||||||
|  |  * Description:  | ||||||
|  |  *       Update the TvDevice service state table, and notify all subscribed  | ||||||
|  |  *       control points of the updated state.  Note that since this function | ||||||
|  |  *       blocks on the mutex TVDevMutex, to avoid a hang this function should  | ||||||
|  |  *       not be called within any other function that currently has this mutex  | ||||||
|  |  *       locked. | ||||||
|  |  * | ||||||
|  |  * Parameters: | ||||||
|  |  *   service -- The service number (TV_SERVICE_CONTROL or TV_SERVICE_PICTURE) | ||||||
|  |  *   variable -- The variable number (TV_CONTROL_POWER, TV_CONTROL_CHANNEL, | ||||||
|  |  *                   TV_CONTROL_VOLUME, TV_PICTURE_COLOR, TV_PICTURE_TINT, | ||||||
|  |  *                   TV_PICTURE_CONTRAST, or TV_PICTURE_BRIGHTNESS) | ||||||
|  |  *   value -- The string representation of the new value | ||||||
|  |  * | ||||||
|  |  *****************************************************************************/ | ||||||
|  | int TvDeviceSetServiceTableVar(unsigned int, unsigned int, char*); | ||||||
|  |  | ||||||
|  | //Control Service Actions | ||||||
|  |  | ||||||
|  | /****************************************************************************** | ||||||
|  |  * TvDevicePowerOn | ||||||
|  |  * | ||||||
|  |  * Description:  | ||||||
|  |  *       Turn the power on. | ||||||
|  |  * | ||||||
|  |  * Parameters: | ||||||
|  |  * | ||||||
|  |  *    IXML_Document * in - document of action request | ||||||
|  |  *    IXML_Document **out - action result | ||||||
|  |  *    char **errorString - errorString (in case action was unsuccessful) | ||||||
|  |  * | ||||||
|  |  *****************************************************************************/ | ||||||
|  | int TvDevicePowerOn(IN IXML_Document * in, OUT IXML_Document **out,  | ||||||
|  | 		    OUT char **errorString); | ||||||
|  |  | ||||||
|  | /****************************************************************************** | ||||||
|  |  * TvDevicePowerOff | ||||||
|  |  * | ||||||
|  |  * Description:  | ||||||
|  |  *       Turn the power off. | ||||||
|  |  * | ||||||
|  |  * Parameters: | ||||||
|  |  *     | ||||||
|  |  *    IXML_Document * in - document of action request | ||||||
|  |  *    IXML_Document **out - action result | ||||||
|  |  *    char **errorString - errorString (in case action was unsuccessful) | ||||||
|  |  * | ||||||
|  |  *****************************************************************************/ | ||||||
|  | int TvDevicePowerOff(IN IXML_Document *in, OUT IXML_Document **out,  | ||||||
|  | 		     OUT char **errorString); | ||||||
|  |  | ||||||
|  | /****************************************************************************** | ||||||
|  |  * TvDeviceSetChannel | ||||||
|  |  * | ||||||
|  |  * Description:  | ||||||
|  |  *       Change the channel, update the TvDevice control service | ||||||
|  |  *       state table, and notify all subscribed control points of the | ||||||
|  |  *       updated state. | ||||||
|  |  * | ||||||
|  |  * Parameters: | ||||||
|  |  *     | ||||||
|  |  *    IXML_Document * in -  action request document | ||||||
|  |  *    IXML_Document **out - action result document | ||||||
|  |  *    char **errorString - errorString (in case action was unsuccessful) | ||||||
|  |  * | ||||||
|  |  *****************************************************************************/ | ||||||
|  | int TvDeviceSetChannel(IN IXML_Document *in, OUT IXML_Document **out,  | ||||||
|  | 		       OUT char **errorString); | ||||||
|  |  | ||||||
|  | /****************************************************************************** | ||||||
|  |  * TvDeviceIncreaseChannel | ||||||
|  |  * | ||||||
|  |  * Description:  | ||||||
|  |  *       Increase the channel.   | ||||||
|  |  * | ||||||
|  |  * Parameters: | ||||||
|  |  *    | ||||||
|  |  *    IXML_Document * in -  action request document | ||||||
|  |  *    IXML_Document **out - action result document | ||||||
|  |  *    char **errorString - errorString (in case action was unsuccessful) | ||||||
|  |  * | ||||||
|  |  *****************************************************************************/ | ||||||
|  | int TvDeviceIncreaseChannel(IN IXML_Document *in, OUT IXML_Document **out,  | ||||||
|  | 			    OUT char **errorString); | ||||||
|  | /****************************************************************************** | ||||||
|  |  * TvDeviceDecreaseChannel | ||||||
|  |  * | ||||||
|  |  * Description:  | ||||||
|  |  *       Decrease the channel.   | ||||||
|  |  * | ||||||
|  |  * Parameters: | ||||||
|  |  *    | ||||||
|  |  *    IXML_Document * in -  action request document | ||||||
|  |  *    IXML_Document **out - action result document | ||||||
|  |  *    char **errorString - errorString (in case action was unsuccessful) | ||||||
|  |  * | ||||||
|  |  *****************************************************************************/ | ||||||
|  | int TvDeviceDecreaseChannel(IN IXML_Document *in, OUT IXML_Document **out,  | ||||||
|  | 			    OUT char **errorString); | ||||||
|  | /****************************************************************************** | ||||||
|  |  * TvDeviceSetVolume | ||||||
|  |  * | ||||||
|  |  * Description:  | ||||||
|  |  *       Change the volume, update the TvDevice control service | ||||||
|  |  *       state table, and notify all subscribed control points of the | ||||||
|  |  *       updated state. | ||||||
|  |  * | ||||||
|  |  * Parameters: | ||||||
|  |  *   | ||||||
|  |  *    IXML_Document * in -  action request document | ||||||
|  |  *    IXML_Document **out - action result document | ||||||
|  |  *    char **errorString - errorString (in case action was unsuccessful) | ||||||
|  |  * | ||||||
|  |  *****************************************************************************/ | ||||||
|  | int TvDeviceSetVolume(IN IXML_Document *in, OUT IXML_Document **out,  | ||||||
|  | 		      OUT char **errorString); | ||||||
|  |  | ||||||
|  | /****************************************************************************** | ||||||
|  |  * TvDeviceIncreaseVolume | ||||||
|  |  * | ||||||
|  |  * Description:  | ||||||
|  |  *       Increase the volume.  | ||||||
|  |  * | ||||||
|  |  * Parameters: | ||||||
|  |  *    | ||||||
|  |  * | ||||||
|  |  *    IXML_Document * in -  action request document | ||||||
|  |  *    IXML_Document **out - action result document | ||||||
|  |  *    char **errorString - errorString (in case action was unsuccessful) | ||||||
|  |  *****************************************************************************/ | ||||||
|  | int TvDeviceIncreaseVolume(IN IXML_Document *in, OUT IXML_Document**out,  | ||||||
|  | 			   OUT char **errorString); | ||||||
|  |  | ||||||
|  |  | ||||||
|  | /****************************************************************************** | ||||||
|  |  * TvDeviceDecreaseVolume | ||||||
|  |  * | ||||||
|  |  * Description:  | ||||||
|  |  *       Decrease the volume. | ||||||
|  |  * | ||||||
|  |  * Parameters: | ||||||
|  |  *    | ||||||
|  |  *    IXML_Document * in -  action request document | ||||||
|  |  *    IXML_Document **out - action result document | ||||||
|  |  *    char **errorString - errorString (in case action was unsuccessful) | ||||||
|  |  * | ||||||
|  |  *****************************************************************************/ | ||||||
|  | int TvDeviceDecreaseVolume(IN IXML_Document *in, OUT IXML_Document**out,  | ||||||
|  | 			   OUT char **errorString); | ||||||
|  |  | ||||||
|  |  | ||||||
|  | //Picture Service Actions | ||||||
|  |  | ||||||
|  | /****************************************************************************** | ||||||
|  |  * TvDeviceSetColor | ||||||
|  |  * | ||||||
|  |  * Description:  | ||||||
|  |  *       Change the color, update the TvDevice picture service | ||||||
|  |  *       state table, and notify all subscribed control points of the | ||||||
|  |  *       updated state. | ||||||
|  |  * | ||||||
|  |  * Parameters: | ||||||
|  |  *    | ||||||
|  |  *    IXML_Document * in -  action request document | ||||||
|  |  *    IXML_Document **out - action result document | ||||||
|  |  *    char **errorString - errorString (in case action was unsuccessful) | ||||||
|  |  * | ||||||
|  |  *****************************************************************************/ | ||||||
|  | int TvDeviceSetColor(IN IXML_Document *in, OUT IXML_Document **out,  | ||||||
|  | 		     OUT char **errorString); | ||||||
|  |  | ||||||
|  |  | ||||||
|  | /****************************************************************************** | ||||||
|  |  * TvDeviceIncreaseColor | ||||||
|  |  * | ||||||
|  |  * Description:  | ||||||
|  |  *       Increase the color. | ||||||
|  |  * | ||||||
|  |  * Parameters: | ||||||
|  |  * | ||||||
|  |  *    IXML_Document * in -  action request document | ||||||
|  |  *    IXML_Document **out - action result document | ||||||
|  |  *    char **errorString - errorString (in case action was unsuccessful) | ||||||
|  |  *****************************************************************************/ | ||||||
|  | int TvDeviceIncreaseColor(IN IXML_Document * in, OUT IXML_Document **out,  | ||||||
|  | 			  OUT char **errorString); | ||||||
|  |  | ||||||
|  | /****************************************************************************** | ||||||
|  |  * TvDeviceDecreaseColor | ||||||
|  |  * | ||||||
|  |  * Description:  | ||||||
|  |  *       Decrease the color.   | ||||||
|  |  * | ||||||
|  |  * Parameters: | ||||||
|  |  *    | ||||||
|  |  *    IXML_Document * in -  action request document | ||||||
|  |  *    IXML_Document **out - action result document | ||||||
|  |  *    char **errorString - errorString (in case action was unsuccessful) | ||||||
|  |  *****************************************************************************/ | ||||||
|  | int TvDeviceDecreaseColor(IN IXML_Document * in, OUT IXML_Document **out,  | ||||||
|  | 			  OUT char **errorString); | ||||||
|  |  | ||||||
|  | /****************************************************************************** | ||||||
|  |  * TvDeviceSetTint | ||||||
|  |  * | ||||||
|  |  * Description:  | ||||||
|  |  *       Change the tint, update the TvDevice picture service | ||||||
|  |  *       state table, and notify all subscribed control points of the | ||||||
|  |  *       updated state. | ||||||
|  |  * | ||||||
|  |  * Parameters: | ||||||
|  |  * | ||||||
|  |  *    IXML_Document * in -  action request document | ||||||
|  |  *    IXML_Document **out - action result document | ||||||
|  |  *    char **errorString - errorString (in case action was unsuccessful) | ||||||
|  |  * | ||||||
|  |  *****************************************************************************/ | ||||||
|  | int TvDeviceSetTint(IN IXML_Document *in, OUT IXML_Document **out,  | ||||||
|  | 		    OUT char **errorString); | ||||||
|  |  | ||||||
|  | /****************************************************************************** | ||||||
|  |  * TvDeviceIncreaseTint | ||||||
|  |  * | ||||||
|  |  * Description:  | ||||||
|  |  *       Increase tint. | ||||||
|  |  * | ||||||
|  |  * Parameters: | ||||||
|  |  *    | ||||||
|  |  *    IXML_Document * in -  action request document | ||||||
|  |  *    IXML_Document **out - action result document | ||||||
|  |  *    char **errorString - errorString (in case action was unsuccessful) | ||||||
|  |  * | ||||||
|  |  *****************************************************************************/ | ||||||
|  | int TvDeviceIncreaseTint(IN IXML_Document *in, OUT IXML_Document **out,  | ||||||
|  | 			 OUT char **errorString); | ||||||
|  |  | ||||||
|  | /****************************************************************************** | ||||||
|  |  * TvDeviceDecreaseTint | ||||||
|  |  * | ||||||
|  |  * Description:  | ||||||
|  |  *       Decrease tint. | ||||||
|  |  * | ||||||
|  |  * Parameters: | ||||||
|  |  *   | ||||||
|  |  *    IXML_Document * in -  action request document | ||||||
|  |  *    IXML_Document **out - action result document | ||||||
|  |  *    char **errorString - errorString (in case action was unsuccessful) | ||||||
|  |  * | ||||||
|  |  *****************************************************************************/ | ||||||
|  | int TvDeviceDecreaseTint(IN IXML_Document *in, OUT IXML_Document **out,  | ||||||
|  | 			 OUT char **errorString); | ||||||
|  |  | ||||||
|  | /***************************************************************************** | ||||||
|  |  * TvDeviceSetContrast | ||||||
|  |  * | ||||||
|  |  * Description:  | ||||||
|  |  *       Change the contrast, update the TvDevice picture service | ||||||
|  |  *       state table, and notify all subscribed control points of the | ||||||
|  |  *       updated state. | ||||||
|  |  * | ||||||
|  |  * Parameters: | ||||||
|  |  *    | ||||||
|  |  *    IXML_Document * in -  action request document | ||||||
|  |  *    IXML_Document **out - action result document | ||||||
|  |  *    char **errorString - errorString (in case action was unsuccessful) | ||||||
|  |  * | ||||||
|  |  ****************************************************************************/ | ||||||
|  | int TvDeviceSetContrast(IN IXML_Document *in, OUT IXML_Document **out,  | ||||||
|  | 			OUT char **errorString); | ||||||
|  |  | ||||||
|  | /****************************************************************************** | ||||||
|  |  * TvDeviceIncreaseContrast | ||||||
|  |  * | ||||||
|  |  * Description:  | ||||||
|  |  * | ||||||
|  |  *      Increase the contrast. | ||||||
|  |  * | ||||||
|  |  * Parameters: | ||||||
|  |  *        | ||||||
|  |  *    IXML_Document * in -  action request document | ||||||
|  |  *    IXML_Document **out - action result document | ||||||
|  |  *    char **errorString - errorString (in case action was unsuccessful) | ||||||
|  |  * | ||||||
|  |  *****************************************************************************/ | ||||||
|  | int TvDeviceIncreaseContrast(IN IXML_Document *in, OUT IXML_Document **out,  | ||||||
|  | 			     OUT char **errorString); | ||||||
|  | /****************************************************************************** | ||||||
|  |  * TvDeviceDecreaseContrast | ||||||
|  |  * | ||||||
|  |  * Description:  | ||||||
|  |  *      Decrease the contrast. | ||||||
|  |  * | ||||||
|  |  * Parameters: | ||||||
|  |  *           | ||||||
|  |  *    IXML_Document * in -  action request document | ||||||
|  |  *    IXML_Document **out - action result document | ||||||
|  |  *    char **errorString - errorString (in case action was unsuccessful) | ||||||
|  |  * | ||||||
|  |  *****************************************************************************/ | ||||||
|  | int TvDeviceDecreaseContrast(IN IXML_Document *in, OUT IXML_Document **out,  | ||||||
|  | 			     OUT char **errorString); | ||||||
|  |  | ||||||
|  | /****************************************************************************** | ||||||
|  |  * TvDeviceSetBrightness | ||||||
|  |  * | ||||||
|  |  * Description:  | ||||||
|  |  *       Change the brightness, update the TvDevice picture service | ||||||
|  |  *       state table, and notify all subscribed control points of the | ||||||
|  |  *       updated state. | ||||||
|  |  * | ||||||
|  |  * Parameters: | ||||||
|  |  *   brightness -- The brightness value to change to. | ||||||
|  |  * | ||||||
|  |  *****************************************************************************/ | ||||||
|  | int TvDeviceSetBrightness(IN IXML_Document *in, OUT IXML_Document **out,  | ||||||
|  | 			  OUT char **errorString); | ||||||
|  |  | ||||||
|  | /****************************************************************************** | ||||||
|  |  * TvDeviceIncreaseBrightness | ||||||
|  |  * | ||||||
|  |  * Description:  | ||||||
|  |  *       Increase brightness. | ||||||
|  |  * | ||||||
|  |  * Parameters: | ||||||
|  |  * | ||||||
|  |  *    IXML_Document * in -  action request document | ||||||
|  |  *    IXML_Document **out - action result document | ||||||
|  |  *    char **errorString - errorString (in case action was unsuccessful) | ||||||
|  |  * | ||||||
|  |  *****************************************************************************/ | ||||||
|  | int TvDeviceIncreaseBrightness(IN IXML_Document *in, OUT IXML_Document **out,  | ||||||
|  | 			       OUT char **errorString); | ||||||
|  |  | ||||||
|  | /****************************************************************************** | ||||||
|  |  * TvDeviceDecreaseBrightness | ||||||
|  |  * | ||||||
|  |  * Description:  | ||||||
|  |  *       Decrease brightnesss. | ||||||
|  |  * | ||||||
|  |  * Parameters: | ||||||
|  |  *    IXML_Document * in -  action request document | ||||||
|  |  *    IXML_Document **out - action result document | ||||||
|  |  *    char **errorString - errorString (in case action was unsuccessful) | ||||||
|  |  * | ||||||
|  |  *****************************************************************************/ | ||||||
|  | int TvDeviceDecreaseBrightness(IN IXML_Document *in, OUT IXML_Document **out,  | ||||||
|  | 			       OUT char **errorString); | ||||||
|  |  | ||||||
|  | int TvDeviceStart(char * ip_address, unsigned short port,char * desc_doc_name, | ||||||
|  | 				  char *web_dir_path, print_string pfun); | ||||||
|  | int TvDeviceStop(); | ||||||
|  |  | ||||||
|  | #ifdef __cplusplus | ||||||
|  | } | ||||||
|  | #endif | ||||||
|  |  | ||||||
|  | #endif | ||||||
							
								
								
									
										37
									
								
								upnp/sample/web/tvcombodesc.xml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										37
									
								
								upnp/sample/web/tvcombodesc.xml
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,37 @@ | |||||||
|  | <?xml version="1.0"?> | ||||||
|  | <root xmlns="urn:schemas-upnp-org:device-1-0"> | ||||||
|  |   <specVersion> | ||||||
|  |     <major>1</major> | ||||||
|  |     <minor>0</minor> | ||||||
|  |   </specVersion> | ||||||
|  |   <device> | ||||||
|  |     <deviceType>urn:schemas-upnp-org:device:tvdevice:1</deviceType> | ||||||
|  |     <friendlyName>UPnP Television Emulator</friendlyName> | ||||||
|  |     <manufacturer>TV Manufacturer Name</manufacturer> | ||||||
|  |     <manufacturerURL>http://www.manufacturer.com</manufacturerURL> | ||||||
|  |     <modelDescription>UPnP Television Device Emulator 1.0</modelDescription> | ||||||
|  |     <modelName>TVEmulator</modelName> | ||||||
|  |     <modelNumber>1.0</modelNumber> | ||||||
|  |     <modelURL>http://www.manufacturer.com/TVEmulator/</modelURL> | ||||||
|  |     <serialNumber>123456789001</serialNumber> | ||||||
|  |     <UDN>uuid:Upnp-TVEmulator-1_0-1234567890002</UDN> | ||||||
|  |     <UPC>123456789</UPC> | ||||||
|  |     <serviceList> | ||||||
|  |       <service> | ||||||
|  |         <serviceType>urn:schemas-upnp-org:service:tvcontrol:1</serviceType> | ||||||
|  |         <serviceId>urn:upnp-org:serviceId:tvcontrol1</serviceId> | ||||||
|  |         <controlURL>/upnp/control/tvcontrol1</controlURL> | ||||||
|  |         <eventSubURL>/upnp/event/tvcontrol1</eventSubURL> | ||||||
|  |         <SCPDURL>/tvcontrolSCPD.xml</SCPDURL> | ||||||
|  |       </service> | ||||||
|  |       <service> | ||||||
|  |         <serviceType>urn:schemas-upnp-org:service:tvpicture:1</serviceType> | ||||||
|  |         <serviceId>urn:upnp-org:serviceId:tvpicture1</serviceId> | ||||||
|  |         <controlURL>/upnp/control/tvpicture1</controlURL> | ||||||
|  |         <eventSubURL>/upnp/event/tvpicture1</eventSubURL> | ||||||
|  |         <SCPDURL>/tvpictureSCPD.xml</SCPDURL> | ||||||
|  |       </service> | ||||||
|  |     </serviceList> | ||||||
|  |    <presentationURL>/tvdevicepres.html</presentationURL> | ||||||
|  | </device> | ||||||
|  | </root> | ||||||
| @@ -7,7 +7,6 @@ | |||||||
|   </specVersion> |   </specVersion> | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| 
 |  | ||||||
|   <actionList> |   <actionList> | ||||||
| 
 | 
 | ||||||
|     <action> |     <action> | ||||||
| @@ -38,6 +37,12 @@ | |||||||
|       <name>SetChannel</name> |       <name>SetChannel</name> | ||||||
|       <argumentList> |       <argumentList> | ||||||
| 
 | 
 | ||||||
|  |         <argument> | ||||||
|  |         <name>Channel</name> | ||||||
|  |           <relatedStateVariable>Channel</relatedStateVariable> | ||||||
|  |           <direction>in</direction> | ||||||
|  |         </argument> | ||||||
|  | 
 | ||||||
|         <argument> |         <argument> | ||||||
|          <name>NewChannel</name> |          <name>NewChannel</name> | ||||||
|          <retval /> |          <retval /> | ||||||
| @@ -45,11 +50,6 @@ | |||||||
|          <direction>out</direction> |          <direction>out</direction> | ||||||
|         </argument> |         </argument> | ||||||
| 
 | 
 | ||||||
|         <argument> |  | ||||||
|         <name>Channel</name> |  | ||||||
|           <relatedStateVariable>Channel</relatedStateVariable> |  | ||||||
|           <direction>in</direction> |  | ||||||
|         </argument> |  | ||||||
|       </argumentList> |       </argumentList> | ||||||
|     </action> |     </action> | ||||||
| 
 | 
 | ||||||
| @@ -80,6 +80,11 @@ | |||||||
|     <action> |     <action> | ||||||
|       <name>SetVolume</name> |       <name>SetVolume</name> | ||||||
|       <argumentList> |       <argumentList> | ||||||
|  |         <argument> | ||||||
|  |         <name>Volume</name> | ||||||
|  |           <relatedStateVariable>Volume</relatedStateVariable> | ||||||
|  |           <direction>in</direction> | ||||||
|  |         </argument> | ||||||
| 
 | 
 | ||||||
|         <argument> |         <argument> | ||||||
|          <name>NewVolume</name> |          <name>NewVolume</name> | ||||||
| @@ -87,11 +92,6 @@ | |||||||
|          <relatedStateVariable>Volume</relatedStateVariable> |          <relatedStateVariable>Volume</relatedStateVariable> | ||||||
|          <direction>out</direction> |          <direction>out</direction> | ||||||
|          </argument> |          </argument> | ||||||
|         <argument> |  | ||||||
|         <name>Volume</name> |  | ||||||
|           <relatedStateVariable>Volume</relatedStateVariable> |  | ||||||
|           <direction>in</direction> |  | ||||||
|         </argument> |  | ||||||
|       </argumentList> |       </argumentList> | ||||||
|     </action> |     </action> | ||||||
| 
 | 
 | ||||||
| @@ -124,9 +124,6 @@ | |||||||
| 
 | 
 | ||||||
|   </actionList> |   </actionList> | ||||||
| 
 | 
 | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
|   <serviceStateTable> |   <serviceStateTable> | ||||||
| 
 | 
 | ||||||
|     <stateVariable sendEvents="yes"> |     <stateVariable sendEvents="yes"> | ||||||
| @@ -12,6 +12,12 @@ | |||||||
|     <action> |     <action> | ||||||
|       <name>SetColor</name> |       <name>SetColor</name> | ||||||
|       <argumentList> |       <argumentList> | ||||||
|  |         <argument> | ||||||
|  |         <name>Color</name> | ||||||
|  |           <relatedStateVariable>Color</relatedStateVariable> | ||||||
|  |           <direction>in</direction> | ||||||
|  |         </argument> | ||||||
|  | 
 | ||||||
|         <argument> |         <argument> | ||||||
|         <name>NewColor</name> |         <name>NewColor</name> | ||||||
|           <retval /> |           <retval /> | ||||||
| @@ -19,11 +25,6 @@ | |||||||
|           <direction>out</direction> |           <direction>out</direction> | ||||||
|         </argument> |         </argument> | ||||||
| 
 | 
 | ||||||
|         <argument> |  | ||||||
|         <name>Color</name> |  | ||||||
|           <relatedStateVariable>Color</relatedStateVariable> |  | ||||||
|           <direction>in</direction> |  | ||||||
|         </argument> |  | ||||||
|       </argumentList> |       </argumentList> | ||||||
|     </action> |     </action> | ||||||
| 
 | 
 | ||||||
| @@ -54,6 +55,11 @@ | |||||||
|     <action> |     <action> | ||||||
|       <name>SetTint</name> |       <name>SetTint</name> | ||||||
|       <argumentList> |       <argumentList> | ||||||
|  |         <argument> | ||||||
|  |         <name>Tint</name> | ||||||
|  |           <relatedStateVariable>Tint</relatedStateVariable> | ||||||
|  |           <direction>in</direction> | ||||||
|  |         </argument> | ||||||
|         <argument> |         <argument> | ||||||
|         <name>NewTint</name> |         <name>NewTint</name> | ||||||
|           <retval /> |           <retval /> | ||||||
| @@ -61,11 +67,6 @@ | |||||||
|           <direction>out</direction> |           <direction>out</direction> | ||||||
|         </argument> |         </argument> | ||||||
| 
 | 
 | ||||||
|         <argument> |  | ||||||
|         <name>Tint</name> |  | ||||||
|           <relatedStateVariable>Tint</relatedStateVariable> |  | ||||||
|           <direction>in</direction> |  | ||||||
|         </argument> |  | ||||||
|     </argumentList> |     </argumentList> | ||||||
|     </action> |     </action> | ||||||
| 
 | 
 | ||||||
| @@ -96,17 +97,17 @@ | |||||||
|     <action> |     <action> | ||||||
|       <name>SetContrast</name> |       <name>SetContrast</name> | ||||||
|       <argumentList> |       <argumentList> | ||||||
|  |     	<argument> | ||||||
|  |         	<name>Contrast</name> | ||||||
|  | 	          <relatedStateVariable>Contrast</relatedStateVariable> | ||||||
|  |     	      <direction>in</direction> | ||||||
|  |        	</argument> | ||||||
| 	    <argument> | 	    <argument> | ||||||
|         <name>NewContrast</name> |         <name>NewContrast</name> | ||||||
|           <retval /> |           <retval /> | ||||||
|           <relatedStateVariable>Contrast</relatedStateVariable> |           <relatedStateVariable>Contrast</relatedStateVariable> | ||||||
|           <direction>out</direction> |           <direction>out</direction> | ||||||
|         </argument>   |         </argument>   | ||||||
|         <argument> |  | ||||||
|         <name>Contrast</name> |  | ||||||
|           <relatedStateVariable>Contrast</relatedStateVariable> |  | ||||||
|           <direction>in</direction> |  | ||||||
|         </argument> |  | ||||||
|     </argumentList> |     </argumentList> | ||||||
|     </action> |     </action> | ||||||
| 
 | 
 | ||||||
| @@ -137,19 +138,17 @@ | |||||||
|     <action> |     <action> | ||||||
|       <name>SetBrightness</name> |       <name>SetBrightness</name> | ||||||
|       <argumentList> |       <argumentList> | ||||||
| 
 | 		<argument> | ||||||
|  |         <name>Brightness</name> | ||||||
|  |           <relatedStateVariable>Brightness</relatedStateVariable> | ||||||
|  |           <direction>in</direction> | ||||||
|  |         </argument> | ||||||
|          <argument> |          <argument> | ||||||
|         <name>NewBrightness</name> |         <name>NewBrightness</name> | ||||||
|           <retval /> |           <retval /> | ||||||
|           <relatedStateVariable>Brightness</relatedStateVariable> |           <relatedStateVariable>Brightness</relatedStateVariable> | ||||||
|           <direction>out</direction> |           <direction>out</direction> | ||||||
|         </argument> |         </argument> | ||||||
| 
 |  | ||||||
|         <argument> |  | ||||||
|         <name>Brightness</name> |  | ||||||
|           <relatedStateVariable>Brightness</relatedStateVariable> |  | ||||||
|           <direction>in</direction> |  | ||||||
|         </argument> |  | ||||||
|       </argumentList> |       </argumentList> | ||||||
|     </action> |     </action> | ||||||
| 
 | 
 | ||||||
| @@ -182,7 +181,6 @@ | |||||||
|   </actionList> |   </actionList> | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| 
 |  | ||||||
|   <serviceStateTable> |   <serviceStateTable> | ||||||
| 
 | 
 | ||||||
|     <stateVariable sendEvents="yes"> |     <stateVariable sendEvents="yes"> | ||||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -94,12 +94,13 @@ UpnpSetLogFileNames ( IN const char *ErrFileName, | |||||||
|  * |  * | ||||||
|  * Description: |  * Description: | ||||||
|  *	This functions initializes the log files |  *	This functions initializes the log files | ||||||
|  |  * | ||||||
|  * Returns: int |  * Returns: int | ||||||
|  *	-1 : If fails |  *	-1 : If fails | ||||||
|  *	UPNP_E_SUCCESS : if success |  *	UPNP_E_SUCCESS : if success | ||||||
|  ***************************************************************************/ |  ***************************************************************************/ | ||||||
| int | int | ||||||
| UpnpInitLog(  ) | UpnpInitLog() | ||||||
| { | { | ||||||
|     ithread_mutex_init( &GlobalDebugMutex, NULL ); |     ithread_mutex_init( &GlobalDebugMutex, NULL ); | ||||||
|  |  | ||||||
| @@ -116,7 +117,7 @@ UpnpInitLog(  ) | |||||||
| /*************************************************************************** | /*************************************************************************** | ||||||
|  * Function : UpnpSetLogLevel |  * Function : UpnpSetLogLevel | ||||||
|  *				 |  *				 | ||||||
|  * Parameters:	void |  * Parameters:	Upnp_LogLevel log_level | ||||||
|  * |  * | ||||||
|  * Description:							 |  * Description:							 | ||||||
|  *	This functions set the log level (see {\tt Upnp_LogLevel} |  *	This functions set the log level (see {\tt Upnp_LogLevel} | ||||||
| @@ -139,7 +140,7 @@ UpnpSetLogLevel (Upnp_LogLevel log_level) | |||||||
|  * Returns: void |  * Returns: void | ||||||
|  ***************************************************************************/ |  ***************************************************************************/ | ||||||
| void | void | ||||||
| UpnpCloseLog(  ) | UpnpCloseLog() | ||||||
| { | { | ||||||
|     if( DEBUG_TARGET == 1 ) { |     if( DEBUG_TARGET == 1 ) { | ||||||
|         fflush( ErrFileHnd ); |         fflush( ErrFileHnd ); | ||||||
| @@ -152,11 +153,47 @@ UpnpCloseLog(  ) | |||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
|  | /*************************************************************************** | ||||||
|  |  * Function : DebugAtThisLevel					 | ||||||
|  |  *									 | ||||||
|  |  * Parameters:			 | ||||||
|  |  *	IN Upnp_LogLevel DLevel: The level of the debug logging. It will decide  | ||||||
|  |  *		whether debug statement will go to standard output,  | ||||||
|  |  *		or any of the log files. | ||||||
|  |  *	IN Dbg_Module Module: debug will go in the name of this module | ||||||
|  |  *					 | ||||||
|  |  * Description:					 | ||||||
|  |  *	This functions returns true if debug output should be done in this | ||||||
|  |  *	module. | ||||||
|  |  * | ||||||
|  |  * Returns: int | ||||||
|  |  ***************************************************************************/ | ||||||
|  | #ifdef DEBUG | ||||||
|  | int DebugAtThisLevel( | ||||||
|  | 	IN Upnp_LogLevel DLevel, | ||||||
|  | 	IN Dbg_Module Module) | ||||||
|  | { | ||||||
|  | 	int ret = g_log_level >= DLevel; | ||||||
|  | 	ret &= | ||||||
|  | 		DEBUG_ALL || | ||||||
|  | 		(Module == SSDP  && DEBUG_SSDP ) || | ||||||
|  | 		(Module == SOAP  && DEBUG_SOAP ) || | ||||||
|  | 		(Module == GENA  && DEBUG_GENA ) || | ||||||
|  | 		(Module == TPOOL && DEBUG_TPOOL) || | ||||||
|  | 		(Module == MSERV && DEBUG_MSERV) || | ||||||
|  | 		(Module == DOM   && DEBUG_DOM  ) || | ||||||
|  | 		(Module == HTTP  && DEBUG_HTTP ); | ||||||
|  | 	 | ||||||
|  | 	return ret; | ||||||
|  | } | ||||||
|  | #endif | ||||||
|  |  | ||||||
|  |  | ||||||
| /*************************************************************************** | /*************************************************************************** | ||||||
|  * Function : UpnpPrintf					 |  * Function : UpnpPrintf					 | ||||||
|  *									 |  *									 | ||||||
|  * Parameters:			 |  * Parameters:			 | ||||||
|  *	IN Dbg_Level DLevel: The level of the debug logging. It will decide  |  *	IN Upnp_LogLevel DLevel: The level of the debug logging. It will decide  | ||||||
|  *		whether debug statement will go to standard output,  |  *		whether debug statement will go to standard output,  | ||||||
|  *		or any of the log files. |  *		or any of the log files. | ||||||
|  *	IN Dbg_Module Module: debug will go in the name of this module |  *	IN Dbg_Module Module: debug will go in the name of this module | ||||||
| @@ -173,71 +210,53 @@ UpnpCloseLog(  ) | |||||||
|  *	statement is coming |  *	statement is coming | ||||||
|  * Returns: void |  * Returns: void | ||||||
|  ***************************************************************************/ |  ***************************************************************************/ | ||||||
| DBGONLY( void UpnpPrintf( IN Upnp_LogLevel DLevel, | #ifdef DEBUG | ||||||
|  | void UpnpPrintf( | ||||||
|  | 	IN Upnp_LogLevel DLevel, | ||||||
| 	IN Dbg_Module Module, | 	IN Dbg_Module Module, | ||||||
| 	IN const char *DbgFileName, | 	IN const char *DbgFileName, | ||||||
| 	IN int DbgLineNo, | 	IN int DbgLineNo, | ||||||
| 	IN const char *FmtStr, | 	IN const char *FmtStr, | ||||||
|                           ... ) { | 	... ) | ||||||
|  | { | ||||||
| 	va_list ArgList; | 	va_list ArgList; | ||||||
|          va_start( ArgList, FmtStr ); | 	 | ||||||
|          if( g_log_level < DLevel ) return; if( DEBUG_ALL == 0 ) { | 	if (!DebugAtThisLevel(DLevel, Module)) { | ||||||
|          switch ( Module ) { | 		return; | ||||||
| case SSDP: |  | ||||||
|          if( DEBUG_SSDP == 1 ) break; |  | ||||||
|          else |  | ||||||
| return; case SOAP: |  | ||||||
|          if( DEBUG_SOAP == 1 ) break; |  | ||||||
|          else |  | ||||||
| return; case GENA: |  | ||||||
|          if( DEBUG_GENA == 1 ) break; |  | ||||||
|          else |  | ||||||
| return; case TPOOL: |  | ||||||
|          if( DEBUG_TPOOL == 1 ) break; |  | ||||||
|          else |  | ||||||
| return; case MSERV: |  | ||||||
|          if( DEBUG_MSERV == 1 ) break; |  | ||||||
|          else |  | ||||||
| return; case DOM: |  | ||||||
|          if( DEBUG_DOM == 1 ) break; |  | ||||||
|          else |  | ||||||
| return; case HTTP: |  | ||||||
|          if( DEBUG_HTTP == 1 ) break; |  | ||||||
|          else |  | ||||||
| return; case API: |  | ||||||
|          if( DEBUG_API == 1 ) break; |  | ||||||
|          else |  | ||||||
| return; default: |  | ||||||
|          return;} |  | ||||||
| 	} | 	} | ||||||
| 	 | 	 | ||||||
|          ithread_mutex_lock( &GlobalDebugMutex ); if( DEBUG_TARGET == 0 ) { | 	ithread_mutex_lock(&GlobalDebugMutex); | ||||||
|  | 	va_start(ArgList, FmtStr); | ||||||
|  | 	if (!DEBUG_TARGET) { | ||||||
| 		if( DbgFileName ) { | 		if( DbgFileName ) { | ||||||
|          UpnpDisplayFileAndLine( stdout, DbgFileName, DbgLineNo );} | 			UpnpDisplayFileAndLine(stdout, DbgFileName, DbgLineNo); | ||||||
|          vfprintf( stdout, FmtStr, ArgList ); fflush( stdout );} |  | ||||||
|          else |  | ||||||
|          { |  | ||||||
|          if( DLevel == 0 ) { |  | ||||||
|          if( DbgFileName ) { |  | ||||||
|          UpnpDisplayFileAndLine( ErrFileHnd, DbgFileName, DbgLineNo );} |  | ||||||
|          vfprintf( ErrFileHnd, FmtStr, ArgList ); fflush( ErrFileHnd );} |  | ||||||
|          else |  | ||||||
|          { |  | ||||||
|          if( DbgFileName ) { |  | ||||||
|          UpnpDisplayFileAndLine( InfoFileHnd, DbgFileName, DbgLineNo );} |  | ||||||
|          vfprintf( InfoFileHnd, FmtStr, ArgList ); fflush( InfoFileHnd );} |  | ||||||
| 		} | 		} | ||||||
|          va_end( ArgList ); ithread_mutex_unlock( &GlobalDebugMutex );} | 		vfprintf(stdout, FmtStr, ArgList); | ||||||
|  | 		fflush(stdout); | ||||||
|  ) | 	} else if (DLevel == 0) { | ||||||
|  | 		if (DbgFileName) { | ||||||
|  | 			UpnpDisplayFileAndLine(ErrFileHnd, DbgFileName, DbgLineNo); | ||||||
|  | 		} | ||||||
|  | 		vfprintf(ErrFileHnd, FmtStr, ArgList); | ||||||
|  | 		fflush(ErrFileHnd); | ||||||
|  | 	} else { | ||||||
|  | 		if (DbgFileName) { | ||||||
|  | 			UpnpDisplayFileAndLine(InfoFileHnd, DbgFileName, DbgLineNo); | ||||||
|  | 		} | ||||||
|  | 		vfprintf(InfoFileHnd, FmtStr, ArgList); | ||||||
|  | 		fflush(InfoFileHnd); | ||||||
|  | 	} | ||||||
|  | 	va_end(ArgList); | ||||||
|  | 	ithread_mutex_unlock(&GlobalDebugMutex); | ||||||
|  | } | ||||||
|  | #endif | ||||||
|  |  | ||||||
|  |  | ||||||
| /*************************************************************************** | /*************************************************************************** | ||||||
|  * Function : UpnpGetDebugFile					 |  * Function : UpnpGetDebugFile					 | ||||||
|  *				 |  *				 | ||||||
|  * Parameters:			 |  * Parameters:			 | ||||||
|  *	IN Dbg_Level DLevel: The level of the debug logging. It will decide  |  *	IN Upnp_LogLevel DLevel: The level of the debug logging. It will decide  | ||||||
|  *		whether debug statement will go to standard output,  |  *		whether debug statement will go to standard output,  | ||||||
|  *		or any of the log files. |  *		or any of the log files. | ||||||
|  *	IN Dbg_Module Module: debug will go in the name of this module |  *	IN Dbg_Module Module: debug will go in the name of this module | ||||||
| @@ -249,46 +268,26 @@ return; default: | |||||||
|  *	NULL : if the module is turn off for debug  |  *	NULL : if the module is turn off for debug  | ||||||
|  *	else returns the right file descriptor |  *	else returns the right file descriptor | ||||||
|  ***************************************************************************/ |  ***************************************************************************/ | ||||||
|     DBGONLY( FILE * GetDebugFile( Upnp_LogLevel DLevel, Dbg_Module Module ) { | #ifdef DEBUG | ||||||
|              if( g_log_level < DLevel ) return NULL; if( DEBUG_ALL == 0 ) { | FILE *GetDebugFile( Upnp_LogLevel DLevel, Dbg_Module Module ) | ||||||
|              switch ( Module ) { | { | ||||||
| case SSDP: | 	FILE *ret; | ||||||
|              if( DEBUG_SSDP == 1 ) break; |  | ||||||
|              else | 	if (!DebugAtThisLevel(DLevel, Module)) { | ||||||
| return NULL; case SOAP: | 		ret = NULL; | ||||||
|              if( DEBUG_SOAP == 1 ) break; |  | ||||||
|              else |  | ||||||
| return NULL; case GENA: |  | ||||||
|              if( DEBUG_GENA == 1 ) break; |  | ||||||
|              else |  | ||||||
| return NULL; case TPOOL: |  | ||||||
|              if( DEBUG_TPOOL == 1 ) break; |  | ||||||
|              else |  | ||||||
| return NULL; case MSERV: |  | ||||||
|              if( DEBUG_MSERV == 1 ) break; |  | ||||||
|              else |  | ||||||
| return NULL; case DOM: |  | ||||||
|              if( DEBUG_DOM == 1 ) break; |  | ||||||
|              else |  | ||||||
| return NULL; case API: |  | ||||||
|              if( DEBUG_API == 1 ) break; |  | ||||||
|              else |  | ||||||
| return NULL; default: |  | ||||||
|              return NULL;} |  | ||||||
| 	} | 	} | ||||||
| 	 | 	 | ||||||
|              if( DEBUG_TARGET == 0 ) { | 	if (!DEBUG_TARGET) { | ||||||
|              return stdout;} | 		ret = stdout; | ||||||
|              else | 	} else if (DLevel == 0) { | ||||||
|              { | 		ret = ErrFileHnd; | ||||||
|              if( DLevel == 0 ) { | 	} else { | ||||||
|              return ErrFileHnd;} | 		ret = InfoFileHnd; | ||||||
|              else |  | ||||||
|              { |  | ||||||
|              return InfoFileHnd;} |  | ||||||
| 	} | 	} | ||||||
|              } |  | ||||||
|  ) | 	return ret; | ||||||
|  | } | ||||||
|  | #endif | ||||||
|  |  | ||||||
|  |  | ||||||
| /*************************************************************************** | /*************************************************************************** | ||||||
| @@ -305,17 +304,26 @@ return NULL; default: | |||||||
|  *		debug statement is coming to the log file |  *		debug statement is coming to the log file | ||||||
|  * Returns: void |  * Returns: void | ||||||
|  ***************************************************************************/ |  ***************************************************************************/ | ||||||
|     DBGONLY( void UpnpDisplayFileAndLine( IN FILE * fd, | #ifdef DEBUG | ||||||
|  | void UpnpDisplayFileAndLine( | ||||||
|  | 	IN FILE * fd, | ||||||
| 	IN const char *DbgFileName, | 	IN const char *DbgFileName, | ||||||
|                                           IN int DbgLineNo ) { | 	IN int DbgLineNo) | ||||||
|  | { | ||||||
| 	int starlength = 66; | 	int starlength = 66; | ||||||
| 	const char *lines[2]; | 	const char *lines[2]; | ||||||
|              char FileAndLine[500]; lines[0] = "DEBUG"; if( DbgFileName ) { | 	char FileAndLine[500]; | ||||||
|              sprintf( FileAndLine, "FILE: %s, LINE: %d", DbgFileName, | 	lines[0] = "DEBUG"; | ||||||
|                       DbgLineNo ); lines[1] = FileAndLine;} | 	if (DbgFileName) { | ||||||
|  | 		sprintf(FileAndLine, | ||||||
|              UpnpDisplayBanner( fd, lines, 2, starlength ); fflush( fd );} | 			"FILE: %s, LINE: %d", | ||||||
|  ) | 			DbgFileName, DbgLineNo); | ||||||
|  | 		lines[1] = FileAndLine; | ||||||
|  | 	} | ||||||
|  | 	UpnpDisplayBanner(fd, lines, 2, starlength); | ||||||
|  | 	fflush(fd); | ||||||
|  | } | ||||||
|  | #endif | ||||||
|  |  | ||||||
|  |  | ||||||
| /*************************************************************************** | /*************************************************************************** | ||||||
| @@ -332,47 +340,58 @@ return NULL; default: | |||||||
|  *	per the requested banner |  *	per the requested banner | ||||||
|  * Returns: void |  * Returns: void | ||||||
|  ***************************************************************************/ |  ***************************************************************************/ | ||||||
|     DBGONLY( void UpnpDisplayBanner( IN FILE * fd, | #ifdef DEBUG | ||||||
|  | void UpnpDisplayBanner( | ||||||
|  | 	IN FILE * fd, | ||||||
| 	IN const char **lines, | 	IN const char **lines, | ||||||
| 	IN size_t size, | 	IN size_t size, | ||||||
|                                      IN int starLength ) { | 	IN int starLength) | ||||||
|              char *stars = ( char * )malloc( starLength + 1 ); | { | ||||||
|              const char *line = NULL; |  | ||||||
| 	int leftMarginLength = starLength / 2 + 1; | 	int leftMarginLength = starLength / 2 + 1; | ||||||
| 	int rightMarginLength = starLength / 2 + 1; | 	int rightMarginLength = starLength / 2 + 1; | ||||||
|              char *leftMargin = ( char * )malloc( leftMarginLength ); |  | ||||||
|              char *rightMargin = ( char * )malloc( rightMarginLength ); |  | ||||||
| 	int i = 0; | 	int i = 0; | ||||||
| 	int LineSize = 0; | 	int LineSize = 0; | ||||||
|  | 	int starLengthMinus2 = starLength - 2; | ||||||
|  |  | ||||||
|  | 	char *leftMargin = ( char * )malloc( leftMarginLength ); | ||||||
|  | 	char *rightMargin = ( char * )malloc( rightMarginLength ); | ||||||
|  | 	char *stars = ( char * )malloc( starLength + 1 ); | ||||||
| 	char *currentLine = ( char * )malloc( starLength + 1 ); | 	char *currentLine = ( char * )malloc( starLength + 1 ); | ||||||
|  | 	const char *line = NULL; | ||||||
|  |  | ||||||
| 	memset( stars, '*', starLength ); | 	memset( stars, '*', starLength ); | ||||||
| 	stars[starLength] = 0; | 	stars[starLength] = 0; | ||||||
| 	memset( leftMargin, 0, leftMarginLength ); | 	memset( leftMargin, 0, leftMarginLength ); | ||||||
| 	memset( rightMargin, 0, rightMarginLength ); | 	memset( rightMargin, 0, rightMarginLength ); | ||||||
|              fprintf( fd, "\n%s\n", stars ); for( i = 0; i < size; i++ ) { | 	fprintf( fd, "\n%s\n", stars ); | ||||||
|  | 	for( i = 0; i < size; i++ ) { | ||||||
| 		LineSize = strlen( lines[i] ); | 		LineSize = strlen( lines[i] ); | ||||||
|              line = lines[i]; while( LineSize > ( starLength - 2 ) ) { | 		line = lines[i]; | ||||||
|              memcpy( currentLine, line, ( starLength - 2 ) ); | 		while( LineSize > starLengthMinus2 ) { | ||||||
|              currentLine[( starLength - 2 )] = 0; | 			memcpy( currentLine, line, starLengthMinus2 ); | ||||||
|  | 			currentLine[starLengthMinus2] = 0; | ||||||
| 			fprintf( fd, "*%s*\n", currentLine ); | 			fprintf( fd, "*%s*\n", currentLine ); | ||||||
|              LineSize -= ( starLength - 2 ); line += ( starLength - 2 );} | 			LineSize -= starLengthMinus2; | ||||||
|  | 			line += starLengthMinus2; | ||||||
|  | 		} | ||||||
|  | 		leftMarginLength = (starLengthMinus2 - LineSize)/2; | ||||||
| 		if( LineSize % 2 == 0 ) { | 		if( LineSize % 2 == 0 ) { | ||||||
|              leftMarginLength = rightMarginLength = | 			rightMarginLength = leftMarginLength; | ||||||
|              ( ( starLength - 2 ) - LineSize ) / 2;} | 		} else { | ||||||
|              else | 			rightMarginLength = leftMarginLength + 1; | ||||||
|              { | 		} | ||||||
|              leftMarginLength = ( ( starLength - 2 ) - LineSize ) / 2; |  | ||||||
|              rightMarginLength = |  | ||||||
|              ( ( starLength - 2 ) - LineSize ) / 2 + 1;} |  | ||||||
|  |  | ||||||
| 		memset( leftMargin, ' ', leftMarginLength ); | 		memset( leftMargin, ' ', leftMarginLength ); | ||||||
| 		memset( rightMargin, ' ', rightMarginLength ); | 		memset( rightMargin, ' ', rightMarginLength ); | ||||||
| 		leftMargin[leftMarginLength] = 0; | 		leftMargin[leftMarginLength] = 0; | ||||||
| 		rightMargin[rightMarginLength] = 0; | 		rightMargin[rightMarginLength] = 0; | ||||||
|              fprintf( fd, "*%s%s%s*\n", leftMargin, line, rightMargin );} | 		fprintf( fd, "*%s%s%s*\n", leftMargin, line, rightMargin ); | ||||||
|  | 	} | ||||||
| 	fprintf( fd, "%s\n\n", stars ); | 	fprintf( fd, "%s\n\n", stars ); | ||||||
|  |  | ||||||
|  | 	free( currentLine ); | ||||||
|  | 	free( stars ); | ||||||
|  | 	free( rightMargin ); | ||||||
| 	free( leftMargin ); | 	free( leftMargin ); | ||||||
|              free( rightMargin ); free( stars ); free( currentLine );} | } | ||||||
|  ) | #endif | ||||||
|  |   | ||||||
|   | |||||||
| @@ -256,8 +256,8 @@ makeAction( IN int response, | |||||||
|             IN const char *Arg, |             IN const char *Arg, | ||||||
|             IN va_list ArgList ) |             IN va_list ArgList ) | ||||||
| { | { | ||||||
|     const char *ArgName, |     const char *ArgName; | ||||||
|      *ArgValue; |     const char *ArgValue; | ||||||
|     char *ActBuff; |     char *ActBuff; | ||||||
|     int Idx = 0; |     int Idx = 0; | ||||||
|     IXML_Document *ActionDoc; |     IXML_Document *ActionDoc; | ||||||
| @@ -298,7 +298,7 @@ makeAction( IN int response, | |||||||
|     if( NumArg > 0 ) { |     if( NumArg > 0 ) { | ||||||
|         //va_start(ArgList, Arg); |         //va_start(ArgList, Arg); | ||||||
|         ArgName = Arg; |         ArgName = Arg; | ||||||
|         while( Idx++ != NumArg ) { |         for ( ; ; ) { | ||||||
|             ArgValue = va_arg( ArgList, const char * ); |             ArgValue = va_arg( ArgList, const char * ); | ||||||
|  |  | ||||||
|             if( ArgName != NULL ) { |             if( ArgName != NULL ) { | ||||||
| @@ -313,7 +313,11 @@ makeAction( IN int response, | |||||||
|                 ixmlNode_appendChild( node, ( IXML_Node * ) Ele ); |                 ixmlNode_appendChild( node, ( IXML_Node * ) Ele ); | ||||||
|             } |             } | ||||||
|  |  | ||||||
|  |             if (++Idx < NumArg) { | ||||||
|                 ArgName = va_arg( ArgList, const char * ); |                 ArgName = va_arg( ArgList, const char * ); | ||||||
|  |             } else { | ||||||
|  |                 break; | ||||||
|  |             } | ||||||
|         } |         } | ||||||
|         //va_end(ArgList); |         //va_end(ArgList); | ||||||
|     } |     } | ||||||
|   | |||||||
| @@ -93,37 +93,35 @@ genaCallback( IN http_parser_t * parser, | |||||||
|     xboolean found_function = FALSE; |     xboolean found_function = FALSE; | ||||||
|  |  | ||||||
|     if( request->method == HTTPMETHOD_SUBSCRIBE ) { |     if( request->method == HTTPMETHOD_SUBSCRIBE ) { | ||||||
|         DEVICEONLY( found_function = TRUE; | #ifdef INCLUDE_DEVICE_APIS | ||||||
|                     if( httpmsg_find_hdr( request, HDR_NT, NULL ) == NULL ) |         found_function = TRUE; | ||||||
|                     { |         if( httpmsg_find_hdr( request, HDR_NT, NULL ) == NULL ) { | ||||||
|             // renew subscription |             // renew subscription | ||||||
|             gena_process_subscription_renewal_request |             gena_process_subscription_renewal_request | ||||||
|                     ( info, request );} |             ( info, request ); | ||||||
|                     else | 	} else { | ||||||
|                     { |  | ||||||
|             // subscribe |             // subscribe | ||||||
|                     gena_process_subscription_request( info, request );} |             gena_process_subscription_request( info, request ); | ||||||
|  |  | ||||||
|                     DBGONLY( UpnpPrintf |  | ||||||
|                              ( UPNP_ALL, GENA, __FILE__, __LINE__, |  | ||||||
|                                "got subscription request\n" ); ) |  | ||||||
|              ) |  | ||||||
| 	} | 	} | ||||||
|             else |         UpnpPrintf( UPNP_ALL, GENA, __FILE__, __LINE__, | ||||||
|         if( request->method == HTTPMETHOD_UNSUBSCRIBE ) { |             "got subscription request\n" ); | ||||||
|             DEVICEONLY( found_function = TRUE; |     } else if( request->method == HTTPMETHOD_UNSUBSCRIBE ) { | ||||||
|  |         found_function = TRUE; | ||||||
|         // unsubscribe |         // unsubscribe | ||||||
|                         gena_process_unsubscribe_request( info, |         gena_process_unsubscribe_request( info, request ); | ||||||
|                                                           request ); ) | #endif | ||||||
|     } else if( request->method == HTTPMETHOD_NOTIFY ) { |     } else if( request->method == HTTPMETHOD_NOTIFY ) { | ||||||
|             CLIENTONLY( found_function = TRUE; | #ifdef INCLUDE_CLIENT_APIS | ||||||
|  |         found_function = TRUE; | ||||||
|         // notify |         // notify | ||||||
|                         gena_process_notification_event( info, request ); ) |         gena_process_notification_event( info, request ); | ||||||
|  | #endif | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     if( !found_function ) { |     if( !found_function ) { | ||||||
|             // handle missing functions of device or ctrl pt |             // handle missing functions of device or ctrl pt | ||||||
|             error_respond( info, HTTP_NOT_IMPLEMENTED, request ); |             error_respond( info, HTTP_NOT_IMPLEMENTED, request ); | ||||||
|     } |     } | ||||||
|     } | } | ||||||
| #endif // EXCLUDE_GENA | #endif // EXCLUDE_GENA | ||||||
|  |  | ||||||
|   | |||||||
| @@ -72,14 +72,14 @@ GenaAutoRenewSubscription( IN void *input ) | |||||||
|     int eventType = 0; |     int eventType = 0; | ||||||
|  |  | ||||||
|     if( AUTO_RENEW_TIME == 0 ) { |     if( AUTO_RENEW_TIME == 0 ) { | ||||||
|         DBGONLY( UpnpPrintf( UPNP_INFO, GENA, __FILE__, __LINE__, |         UpnpPrintf( UPNP_INFO, GENA, __FILE__, __LINE__, | ||||||
|                              "GENA SUB EXPIRED" ) ); |             "GENA SUB EXPIRED" ); | ||||||
|         sub_struct->ErrCode = UPNP_E_SUCCESS; |         sub_struct->ErrCode = UPNP_E_SUCCESS; | ||||||
|         send_callback = 1; |         send_callback = 1; | ||||||
|         eventType = UPNP_EVENT_SUBSCRIPTION_EXPIRED; |         eventType = UPNP_EVENT_SUBSCRIPTION_EXPIRED; | ||||||
|     } else { |     } else { | ||||||
|         DBGONLY( UpnpPrintf( UPNP_INFO, GENA, __FILE__, __LINE__, |         UpnpPrintf( UPNP_INFO, GENA, __FILE__, __LINE__, | ||||||
|                              "GENA AUTO RENEW" ) ); |             "GENA AUTO RENEW" ); | ||||||
|         if( ( ( sub_struct->ErrCode = genaRenewSubscription( event->handle, |         if( ( ( sub_struct->ErrCode = genaRenewSubscription( event->handle, | ||||||
|                                                              sub_struct-> |                                                              sub_struct-> | ||||||
|                                                              Sid, |                                                              Sid, | ||||||
| @@ -93,17 +93,17 @@ GenaAutoRenewSubscription( IN void *input ) | |||||||
|         } |         } | ||||||
|     } |     } | ||||||
|     if( send_callback ) { |     if( send_callback ) { | ||||||
|         HandleLock(  ); |         HandleLock(); | ||||||
|         if( GetHandleInfo( event->handle, &handle_info ) != HND_CLIENT ) { |         if( GetHandleInfo( event->handle, &handle_info ) != HND_CLIENT ) { | ||||||
|             HandleUnlock(  ); |             HandleUnlock(); | ||||||
|             free_upnp_timeout( event ); |             free_upnp_timeout( event ); | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|         DBGONLY( UpnpPrintf( UPNP_INFO, GENA, __FILE__, __LINE__, |         UpnpPrintf( UPNP_INFO, GENA, __FILE__, __LINE__, | ||||||
|                              "HANDLE IS VALID" ) ); |             "HANDLE IS VALID" ); | ||||||
|         callback_fun = handle_info->Callback; |         callback_fun = handle_info->Callback; | ||||||
|         cookie = handle_info->Cookie; |         cookie = handle_info->Cookie; | ||||||
|         HandleUnlock(  ); |         HandleUnlock(); | ||||||
|         //make callback |         //make callback | ||||||
|  |  | ||||||
|         callback_fun( eventType, event->Event, cookie ); |         callback_fun( eventType, event->Event, cookie ); | ||||||
| @@ -397,9 +397,9 @@ genaUnregisterClient( IN UpnpClient_Handle client_handle ) | |||||||
|     http_parser_t response; |     http_parser_t response; | ||||||
|  |  | ||||||
|     while( TRUE ) { |     while( TRUE ) { | ||||||
|         HandleLock(  ); |         HandleLock(); | ||||||
|         if( GetHandleInfo( client_handle, &handle_info ) != HND_CLIENT ) { |         if( GetHandleInfo( client_handle, &handle_info ) != HND_CLIENT ) { | ||||||
|             HandleUnlock(  ); |             HandleUnlock(); | ||||||
|             return GENA_E_BAD_HANDLE; |             return GENA_E_BAD_HANDLE; | ||||||
|         } |         } | ||||||
|  |  | ||||||
| @@ -417,7 +417,7 @@ genaUnregisterClient( IN UpnpClient_Handle client_handle ) | |||||||
|         RemoveClientSubClientSID( &handle_info->ClientSubList, |         RemoveClientSubClientSID( &handle_info->ClientSubList, | ||||||
|                                   sub_copy.sid ); |                                   sub_copy.sid ); | ||||||
|  |  | ||||||
|         HandleUnlock(  ); |         HandleUnlock(); | ||||||
|  |  | ||||||
|         return_code = gena_unsubscribe( sub_copy.EventURL, |         return_code = gena_unsubscribe( sub_copy.EventURL, | ||||||
|                                         sub_copy.ActualSID, &response ); |                                         sub_copy.ActualSID, &response ); | ||||||
| @@ -429,7 +429,7 @@ genaUnregisterClient( IN UpnpClient_Handle client_handle ) | |||||||
|     } |     } | ||||||
|  |  | ||||||
|     freeClientSubList( handle_info->ClientSubList ); |     freeClientSubList( handle_info->ClientSubList ); | ||||||
|     HandleUnlock(  ); |     HandleUnlock(); | ||||||
|     return return_code; |     return return_code; | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -449,6 +449,7 @@ genaUnregisterClient( IN UpnpClient_Handle client_handle ) | |||||||
| *	return UPNP_E_SUCCESS if service response is OK else  | *	return UPNP_E_SUCCESS if service response is OK else  | ||||||
| *	returns appropriate error | *	returns appropriate error | ||||||
| ***************************************************************************/ | ***************************************************************************/ | ||||||
|  | #ifdef INCLUDE_CLIENT_APIS | ||||||
| int | int | ||||||
| genaUnSubscribe( IN UpnpClient_Handle client_handle, | genaUnSubscribe( IN UpnpClient_Handle client_handle, | ||||||
|                  IN const Upnp_SID in_sid ) |                  IN const Upnp_SID in_sid ) | ||||||
| @@ -459,25 +460,25 @@ genaUnSubscribe( IN UpnpClient_Handle client_handle, | |||||||
|     client_subscription sub_copy; |     client_subscription sub_copy; | ||||||
|     http_parser_t response; |     http_parser_t response; | ||||||
|  |  | ||||||
|     HandleLock(  ); |     HandleLock(); | ||||||
|  |  | ||||||
|     // validate handle and sid |     // validate handle and sid | ||||||
|  |  | ||||||
|     if( GetHandleInfo( client_handle, &handle_info ) != HND_CLIENT ) { |     if( GetHandleInfo( client_handle, &handle_info ) != HND_CLIENT ) { | ||||||
|         HandleUnlock(  ); |         HandleUnlock(); | ||||||
|         return GENA_E_BAD_HANDLE; |         return GENA_E_BAD_HANDLE; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     if( ( sub = |     if( ( sub = | ||||||
|           GetClientSubClientSID( handle_info->ClientSubList, in_sid ) ) |           GetClientSubClientSID( handle_info->ClientSubList, in_sid ) ) | ||||||
|         == NULL ) { |         == NULL ) { | ||||||
|         HandleUnlock(  ); |         HandleUnlock(); | ||||||
|         return GENA_E_BAD_SID; |         return GENA_E_BAD_SID; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     return_code = copy_client_subscription( sub, &sub_copy ); |     return_code = copy_client_subscription( sub, &sub_copy ); | ||||||
|  |  | ||||||
|     HandleUnlock(  ); |     HandleUnlock(); | ||||||
|  |  | ||||||
|     return_code = gena_unsubscribe( sub_copy.EventURL, sub_copy.ActualSID, |     return_code = gena_unsubscribe( sub_copy.EventURL, sub_copy.ActualSID, | ||||||
|                                     &response ); |                                     &response ); | ||||||
| @@ -488,19 +489,20 @@ genaUnSubscribe( IN UpnpClient_Handle client_handle, | |||||||
|  |  | ||||||
|     free_client_subscription( &sub_copy ); |     free_client_subscription( &sub_copy ); | ||||||
|  |  | ||||||
|     HandleLock(  ); |     HandleLock(); | ||||||
|  |  | ||||||
|     if( GetHandleInfo( client_handle, &handle_info ) != HND_CLIENT ) { |     if( GetHandleInfo( client_handle, &handle_info ) != HND_CLIENT ) { | ||||||
|         HandleUnlock(  ); |         HandleUnlock(); | ||||||
|         return GENA_E_BAD_HANDLE; |         return GENA_E_BAD_HANDLE; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     RemoveClientSubClientSID( &handle_info->ClientSubList, in_sid ); |     RemoveClientSubClientSID( &handle_info->ClientSubList, in_sid ); | ||||||
|  |  | ||||||
|     HandleUnlock(  ); |     HandleUnlock(); | ||||||
|  |  | ||||||
|     return return_code; |     return return_code; | ||||||
| } | } | ||||||
|  | #endif | ||||||
|  |  | ||||||
| /************************************************************************ | /************************************************************************ | ||||||
| * Function : genaSubscribe | * Function : genaSubscribe | ||||||
| @@ -524,6 +526,7 @@ genaUnSubscribe( IN UpnpClient_Handle client_handle, | |||||||
| *	return UPNP_E_SUCCESS if service response is OK else  | *	return UPNP_E_SUCCESS if service response is OK else  | ||||||
| *	returns appropriate error | *	returns appropriate error | ||||||
| ***************************************************************************/ | ***************************************************************************/ | ||||||
|  | #ifdef INCLUDE_CLIENT_APIS | ||||||
| int | int | ||||||
| genaSubscribe( IN UpnpClient_Handle client_handle, | genaSubscribe( IN UpnpClient_Handle client_handle, | ||||||
|                IN char *PublisherURL, |                IN char *PublisherURL, | ||||||
| @@ -538,28 +541,28 @@ genaSubscribe( IN UpnpClient_Handle client_handle, | |||||||
|     struct Handle_Info *handle_info; |     struct Handle_Info *handle_info; | ||||||
|     char *EventURL = NULL; |     char *EventURL = NULL; | ||||||
|  |  | ||||||
|     DBGONLY( UpnpPrintf( UPNP_INFO, GENA, __FILE__, __LINE__, |     UpnpPrintf( UPNP_INFO, GENA, __FILE__, __LINE__, | ||||||
|                          "GENA SUBSCRIBE BEGIN" ) ); |         "GENA SUBSCRIBE BEGIN" ); | ||||||
|     HandleLock(  ); |     HandleLock(); | ||||||
|  |  | ||||||
|     memset( out_sid, 0, sizeof( Upnp_SID ) ); |     memset( out_sid, 0, sizeof( Upnp_SID ) ); | ||||||
|  |  | ||||||
|     // validate handle |     // validate handle | ||||||
|     if( GetHandleInfo( client_handle, &handle_info ) != HND_CLIENT ) { |     if( GetHandleInfo( client_handle, &handle_info ) != HND_CLIENT ) { | ||||||
|         HandleUnlock(  ); |         HandleUnlock(); | ||||||
|         return GENA_E_BAD_HANDLE; |         return GENA_E_BAD_HANDLE; | ||||||
|     } |     } | ||||||
|     HandleUnlock(  ); |     HandleUnlock(); | ||||||
|  |  | ||||||
|     // subscribe |     // subscribe | ||||||
|     SubscribeLock(  ); |     SubscribeLock(); | ||||||
|     return_code = |     return_code = | ||||||
|         gena_subscribe( PublisherURL, TimeOut, NULL, &ActualSID ); |         gena_subscribe( PublisherURL, TimeOut, NULL, &ActualSID ); | ||||||
|     HandleLock(  ); |     HandleLock(); | ||||||
|     if( return_code != UPNP_E_SUCCESS ) { |     if( return_code != UPNP_E_SUCCESS ) { | ||||||
|         DBGONLY( UpnpPrintf( UPNP_CRITICAL, GENA, __FILE__, __LINE__, |         UpnpPrintf( UPNP_CRITICAL, GENA, __FILE__, __LINE__, | ||||||
|             "SUBSCRIBE FAILED in transfer error code: %d returned\n", |             "SUBSCRIBE FAILED in transfer error code: %d returned\n", | ||||||
|                              return_code ) ); |             return_code ); | ||||||
|         goto error_handler; |         goto error_handler; | ||||||
|     } |     } | ||||||
|  |  | ||||||
| @@ -605,10 +608,11 @@ genaSubscribe( IN UpnpClient_Handle client_handle, | |||||||
|         free( EventURL ); |         free( EventURL ); | ||||||
|         free( newSubscription ); |         free( newSubscription ); | ||||||
|     } |     } | ||||||
|     HandleUnlock(  ); |     HandleUnlock(); | ||||||
|     SubscribeUnlock(  ); |     SubscribeUnlock(); | ||||||
|     return return_code; |     return return_code; | ||||||
| } | } | ||||||
|  | #endif | ||||||
|  |  | ||||||
| /************************************************************************ | /************************************************************************ | ||||||
| * Function : genaRenewSubscription | * Function : genaRenewSubscription | ||||||
| @@ -643,17 +647,17 @@ genaRenewSubscription( IN UpnpClient_Handle client_handle, | |||||||
|     char *ActualSID; |     char *ActualSID; | ||||||
|     ThreadPoolJob tempJob; |     ThreadPoolJob tempJob; | ||||||
|  |  | ||||||
|     HandleLock(  ); |     HandleLock(); | ||||||
|  |  | ||||||
|     // validate handle and sid |     // validate handle and sid | ||||||
|     if( GetHandleInfo( client_handle, &handle_info ) != HND_CLIENT ) { |     if( GetHandleInfo( client_handle, &handle_info ) != HND_CLIENT ) { | ||||||
|         HandleUnlock(  ); |         HandleUnlock(); | ||||||
|         return GENA_E_BAD_HANDLE; |         return GENA_E_BAD_HANDLE; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     if( ( sub = GetClientSubClientSID( handle_info->ClientSubList, |     if( ( sub = GetClientSubClientSID( handle_info->ClientSubList, | ||||||
|                                        in_sid ) ) == NULL ) { |                                        in_sid ) ) == NULL ) { | ||||||
|         HandleUnlock(  ); |         HandleUnlock(); | ||||||
|         return GENA_E_BAD_SID; |         return GENA_E_BAD_SID; | ||||||
|     } |     } | ||||||
|     // remove old events |     // remove old events | ||||||
| @@ -663,13 +667,13 @@ genaRenewSubscription( IN UpnpClient_Handle client_handle, | |||||||
|         free_upnp_timeout( ( upnp_timeout * ) tempJob.arg ); |         free_upnp_timeout( ( upnp_timeout * ) tempJob.arg ); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     DBGONLY( UpnpPrintf( UPNP_INFO, GENA, __FILE__, __LINE__, |     UpnpPrintf( UPNP_INFO, GENA, __FILE__, __LINE__, | ||||||
|                          "REMOVED AUTO RENEW  EVENT" ) ); |         "REMOVED AUTO RENEW  EVENT" ); | ||||||
|  |  | ||||||
|     sub->RenewEventId = -1; |     sub->RenewEventId = -1; | ||||||
|     return_code = copy_client_subscription( sub, &sub_copy ); |     return_code = copy_client_subscription( sub, &sub_copy ); | ||||||
|  |  | ||||||
|     HandleUnlock(  ); |     HandleUnlock(); | ||||||
|  |  | ||||||
|     if( return_code != HTTP_SUCCESS ) { |     if( return_code != HTTP_SUCCESS ) { | ||||||
|         return return_code; |         return return_code; | ||||||
| @@ -677,10 +681,10 @@ genaRenewSubscription( IN UpnpClient_Handle client_handle, | |||||||
|  |  | ||||||
|     return_code = gena_subscribe( sub_copy.EventURL, TimeOut, |     return_code = gena_subscribe( sub_copy.EventURL, TimeOut, | ||||||
|                                   sub_copy.ActualSID, &ActualSID ); |                                   sub_copy.ActualSID, &ActualSID ); | ||||||
|     HandleLock(  ); |     HandleLock(); | ||||||
|  |  | ||||||
|     if( GetHandleInfo( client_handle, &handle_info ) != HND_CLIENT ) { |     if( GetHandleInfo( client_handle, &handle_info ) != HND_CLIENT ) { | ||||||
|         HandleUnlock(  ); |         HandleUnlock(); | ||||||
|         if( return_code == UPNP_E_SUCCESS ) { |         if( return_code == UPNP_E_SUCCESS ) { | ||||||
|             free( ActualSID ); |             free( ActualSID ); | ||||||
|         } |         } | ||||||
| @@ -693,7 +697,7 @@ genaRenewSubscription( IN UpnpClient_Handle client_handle, | |||||||
|         // network failure (remove client sub) |         // network failure (remove client sub) | ||||||
|         RemoveClientSubClientSID( &handle_info->ClientSubList, in_sid ); |         RemoveClientSubClientSID( &handle_info->ClientSubList, in_sid ); | ||||||
|         free_client_subscription( &sub_copy ); |         free_client_subscription( &sub_copy ); | ||||||
|         HandleUnlock(  ); |         HandleUnlock(); | ||||||
|         return return_code; |         return return_code; | ||||||
|     } |     } | ||||||
|     // get subscription |     // get subscription | ||||||
| @@ -701,7 +705,7 @@ genaRenewSubscription( IN UpnpClient_Handle client_handle, | |||||||
|                                        in_sid ) ) == NULL ) { |                                        in_sid ) ) == NULL ) { | ||||||
|         free( ActualSID ); |         free( ActualSID ); | ||||||
|         free_client_subscription( &sub_copy ); |         free_client_subscription( &sub_copy ); | ||||||
|         HandleUnlock(  ); |         HandleUnlock(); | ||||||
|         return GENA_E_BAD_SID; |         return GENA_E_BAD_SID; | ||||||
|     } |     } | ||||||
|     // store actual sid |     // store actual sid | ||||||
| @@ -714,7 +718,7 @@ genaRenewSubscription( IN UpnpClient_Handle client_handle, | |||||||
|         RemoveClientSubClientSID( &handle_info->ClientSubList, sub->sid ); |         RemoveClientSubClientSID( &handle_info->ClientSubList, sub->sid ); | ||||||
|     } |     } | ||||||
|     free_client_subscription( &sub_copy ); |     free_client_subscription( &sub_copy ); | ||||||
|     HandleUnlock(  ); |     HandleUnlock(); | ||||||
|     return return_code; |     return return_code; | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -795,12 +799,12 @@ gena_process_notification_event( IN SOCKINFO * info, | |||||||
|         return; |         return; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     HandleLock(  ); |     HandleLock(); | ||||||
|  |  | ||||||
|     // get client info |     // get client info | ||||||
|     if( GetClientHandleInfo( &client_handle, &handle_info ) != HND_CLIENT ) { |     if( GetClientHandleInfo( &client_handle, &handle_info ) != HND_CLIENT ) { | ||||||
|         error_respond( info, HTTP_PRECONDITION_FAILED, event ); |         error_respond( info, HTTP_PRECONDITION_FAILED, event ); | ||||||
|         HandleUnlock(  ); |         HandleUnlock(); | ||||||
|         ixmlDocument_free( ChangedVars ); |         ixmlDocument_free( ChangedVars ); | ||||||
|  |  | ||||||
|         return; |         return; | ||||||
| @@ -813,20 +817,20 @@ gena_process_notification_event( IN SOCKINFO * info, | |||||||
|             //   (if we are in the middle) |             //   (if we are in the middle) | ||||||
|             // this is to avoid mistakenly rejecting the first event if we  |             // this is to avoid mistakenly rejecting the first event if we  | ||||||
|             //   receive it before the subscription response |             //   receive it before the subscription response | ||||||
|             HandleUnlock(  ); |             HandleUnlock(); | ||||||
|  |  | ||||||
|             // try and get Subscription Lock  |             // try and get Subscription Lock  | ||||||
|             //   (in case we are in the process of subscribing) |             //   (in case we are in the process of subscribing) | ||||||
|             SubscribeLock(  ); |             SubscribeLock(); | ||||||
|  |  | ||||||
|             // get HandleLock again |             // get HandleLock again | ||||||
|             HandleLock(  ); |             HandleLock(); | ||||||
|  |  | ||||||
|             if( GetClientHandleInfo( &client_handle, &handle_info ) |             if( GetClientHandleInfo( &client_handle, &handle_info ) | ||||||
|                 != HND_CLIENT ) { |                 != HND_CLIENT ) { | ||||||
|                 error_respond( info, HTTP_PRECONDITION_FAILED, event ); |                 error_respond( info, HTTP_PRECONDITION_FAILED, event ); | ||||||
|                 SubscribeUnlock(  ); |                 SubscribeUnlock(); | ||||||
|                 HandleUnlock(  ); |                 HandleUnlock(); | ||||||
|                 ixmlDocument_free( ChangedVars ); |                 ixmlDocument_free( ChangedVars ); | ||||||
|  |  | ||||||
|                 return; |                 return; | ||||||
| @@ -836,17 +840,17 @@ gena_process_notification_event( IN SOCKINFO * info, | |||||||
|                   GetClientSubActualSID( handle_info->ClientSubList, |                   GetClientSubActualSID( handle_info->ClientSubList, | ||||||
|                                          &sid ) ) == NULL ) { |                                          &sid ) ) == NULL ) { | ||||||
|                 error_respond( info, HTTP_PRECONDITION_FAILED, event ); |                 error_respond( info, HTTP_PRECONDITION_FAILED, event ); | ||||||
|                 SubscribeUnlock(  ); |                 SubscribeUnlock(); | ||||||
|                 HandleUnlock(  ); |                 HandleUnlock(); | ||||||
|                 ixmlDocument_free( ChangedVars ); |                 ixmlDocument_free( ChangedVars ); | ||||||
|  |  | ||||||
|                 return; |                 return; | ||||||
|             } |             } | ||||||
|  |  | ||||||
|             SubscribeUnlock(  ); |             SubscribeUnlock(); | ||||||
|         } else { |         } else { | ||||||
|             error_respond( info, HTTP_PRECONDITION_FAILED, event ); |             error_respond( info, HTTP_PRECONDITION_FAILED, event ); | ||||||
|             HandleUnlock(  ); |             HandleUnlock(); | ||||||
|             ixmlDocument_free( ChangedVars ); |             ixmlDocument_free( ChangedVars ); | ||||||
|  |  | ||||||
|             return; |             return; | ||||||
| @@ -864,7 +868,7 @@ gena_process_notification_event( IN SOCKINFO * info, | |||||||
|     callback = handle_info->Callback; |     callback = handle_info->Callback; | ||||||
|     cookie = handle_info->Cookie; |     cookie = handle_info->Cookie; | ||||||
|  |  | ||||||
|     HandleUnlock(  ); |     HandleUnlock(); | ||||||
|  |  | ||||||
|     // make callback with event struct |     // make callback with event struct | ||||||
|     // In future, should find a way of mainting |     // In future, should find a way of mainting | ||||||
|   | |||||||
| @@ -62,19 +62,19 @@ genaUnregisterDevice( IN UpnpDevice_Handle device_handle ) | |||||||
| { | { | ||||||
|     struct Handle_Info *handle_info; |     struct Handle_Info *handle_info; | ||||||
|  |  | ||||||
|     HandleLock(  ); |     HandleLock(); | ||||||
|     if( GetHandleInfo( device_handle, &handle_info ) != HND_DEVICE ) { |     if( GetHandleInfo( device_handle, &handle_info ) != HND_DEVICE ) { | ||||||
|  |  | ||||||
|         DBGONLY( UpnpPrintf( UPNP_CRITICAL, GENA, __FILE__, __LINE__, |         UpnpPrintf( UPNP_CRITICAL, GENA, __FILE__, __LINE__, | ||||||
|             "genaUnregisterDevice : BAD Handle : %d\n", |             "genaUnregisterDevice : BAD Handle : %d\n", | ||||||
|                              device_handle ) ); |             device_handle ); | ||||||
|  |  | ||||||
|         HandleUnlock(  ); |         HandleUnlock(); | ||||||
|         return GENA_E_BAD_HANDLE; |         return GENA_E_BAD_HANDLE; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     freeServiceTable( &handle_info->ServiceTable ); |     freeServiceTable( &handle_info->ServiceTable ); | ||||||
|     HandleUnlock(  ); |     HandleUnlock(); | ||||||
|  |  | ||||||
|     return UPNP_E_SUCCESS; |     return UPNP_E_SUCCESS; | ||||||
| } | } | ||||||
| @@ -188,7 +188,7 @@ free_notify_struct( IN notify_thread_struct * input ) | |||||||
| * | * | ||||||
| *	Note : called by genaNotify | *	Note : called by genaNotify | ||||||
| ****************************************************************************/ | ****************************************************************************/ | ||||||
| static XINLINE int | static UPNP_INLINE int | ||||||
| notify_send_and_recv( IN uri_type * destination_url, | notify_send_and_recv( IN uri_type * destination_url, | ||||||
|                       IN membuffer * mid_msg, |                       IN membuffer * mid_msg, | ||||||
|                       IN char *propertySet, |                       IN char *propertySet, | ||||||
| @@ -203,10 +203,10 @@ notify_send_and_recv( IN uri_type * destination_url, | |||||||
|     SOCKINFO info; |     SOCKINFO info; | ||||||
|  |  | ||||||
|     // connect |     // connect | ||||||
|     DBGONLY( UpnpPrintf( UPNP_ALL, GENA, __FILE__, __LINE__, |     UpnpPrintf( UPNP_ALL, GENA, __FILE__, __LINE__, | ||||||
|         "gena notify to: %.*s\n", |         "gena notify to: %.*s\n", | ||||||
|                          destination_url->hostport.text.size, |         (int)destination_url->hostport.text.size, | ||||||
|                          destination_url->hostport.text.buff ); ) |         destination_url->hostport.text.buff ); | ||||||
|  |  | ||||||
|     conn_fd = http_Connect( destination_url, &url ); |     conn_fd = http_Connect( destination_url, &url ); | ||||||
|     if( conn_fd < 0 ) { |     if( conn_fd < 0 ) { | ||||||
| @@ -365,12 +365,12 @@ genaNotifyThread( IN void *input ) | |||||||
|     struct Handle_Info *handle_info; |     struct Handle_Info *handle_info; | ||||||
|     ThreadPoolJob job; |     ThreadPoolJob job; | ||||||
|  |  | ||||||
|     HandleLock(  ); |     HandleLock(); | ||||||
|     //validate context |     //validate context | ||||||
|  |  | ||||||
|     if( GetHandleInfo( in->device_handle, &handle_info ) != HND_DEVICE ) { |     if( GetHandleInfo( in->device_handle, &handle_info ) != HND_DEVICE ) { | ||||||
|         free_notify_struct( in ); |         free_notify_struct( in ); | ||||||
|         HandleUnlock(  ); |         HandleUnlock(); | ||||||
|         return; |         return; | ||||||
|     } |     } | ||||||
|  |  | ||||||
| @@ -380,7 +380,7 @@ genaNotifyThread( IN void *input ) | |||||||
|         || ( ( sub = GetSubscriptionSID( in->sid, service ) ) == NULL ) |         || ( ( sub = GetSubscriptionSID( in->sid, service ) ) == NULL ) | ||||||
|         || ( ( copy_subscription( sub, &sub_copy ) != HTTP_SUCCESS ) ) ) { |         || ( ( copy_subscription( sub, &sub_copy ) != HTTP_SUCCESS ) ) ) { | ||||||
|         free_notify_struct( in ); |         free_notify_struct( in ); | ||||||
|         HandleUnlock(  ); |         HandleUnlock(); | ||||||
|         return; |         return; | ||||||
|     } |     } | ||||||
|     //If the event is out of order push it back to the job queue |     //If the event is out of order push it back to the job queue | ||||||
| @@ -392,22 +392,22 @@ genaNotifyThread( IN void *input ) | |||||||
|         ThreadPoolAdd( &gSendThreadPool, &job, NULL ); |         ThreadPoolAdd( &gSendThreadPool, &job, NULL ); | ||||||
|  |  | ||||||
|         freeSubscription( &sub_copy ); |         freeSubscription( &sub_copy ); | ||||||
|         HandleUnlock(  ); |         HandleUnlock(); | ||||||
|         return; |         return; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     HandleUnlock(  ); |     HandleUnlock(); | ||||||
|  |  | ||||||
|     //send the notify |     //send the notify | ||||||
|     return_code = genaNotify( in->headers, in->propertySet, &sub_copy ); |     return_code = genaNotify( in->headers, in->propertySet, &sub_copy ); | ||||||
|  |  | ||||||
|     freeSubscription( &sub_copy ); |     freeSubscription( &sub_copy ); | ||||||
|  |  | ||||||
|     HandleLock(  ); |     HandleLock(); | ||||||
|  |  | ||||||
|     if( GetHandleInfo( in->device_handle, &handle_info ) != HND_DEVICE ) { |     if( GetHandleInfo( in->device_handle, &handle_info ) != HND_DEVICE ) { | ||||||
|         free_notify_struct( in ); |         free_notify_struct( in ); | ||||||
|         HandleUnlock(  ); |         HandleUnlock(); | ||||||
|         return; |         return; | ||||||
|     } |     } | ||||||
|     //validate context |     //validate context | ||||||
| @@ -416,7 +416,7 @@ genaNotifyThread( IN void *input ) | |||||||
|         || ( !service->active ) |         || ( !service->active ) | ||||||
|         || ( ( sub = GetSubscriptionSID( in->sid, service ) ) == NULL ) ) { |         || ( ( sub = GetSubscriptionSID( in->sid, service ) ) == NULL ) ) { | ||||||
|         free_notify_struct( in ); |         free_notify_struct( in ); | ||||||
|         HandleUnlock(  ); |         HandleUnlock(); | ||||||
|         return; |         return; | ||||||
|     } |     } | ||||||
|  |  | ||||||
| @@ -430,7 +430,7 @@ genaNotifyThread( IN void *input ) | |||||||
|     } |     } | ||||||
|  |  | ||||||
|     free_notify_struct( in ); |     free_notify_struct( in ); | ||||||
|     HandleUnlock(  ); |     HandleUnlock(); | ||||||
| } | } | ||||||
|  |  | ||||||
| /**************************************************************************** | /**************************************************************************** | ||||||
| @@ -477,8 +477,8 @@ genaInitNotify( IN UpnpDevice_Handle device_handle, | |||||||
|  |  | ||||||
|     notify_thread_struct *thread_struct = NULL; |     notify_thread_struct *thread_struct = NULL; | ||||||
|  |  | ||||||
|     DBGONLY( UpnpPrintf( UPNP_INFO, GENA, __FILE__, __LINE__, |     UpnpPrintf( UPNP_INFO, GENA, __FILE__, __LINE__, | ||||||
|                          "GENA BEGIN INITIAL NOTIFY " ) ); |         "GENA BEGIN INITIAL NOTIFY " ); | ||||||
|  |  | ||||||
|     reference_count = ( int * )malloc( sizeof( int ) ); |     reference_count = ( int * )malloc( sizeof( int ) ); | ||||||
|  |  | ||||||
| @@ -504,13 +504,13 @@ genaInitNotify( IN UpnpDevice_Handle device_handle, | |||||||
|     strcpy( UDN_copy, UDN ); |     strcpy( UDN_copy, UDN ); | ||||||
|     strcpy( servId_copy, servId ); |     strcpy( servId_copy, servId ); | ||||||
|  |  | ||||||
|     HandleLock(  ); |     HandleLock(); | ||||||
|  |  | ||||||
|     if( GetHandleInfo( device_handle, &handle_info ) != HND_DEVICE ) { |     if( GetHandleInfo( device_handle, &handle_info ) != HND_DEVICE ) { | ||||||
|         free( UDN_copy ); |         free( UDN_copy ); | ||||||
|         free( reference_count ); |         free( reference_count ); | ||||||
|         free( servId_copy ); |         free( servId_copy ); | ||||||
|         HandleUnlock(  ); |         HandleUnlock(); | ||||||
|         return GENA_E_BAD_HANDLE; |         return GENA_E_BAD_HANDLE; | ||||||
|     } |     } | ||||||
|  |  | ||||||
| @@ -519,26 +519,25 @@ genaInitNotify( IN UpnpDevice_Handle device_handle, | |||||||
|         free( UDN_copy ); |         free( UDN_copy ); | ||||||
|         free( reference_count ); |         free( reference_count ); | ||||||
|         free( servId_copy ); |         free( servId_copy ); | ||||||
|         HandleUnlock(  ); |         HandleUnlock(); | ||||||
|         return GENA_E_BAD_SERVICE; |         return GENA_E_BAD_SERVICE; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     DBGONLY( UpnpPrintf( UPNP_INFO, GENA, __FILE__, __LINE__, |     UpnpPrintf( UPNP_INFO, GENA, __FILE__, __LINE__, | ||||||
|         "FOUND SERVICE IN INIT NOTFY: UDN %s, ServID: %s ", |         "FOUND SERVICE IN INIT NOTFY: UDN %s, ServID: %s ", | ||||||
|                          UDN, servId ) ); |         UDN, servId ); | ||||||
|  |  | ||||||
|     if( ( ( sub = GetSubscriptionSID( sid, service ) ) == NULL ) || |     if( ( ( sub = GetSubscriptionSID( sid, service ) ) == NULL ) || | ||||||
|         ( sub->active ) ) { |         ( sub->active ) ) { | ||||||
|         free( UDN_copy ); |         free( UDN_copy ); | ||||||
|         free( reference_count ); |         free( reference_count ); | ||||||
|         free( servId_copy ); |         free( servId_copy ); | ||||||
|         HandleUnlock(  ); |         HandleUnlock(); | ||||||
|         return GENA_E_BAD_SID; |         return GENA_E_BAD_SID; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     DBGONLY( UpnpPrintf( UPNP_INFO, GENA, __FILE__, __LINE__, |     UpnpPrintf( UPNP_INFO, GENA, __FILE__, __LINE__, | ||||||
|                          "FOUND SUBSCRIPTION IN INIT NOTIFY: SID %s ", |         "FOUND SUBSCRIPTION IN INIT NOTIFY: SID %s ", sid ); | ||||||
|                          sid ) ); |  | ||||||
|  |  | ||||||
|     sub->active = 1; |     sub->active = 1; | ||||||
|  |  | ||||||
| @@ -549,13 +548,13 @@ genaInitNotify( IN UpnpDevice_Handle device_handle, | |||||||
|         free( UDN_copy ); |         free( UDN_copy ); | ||||||
|         free( reference_count ); |         free( reference_count ); | ||||||
|         free( servId_copy ); |         free( servId_copy ); | ||||||
|         HandleUnlock(  ); |         HandleUnlock(); | ||||||
|         return return_code; |         return return_code; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     DBGONLY( UpnpPrintf( UPNP_INFO, GENA, __FILE__, __LINE__, |     UpnpPrintf( UPNP_INFO, GENA, __FILE__, __LINE__, | ||||||
|         "GENERATED PROPERY SET IN INIT NOTIFY: \n'%s'\n", |         "GENERATED PROPERY SET IN INIT NOTIFY: \n'%s'\n", | ||||||
|                          propertySet ) ); |         propertySet ); | ||||||
|  |  | ||||||
|     headers_size = strlen( "CONTENT-TYPE text/xml\r\n" ) + |     headers_size = strlen( "CONTENT-TYPE text/xml\r\n" ) + | ||||||
|         strlen( "CONTENT-LENGTH: \r\n" ) + MAX_CONTENT_LENGTH + |         strlen( "CONTENT-LENGTH: \r\n" ) + MAX_CONTENT_LENGTH + | ||||||
| @@ -569,12 +568,12 @@ genaInitNotify( IN UpnpDevice_Handle device_handle, | |||||||
|         free( UDN_copy ); |         free( UDN_copy ); | ||||||
|         free( servId_copy ); |         free( servId_copy ); | ||||||
|         free( reference_count ); |         free( reference_count ); | ||||||
|         HandleUnlock(  ); |         HandleUnlock(); | ||||||
|         return UPNP_E_OUTOF_MEMORY; |         return UPNP_E_OUTOF_MEMORY; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     sprintf( headers, "CONTENT-TYPE: text/xml\r\nCONTENT-LENGTH: " |     sprintf( headers, "CONTENT-TYPE: text/xml\r\nCONTENT-LENGTH: " | ||||||
|              "%zd\r\nNT: upnp:event\r\nNTS: upnp:propchange\r\n", |              "%"PRIzu"\r\nNT: upnp:event\r\nNTS: upnp:propchange\r\n", | ||||||
|              strlen( propertySet ) + 1 ); |              strlen( propertySet ) + 1 ); | ||||||
|  |  | ||||||
|     //schedule thread for initial notification |     //schedule thread for initial notification | ||||||
| @@ -621,7 +620,7 @@ genaInitNotify( IN UpnpDevice_Handle device_handle, | |||||||
|         free( headers ); |         free( headers ); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     HandleUnlock(  ); |     HandleUnlock(); | ||||||
|  |  | ||||||
|     return return_code; |     return return_code; | ||||||
| } | } | ||||||
| @@ -668,8 +667,8 @@ genaInitNotifyExt( IN UpnpDevice_Handle device_handle, | |||||||
|  |  | ||||||
|     notify_thread_struct *thread_struct = NULL; |     notify_thread_struct *thread_struct = NULL; | ||||||
|  |  | ||||||
|     DBGONLY( UpnpPrintf( UPNP_INFO, GENA, __FILE__, __LINE__, |     UpnpPrintf( UPNP_INFO, GENA, __FILE__, __LINE__, | ||||||
|                          "GENA BEGIN INITIAL NOTIFY EXT" ) ); |         "GENA BEGIN INITIAL NOTIFY EXT" ); | ||||||
|     reference_count = ( int * )malloc( sizeof( int ) ); |     reference_count = ( int * )malloc( sizeof( int ) ); | ||||||
|  |  | ||||||
|     if( reference_count == NULL ) { |     if( reference_count == NULL ) { | ||||||
| @@ -694,13 +693,13 @@ genaInitNotifyExt( IN UpnpDevice_Handle device_handle, | |||||||
|     strcpy( UDN_copy, UDN ); |     strcpy( UDN_copy, UDN ); | ||||||
|     strcpy( servId_copy, servId ); |     strcpy( servId_copy, servId ); | ||||||
|  |  | ||||||
|     HandleLock(  ); |     HandleLock(); | ||||||
|  |  | ||||||
|     if( GetHandleInfo( device_handle, &handle_info ) != HND_DEVICE ) { |     if( GetHandleInfo( device_handle, &handle_info ) != HND_DEVICE ) { | ||||||
|         free( UDN_copy ); |         free( UDN_copy ); | ||||||
|         free( reference_count ); |         free( reference_count ); | ||||||
|         free( servId_copy ); |         free( servId_copy ); | ||||||
|         HandleUnlock(  ); |         HandleUnlock(); | ||||||
|         return GENA_E_BAD_HANDLE; |         return GENA_E_BAD_HANDLE; | ||||||
|     } |     } | ||||||
|  |  | ||||||
| @@ -709,24 +708,23 @@ genaInitNotifyExt( IN UpnpDevice_Handle device_handle, | |||||||
|         free( UDN_copy ); |         free( UDN_copy ); | ||||||
|         free( reference_count ); |         free( reference_count ); | ||||||
|         free( servId_copy ); |         free( servId_copy ); | ||||||
|         HandleUnlock(  ); |         HandleUnlock(); | ||||||
|         return GENA_E_BAD_SERVICE; |         return GENA_E_BAD_SERVICE; | ||||||
|     } |     } | ||||||
|     DBGONLY( UpnpPrintf( UPNP_INFO, GENA, __FILE__, __LINE__, |     UpnpPrintf( UPNP_INFO, GENA, __FILE__, __LINE__, | ||||||
|         "FOUND SERVICE IN INIT NOTFY EXT: UDN %s, ServID: %s\n", |         "FOUND SERVICE IN INIT NOTFY EXT: UDN %s, ServID: %s\n", | ||||||
|                          UDN, servId ) ); |         UDN, servId ); | ||||||
|  |  | ||||||
|     if( ( ( sub = GetSubscriptionSID( sid, service ) ) == NULL ) || |     if( ( ( sub = GetSubscriptionSID( sid, service ) ) == NULL ) || | ||||||
|         ( sub->active ) ) { |         ( sub->active ) ) { | ||||||
|         free( UDN_copy ); |         free( UDN_copy ); | ||||||
|         free( reference_count ); |         free( reference_count ); | ||||||
|         free( servId_copy ); |         free( servId_copy ); | ||||||
|         HandleUnlock(  ); |         HandleUnlock(); | ||||||
|         return GENA_E_BAD_SID; |         return GENA_E_BAD_SID; | ||||||
|     } |     } | ||||||
|     DBGONLY( UpnpPrintf( UPNP_INFO, GENA, __FILE__, __LINE__, |     UpnpPrintf( UPNP_INFO, GENA, __FILE__, __LINE__, | ||||||
|                          "FOUND SUBSCRIPTION IN INIT NOTIFY EXT: SID %s", |         "FOUND SUBSCRIPTION IN INIT NOTIFY EXT: SID %s", sid ); | ||||||
|                          sid ) ); |  | ||||||
|  |  | ||||||
|     sub->active = 1; |     sub->active = 1; | ||||||
|  |  | ||||||
| @@ -735,13 +733,13 @@ genaInitNotifyExt( IN UpnpDevice_Handle device_handle, | |||||||
|         free( UDN_copy ); |         free( UDN_copy ); | ||||||
|         free( reference_count ); |         free( reference_count ); | ||||||
|         free( servId_copy ); |         free( servId_copy ); | ||||||
|         HandleUnlock(  ); |         HandleUnlock(); | ||||||
|         return UPNP_E_INVALID_PARAM; |         return UPNP_E_INVALID_PARAM; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     DBGONLY( UpnpPrintf( UPNP_INFO, GENA, __FILE__, __LINE__, |     UpnpPrintf( UPNP_INFO, GENA, __FILE__, __LINE__, | ||||||
|         "GENERATED PROPERY SET IN INIT EXT NOTIFY: %s", |         "GENERATED PROPERY SET IN INIT EXT NOTIFY: %s", | ||||||
|                          propertySet ) ); |         propertySet ); | ||||||
|  |  | ||||||
|     headers_size = strlen( "CONTENT-TYPE text/xml\r\n" ) + |     headers_size = strlen( "CONTENT-TYPE text/xml\r\n" ) + | ||||||
|         strlen( "CONTENT-LENGTH: \r\n" ) + MAX_CONTENT_LENGTH + |         strlen( "CONTENT-LENGTH: \r\n" ) + MAX_CONTENT_LENGTH + | ||||||
| @@ -754,7 +752,7 @@ genaInitNotifyExt( IN UpnpDevice_Handle device_handle, | |||||||
|         free( servId_copy ); |         free( servId_copy ); | ||||||
|         free( reference_count ); |         free( reference_count ); | ||||||
|         ixmlFreeDOMString( propertySet ); |         ixmlFreeDOMString( propertySet ); | ||||||
|         HandleUnlock(  ); |         HandleUnlock(); | ||||||
|         return UPNP_E_OUTOF_MEMORY; |         return UPNP_E_OUTOF_MEMORY; | ||||||
|     } |     } | ||||||
|  |  | ||||||
| @@ -804,7 +802,7 @@ genaInitNotifyExt( IN UpnpDevice_Handle device_handle, | |||||||
|         free( thread_struct ); |         free( thread_struct ); | ||||||
|         free( headers ); |         free( headers ); | ||||||
|     } |     } | ||||||
|     HandleUnlock(  ); |     HandleUnlock(); | ||||||
|  |  | ||||||
|     return return_code; |     return return_code; | ||||||
| } | } | ||||||
| @@ -899,7 +897,7 @@ genaNotifyAllExt( IN UpnpDevice_Handle device_handle, | |||||||
|              "%ld\r\nNT: upnp:event\r\nNTS: upnp:propchange\r\n", |              "%ld\r\nNT: upnp:event\r\nNTS: upnp:propchange\r\n", | ||||||
|              (long) strlen( propertySet ) + 1 ); |              (long) strlen( propertySet ) + 1 ); | ||||||
|  |  | ||||||
|     HandleLock(  ); |     HandleLock(); | ||||||
|  |  | ||||||
|     if( GetHandleInfo( device_handle, &handle_info ) != HND_DEVICE ) |     if( GetHandleInfo( device_handle, &handle_info ) != HND_DEVICE ) | ||||||
|         return_code = GENA_E_BAD_HANDLE; |         return_code = GENA_E_BAD_HANDLE; | ||||||
| @@ -959,7 +957,7 @@ genaNotifyAllExt( IN UpnpDevice_Handle device_handle, | |||||||
|         free( servId_copy ); |         free( servId_copy ); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     HandleUnlock(  ); |     HandleUnlock(); | ||||||
|  |  | ||||||
|     return return_code; |     return return_code; | ||||||
| } | } | ||||||
| @@ -1061,7 +1059,7 @@ genaNotifyAll( IN UpnpDevice_Handle device_handle, | |||||||
|              " upnp:event\r\nNTS: upnp:propchange\r\n", |              " upnp:event\r\nNTS: upnp:propchange\r\n", | ||||||
|              (long) strlen( propertySet ) + 1 ); |              (long) strlen( propertySet ) + 1 ); | ||||||
|  |  | ||||||
|     HandleLock(  ); |     HandleLock(); | ||||||
|  |  | ||||||
|     if( GetHandleInfo( device_handle, &handle_info ) != HND_DEVICE ) { |     if( GetHandleInfo( device_handle, &handle_info ) != HND_DEVICE ) { | ||||||
|         return_code = GENA_E_BAD_HANDLE; |         return_code = GENA_E_BAD_HANDLE; | ||||||
| @@ -1123,7 +1121,7 @@ genaNotifyAll( IN UpnpDevice_Handle device_handle, | |||||||
|         free( UDN_copy ); |         free( UDN_copy ); | ||||||
|         free( servId_copy ); |         free( servId_copy ); | ||||||
|     } |     } | ||||||
|     HandleUnlock(  ); |     HandleUnlock(); | ||||||
|  |  | ||||||
|     return return_code; |     return return_code; | ||||||
| } | } | ||||||
| @@ -1317,8 +1315,8 @@ gena_process_subscription_request( IN SOCKINFO * info, | |||||||
|     memptr callback_hdr; |     memptr callback_hdr; | ||||||
|     memptr timeout_hdr; |     memptr timeout_hdr; | ||||||
|  |  | ||||||
|     DBGONLY( UpnpPrintf( UPNP_INFO, GENA, __FILE__, __LINE__, |     UpnpPrintf( UPNP_INFO, GENA, __FILE__, __LINE__, | ||||||
|                          "Subscription Request Received:\n" ) ); |         "Subscription Request Received:\n" ); | ||||||
|  |  | ||||||
|     if( httpmsg_find_hdr( request, HDR_NT, &nt_hdr ) == NULL ) { |     if( httpmsg_find_hdr( request, HDR_NT, &nt_hdr ) == NULL ) { | ||||||
|         error_respond( info, HTTP_BAD_REQUEST, request ); |         error_respond( info, HTTP_BAD_REQUEST, request ); | ||||||
| @@ -1347,18 +1345,17 @@ gena_process_subscription_request( IN SOCKINFO * info, | |||||||
|         return; |         return; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     DBGONLY( UpnpPrintf( UPNP_INFO, GENA, __FILE__, __LINE__, |     UpnpPrintf( UPNP_INFO, GENA, __FILE__, __LINE__, | ||||||
|         "SubscriptionRequest for event URL path: %s\n", |         "SubscriptionRequest for event URL path: %s\n", | ||||||
|         event_url_path ); |         event_url_path ); | ||||||
|          ) |  | ||||||
|  |  | ||||||
|         HandleLock(  ); |     HandleLock(); | ||||||
|  |  | ||||||
|     // CURRENTLY, ONLY ONE DEVICE |     // CURRENTLY, ONLY ONE DEVICE | ||||||
|     if( GetDeviceHandleInfo( &device_handle, &handle_info ) != HND_DEVICE ) { |     if( GetDeviceHandleInfo( &device_handle, &handle_info ) != HND_DEVICE ) { | ||||||
|         free( event_url_path ); |         free( event_url_path ); | ||||||
|         error_respond( info, HTTP_INTERNAL_SERVER_ERROR, request ); |         error_respond( info, HTTP_INTERNAL_SERVER_ERROR, request ); | ||||||
|         HandleUnlock(  ); |         HandleUnlock(); | ||||||
|         return; |         return; | ||||||
|     } |     } | ||||||
|     service = FindServiceEventURLPath( &handle_info->ServiceTable, |     service = FindServiceEventURLPath( &handle_info->ServiceTable, | ||||||
| @@ -1367,28 +1364,28 @@ gena_process_subscription_request( IN SOCKINFO * info, | |||||||
|  |  | ||||||
|     if( service == NULL || !service->active ) { |     if( service == NULL || !service->active ) { | ||||||
|         error_respond( info, HTTP_NOT_FOUND, request ); |         error_respond( info, HTTP_NOT_FOUND, request ); | ||||||
|         HandleUnlock(  ); |         HandleUnlock(); | ||||||
|         return; |         return; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     DBGONLY( UpnpPrintf( UPNP_INFO, GENA, __FILE__, __LINE__, |     UpnpPrintf( UPNP_INFO, GENA, __FILE__, __LINE__, | ||||||
|         "Subscription Request: Number of Subscriptions already %d\n " |         "Subscription Request: Number of Subscriptions already %d\n " | ||||||
|         "Max Subscriptions allowed: %d\n", |         "Max Subscriptions allowed: %d\n", | ||||||
|         service->TotalSubscriptions, |         service->TotalSubscriptions, | ||||||
|                          handle_info->MaxSubscriptions ) ); |         handle_info->MaxSubscriptions ); | ||||||
|  |  | ||||||
|     // too many subscriptions |     // too many subscriptions | ||||||
|     if( handle_info->MaxSubscriptions != -1 && |     if( handle_info->MaxSubscriptions != -1 && | ||||||
|         service->TotalSubscriptions >= handle_info->MaxSubscriptions ) { |         service->TotalSubscriptions >= handle_info->MaxSubscriptions ) { | ||||||
|         error_respond( info, HTTP_INTERNAL_SERVER_ERROR, request ); |         error_respond( info, HTTP_INTERNAL_SERVER_ERROR, request ); | ||||||
|         HandleUnlock(  ); |         HandleUnlock(); | ||||||
|         return; |         return; | ||||||
|     } |     } | ||||||
|     // generate new subscription |     // generate new subscription | ||||||
|     sub = ( subscription * ) malloc( sizeof( subscription ) ); |     sub = ( subscription * ) malloc( sizeof( subscription ) ); | ||||||
|     if( sub == NULL ) { |     if( sub == NULL ) { | ||||||
|         error_respond( info, HTTP_INTERNAL_SERVER_ERROR, request ); |         error_respond( info, HTTP_INTERNAL_SERVER_ERROR, request ); | ||||||
|         HandleUnlock(  ); |         HandleUnlock(); | ||||||
|         return; |         return; | ||||||
|     } |     } | ||||||
|     sub->eventKey = 0; |     sub->eventKey = 0; | ||||||
| @@ -1405,13 +1402,13 @@ gena_process_subscription_request( IN SOCKINFO * info, | |||||||
|                                          &sub->DeliveryURLs ) ) == 0 ) { |                                          &sub->DeliveryURLs ) ) == 0 ) { | ||||||
|         error_respond( info, HTTP_PRECONDITION_FAILED, request ); |         error_respond( info, HTTP_PRECONDITION_FAILED, request ); | ||||||
|         freeSubscriptionList( sub ); |         freeSubscriptionList( sub ); | ||||||
|         HandleUnlock(  ); |         HandleUnlock(); | ||||||
|         return; |         return; | ||||||
|     } |     } | ||||||
|     if( return_code == UPNP_E_OUTOF_MEMORY ) { |     if( return_code == UPNP_E_OUTOF_MEMORY ) { | ||||||
|         error_respond( info, HTTP_INTERNAL_SERVER_ERROR, request ); |         error_respond( info, HTTP_INTERNAL_SERVER_ERROR, request ); | ||||||
|         freeSubscriptionList( sub ); |         freeSubscriptionList( sub ); | ||||||
|         HandleUnlock(  ); |         HandleUnlock(); | ||||||
|         return; |         return; | ||||||
|     } |     } | ||||||
|     // set the timeout |     // set the timeout | ||||||
| @@ -1447,7 +1444,7 @@ gena_process_subscription_request( IN SOCKINFO * info, | |||||||
|     // respond OK |     // respond OK | ||||||
|     if( respond_ok( info, time_out, sub, request ) != UPNP_E_SUCCESS ) { |     if( respond_ok( info, time_out, sub, request ) != UPNP_E_SUCCESS ) { | ||||||
|         freeSubscriptionList( sub ); |         freeSubscriptionList( sub ); | ||||||
|         HandleUnlock(  ); |         HandleUnlock(); | ||||||
|         return; |         return; | ||||||
|     } |     } | ||||||
|     //add to subscription list |     //add to subscription list | ||||||
| @@ -1464,7 +1461,7 @@ gena_process_subscription_request( IN SOCKINFO * info, | |||||||
|     callback_fun = handle_info->Callback; |     callback_fun = handle_info->Callback; | ||||||
|     cookie = handle_info->Cookie; |     cookie = handle_info->Cookie; | ||||||
|  |  | ||||||
|     HandleUnlock(  ); |     HandleUnlock(); | ||||||
|  |  | ||||||
|     //make call back with request struct |     //make call back with request struct | ||||||
|     //in the future should find a way of mainting |     //in the future should find a way of mainting | ||||||
| @@ -1527,7 +1524,7 @@ gena_process_subscription_renewal_request( IN SOCKINFO * info, | |||||||
|         return; |         return; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     HandleLock(  ); |     HandleLock(); | ||||||
|  |  | ||||||
|     // CURRENTLY, ONLY SUPPORT ONE DEVICE |     // CURRENTLY, ONLY SUPPORT ONE DEVICE | ||||||
|     if( GetDeviceHandleInfo( &device_handle, &handle_info ) != HND_DEVICE ) { |     if( GetDeviceHandleInfo( &device_handle, &handle_info ) != HND_DEVICE ) { | ||||||
| @@ -1544,22 +1541,21 @@ gena_process_subscription_renewal_request( IN SOCKINFO * info, | |||||||
|         !service->active || |         !service->active || | ||||||
|         ( ( sub = GetSubscriptionSID( sid, service ) ) == NULL ) ) { |         ( ( sub = GetSubscriptionSID( sid, service ) ) == NULL ) ) { | ||||||
|         error_respond( info, HTTP_PRECONDITION_FAILED, request ); |         error_respond( info, HTTP_PRECONDITION_FAILED, request ); | ||||||
|         HandleUnlock(  ); |         HandleUnlock(); | ||||||
|         return; |         return; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     DBGONLY( UpnpPrintf( UPNP_INFO, GENA, __FILE__, __LINE__, |     UpnpPrintf( UPNP_INFO, GENA, __FILE__, __LINE__, | ||||||
|         "Renew request: Number of subscriptions already: %d\n " |         "Renew request: Number of subscriptions already: %d\n " | ||||||
|         "Max Subscriptions allowed:%d\n", |         "Max Subscriptions allowed:%d\n", | ||||||
|         service->TotalSubscriptions, |         service->TotalSubscriptions, | ||||||
|         handle_info->MaxSubscriptions ); |         handle_info->MaxSubscriptions ); | ||||||
|          ) |  | ||||||
|     // too many subscriptions |     // too many subscriptions | ||||||
|     if( handle_info->MaxSubscriptions != -1 && |     if( handle_info->MaxSubscriptions != -1 && | ||||||
|             service->TotalSubscriptions > handle_info->MaxSubscriptions ) { |             service->TotalSubscriptions > handle_info->MaxSubscriptions ) { | ||||||
|         error_respond( info, HTTP_INTERNAL_SERVER_ERROR, request ); |         error_respond( info, HTTP_INTERNAL_SERVER_ERROR, request ); | ||||||
|         RemoveSubscriptionSID( sub->sid, service ); |         RemoveSubscriptionSID( sub->sid, service ); | ||||||
|         HandleUnlock(  ); |         HandleUnlock(); | ||||||
|         return; |         return; | ||||||
|     } |     } | ||||||
|     // set the timeout |     // set the timeout | ||||||
| @@ -1598,7 +1594,7 @@ gena_process_subscription_renewal_request( IN SOCKINFO * info, | |||||||
|         RemoveSubscriptionSID( sub->sid, service ); |         RemoveSubscriptionSID( sub->sid, service ); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     HandleUnlock(  ); |     HandleUnlock(); | ||||||
| } | } | ||||||
|  |  | ||||||
| /**************************************************************************** | /**************************************************************************** | ||||||
| @@ -1651,13 +1647,13 @@ gena_process_unsubscribe_request( IN SOCKINFO * info, | |||||||
|         return; |         return; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     HandleLock(  ); |     HandleLock(); | ||||||
|  |  | ||||||
|     // CURRENTLY, ONLY SUPPORT ONE DEVICE |     // CURRENTLY, ONLY SUPPORT ONE DEVICE | ||||||
|     if( GetDeviceHandleInfo( &device_handle, &handle_info ) != HND_DEVICE ) { |     if( GetDeviceHandleInfo( &device_handle, &handle_info ) != HND_DEVICE ) { | ||||||
|         error_respond( info, HTTP_PRECONDITION_FAILED, request ); |         error_respond( info, HTTP_PRECONDITION_FAILED, request ); | ||||||
|         membuffer_destroy( &event_url_path ); |         membuffer_destroy( &event_url_path ); | ||||||
|         HandleUnlock(  ); |         HandleUnlock(); | ||||||
|         return; |         return; | ||||||
|     } |     } | ||||||
|     service = FindServiceEventURLPath( &handle_info->ServiceTable, |     service = FindServiceEventURLPath( &handle_info->ServiceTable, | ||||||
| @@ -1670,14 +1666,14 @@ gena_process_unsubscribe_request( IN SOCKINFO * info, | |||||||
|         //CheckSubscriptionSID(sid, service) == NULL ) |         //CheckSubscriptionSID(sid, service) == NULL ) | ||||||
|     { |     { | ||||||
|         error_respond( info, HTTP_PRECONDITION_FAILED, request ); |         error_respond( info, HTTP_PRECONDITION_FAILED, request ); | ||||||
|         HandleUnlock(  ); |         HandleUnlock(); | ||||||
|         return; |         return; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     RemoveSubscriptionSID( sid, service ); |     RemoveSubscriptionSID( sid, service ); | ||||||
|     error_respond( info, HTTP_OK, request );    // success |     error_respond( info, HTTP_OK, request );    // success | ||||||
|  |  | ||||||
|     HandleUnlock(  ); |     HandleUnlock(); | ||||||
| } | } | ||||||
|  |  | ||||||
| #endif // INCLUDE_DEVICE_APIS | #endif // INCLUDE_DEVICE_APIS | ||||||
|   | |||||||
| @@ -174,10 +174,8 @@ dispatch_request( IN SOCKINFO * info, | |||||||
|         case HTTPMETHOD_NOTIFY: |         case HTTPMETHOD_NOTIFY: | ||||||
|         case HTTPMETHOD_SUBSCRIBE: |         case HTTPMETHOD_SUBSCRIBE: | ||||||
|         case HTTPMETHOD_UNSUBSCRIBE: |         case HTTPMETHOD_UNSUBSCRIBE: | ||||||
|             DBGONLY( UpnpPrintf |             UpnpPrintf( UPNP_INFO, MSERV, __FILE__, __LINE__, | ||||||
|                      ( UPNP_INFO, MSERV, __FILE__, __LINE__, |  | ||||||
|                 "miniserver %d: got GENA msg\n", info->socket ); |                 "miniserver %d: got GENA msg\n", info->socket ); | ||||||
|                  ) |  | ||||||
|             callback = gGenaCallback; |             callback = gGenaCallback; | ||||||
|             break; |             break; | ||||||
|  |  | ||||||
| @@ -217,7 +215,7 @@ dispatch_request( IN SOCKINFO * info, | |||||||
| * | * | ||||||
| *	Note : | *	Note : | ||||||
| ************************************************************************/ | ************************************************************************/ | ||||||
| static XINLINE void | static UPNP_INLINE void | ||||||
| handle_error( IN SOCKINFO * info, | handle_error( IN SOCKINFO * info, | ||||||
|               int http_error_code, |               int http_error_code, | ||||||
|               int major, |               int major, | ||||||
| @@ -275,10 +273,8 @@ handle_request( void *args ) | |||||||
|     struct mserv_request_t *request = ( struct mserv_request_t * )args; |     struct mserv_request_t *request = ( struct mserv_request_t * )args; | ||||||
|     int connfd = request->connfd; |     int connfd = request->connfd; | ||||||
|  |  | ||||||
|     DBGONLY( UpnpPrintf |     UpnpPrintf( UPNP_INFO, MSERV, __FILE__, __LINE__, | ||||||
|              ( UPNP_INFO, MSERV, __FILE__, __LINE__, |  | ||||||
|         "miniserver %d: READING\n", connfd ); |         "miniserver %d: READING\n", connfd ); | ||||||
|          ) |  | ||||||
|     //parser_request_init( &parser ); ////LEAK_FIX_MK |     //parser_request_init( &parser ); ////LEAK_FIX_MK | ||||||
|     hmsg = &parser.msg; |     hmsg = &parser.msg; | ||||||
|  |  | ||||||
| @@ -295,10 +291,8 @@ handle_request( void *args ) | |||||||
|         goto error_handler; |         goto error_handler; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     DBGONLY( UpnpPrintf |     UpnpPrintf( UPNP_INFO, MSERV, __FILE__, __LINE__, | ||||||
|              ( UPNP_INFO, MSERV, __FILE__, __LINE__, |  | ||||||
|         "miniserver %d: PROCESSING...\n", connfd ); |         "miniserver %d: PROCESSING...\n", connfd ); | ||||||
|          ) |  | ||||||
|     // dispatch |     // dispatch | ||||||
|     http_error_code = dispatch_request( &info, &parser ); |     http_error_code = dispatch_request( &info, &parser ); | ||||||
|     if( http_error_code != 0 ) { |     if( http_error_code != 0 ) { | ||||||
| @@ -316,10 +310,8 @@ handle_request( void *args ) | |||||||
|         handle_error( &info, http_error_code, major, minor ); |         handle_error( &info, http_error_code, major, minor ); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     DBGONLY( UpnpPrintf |     UpnpPrintf( UPNP_INFO, MSERV, __FILE__, __LINE__, | ||||||
|              ( UPNP_INFO, MSERV, __FILE__, __LINE__, |  | ||||||
|         "miniserver %d: COMPLETE\n", connfd ); |         "miniserver %d: COMPLETE\n", connfd ); | ||||||
|          ) |  | ||||||
|     sock_destroy( &info, SD_BOTH ); //should shutdown completely |     sock_destroy( &info, SD_BOTH ); //should shutdown completely | ||||||
|  |  | ||||||
|     httpmsg_destroy( hmsg ); |     httpmsg_destroy( hmsg ); | ||||||
| @@ -341,7 +333,7 @@ handle_request( void *args ) | |||||||
| * | * | ||||||
| *	Note : | *	Note : | ||||||
| ************************************************************************/ | ************************************************************************/ | ||||||
| static XINLINE void | static UPNP_INLINE void | ||||||
| schedule_request_job( IN int connfd, | schedule_request_job( IN int connfd, | ||||||
|                       IN struct sockaddr_in *clientAddr ) |                       IN struct sockaddr_in *clientAddr ) | ||||||
| { | { | ||||||
| @@ -352,10 +344,8 @@ schedule_request_job( IN int connfd, | |||||||
|         ( struct mserv_request_t * ) |         ( struct mserv_request_t * ) | ||||||
|         malloc( sizeof( struct mserv_request_t ) ); |         malloc( sizeof( struct mserv_request_t ) ); | ||||||
|     if( request == NULL ) { |     if( request == NULL ) { | ||||||
|         DBGONLY( UpnpPrintf |         UpnpPrintf( UPNP_INFO, MSERV, __FILE__, __LINE__, | ||||||
|                  ( UPNP_INFO, MSERV, __FILE__, __LINE__, |  | ||||||
|             "mserv %d: out of memory\n", connfd ); |             "mserv %d: out of memory\n", connfd ); | ||||||
|              ) |  | ||||||
|         shutdown( request->connfd, SD_BOTH ); |         shutdown( request->connfd, SD_BOTH ); | ||||||
|         UpnpCloseSocket( connfd ); |         UpnpCloseSocket( connfd ); | ||||||
|         return; |         return; | ||||||
| @@ -369,11 +359,9 @@ schedule_request_job( IN int connfd, | |||||||
|     TPJobSetFreeFunction( &job, free_handle_request_arg ); |     TPJobSetFreeFunction( &job, free_handle_request_arg ); | ||||||
|     TPJobSetPriority( &job, MED_PRIORITY ); |     TPJobSetPriority( &job, MED_PRIORITY ); | ||||||
|  |  | ||||||
|     if( ThreadPoolAdd( &gRecvThreadPool, &job, NULL ) != 0 ) { |     if( ThreadPoolAdd( &gMiniServerThreadPool, &job, NULL ) != 0 ) { | ||||||
|         DBGONLY( UpnpPrintf |         UpnpPrintf( UPNP_INFO, MSERV, __FILE__, __LINE__, | ||||||
|                  ( UPNP_INFO, MSERV, __FILE__, __LINE__, |  | ||||||
|             "mserv %d: cannot schedule request\n", connfd ); |             "mserv %d: cannot schedule request\n", connfd ); | ||||||
|              ) |  | ||||||
|             free( request ); |             free( request ); | ||||||
|         shutdown( connfd, SD_BOTH ); |         shutdown( connfd, SD_BOTH ); | ||||||
|         UpnpCloseSocket( connfd ); |         UpnpCloseSocket( connfd ); | ||||||
| @@ -446,10 +434,8 @@ RunMiniServer( MiniServerSockArray * miniSock ) | |||||||
|  |  | ||||||
|         if( select( maxMiniSock, &rdSet, NULL, &expSet, NULL ) == |         if( select( maxMiniSock, &rdSet, NULL, &expSet, NULL ) == | ||||||
|             UPNP_SOCKETERROR ) { |             UPNP_SOCKETERROR ) { | ||||||
|             DBGONLY( UpnpPrintf |             UpnpPrintf( UPNP_CRITICAL, SSDP, __FILE__, __LINE__, | ||||||
|                      ( UPNP_CRITICAL, SSDP, __FILE__, __LINE__, |  | ||||||
|                 "Error in select call !!!\n" ); |                 "Error in select call !!!\n" ); | ||||||
|                  ) |  | ||||||
|             continue; |             continue; | ||||||
|         } else { |         } else { | ||||||
|  |  | ||||||
| @@ -459,11 +445,9 @@ RunMiniServer( MiniServerSockArray * miniSock ) | |||||||
|                                      ( struct sockaddr * )&clientAddr, |                                      ( struct sockaddr * )&clientAddr, | ||||||
|                                      &clientLen ); |                                      &clientLen ); | ||||||
|                 if( connectHnd == UPNP_INVALID_SOCKET ) { |                 if( connectHnd == UPNP_INVALID_SOCKET ) { | ||||||
|                     DBGONLY( UpnpPrintf |                     UpnpPrintf( UPNP_INFO, MSERV, __FILE__, __LINE__, | ||||||
|                              ( UPNP_INFO, MSERV, __FILE__, __LINE__, |  | ||||||
|                         "miniserver: Error" |                         "miniserver: Error" | ||||||
|                         " in accepting connection\n" ); |                         " in accepting connection\n" ); | ||||||
|                          ) |  | ||||||
|                     continue; |                     continue; | ||||||
|                 } |                 } | ||||||
|                 schedule_request_job( connectHnd, &clientAddr ); |                 schedule_request_job( connectHnd, &clientAddr ); | ||||||
| @@ -489,24 +473,19 @@ RunMiniServer( MiniServerSockArray * miniSock ) | |||||||
|                               &clientLen ); |                               &clientLen ); | ||||||
|                 if( byteReceived > 0 ) { |                 if( byteReceived > 0 ) { | ||||||
|                     requestBuf[byteReceived] = '\0'; |                     requestBuf[byteReceived] = '\0'; | ||||||
|                     DBGONLY( UpnpPrintf |                     UpnpPrintf( UPNP_INFO, MSERV, __FILE__, __LINE__, | ||||||
|                              ( UPNP_INFO, MSERV, __FILE__, __LINE__, |  | ||||||
|                         "Received response !!!  %s From host %s \n", |                         "Received response !!!  %s From host %s \n", | ||||||
|                                requestBuf, |                         requestBuf, inet_ntoa( clientAddr.sin_addr ) ); | ||||||
|                                inet_ntoa( clientAddr.sin_addr ) ); |                     UpnpPrintf( UPNP_PACKET, MSERV, __FILE__, __LINE__, | ||||||
|                          ) |  | ||||||
|                         DBGONLY( UpnpPrintf |  | ||||||
|                                  ( UPNP_PACKET, MSERV, __FILE__, __LINE__, |  | ||||||
|                         "Received multicast packet: \n %s\n", |                         "Received multicast packet: \n %s\n", | ||||||
|                         requestBuf ); |                         requestBuf ); | ||||||
|                          ) |  | ||||||
|  |  | ||||||
|                         if( NULL != strstr( requestBuf, "ShutDown" ) ) |                     if( NULL != strstr( requestBuf, "ShutDown" ) ) { | ||||||
|                         break; |                         break; | ||||||
| 		    } | 		    } | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|  |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     shutdown( miniServSock, SD_BOTH ); |     shutdown( miniServSock, SD_BOTH ); | ||||||
| @@ -555,10 +534,8 @@ get_port( int sockfd ) | |||||||
|     } |     } | ||||||
|  |  | ||||||
|     port = ntohs( sockinfo.sin_port ); |     port = ntohs( sockinfo.sin_port ); | ||||||
|     DBGONLY( UpnpPrintf |     UpnpPrintf( UPNP_INFO, MSERV, __FILE__, __LINE__, | ||||||
|              ( UPNP_INFO, MSERV, __FILE__, __LINE__, |  | ||||||
|         "sockfd = %d, .... port = %d\n", sockfd, port ); |         "sockfd = %d, .... port = %d\n", sockfd, port ); | ||||||
|          ) |  | ||||||
|  |  | ||||||
|     return port; |     return port; | ||||||
| } | } | ||||||
| @@ -623,16 +600,10 @@ get_miniserver_sockets( MiniServerSockArray * out, | |||||||
|         //THIS MAY CAUSE TCP TO BECOME LESS RELIABLE |         //THIS MAY CAUSE TCP TO BECOME LESS RELIABLE | ||||||
|         //HOWEVER IT HAS BEEN SUGESTED FOR TCP SERVERS |         //HOWEVER IT HAS BEEN SUGESTED FOR TCP SERVERS | ||||||
|  |  | ||||||
|         DBGONLY( UpnpPrintf( UPNP_INFO, MSERV, __FILE__, __LINE__, |         UpnpPrintf( UPNP_INFO, MSERV, __FILE__, __LINE__, | ||||||
|             "mserv start: resuseaddr set\n" ); |             "mserv start: resuseaddr set\n" ); | ||||||
|              ) |         sockError = setsockopt( listenfd, SOL_SOCKET, SO_REUSEADDR, | ||||||
|  |             ( const char * )&reuseaddr_on, sizeof( int )); | ||||||
|             sockError = setsockopt( listenfd, |  | ||||||
|                                     SOL_SOCKET, |  | ||||||
|                                     SO_REUSEADDR, |  | ||||||
|                                     ( const char * )&reuseaddr_on, |  | ||||||
|                                     sizeof( int ) |  | ||||||
|              ); |  | ||||||
|         if( sockError == UPNP_SOCKETERROR ) { |         if( sockError == UPNP_SOCKETERROR ) { | ||||||
|             shutdown( listenfd, SD_BOTH ); |             shutdown( listenfd, SD_BOTH ); | ||||||
|             UpnpCloseSocket( listenfd ); |             UpnpCloseSocket( listenfd ); | ||||||
| @@ -665,16 +636,14 @@ get_miniserver_sockets( MiniServerSockArray * out, | |||||||
|     } |     } | ||||||
|  |  | ||||||
|     if( sockError == UPNP_SOCKETERROR ) { |     if( sockError == UPNP_SOCKETERROR ) { | ||||||
|         DBGONLY( perror( "mserv start: bind failed" ); |         perror( "mserv start: bind failed" ); | ||||||
|              ) |  | ||||||
|         shutdown( listenfd, SD_BOTH ); |         shutdown( listenfd, SD_BOTH ); | ||||||
|         UpnpCloseSocket( listenfd ); |         UpnpCloseSocket( listenfd ); | ||||||
|         return UPNP_E_SOCKET_BIND;  // bind failed |         return UPNP_E_SOCKET_BIND;  // bind failed | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     DBGONLY( UpnpPrintf( UPNP_INFO, MSERV, __FILE__, __LINE__, |     UpnpPrintf( UPNP_INFO, MSERV, __FILE__, __LINE__, | ||||||
|         "mserv start: bind success\n" ); |         "mserv start: bind success\n" ); | ||||||
|          ) |  | ||||||
|  |  | ||||||
|     success = listen( listenfd, SOMAXCONN ); |     success = listen( listenfd, SOMAXCONN ); | ||||||
|     if( success == UPNP_SOCKETERROR ) { |     if( success == UPNP_SOCKETERROR ) { | ||||||
| @@ -694,10 +663,9 @@ get_miniserver_sockets( MiniServerSockArray * out, | |||||||
|  |  | ||||||
|     if( ( miniServerStopSock = socket( AF_INET, SOCK_DGRAM, 0 ) ) == |     if( ( miniServerStopSock = socket( AF_INET, SOCK_DGRAM, 0 ) ) == | ||||||
|         UPNP_INVALID_SOCKET ) { |         UPNP_INVALID_SOCKET ) { | ||||||
|         DBGONLY( UpnpPrintf( UPNP_CRITICAL, |         UpnpPrintf( UPNP_CRITICAL, | ||||||
|             MSERV, __FILE__, __LINE__, |             MSERV, __FILE__, __LINE__, | ||||||
|             "Error in socket operation !!!\n" ); |             "Error in socket operation !!!\n" ); | ||||||
|              ) |  | ||||||
|         shutdown( listenfd, SD_BOTH ); |         shutdown( listenfd, SD_BOTH ); | ||||||
|         UpnpCloseSocket( listenfd ); |         UpnpCloseSocket( listenfd ); | ||||||
|         return UPNP_E_OUTOF_SOCKET; |         return UPNP_E_OUTOF_SOCKET; | ||||||
| @@ -711,10 +679,9 @@ get_miniserver_sockets( MiniServerSockArray * out, | |||||||
|     if( bind( miniServerStopSock, ( struct sockaddr * )&serverAddr, |     if( bind( miniServerStopSock, ( struct sockaddr * )&serverAddr, | ||||||
|               sizeof( serverAddr ) ) == UPNP_SOCKETERROR ) { |               sizeof( serverAddr ) ) == UPNP_SOCKETERROR ) { | ||||||
|  |  | ||||||
|         DBGONLY( UpnpPrintf( UPNP_CRITICAL, |         UpnpPrintf( UPNP_CRITICAL, | ||||||
|             MSERV, __FILE__, __LINE__, |             MSERV, __FILE__, __LINE__, | ||||||
|             "Error in binding localhost!!!\n" ); |             "Error in binding localhost!!!\n" ); | ||||||
|              ) |  | ||||||
|         shutdown( listenfd, SD_BOTH ); |         shutdown( listenfd, SD_BOTH ); | ||||||
|         UpnpCloseSocket( listenfd ); |         UpnpCloseSocket( listenfd ); | ||||||
|         shutdown( miniServerStopSock, SD_BOTH ); |         shutdown( miniServerStopSock, SD_BOTH ); | ||||||
| @@ -805,7 +772,7 @@ StartMiniServer( unsigned short listen_port ) | |||||||
|  |  | ||||||
|     TPJobSetFreeFunction( &job, ( free_routine ) free ); |     TPJobSetFreeFunction( &job, ( free_routine ) free ); | ||||||
|  |  | ||||||
|     success = ThreadPoolAddPersistent( &gRecvThreadPool, &job, NULL ); |     success = ThreadPoolAddPersistent( &gMiniServerThreadPool, &job, NULL ); | ||||||
|  |  | ||||||
|     if( success < 0 ) { |     if( success < 0 ) { | ||||||
|         shutdown( miniSocket->miniServerSock, SD_BOTH ); |         shutdown( miniSocket->miniServerSock, SD_BOTH ); | ||||||
| @@ -877,10 +844,8 @@ StopMiniServer( void ) | |||||||
|  |  | ||||||
|     sock = socket( AF_INET, SOCK_DGRAM, 0 ); |     sock = socket( AF_INET, SOCK_DGRAM, 0 ); | ||||||
|     if( sock == UPNP_INVALID_SOCKET ) { |     if( sock == UPNP_INVALID_SOCKET ) { | ||||||
|         DBGONLY( UpnpPrintf |         UpnpPrintf( UPNP_INFO, SSDP, __FILE__, __LINE__, | ||||||
|                  ( UPNP_INFO, SSDP, __FILE__, __LINE__, |  | ||||||
|             "SSDP_SERVER:StopSSDPServer: Error in socket operation !!!\n" ); |             "SSDP_SERVER:StopSSDPServer: Error in socket operation !!!\n" ); | ||||||
|              ) |  | ||||||
|         return 0; |         return 0; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -34,6 +34,7 @@ | |||||||
| * messages. | * messages. | ||||||
| ************************************************************************/ | ************************************************************************/ | ||||||
|  |  | ||||||
|  | #define _GNU_SOURCE	// For strcasestr() in string.h | ||||||
| #include "config.h" | #include "config.h" | ||||||
| #include <assert.h> | #include <assert.h> | ||||||
| #include <string.h> | #include <string.h> | ||||||
| @@ -100,7 +101,7 @@ str_int_entry Http_Header_Names[NUM_HTTP_HEADER_NAMES] = { | |||||||
|  |  | ||||||
| /***********************************************************************/ | /***********************************************************************/ | ||||||
|  |  | ||||||
| /*************				 scanner					  **************/ | /*************                 scanner                     *************/ | ||||||
|  |  | ||||||
| /***********************************************************************/ | /***********************************************************************/ | ||||||
|  |  | ||||||
| @@ -120,7 +121,7 @@ str_int_entry Http_Header_Names[NUM_HTTP_HEADER_NAMES] = { | |||||||
| * | * | ||||||
| * Note : | * Note : | ||||||
| ************************************************************************/ | ************************************************************************/ | ||||||
| static XINLINE void | static UPNP_INLINE void | ||||||
| scanner_init( OUT scanner_t * scanner, | scanner_init( OUT scanner_t * scanner, | ||||||
|               IN membuffer * bufptr ) |               IN membuffer * bufptr ) | ||||||
| { | { | ||||||
| @@ -141,7 +142,7 @@ scanner_init( OUT scanner_t * scanner, | |||||||
| * | * | ||||||
| * Note : | * Note : | ||||||
| ************************************************************************/ | ************************************************************************/ | ||||||
| static XINLINE xboolean | static UPNP_INLINE xboolean | ||||||
| is_separator_char( IN char c ) | is_separator_char( IN char c ) | ||||||
| { | { | ||||||
|     return strchr( " \t()<>@,;:\\\"/[]?={}", c ) != NULL; |     return strchr( " \t()<>@,;:\\\"/[]?={}", c ) != NULL; | ||||||
| @@ -159,7 +160,7 @@ is_separator_char( IN char c ) | |||||||
| * | * | ||||||
| * Note : | * Note : | ||||||
| ************************************************************************/ | ************************************************************************/ | ||||||
| static XINLINE xboolean | static UPNP_INLINE xboolean | ||||||
| is_identifier_char( IN char c ) | is_identifier_char( IN char c ) | ||||||
| { | { | ||||||
|     return ( c >= 32 && c <= 126 ) && !is_separator_char( c ); |     return ( c >= 32 && c <= 126 ) && !is_separator_char( c ); | ||||||
| @@ -177,7 +178,7 @@ is_identifier_char( IN char c ) | |||||||
| * | * | ||||||
| * Note : | * Note : | ||||||
| ************************************************************************/ | ************************************************************************/ | ||||||
| static XINLINE xboolean | static UPNP_INLINE xboolean | ||||||
| is_control_char( IN char c ) | is_control_char( IN char c ) | ||||||
| { | { | ||||||
|     return ( ( c >= 0 && c <= 31 ) || ( c == 127 ) ); |     return ( ( c >= 0 && c <= 31 ) || ( c == 127 ) ); | ||||||
| @@ -195,7 +196,7 @@ is_control_char( IN char c ) | |||||||
| * | * | ||||||
| * Note : | * Note : | ||||||
| ************************************************************************/ | ************************************************************************/ | ||||||
| static XINLINE xboolean | static UPNP_INLINE xboolean | ||||||
| is_qdtext_char( IN char cc ) | is_qdtext_char( IN char cc ) | ||||||
| { | { | ||||||
|     unsigned char c = ( unsigned char )cc; |     unsigned char c = ( unsigned char )cc; | ||||||
| @@ -374,7 +375,7 @@ scanner_get_token( INOUT scanner_t * scanner, | |||||||
| * | * | ||||||
| * Note : | * Note : | ||||||
| ************************************************************************/ | ************************************************************************/ | ||||||
| static XINLINE char * | static UPNP_INLINE char * | ||||||
| scanner_get_str( IN scanner_t * scanner ) | scanner_get_str( IN scanner_t * scanner ) | ||||||
| { | { | ||||||
|     return scanner->msg->buf + scanner->cursor; |     return scanner->msg->buf + scanner->cursor; | ||||||
| @@ -394,7 +395,9 @@ scanner_get_str( IN scanner_t * scanner ) | |||||||
| * | * | ||||||
| * Note : | * Note : | ||||||
| ************************************************************************/ | ************************************************************************/ | ||||||
| static XINLINE void | #warning The only use of the function 'scanner_pushback()' in the code is commented out. | ||||||
|  | #warning 'scanner_pushback()' is a good candidate for removal. | ||||||
|  | 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 ) | ||||||
| { | { | ||||||
| @@ -561,7 +564,7 @@ httpmsg_find_hdr_str( IN http_message_t * msg, | |||||||
| * | * | ||||||
| * Description :	Finds header from a list, with the given 'name_id'. | * Description :	Finds header from a list, with the given 'name_id'. | ||||||
| * | * | ||||||
| *	Return : http_header_t*  - Pointer to a header on success;										* | * Return : http_header_t*  - Pointer to a header on success; | ||||||
| *				NULL on failure | *				NULL on failure | ||||||
| * | * | ||||||
| * Note : | * Note : | ||||||
| @@ -613,7 +616,7 @@ httpmsg_find_hdr( IN http_message_t * msg, | |||||||
| * | * | ||||||
| * Note : | * Note : | ||||||
| ************************************************************************/ | ************************************************************************/ | ||||||
| static XINLINE int | static UPNP_INLINE int | ||||||
| skip_blank_lines( INOUT scanner_t * scanner ) | skip_blank_lines( INOUT scanner_t * scanner ) | ||||||
| { | { | ||||||
|     memptr token; |     memptr token; | ||||||
| @@ -650,7 +653,7 @@ skip_blank_lines( INOUT scanner_t * scanner ) | |||||||
| * | * | ||||||
| * Note : | * Note : | ||||||
| ************************************************************************/ | ************************************************************************/ | ||||||
| static XINLINE int | static UPNP_INLINE int | ||||||
| skip_lws( INOUT scanner_t * scanner ) | skip_lws( INOUT scanner_t * scanner ) | ||||||
| { | { | ||||||
|     memptr token; |     memptr token; | ||||||
| @@ -697,7 +700,7 @@ skip_lws( INOUT scanner_t * scanner ) | |||||||
| * | * | ||||||
| * Description :	Match a string without whitespace or CRLF (%S) | * Description :	Match a string without whitespace or CRLF (%S) | ||||||
| * | * | ||||||
| *	Return : XINLINE parse_status_t ; | * Return : UPNP_INLINE parse_status_t ; | ||||||
| *	PARSE_OK | *	PARSE_OK | ||||||
| *	PARSE_NO_MATCH | *	PARSE_NO_MATCH | ||||||
| *	PARSE_FAILURE | *	PARSE_FAILURE | ||||||
| @@ -705,7 +708,7 @@ skip_lws( INOUT scanner_t * scanner ) | |||||||
| * | * | ||||||
| * Note : | * Note : | ||||||
| ************************************************************************/ | ************************************************************************/ | ||||||
| static XINLINE parse_status_t | static UPNP_INLINE parse_status_t | ||||||
| match_non_ws_string( INOUT scanner_t * scanner, | match_non_ws_string( INOUT scanner_t * scanner, | ||||||
|                      OUT memptr * str ) |                      OUT memptr * str ) | ||||||
| { | { | ||||||
| @@ -771,7 +774,7 @@ match_non_ws_string( INOUT scanner_t * scanner, | |||||||
| * | * | ||||||
| * Note : | * Note : | ||||||
| ************************************************************************/ | ************************************************************************/ | ||||||
| static XINLINE parse_status_t | static UPNP_INLINE parse_status_t | ||||||
| match_raw_value( INOUT scanner_t * scanner, | match_raw_value( INOUT scanner_t * scanner, | ||||||
|                  OUT memptr * raw_value ) |                  OUT memptr * raw_value ) | ||||||
| { | { | ||||||
| @@ -862,7 +865,7 @@ match_raw_value( INOUT scanner_t * scanner, | |||||||
| *   PARSE_FAILURE		-- bad input | *   PARSE_FAILURE		-- bad input | ||||||
| *   PARSE_INCOMPLETE | *   PARSE_INCOMPLETE | ||||||
| ************************************************************************/ | ************************************************************************/ | ||||||
| static XINLINE int | static UPNP_INLINE int | ||||||
| match_int( INOUT scanner_t * scanner, | match_int( INOUT scanner_t * scanner, | ||||||
|            IN int base, |            IN int base, | ||||||
|            OUT int *value ) |            OUT int *value ) | ||||||
| @@ -909,7 +912,7 @@ match_int( INOUT scanner_t * scanner, | |||||||
| * Function: read_until_crlf | * Function: read_until_crlf | ||||||
| * | * | ||||||
| * Parameters: | * Parameters: | ||||||
| *	INOUT scanner_t* scanner ;	Scanner Object											 | *	INOUT scanner_t* scanner ;Scanner Object | ||||||
| *	OUT memptr* str ;	Buffer to copy scanner buffer contents to | *	OUT memptr* str ;	Buffer to copy scanner buffer contents to | ||||||
| * | * | ||||||
| * Description: Reads data until end of line; the crlf at the end of		 | * Description: Reads data until end of line; the crlf at the end of		 | ||||||
| @@ -921,7 +924,7 @@ match_int( INOUT scanner_t * scanner, | |||||||
| *   PARSE_FAILURE | *   PARSE_FAILURE | ||||||
| *   PARSE_INCOMPLETE | *   PARSE_INCOMPLETE | ||||||
| ************************************************************************/ | ************************************************************************/ | ||||||
| static XINLINE int | static UPNP_INLINE int | ||||||
| read_until_crlf( INOUT scanner_t * scanner, | read_until_crlf( INOUT scanner_t * scanner, | ||||||
|                  OUT memptr * str ) |                  OUT memptr * str ) | ||||||
| { | { | ||||||
| @@ -962,7 +965,9 @@ read_until_crlf( INOUT scanner_t * scanner, | |||||||
| *   PARSE_FAILURE | *   PARSE_FAILURE | ||||||
| *   PARSE_INCOMPLETE | *   PARSE_INCOMPLETE | ||||||
| ************************************************************************/ | ************************************************************************/ | ||||||
| static XINLINE int | #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. | ||||||
|  | static UPNP_INLINE int | ||||||
| skip_to_end_of_header( INOUT scanner_t * scanner ) | skip_to_end_of_header( INOUT scanner_t * scanner ) | ||||||
| { | { | ||||||
|     memptr dummy_raw_value; |     memptr dummy_raw_value; | ||||||
| @@ -978,8 +983,8 @@ skip_to_end_of_header( INOUT scanner_t * scanner ) | |||||||
| * Parameters: | * Parameters: | ||||||
| *	INOUT scanner_t* scanner ;	Scanner Object | *	INOUT scanner_t* scanner ;	Scanner Object | ||||||
| *	IN char c ;			Character to be compared with | *	IN char c ;			Character to be compared with | ||||||
| *	IN xboolean case_sensitive; Flag indicating whether comparison should | *	IN xboolean case_sensitive;	Flag indicating whether | ||||||
| *								be case sensitive | *					comparison should be case sensitive | ||||||
| * | * | ||||||
| * Description: Compares a character to the next char in the scanner; | * Description: Compares a character to the next char in the scanner; | ||||||
| *	on error, scanner chars are not restored | *	on error, scanner chars are not restored | ||||||
| @@ -989,7 +994,7 @@ skip_to_end_of_header( INOUT scanner_t * scanner ) | |||||||
| *   PARSE_NO_MATCH | *   PARSE_NO_MATCH | ||||||
| *   PARSE_INCOMPLETE | *   PARSE_INCOMPLETE | ||||||
| ************************************************************************/ | ************************************************************************/ | ||||||
| static XINLINE parse_status_t | static UPNP_INLINE parse_status_t | ||||||
| match_char( INOUT scanner_t * scanner, | match_char( INOUT scanner_t * scanner, | ||||||
|             IN char c, |             IN char c, | ||||||
|             IN xboolean case_sensitive ) |             IN xboolean case_sensitive ) | ||||||
| @@ -1336,7 +1341,7 @@ matchstr( IN char *str, | |||||||
| * Returns: | * Returns: | ||||||
| *	void | *	void | ||||||
| ************************************************************************/ | ************************************************************************/ | ||||||
| static XINLINE void | static UPNP_INLINE void | ||||||
| parser_init( OUT http_parser_t * parser ) | parser_init( OUT http_parser_t * parser ) | ||||||
| { | { | ||||||
|     memset( parser, 0, sizeof( http_parser_t ) ); |     memset( parser, 0, sizeof( http_parser_t ) ); | ||||||
| @@ -1871,7 +1876,7 @@ parser_parse_headers_old( INOUT http_parser_t * parser ) | |||||||
| *	 PARSE_FAILURE -- entity length > content-length value | *	 PARSE_FAILURE -- entity length > content-length value | ||||||
| *	 PARSE_SUCCESS | *	 PARSE_SUCCESS | ||||||
| ************************************************************************/ | ************************************************************************/ | ||||||
| static XINLINE parse_status_t | static UPNP_INLINE parse_status_t | ||||||
| parser_parse_entity_using_clen( INOUT http_parser_t * parser ) | parser_parse_entity_using_clen( INOUT http_parser_t * parser ) | ||||||
| { | { | ||||||
|     //int entity_length; |     //int entity_length; | ||||||
| @@ -1918,7 +1923,7 @@ parser_parse_entity_using_clen( INOUT http_parser_t * parser ) | |||||||
| *	 PARSE_FAILURE -- entity length > content-length value | *	 PARSE_FAILURE -- entity length > content-length value | ||||||
| *	 PARSE_SUCCESS | *	 PARSE_SUCCESS | ||||||
| ************************************************************************/ | ************************************************************************/ | ||||||
| static XINLINE parse_status_t | static UPNP_INLINE parse_status_t | ||||||
| parser_parse_chunky_body( INOUT http_parser_t * parser ) | parser_parse_chunky_body( INOUT http_parser_t * parser ) | ||||||
| { | { | ||||||
|     parse_status_t status; |     parse_status_t status; | ||||||
| @@ -1963,7 +1968,7 @@ parser_parse_chunky_body( INOUT http_parser_t * parser ) | |||||||
| *	 PARSE_FAILURE -- entity length > content-length value | *	 PARSE_FAILURE -- entity length > content-length value | ||||||
| *	 PARSE_SUCCESS | *	 PARSE_SUCCESS | ||||||
| ************************************************************************/ | ************************************************************************/ | ||||||
| static XINLINE parse_status_t | static UPNP_INLINE parse_status_t | ||||||
| parser_parse_chunky_headers( INOUT http_parser_t * parser ) | parser_parse_chunky_headers( INOUT http_parser_t * parser ) | ||||||
| { | { | ||||||
|     parse_status_t status; |     parse_status_t status; | ||||||
| @@ -2003,7 +2008,7 @@ parser_parse_chunky_headers( INOUT http_parser_t * parser ) | |||||||
| *	 PARSE_SUCCESS | *	 PARSE_SUCCESS | ||||||
| *	 PARSE_CONTINUE_1 | *	 PARSE_CONTINUE_1 | ||||||
| ************************************************************************/ | ************************************************************************/ | ||||||
| static XINLINE parse_status_t | static UPNP_INLINE parse_status_t | ||||||
| parser_parse_chunky_entity( INOUT http_parser_t * parser ) | parser_parse_chunky_entity( INOUT http_parser_t * parser ) | ||||||
| { | { | ||||||
|     scanner_t *scanner = &parser->scanner; |     scanner_t *scanner = &parser->scanner; | ||||||
| @@ -2019,9 +2024,8 @@ parser_parse_chunky_entity( INOUT http_parser_t * parser ) | |||||||
|     status = match( scanner, "%x%L%c", &parser->chunk_size, &dummy ); |     status = match( scanner, "%x%L%c", &parser->chunk_size, &dummy ); | ||||||
|     if( status != PARSE_OK ) { |     if( status != PARSE_OK ) { | ||||||
|         scanner->cursor = save_pos; |         scanner->cursor = save_pos; | ||||||
|         DBGONLY( UpnpPrintf |         UpnpPrintf( UPNP_INFO, HTTP, __FILE__, __LINE__, | ||||||
|                  ( UPNP_INFO, HTTP, __FILE__, __LINE__, |             "CHUNK COULD NOT BE PARSED\n" ); | ||||||
|                    "CHUNK COULD NOT BE PARSED\n" ); ) |  | ||||||
|         return status; |         return status; | ||||||
|     } |     } | ||||||
|     // remove chunk info just matched; just retain data |     // remove chunk info just matched; just retain data | ||||||
| @@ -2055,7 +2059,7 @@ parser_parse_chunky_entity( INOUT http_parser_t * parser ) | |||||||
| * Returns: | * Returns: | ||||||
| *	 PARSE_INCOMPLETE_ENTITY | *	 PARSE_INCOMPLETE_ENTITY | ||||||
| ************************************************************************/ | ************************************************************************/ | ||||||
| static XINLINE parse_status_t | static UPNP_INLINE parse_status_t | ||||||
| parser_parse_entity_until_close( INOUT http_parser_t * parser ) | parser_parse_entity_until_close( INOUT http_parser_t * parser ) | ||||||
| { | { | ||||||
|     size_t cursor; |     size_t cursor; | ||||||
| @@ -2090,7 +2094,7 @@ parser_parse_entity_until_close( INOUT http_parser_t * parser ) | |||||||
| * 	 PARSE_FAILURE | * 	 PARSE_FAILURE | ||||||
| *	 PARSE_COMPLETE	-- no more reading to do | *	 PARSE_COMPLETE	-- no more reading to do | ||||||
| ************************************************************************/ | ************************************************************************/ | ||||||
| XINLINE parse_status_t | UPNP_INLINE parse_status_t | ||||||
| parser_get_entity_read_method( INOUT http_parser_t * parser ) | parser_get_entity_read_method( INOUT http_parser_t * parser ) | ||||||
| { | { | ||||||
|     http_message_t *hmsg = &parser->msg; |     http_message_t *hmsg = &parser->msg; | ||||||
| @@ -2148,9 +2152,8 @@ parser_get_entity_read_method( INOUT http_parser_t * parser ) | |||||||
|         if( raw_find_str( &hdr_value, "chunked" ) >= 0 ) { |         if( raw_find_str( &hdr_value, "chunked" ) >= 0 ) { | ||||||
|             // read method to use chunked transfer encoding |             // read method to use chunked transfer encoding | ||||||
|             parser->ent_position = ENTREAD_USING_CHUNKED; |             parser->ent_position = ENTREAD_USING_CHUNKED; | ||||||
|             DBGONLY( UpnpPrintf |             UpnpPrintf( UPNP_INFO, HTTP, __FILE__, __LINE__, | ||||||
|                      ( UPNP_INFO, HTTP, __FILE__, __LINE__, |                 "Found Chunked Encoding ....\n" ); | ||||||
|                        "Found Chunked Encoding ....\n" ); ) |  | ||||||
|  |  | ||||||
|             return PARSE_CONTINUE_1; |             return PARSE_CONTINUE_1; | ||||||
|         } |         } | ||||||
| @@ -2196,7 +2199,7 @@ parser_get_entity_read_method( INOUT http_parser_t * parser ) | |||||||
| * 	 PARSE_FAILURE | * 	 PARSE_FAILURE | ||||||
| *	 PARSE_COMPLETE	-- no more reading to do | *	 PARSE_COMPLETE	-- no more reading to do | ||||||
| ************************************************************************/ | ************************************************************************/ | ||||||
| XINLINE parse_status_t | UPNP_INLINE parse_status_t | ||||||
| parser_parse_entity( INOUT http_parser_t * parser ) | parser_parse_entity( INOUT http_parser_t * parser ) | ||||||
| { | { | ||||||
|     parse_status_t status = PARSE_OK; |     parse_status_t status = PARSE_OK; | ||||||
| @@ -2421,28 +2424,42 @@ raw_to_int( IN memptr * raw_value, | |||||||
| * | * | ||||||
| * Description: Find a substring from raw character string buffer | * Description: Find a substring from raw character string buffer | ||||||
| * | * | ||||||
|  | * Side effects: raw_value is transformed to lowercase. | ||||||
|  | * | ||||||
| * Returns: | * Returns: | ||||||
| *	 int - index at which the substring is found.						 | *	 int - index at which the substring is found.						 | ||||||
| ************************************************************************/ | ************************************************************************/ | ||||||
| int | int | ||||||
| raw_find_str( IN memptr * raw_value, | raw_find_str( IN memptr *raw_value, | ||||||
|               IN const char *str ) |               IN const char *str ) | ||||||
| { | { | ||||||
|     char c; |     char c; | ||||||
|     char *ptr; |     char *ptr; | ||||||
|  |     int i = 0; | ||||||
|  |  | ||||||
|     c = raw_value->buf[raw_value->length];  // save |     // save | ||||||
|     raw_value->buf[raw_value->length] = 0;  // null-terminate |     c = raw_value->buf[raw_value->length]; | ||||||
|  |  | ||||||
|  |     // Make it lowercase | ||||||
|  |     for (i = 0; raw_value->buf[i]; ++i) { | ||||||
|  |         raw_value->buf[i] = tolower(raw_value->buf[i]); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     // null-terminate | ||||||
|  |     raw_value->buf[raw_value->length] = 0; | ||||||
|  |  | ||||||
|  |     // Find the substring position | ||||||
|     ptr = strstr( raw_value->buf, str ); |     ptr = strstr( raw_value->buf, str ); | ||||||
|  |  | ||||||
|     raw_value->buf[raw_value->length] = c;  // restore |     // restore the "length" byte | ||||||
|  |     raw_value->buf[raw_value->length] = c; | ||||||
|  |  | ||||||
|     if( ptr == 0 ) { |     if( ptr == 0 ) { | ||||||
|         return -1; |         return -1; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     return ptr - raw_value->buf;    // return index |     // return index | ||||||
|  |     return ptr - raw_value->buf; | ||||||
| } | } | ||||||
|  |  | ||||||
| /************************************************************************ | /************************************************************************ | ||||||
| @@ -2455,7 +2472,7 @@ raw_find_str( IN memptr * raw_value, | |||||||
| *	nameConverts a http_method id stored in the HTTP Method | *	nameConverts a http_method id stored in the HTTP Method | ||||||
| * | * | ||||||
| * Returns: | * Returns: | ||||||
| *	 const char* ptr - Ptr to the HTTP Method																							* | *	 const char* ptr - Ptr to the HTTP Method | ||||||
| ************************************************************************/ | ************************************************************************/ | ||||||
| const char * | const char * | ||||||
| method_to_str( IN http_method_t method ) | method_to_str( IN http_method_t method ) | ||||||
| @@ -2480,40 +2497,38 @@ method_to_str( IN http_method_t method ) | |||||||
| * Returns: | * Returns: | ||||||
| *	 void | *	 void | ||||||
| ************************************************************************/ | ************************************************************************/ | ||||||
|  | #ifdef DEBUG | ||||||
| void | void | ||||||
| print_http_headers( http_message_t * hmsg ) | print_http_headers( http_message_t * hmsg ) | ||||||
| { | { | ||||||
|  |  | ||||||
|     ListNode *node; |     ListNode *node; | ||||||
|  |     // NNS:  dlist_node *node; | ||||||
|     //NNS:  dlist_node *node; |  | ||||||
|     http_header_t *header; |     http_header_t *header; | ||||||
|  |  | ||||||
|     // print start line |     // print start line | ||||||
|     if( hmsg->is_request ) { |     if( hmsg->is_request ) { | ||||||
|         //printf( "method = %d, version = %d.%d, url = %.*s\n",  |         printf( "method = %d, version = %d.%d, url = %.*s\n",  | ||||||
|         //  hmsg->method, hmsg->major_version, hmsg->minor_version, |             hmsg->method, hmsg->major_version, hmsg->minor_version, | ||||||
|         //  hmsg->uri.pathquery.size, hmsg->uri.pathquery.buff); |             (int)hmsg->uri.pathquery.size, hmsg->uri.pathquery.buff); | ||||||
|     } else { |     } else { | ||||||
|         //  printf( "resp status = %d, version = %d.%d, status msg = %.*s\n", |         printf( "resp status = %d, version = %d.%d, status msg = %.*s\n", | ||||||
|         //  hmsg->status_code, hmsg->major_version, hmsg->minor_version, |             hmsg->status_code, hmsg->major_version, hmsg->minor_version, | ||||||
|         //  (int)hmsg->status_msg.length, hmsg->status_msg.buf); |             (int)hmsg->status_msg.length, hmsg->status_msg.buf); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     // print headers |     // print headers | ||||||
|  |  | ||||||
|     node = ListHead( &hmsg->headers ); |     node = ListHead( &hmsg->headers ); | ||||||
|     //NNS: node = dlist_first_node( &hmsg->headers ); |     // NNS: node = dlist_first_node( &hmsg->headers ); | ||||||
|     while( node != NULL ) { |     while( node != NULL ) { | ||||||
|  |  | ||||||
|         header = ( http_header_t * ) node->item; |         header = ( http_header_t * ) node->item; | ||||||
|         //NNS: header = (http_header_t *)node->data; |         // NNS: header = (http_header_t *)node->data; | ||||||
|         //printf( "hdr name: %.*s, value: %.*s\n",  |         printf( "hdr name: %.*s, value: %.*s\n",  | ||||||
|         //  (int)header->name.length, header->name.buf, |             (int)header->name.length, header->name.buf, | ||||||
|         //  (int)header->value.length, header->value.buf ); |             (int)header->value.length, header->value.buf ); | ||||||
|  |  | ||||||
|         node = ListNext( &hmsg->headers, node ); |         node = ListNext( &hmsg->headers, node ); | ||||||
|  |         // NNS: node = dlist_next( &hmsg->headers, node ); | ||||||
|         //NNS: node = dlist_next( &hmsg->headers, node ); |  | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  | #endif | ||||||
|  |  | ||||||
|   | |||||||
| @@ -40,13 +40,15 @@ | |||||||
| #include <assert.h> | #include <assert.h> | ||||||
| #include <stdarg.h> | #include <stdarg.h> | ||||||
| #ifndef UPNP_USE_BCBPP | #ifndef UPNP_USE_BCBPP | ||||||
| #ifndef UPNP_USE_MSVCPP | 	#ifndef UPNP_USE_MSVCPP | ||||||
|  | 		#include <inttypes.h> | ||||||
| 		#include <stdint.h> | 		#include <stdint.h> | ||||||
| #endif | 	#endif | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
| #ifndef WIN32 | #ifndef WIN32 | ||||||
| 	#include <arpa/inet.h> | 	#include <arpa/inet.h> | ||||||
|  | 	#include <fcntl.h> | ||||||
| 	#include <netinet/in.h> | 	#include <netinet/in.h> | ||||||
| 	#include <sys/types.h> | 	#include <sys/types.h> | ||||||
| 	#include <sys/socket.h> | 	#include <sys/socket.h> | ||||||
| @@ -54,7 +56,6 @@ | |||||||
| 	#include <sys/wait.h> | 	#include <sys/wait.h> | ||||||
| 	#include <unistd.h> | 	#include <unistd.h> | ||||||
| 	#include <sys/utsname.h> | 	#include <sys/utsname.h> | ||||||
|  #include <fcntl.h> |  | ||||||
| #else | #else | ||||||
| 	#include <winsock2.h> | 	#include <winsock2.h> | ||||||
| 	#include <malloc.h> | 	#include <malloc.h> | ||||||
| @@ -168,10 +169,8 @@ http_Connect( IN uri_type * destination_url, | |||||||
|     if( connect( connfd, ( struct sockaddr * )&url->hostport.IPv4address, |     if( connect( connfd, ( struct sockaddr * )&url->hostport.IPv4address, | ||||||
|                  sizeof( struct sockaddr_in ) ) == -1 ) { |                  sizeof( struct sockaddr_in ) ) == -1 ) { | ||||||
| #ifdef WIN32 | #ifdef WIN32 | ||||||
| 		DBGONLY( |  | ||||||
|         UpnpPrintf(UPNP_CRITICAL, HTTP, __FILE__, __LINE__, |         UpnpPrintf(UPNP_CRITICAL, HTTP, __FILE__, __LINE__, | ||||||
|             "connect error: %d\n", WSAGetLastError()); |             "connect error: %d\n", WSAGetLastError()); | ||||||
| 		) |  | ||||||
| #endif | #endif | ||||||
|         shutdown( connfd, SD_BOTH ); |         shutdown( connfd, SD_BOTH ); | ||||||
|         UpnpCloseSocket( connfd ); |         UpnpCloseSocket( connfd ); | ||||||
| @@ -225,12 +224,10 @@ http_RecvMessage( IN SOCKINFO * info, | |||||||
|             status = parser_append( parser, buf, num_read ); |             status = parser_append( parser, buf, num_read ); | ||||||
|  |  | ||||||
|             if( status == PARSE_SUCCESS ) { |             if( status == PARSE_SUCCESS ) { | ||||||
|                 DBGONLY( UpnpPrintf |                 UpnpPrintf( UPNP_INFO, HTTP, __FILE__, __LINE__, | ||||||
|                          ( UPNP_INFO, HTTP, __FILE__, __LINE__, |  | ||||||
|                     "<<< (RECVD) <<<\n%s\n-----------------\n", |                     "<<< (RECVD) <<<\n%s\n-----------------\n", | ||||||
|                     parser->msg.msg.buf ); |                     parser->msg.msg.buf ); | ||||||
|                          //print_http_headers( &parser->msg ); |                     print_http_headers( &parser->msg ); | ||||||
|                      ) |  | ||||||
|  |  | ||||||
|                 if( parser->content_length > |                 if( parser->content_length > | ||||||
|                     ( unsigned int )g_maxContentLength ) { |                     ( unsigned int )g_maxContentLength ) { | ||||||
| @@ -251,12 +248,10 @@ http_RecvMessage( IN SOCKINFO * info, | |||||||
|             } |             } | ||||||
|         } else if( num_read == 0 ) { |         } else if( num_read == 0 ) { | ||||||
|             if( ok_on_close ) { |             if( ok_on_close ) { | ||||||
|                 DBGONLY( UpnpPrintf |                 UpnpPrintf( UPNP_INFO, HTTP, __FILE__, __LINE__, | ||||||
|                          ( UPNP_INFO, HTTP, __FILE__, __LINE__, |  | ||||||
|                     "<<< (RECVD) <<<\n%s\n-----------------\n", |                     "<<< (RECVD) <<<\n%s\n-----------------\n", | ||||||
|                     parser->msg.msg.buf ); |                     parser->msg.msg.buf ); | ||||||
|                          //print_http_headers( &parser->msg ); |                     print_http_headers( &parser->msg ); | ||||||
|                      ) |  | ||||||
|  |  | ||||||
|                     return 0; |                     return 0; | ||||||
|             } else { |             } else { | ||||||
| @@ -454,11 +449,9 @@ http_SendMessage( IN SOCKINFO * info, | |||||||
|                     num_written = sock_write( info, file_buf, num_read, |                     num_written = sock_write( info, file_buf, num_read, | ||||||
|                                               TimeOut ); |                                               TimeOut ); | ||||||
|  |  | ||||||
|                     DBGONLY( UpnpPrintf |                     UpnpPrintf( UPNP_INFO, HTTP, __FILE__, __LINE__, | ||||||
|                              ( UPNP_INFO, HTTP, __FILE__, __LINE__, |  | ||||||
|                         ">>> (SENT) >>>\n%.*s\n------------\n", |                         ">>> (SENT) >>>\n%.*s\n------------\n", | ||||||
|                         ( int )num_written, file_buf ); |                         ( int )num_written, file_buf ); | ||||||
|                          ) |  | ||||||
|  |  | ||||||
|                         //Send error nothing we can do |                         //Send error nothing we can do | ||||||
|                         if( num_written != num_read ) { |                         if( num_written != num_read ) { | ||||||
| @@ -484,10 +477,9 @@ http_SendMessage( IN SOCKINFO * info, | |||||||
|                 num_written = sock_write( info, buf, buf_length, TimeOut ); |                 num_written = sock_write( info, buf, buf_length, TimeOut ); | ||||||
|                 if( ( size_t ) num_written != buf_length ) |                 if( ( size_t ) num_written != buf_length ) | ||||||
|                     goto end; |                     goto end; | ||||||
|                 DBGONLY( UpnpPrintf( UPNP_INFO, HTTP, __FILE__, __LINE__, |                 UpnpPrintf( UPNP_INFO, HTTP, __FILE__, __LINE__, | ||||||
|                     ">>> (SENT) >>>\n%.*s\n------------\n", |                     ">>> (SENT) >>>\n%.*s\n------------\n", | ||||||
|                     ( int )buf_length, buf ); |                     ( int )buf_length, buf ); | ||||||
|                      ) |  | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| @@ -508,7 +500,7 @@ http_SendMessage( IN SOCKINFO * info, | |||||||
| *	IN size_t request_length ;	Length of the request | *	IN size_t request_length ;	Length of the request | ||||||
| *	IN http_method_t req_method ;	HTTP Request method | *	IN http_method_t req_method ;	HTTP Request method | ||||||
| *	IN int timeout_secs ;		time out value | *	IN int timeout_secs ;		time out value | ||||||
| *	OUT http_parser_t* response	;	Parser object to receive the repsonse | *	OUT http_parser_t* response;	Parser object to receive the repsonse | ||||||
| * | * | ||||||
| * Description: Initiates socket, connects to the destination, sends a | * Description: Initiates socket, connects to the destination, sends a | ||||||
| *	request and waits for the response from the remote end | *	request and waits for the response from the remote end | ||||||
| @@ -574,12 +566,12 @@ http_RequestAndResponse( IN uri_type * destination, | |||||||
| * Function :	http_Download | * Function :	http_Download | ||||||
| * | * | ||||||
| * Parameters : | * Parameters : | ||||||
| *		IN const char* url_str :	String as a URL | *	IN const char* url_str:	String as a URL | ||||||
| *		IN int timeout_secs :		time out value | *	IN int timeout_secs:	time out value | ||||||
| *		OUT char** document :		buffer to store the document extracted | *	OUT char** document:	buffer to store the document extracted | ||||||
| *				from the donloaded message. | *				from the donloaded message. | ||||||
| *		OUT int* doc_length :		length of the extracted document | *	OUT int* doc_length:	length of the extracted document | ||||||
| *	    OUT char* content_type :	Type of content | *	OUT char* content_type:	Type of content | ||||||
| * | * | ||||||
| * Description :	Download the document message and extract the document  | * Description :	Download the document message and extract the document  | ||||||
| *		from the message. | *		from the message. | ||||||
| @@ -588,7 +580,6 @@ http_RequestAndResponse( IN uri_type * destination, | |||||||
| *	UPNP_E_SUCCESS; | *	UPNP_E_SUCCESS; | ||||||
| *	UPNP_E_INVALID_URL; | *	UPNP_E_INVALID_URL; | ||||||
| * | * | ||||||
| * |  | ||||||
| * Note : | * Note : | ||||||
| ************************************************************************/ | ************************************************************************/ | ||||||
| int | int | ||||||
| @@ -600,23 +591,21 @@ http_Download( IN const char *url_str, | |||||||
| { | { | ||||||
|     int ret_code; |     int ret_code; | ||||||
|     uri_type url; |     uri_type url; | ||||||
|     char *msg_start, |     char *msg_start; | ||||||
|      *entity_start, |     char *entity_start; | ||||||
|      *hoststr, |     char *hoststr; | ||||||
|      *temp; |     char *temp; | ||||||
|     http_parser_t response; |     http_parser_t response; | ||||||
|     size_t msg_length, |     size_t msg_length; | ||||||
|       hostlen; |     size_t hostlen; | ||||||
|     memptr ctype; |     memptr ctype; | ||||||
|     size_t copy_len; |     size_t copy_len; | ||||||
|     membuffer request; |     membuffer request; | ||||||
|     char *urlPath = alloca( strlen( url_str ) + 1 ); |     char *urlPath = alloca( strlen( url_str ) + 1 ); | ||||||
|  |  | ||||||
|     //ret_code = parse_uri( (char*)url_str, strlen(url_str), &url ); |     //ret_code = parse_uri( (char*)url_str, strlen(url_str), &url ); | ||||||
|     DBGONLY( UpnpPrintf |     UpnpPrintf( UPNP_INFO, HTTP, __FILE__, __LINE__, "DOWNLOAD URL : %s\n", | ||||||
|              ( UPNP_INFO, HTTP, __FILE__, __LINE__, "DOWNLOAD URL : %s\n", |  | ||||||
|         url_str ); |         url_str ); | ||||||
|          ) |  | ||||||
|     ret_code = |     ret_code = | ||||||
|         http_FixStrUrl( ( char * )url_str, strlen( url_str ), &url ); |         http_FixStrUrl( ( char * )url_str, strlen( url_str ), &url ); | ||||||
|     if( ret_code != UPNP_E_SUCCESS ) { |     if( ret_code != UPNP_E_SUCCESS ) { | ||||||
| @@ -640,29 +629,24 @@ http_Download( IN const char *url_str, | |||||||
|     *temp = '\0'; |     *temp = '\0'; | ||||||
|     hostlen = strlen( hoststr ); |     hostlen = strlen( hoststr ); | ||||||
|     *temp = '/'; |     *temp = '/'; | ||||||
|     DBGONLY( UpnpPrintf |     UpnpPrintf( UPNP_INFO, HTTP, __FILE__, __LINE__, | ||||||
|              ( UPNP_INFO, HTTP, __FILE__, __LINE__, |         "HOSTNAME : %s Length : %"PRIzu"\n", hoststr, hostlen ); | ||||||
|                "HOSTNAME : %s Length : %zu\n", hoststr, hostlen ); |  | ||||||
|          ) |  | ||||||
|  |  | ||||||
|     ret_code = http_MakeMessage( |     ret_code = http_MakeMessage( | ||||||
|         &request, 1, 1, |         &request, 1, 1, | ||||||
|             "QsbcDCUc", |         "Q" "s" "bcDCUc", | ||||||
|         HTTPMETHOD_GET, url.pathquery.buff, url.pathquery.size, |         HTTPMETHOD_GET, url.pathquery.buff, url.pathquery.size, | ||||||
|             "HOST: ", hoststr, hostlen ); |         "HOST: ", | ||||||
|  |         hoststr, hostlen ); | ||||||
|     if( ret_code != 0 ) { |     if( ret_code != 0 ) { | ||||||
|         DBGONLY( UpnpPrintf |         UpnpPrintf( UPNP_INFO, HTTP, __FILE__, __LINE__, | ||||||
|                  ( UPNP_INFO, HTTP, __FILE__, __LINE__, |  | ||||||
|             "HTTP Makemessage failed\n" ); |             "HTTP Makemessage failed\n" ); | ||||||
|              ) |  | ||||||
|             membuffer_destroy( &request ); |             membuffer_destroy( &request ); | ||||||
|         return ret_code; |         return ret_code; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     DBGONLY( UpnpPrintf |     UpnpPrintf( UPNP_INFO, HTTP, __FILE__, __LINE__, | ||||||
|              ( UPNP_INFO, HTTP, __FILE__, __LINE__, |  | ||||||
|         "HTTP Buffer:\n %s\n----------END--------\n", request.buf ); |         "HTTP Buffer:\n %s\n----------END--------\n", request.buf ); | ||||||
|          ) |  | ||||||
|     // get doc msg |     // get doc msg | ||||||
|     ret_code = |     ret_code = | ||||||
|         http_RequestAndResponse( &url, request.buf, request.length, |         http_RequestAndResponse( &url, request.buf, request.length, | ||||||
| @@ -674,11 +658,8 @@ http_Download( IN const char *url_str, | |||||||
|         return ret_code; |         return ret_code; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     DBGONLY( UpnpPrintf |     UpnpPrintf( UPNP_INFO, HTTP, __FILE__, __LINE__, "Response\n" ); | ||||||
|              ( UPNP_INFO, HTTP, __FILE__, __LINE__, "Response\n" ); |     print_http_headers( &response.msg ); | ||||||
|          ) |  | ||||||
|         DBGONLY( print_http_headers( &response.msg ); |  | ||||||
|          ) |  | ||||||
|  |  | ||||||
|         // optional content-type |         // optional content-type | ||||||
|         if( content_type ) { |         if( content_type ) { | ||||||
| @@ -765,17 +746,14 @@ MakePostMessage( const char *url_str, | |||||||
| { | { | ||||||
|     int ret_code = 0; |     int ret_code = 0; | ||||||
|     char *urlPath = alloca( strlen( url_str ) + 1 ); |     char *urlPath = alloca( strlen( url_str ) + 1 ); | ||||||
|     int hostlen = 0; |     size_t hostlen = 0; | ||||||
|     char *hoststr, |     char *hoststr, | ||||||
|      *temp; |      *temp; | ||||||
|  |  | ||||||
|     DBGONLY( UpnpPrintf( UPNP_INFO, HTTP, __FILE__, __LINE__, |     UpnpPrintf( UPNP_INFO, HTTP, __FILE__, __LINE__, | ||||||
|                          "DOWNLOAD URL : %s\n", url_str ); |                          "DOWNLOAD URL : %s\n", url_str ); | ||||||
|          ) |  | ||||||
|  |  | ||||||
|     ret_code = |     ret_code = | ||||||
|         http_FixStrUrl( ( char * )url_str, strlen( url_str ), url ); |         http_FixStrUrl( ( char * )url_str, strlen( url_str ), url ); | ||||||
|  |  | ||||||
|     if( ret_code != UPNP_E_SUCCESS ) { |     if( ret_code != UPNP_E_SUCCESS ) { | ||||||
|         return ret_code; |         return ret_code; | ||||||
|     } |     } | ||||||
| @@ -797,48 +775,49 @@ MakePostMessage( const char *url_str, | |||||||
|     *temp = '\0'; |     *temp = '\0'; | ||||||
|     hostlen = strlen( hoststr ); |     hostlen = strlen( hoststr ); | ||||||
|     *temp = '/'; |     *temp = '/'; | ||||||
|     DBGONLY( UpnpPrintf( UPNP_INFO, HTTP, __FILE__, __LINE__, |     UpnpPrintf( UPNP_INFO, HTTP, __FILE__, __LINE__, | ||||||
|                          "HOSTNAME : %s Length : %d\n", hoststr, hostlen ); |         "HOSTNAME : %s Length : %"PRIzu"\n", hoststr, hostlen ); | ||||||
|          ) |  | ||||||
|  |  | ||||||
|     if( contentLength >= 0 ) { |     if( contentLength >= 0 ) { | ||||||
|         ret_code = http_MakeMessage( |         ret_code = http_MakeMessage( | ||||||
|             request, 1, 1, |             request, 1, 1, | ||||||
|             "QsbcDCUTNc", |             "Q" "s" "bcDCU" "T" "Nc", | ||||||
|             HTTPMETHOD_POST, url->pathquery.buff, url->pathquery.size, |             HTTPMETHOD_POST, url->pathquery.buff, url->pathquery.size, | ||||||
|             "HOST: ", hoststr, hostlen, |             "HOST: ", | ||||||
|  | 	    hoststr, hostlen, | ||||||
|             contentType, |             contentType, | ||||||
|             (off_t)contentLength ); |             (off_t)contentLength ); | ||||||
|     } else if( contentLength == UPNP_USING_CHUNKED ) { |     } else if( contentLength == UPNP_USING_CHUNKED ) { | ||||||
|         ret_code = http_MakeMessage( |         ret_code = http_MakeMessage( | ||||||
|             request, 1, 1, |             request, 1, 1, | ||||||
|             "QsbcDCUTKc", |             "Q" "s" "bcDCU" "TKc", | ||||||
|             HTTPMETHOD_POST, url->pathquery.buff, url->pathquery.size, |             HTTPMETHOD_POST, url->pathquery.buff, url->pathquery.size, | ||||||
|             "HOST: ", hoststr, hostlen, |             "HOST: ", | ||||||
|  | 	    hoststr, hostlen, | ||||||
|             contentType ); |             contentType ); | ||||||
|     } else if( contentLength == UPNP_UNTIL_CLOSE ) { |     } else if( contentLength == UPNP_UNTIL_CLOSE ) { | ||||||
|         ret_code = http_MakeMessage( |         ret_code = http_MakeMessage( | ||||||
|             request, 1, 1, |             request, 1, 1, | ||||||
|             "QsbcDCUTc", |             "Q" "s" "bcDCU" "Tc", | ||||||
|             HTTPMETHOD_POST, url->pathquery.buff, url->pathquery.size, |             HTTPMETHOD_POST, url->pathquery.buff, url->pathquery.size, | ||||||
|             "HOST: ", hoststr, hostlen, |             "HOST: ", | ||||||
|  | 	    hoststr, hostlen, | ||||||
|             contentType ); |             contentType ); | ||||||
|     } else { |     } else { | ||||||
|         ret_code = UPNP_E_INVALID_PARAM; |         ret_code = UPNP_E_INVALID_PARAM; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     if( ret_code != 0 ) { |     if( ret_code != 0 ) { | ||||||
|         DBGONLY( UpnpPrintf( UPNP_INFO, HTTP, __FILE__, __LINE__, |         UpnpPrintf( UPNP_INFO, HTTP, __FILE__, __LINE__, | ||||||
|             "HTTP Makemessage failed\n" ); |             "HTTP Makemessage failed\n" ); | ||||||
|              ) |  | ||||||
|         membuffer_destroy( request ); |         membuffer_destroy( request ); | ||||||
|  |  | ||||||
|         return ret_code; |         return ret_code; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     DBGONLY( UpnpPrintf( UPNP_INFO, HTTP, __FILE__, __LINE__, |     UpnpPrintf( UPNP_INFO, HTTP, __FILE__, __LINE__, | ||||||
|         "HTTP Buffer:\n %s\n" "----------END--------\n", |         "HTTP Buffer:\n %s\n" "----------END--------\n", | ||||||
|         request->buf ); |         request->buf ); | ||||||
|          ) |  | ||||||
|  |  | ||||||
|     return UPNP_E_SUCCESS; |     return UPNP_E_SUCCESS; | ||||||
| } | } | ||||||
| @@ -1097,15 +1076,14 @@ MakeGetMessage( const char *url_str, | |||||||
| { | { | ||||||
|     int ret_code; |     int ret_code; | ||||||
|     char *urlPath = alloca( strlen( url_str ) + 1 ); |     char *urlPath = alloca( strlen( url_str ) + 1 ); | ||||||
|     int querylen = 0; |     size_t querylen = 0; | ||||||
|     const char *querystr; |     const char *querystr; | ||||||
|     int hostlen = 0; |     size_t hostlen = 0; | ||||||
|     char *hoststr, |     char *hoststr, | ||||||
|      *temp; |      *temp; | ||||||
|  |  | ||||||
|     DBGONLY( UpnpPrintf( UPNP_INFO, HTTP, __FILE__, __LINE__, |     UpnpPrintf( UPNP_INFO, HTTP, __FILE__, __LINE__, | ||||||
|         "DOWNLOAD URL : %s\n", url_str ); |         "DOWNLOAD URL : %s\n", url_str ); | ||||||
|          ) |  | ||||||
|  |  | ||||||
|     ret_code = |     ret_code = | ||||||
|         http_FixStrUrl( ( char * )url_str, strlen( url_str ), url ); |         http_FixStrUrl( ( char * )url_str, strlen( url_str ), url ); | ||||||
| @@ -1131,9 +1109,8 @@ MakeGetMessage( const char *url_str, | |||||||
|     *temp = '\0'; |     *temp = '\0'; | ||||||
|     hostlen = strlen( hoststr ); |     hostlen = strlen( hoststr ); | ||||||
|     *temp = '/'; |     *temp = '/'; | ||||||
|     DBGONLY( UpnpPrintf( UPNP_INFO, HTTP, __FILE__, __LINE__, |     UpnpPrintf( UPNP_INFO, HTTP, __FILE__, __LINE__, | ||||||
|                          "HOSTNAME : %s Length : %d\n", hoststr, hostlen ); |         "HOSTNAME : %s Length : %"PRIzu"\n", hoststr, hostlen ); | ||||||
|          ) |  | ||||||
|  |  | ||||||
|     if( proxy_str ) { |     if( proxy_str ) { | ||||||
|         querystr = url_str; |         querystr = url_str; | ||||||
| @@ -1145,22 +1122,22 @@ MakeGetMessage( const char *url_str, | |||||||
|  |  | ||||||
|     ret_code = http_MakeMessage( |     ret_code = http_MakeMessage( | ||||||
|         request, 1, 1, |         request, 1, 1, | ||||||
|         "QsbcDCUc", |         "Q" "s" "bcDCUc", | ||||||
|         HTTPMETHOD_GET, querystr, querylen, |         HTTPMETHOD_GET, querystr, querylen, | ||||||
|         "HOST: ", hoststr, hostlen ); |         "HOST: ", | ||||||
|  |         hoststr, hostlen ); | ||||||
|  |  | ||||||
|     if( ret_code != 0 ) { |     if( ret_code != 0 ) { | ||||||
|         DBGONLY( UpnpPrintf( UPNP_INFO, HTTP, __FILE__, __LINE__, |         UpnpPrintf( UPNP_INFO, HTTP, __FILE__, __LINE__, | ||||||
|             "HTTP Makemessage failed\n" ); |             "HTTP Makemessage failed\n" ); | ||||||
|              ) |  | ||||||
|         membuffer_destroy( request ); |         membuffer_destroy( request ); | ||||||
|  |  | ||||||
|         return ret_code; |         return ret_code; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     DBGONLY( UpnpPrintf( UPNP_INFO, HTTP, __FILE__, __LINE__, |     UpnpPrintf( UPNP_INFO, HTTP, __FILE__, __LINE__, | ||||||
|         "HTTP Buffer:\n %s\n" "----------END--------\n", |         "HTTP Buffer:\n %s\n" "----------END--------\n", | ||||||
|         request->buf ); |         request->buf ); | ||||||
|          ) |  | ||||||
|  |  | ||||||
|     return UPNP_E_SUCCESS; |     return UPNP_E_SUCCESS; | ||||||
| } | } | ||||||
| @@ -1380,11 +1357,9 @@ http_ReadHttpGet( IN void *Handle, | |||||||
|             } |             } | ||||||
|         } else if( num_read == 0 ) { |         } else if( num_read == 0 ) { | ||||||
|             if( ok_on_close ) { |             if( ok_on_close ) { | ||||||
|                 DBGONLY( UpnpPrintf( UPNP_INFO, HTTP, __FILE__, __LINE__, |                 UpnpPrintf( UPNP_INFO, HTTP, __FILE__, __LINE__, | ||||||
|                     "<<< (RECVD) <<<\n%s\n-----------------\n", |                     "<<< (RECVD) <<<\n%s\n-----------------\n", | ||||||
|                     handle->response.msg.msg.buf ); |                     handle->response.msg.msg.buf ); | ||||||
|                          //print_http_headers( &parser->msg ); |  | ||||||
|                      ) |  | ||||||
|                     handle->response.position = POS_COMPLETE; |                     handle->response.position = POS_COMPLETE; | ||||||
|             } else { |             } else { | ||||||
|                 // partial msg |                 // partial msg | ||||||
| @@ -1776,8 +1751,8 @@ http_SendStatusResponse( IN SOCKINFO * info, | |||||||
| *		fmt types: | *		fmt types: | ||||||
| *		'B':	arg = int status_code  | *		'B':	arg = int status_code  | ||||||
| *				appends content-length, content-type and HTML body for given code | *				appends content-length, content-type and HTML body for given code | ||||||
| *		'b':	arg1 = const char* buf; arg2 = size_t buf_length  | *		'b':	arg1 = const char* buf; | ||||||
| *				memory ptr | *			arg2 = size_t buf_length memory ptr | ||||||
| *		'C':	(no args) appends a HTTP CONNECTION: close header  | *		'C':	(no args) appends a HTTP CONNECTION: close header  | ||||||
| *				depending on major,minor version | *				depending on major,minor version | ||||||
| *		'c':	(no args) appends CRLF "\r\n" | *		'c':	(no args) appends CRLF "\r\n" | ||||||
| @@ -1786,15 +1761,17 @@ http_SendStatusResponse( IN SOCKINFO * info, | |||||||
| *		'G':	arg = range information         // add range header | *		'G':	arg = range information         // add range header | ||||||
| *		'h':	arg = off_t number		// appends off_t number | *		'h':	arg = off_t number		// appends off_t number | ||||||
| *		'K':	(no args)                       // add chunky header | *		'K':	(no args)                       // add chunky header | ||||||
| *		'N':	arg1 = int content_length	// content-length header | *		'N':	arg1 = off_t content_length       // content-length header | ||||||
| *               'q':    arg1 = http_method_t, arg2 = (uri_type *) // request start line and HOST header | *		'q':    arg1 = http_method_t            // request start line and HOST header | ||||||
| *		'Q':	arg1 = http_method_t; arg2 = char* url;  | *			arg2 = (uri_type *) | ||||||
| *				arg3 = int url_length // start line of request | *		'Q':	arg1 = http_method_t;           // start line of request | ||||||
|  | *			arg2 = char* url;  | ||||||
|  | *			arg3 = size_t url_length  | ||||||
| *		'R':	arg = int status_code           // adds a response start line | *		'R':	arg = int status_code           // adds a response start line | ||||||
| *		'S':	(no args) appends HTTP SERVER: header | *		'S':	(no args) appends HTTP SERVER: header | ||||||
| *		's':	arg = const char* C_string | *		's':	arg = const char* C_string | ||||||
| *		'T':	arg = char * content_type; format e.g: "text/html";	 | *		'T':	arg = char * content_type; format | ||||||
| *				 content-type header | *			e.g: "text/html"; content-type header | ||||||
| *		't':	arg = time_t * gmt_time         // appends time in RFC 1123 fmt | *		't':	arg = time_t * gmt_time         // appends time in RFC 1123 fmt | ||||||
| *		'U':	(no args) appends HTTP USER-AGENT: header | *		'U':	(no args) appends HTTP USER-AGENT: header | ||||||
| *               'X':    arg = const char useragent; "redsonic" HTTP X-User-Agent: useragent | *               'X':    arg = const char useragent; "redsonic" HTTP X-User-Agent: useragent | ||||||
| @@ -1815,7 +1792,7 @@ http_MakeMessage( INOUT membuffer * buf, | |||||||
| { | { | ||||||
|     char c; |     char c; | ||||||
|     char *s = NULL; |     char *s = NULL; | ||||||
|     int num; |     size_t num; | ||||||
|     off_t bignum; |     off_t bignum; | ||||||
|     size_t length; |     size_t length; | ||||||
|     time_t *loc_time; |     time_t *loc_time; | ||||||
| @@ -1842,31 +1819,26 @@ http_MakeMessage( INOUT membuffer * buf, | |||||||
|     va_start( argp, fmt ); |     va_start( argp, fmt ); | ||||||
|  |  | ||||||
|     while( ( c = *fmt++ ) != 0 ) { |     while( ( c = *fmt++ ) != 0 ) { | ||||||
|  |         if( c == 's' ) { | ||||||
|         if( c == 's' )          // C string |             // C string | ||||||
|         { |  | ||||||
|             s = ( char * )va_arg( argp, char * ); |             s = ( char * )va_arg( argp, char * ); | ||||||
|  |  | ||||||
|             assert( s ); |             assert( s ); | ||||||
|  |             UpnpPrintf(UPNP_ALL,HTTP,__FILE__,__LINE__,"Adding a string : %s\n", s);  | ||||||
|             //DBGONLY(UpnpPrintf(UPNP_ALL,HTTP,__FILE__,__LINE__,"Adding a string : %s\n", s);)  |  | ||||||
|             if( membuffer_append( buf, s, strlen( s ) ) != 0 ) { |             if( membuffer_append( buf, s, strlen( s ) ) != 0 ) { | ||||||
|                 goto error_handler; |                 goto error_handler; | ||||||
|             } |             } | ||||||
|         } else if( c == 'K' )   // Add Chunky header |         } else if( c == 'K' ) { | ||||||
|         { |             // Add Chunky header | ||||||
|             if( membuffer_append |             if( membuffer_append | ||||||
|                 ( buf, "TRANSFER-ENCODING: chunked\r\n", |                 ( buf, "TRANSFER-ENCODING: chunked\r\n", | ||||||
|                   strlen( "Transfer-Encoding: chunked\r\n" ) ) != 0 ) { |                   strlen( "Transfer-Encoding: chunked\r\n" ) ) != 0 ) { | ||||||
|                 goto error_handler; |                 goto error_handler; | ||||||
|             } |             } | ||||||
|         } else if( c == 'G' )   // Add Range header |         } else if( c == 'G' ) { | ||||||
|         { |             // Add Range header | ||||||
|             struct SendInstruction *RespInstr; |             struct SendInstruction *RespInstr; | ||||||
|             RespInstr = |             RespInstr = (struct SendInstruction *) | ||||||
|                 ( struct SendInstruction * )va_arg( argp, |                 va_arg( argp, struct SendInstruction *); | ||||||
|                                                     struct SendInstruction |  | ||||||
|                                                     * ); |  | ||||||
|             assert( RespInstr ); |             assert( RespInstr ); | ||||||
|             // connection header |             // connection header | ||||||
|             if( membuffer_append |             if( membuffer_append | ||||||
| @@ -1874,48 +1846,43 @@ http_MakeMessage( INOUT membuffer * buf, | |||||||
|                   strlen( RespInstr->RangeHeader ) ) != 0 ) { |                   strlen( RespInstr->RangeHeader ) ) != 0 ) { | ||||||
|                 goto error_handler; |                 goto error_handler; | ||||||
|             } |             } | ||||||
|  |         } else if( c == 'b' ) { | ||||||
|         } else if( c == 'b' )   // mem buffer |             // mem buffer | ||||||
|         { |  | ||||||
|             s = ( char * )va_arg( argp, char * ); |             s = ( char * )va_arg( argp, char * ); | ||||||
|  |  | ||||||
|             //DBGONLY(UpnpPrintf(UPNP_ALL,HTTP,__FILE__,__LINE__,"Adding a char Buffer starting with: %c\n", s[0]);) |             UpnpPrintf(UPNP_ALL,HTTP,__FILE__,__LINE__, | ||||||
|  |                 "Adding a char Buffer starting with: %c\n", s[0]); | ||||||
|             assert( s ); |             assert( s ); | ||||||
|             length = ( size_t ) va_arg( argp, size_t ); |             length = ( size_t ) va_arg( argp, size_t ); | ||||||
|             if( membuffer_append( buf, s, length ) != 0 ) { |             if( membuffer_append( buf, s, length ) != 0 ) { | ||||||
|                 goto error_handler; |                 goto error_handler; | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|  |         else if( c == 'c' ) { | ||||||
|         else if( c == 'c' )     // crlf |             // crlf | ||||||
|         { |  | ||||||
|             if( membuffer_append( buf, "\r\n", 2 ) != 0 ) { |             if( membuffer_append( buf, "\r\n", 2 ) != 0 ) { | ||||||
|                 goto error_handler; |                 goto error_handler; | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|  |         else if( c == 'd' ) { | ||||||
|         else if( c == 'd' )     // integer |             // integer | ||||||
|         { |  | ||||||
|             num = ( int )va_arg( argp, int ); |             num = ( int )va_arg( argp, int ); | ||||||
|  |             sprintf( tempbuf, "%"PRIzu, num ); | ||||||
|             sprintf( tempbuf, "%d", num ); |  | ||||||
|             if( membuffer_append( buf, tempbuf, strlen( tempbuf ) ) != 0 ) { |             if( membuffer_append( buf, tempbuf, strlen( tempbuf ) ) != 0 ) { | ||||||
|                 goto error_handler; |                 goto error_handler; | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|  |         else if( c == 'h' ) { | ||||||
|         else if( c == 'h' )     // off_t |             // off_t | ||||||
|         { |  | ||||||
|             bignum = ( off_t )va_arg( argp, off_t ); |             bignum = ( off_t )va_arg( argp, off_t ); | ||||||
|  |  | ||||||
|             sprintf( tempbuf, "%lld", (int64_t)bignum ); |             sprintf( tempbuf, "%"PRId64, (int64_t)bignum ); | ||||||
|             if( membuffer_append( buf, tempbuf, strlen( tempbuf ) ) != 0 ) { |             if( membuffer_append( buf, tempbuf, strlen( tempbuf ) ) != 0 ) { | ||||||
|                 goto error_handler; |                 goto error_handler; | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|  |         else if( c == 't' || c == 'D' ) { | ||||||
|         else if( c == 't' || c == 'D' ) // date |             // date | ||||||
|         { |  | ||||||
|             if( c == 'D' ) { |             if( c == 'D' ) { | ||||||
|                 // header |                 // header | ||||||
|                 start_str = "DATE: "; |                 start_str = "DATE: "; | ||||||
| @@ -1939,9 +1906,7 @@ http_MakeMessage( INOUT membuffer * buf, | |||||||
|             if( membuffer_append( buf, tempbuf, strlen( tempbuf ) ) != 0 ) { |             if( membuffer_append( buf, tempbuf, strlen( tempbuf ) ) != 0 ) { | ||||||
|                 goto error_handler; |                 goto error_handler; | ||||||
|             } |             } | ||||||
|         } |         } else if( c == 'C' ) { | ||||||
|  |  | ||||||
|         else if( c == 'C' ) { |  | ||||||
|             if( ( http_major_version > 1 ) || |             if( ( http_major_version > 1 ) || | ||||||
|                 ( http_major_version == 1 && http_minor_version == 1 ) |                 ( http_major_version == 1 && http_minor_version == 1 ) | ||||||
|                  ) { |                  ) { | ||||||
| @@ -1951,9 +1916,7 @@ http_MakeMessage( INOUT membuffer * buf, | |||||||
|                     goto error_handler; |                     goto error_handler; | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|         } |         } else if( c == 'N' ) { | ||||||
|  |  | ||||||
|         else if( c == 'N' ) { |  | ||||||
|             // content-length header |             // content-length header | ||||||
|             bignum = ( off_t )va_arg( argp, off_t ); |             bignum = ( off_t )va_arg( argp, off_t ); | ||||||
|  |  | ||||||
| @@ -1964,11 +1927,8 @@ http_MakeMessage( INOUT membuffer * buf, | |||||||
|                 "CONTENT-LENGTH: ", bignum ) != 0 ) { |                 "CONTENT-LENGTH: ", bignum ) != 0 ) { | ||||||
|                 goto error_handler; |                 goto error_handler; | ||||||
|             } |             } | ||||||
|         } |         } else if( c == 'S' || c == 'U' ) { | ||||||
|  |  | ||||||
|         else if( c == 'S' || c == 'U' ) { |  | ||||||
|             // SERVER or USER-AGENT header |             // SERVER or USER-AGENT header | ||||||
|  |  | ||||||
|             temp_str = ( c == 'S' ) ? "SERVER: " : "USER-AGENT: "; |             temp_str = ( c == 'S' ) ? "SERVER: " : "USER-AGENT: "; | ||||||
|             get_sdk_info( tempbuf ); |             get_sdk_info( tempbuf ); | ||||||
|             if (http_MakeMessage( |             if (http_MakeMessage( | ||||||
| @@ -1977,34 +1937,25 @@ http_MakeMessage( INOUT membuffer * buf, | |||||||
|                 temp_str, tempbuf ) != 0 ) { |                 temp_str, tempbuf ) != 0 ) { | ||||||
|                 goto error_handler; |                 goto error_handler; | ||||||
|             } |             } | ||||||
|         } |         } else if( c == 'X' ) { | ||||||
|  |             // C string | ||||||
| 	else if( c == 'X' )          // C string |  | ||||||
|         { |  | ||||||
|             s = ( char * )va_arg( argp, char * ); |             s = ( char * )va_arg( argp, char * ); | ||||||
|  |  | ||||||
|             assert( s ); |             assert( s ); | ||||||
|  |  | ||||||
|             if( membuffer_append_str( buf, "X-User-Agent: ") != 0 ) { |             if( membuffer_append_str( buf, "X-User-Agent: ") != 0 ) { | ||||||
|                 goto error_handler; |                 goto error_handler; | ||||||
|             } |             } | ||||||
|             if( membuffer_append( buf, s, strlen( s ) ) != 0 ) { |             if( membuffer_append( buf, s, strlen( s ) ) != 0 ) { | ||||||
|                 goto error_handler; |                 goto error_handler; | ||||||
|             } |             } | ||||||
|         } |         } else if( c == 'R' ) { | ||||||
|          |  | ||||||
|         else if( c == 'R' ) { |  | ||||||
|             // response start line |             // response start line | ||||||
|             //   e.g.: 'HTTP/1.1 200 OK' |             //   e.g.: 'HTTP/1.1 200 OK' | ||||||
|             // |             // | ||||||
|  |  | ||||||
|             // code |             // code | ||||||
|             status_code = ( int )va_arg( argp, int ); |             status_code = ( int )va_arg( argp, int ); | ||||||
|  |  | ||||||
|             assert( status_code > 0 ); |             assert( status_code > 0 ); | ||||||
|             sprintf( tempbuf, "HTTP/%d.%d %d ", |             sprintf( tempbuf, "HTTP/%d.%d %d ", | ||||||
|                      http_major_version, http_minor_version, status_code ); |                      http_major_version, http_minor_version, status_code ); | ||||||
|  |  | ||||||
|             // str |             // str | ||||||
|             status_msg = http_get_code_text( status_code ); |             status_msg = http_get_code_text( status_code ); | ||||||
|             if (http_MakeMessage( |             if (http_MakeMessage( | ||||||
| @@ -2014,40 +1965,31 @@ http_MakeMessage( INOUT membuffer * buf, | |||||||
|                 status_msg ) != 0 ) { |                 status_msg ) != 0 ) { | ||||||
|                 goto error_handler; |                 goto error_handler; | ||||||
|             } |             } | ||||||
|         } |         } else if( c == 'B' ) { | ||||||
|  |  | ||||||
|         else if( c == 'B' ) { |  | ||||||
|             // body of a simple reply |             // body of a simple reply | ||||||
|             //  |             //  | ||||||
|  |  | ||||||
|             status_code = ( int )va_arg( argp, int ); |             status_code = ( int )va_arg( argp, int ); | ||||||
|  |  | ||||||
|             sprintf( tempbuf, "%s%d %s%s", |             sprintf( tempbuf, "%s%d %s%s", | ||||||
|                      "<html><body><h1>", |                      "<html><body><h1>", | ||||||
|                      status_code, http_get_code_text( status_code ), |                      status_code, http_get_code_text( status_code ), | ||||||
|                      "</h1></body></html>" ); |                      "</h1></body></html>" ); | ||||||
|             bignum = strlen( tempbuf ); |             bignum = strlen( tempbuf ); | ||||||
|  |  | ||||||
|             if (http_MakeMessage( |             if (http_MakeMessage( | ||||||
|                     buf, http_major_version, http_minor_version, |                     buf, http_major_version, http_minor_version, | ||||||
|                     "NTcs", |                     "NTcs", | ||||||
|                     bignum, // content-length |                     bignum, // content-length | ||||||
|                     "text/html",  // content-type |                     "text/html",  // content-type | ||||||
|                     tempbuf ) != 0 )  // body |                     tempbuf ) != 0 // body | ||||||
|             { |             ) { | ||||||
|                 goto error_handler; |                 goto error_handler; | ||||||
|             } |             } | ||||||
|         } |         } else if( c == 'Q' ) { | ||||||
|  |  | ||||||
|         else if( c == 'Q' ) { |  | ||||||
|             // request start line |             // request start line | ||||||
|             // GET /foo/bar.html HTTP/1.1\r\n |             // GET /foo/bar.html HTTP/1.1\r\n | ||||||
|  |  | ||||||
|             method = ( http_method_t ) va_arg( argp, http_method_t ); |             method = ( http_method_t ) va_arg( argp, http_method_t ); | ||||||
|             method_str = method_to_str( method ); |             method_str = method_to_str( method ); | ||||||
|             url_str = ( const char * )va_arg( argp, const char * ); |             url_str = ( const char * )va_arg( argp, const char * ); | ||||||
|             num = ( int )va_arg( argp, int );   // length of url_str |             num = ( size_t )va_arg( argp, size_t );   // length of url_str | ||||||
|  |  | ||||||
|             if (http_MakeMessage( |             if (http_MakeMessage( | ||||||
|                 buf, http_major_version, http_minor_version, |                 buf, http_major_version, http_minor_version, | ||||||
|                 "ssbsdsdc", |                 "ssbsdsdc", | ||||||
| @@ -2056,20 +1998,15 @@ http_MakeMessage( INOUT membuffer * buf, | |||||||
|                 " HTTP/", http_major_version, ".", http_minor_version ) != 0 ) { |                 " HTTP/", http_major_version, ".", http_minor_version ) != 0 ) { | ||||||
|                 goto error_handler; |                 goto error_handler; | ||||||
|             } |             } | ||||||
|         } |         } else if( c == 'q' ) { | ||||||
|  |  | ||||||
|         else if( c == 'q' ) { |  | ||||||
|             // request start line and HOST header |             // request start line and HOST header | ||||||
|  |  | ||||||
|             method = ( http_method_t ) va_arg( argp, http_method_t ); |             method = ( http_method_t ) va_arg( argp, http_method_t ); | ||||||
|  |  | ||||||
|             uri_ptr = ( uri_type * ) va_arg( argp, uri_type * ); |             uri_ptr = ( uri_type * ) va_arg( argp, uri_type * ); | ||||||
|             assert( uri_ptr ); |             assert( uri_ptr ); | ||||||
|             if( http_FixUrl( uri_ptr, &url ) != 0 ) { |             if( http_FixUrl( uri_ptr, &url ) != 0 ) { | ||||||
|                 error_code = UPNP_E_INVALID_URL; |                 error_code = UPNP_E_INVALID_URL; | ||||||
|                 goto error_handler; |                 goto error_handler; | ||||||
|             } |             } | ||||||
|  |  | ||||||
|             if (http_MakeMessage( |             if (http_MakeMessage( | ||||||
|                 buf, http_major_version, http_minor_version, |                 buf, http_major_version, http_minor_version, | ||||||
|                 "Q" "sbc", |                 "Q" "sbc", | ||||||
| @@ -2077,28 +2014,23 @@ http_MakeMessage( INOUT membuffer * buf, | |||||||
|                 "HOST: ", url.hostport.text.buff, url.hostport.text.size ) != 0 ) { |                 "HOST: ", url.hostport.text.buff, url.hostport.text.size ) != 0 ) { | ||||||
|                 goto error_handler; |                 goto error_handler; | ||||||
|             } |             } | ||||||
|         } |         } else if( c == 'T' ) { | ||||||
|  |  | ||||||
|         else if( c == 'T' ) { |  | ||||||
|             // content type header |             // content type header | ||||||
|             temp_str = ( const char * )va_arg( argp, const char * );    // type/subtype format |             temp_str = ( const char * )va_arg( argp, const char * );    // type/subtype format | ||||||
|  |  | ||||||
|             if (http_MakeMessage( |             if (http_MakeMessage( | ||||||
|                 buf, http_major_version, http_minor_version, |                 buf, http_major_version, http_minor_version, | ||||||
| 		"ssc", | 		"ssc", | ||||||
|                 "CONTENT-TYPE: ", temp_str ) != 0 ) { |                 "CONTENT-TYPE: ", temp_str ) != 0 ) { | ||||||
|                 goto error_handler; |                 goto error_handler; | ||||||
|             } |             } | ||||||
|         } |         } else { | ||||||
|  |  | ||||||
|         else { |  | ||||||
|             assert( 0 ); |             assert( 0 ); | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     return 0; |     return 0; | ||||||
|  |  | ||||||
|   error_handler: | error_handler: | ||||||
|     va_end( argp ); |     va_end( argp ); | ||||||
|     membuffer_destroy( buf ); |     membuffer_destroy( buf ); | ||||||
|     return error_code; |     return error_code; | ||||||
| @@ -2161,23 +2093,20 @@ MakeGetMessageEx( const char *url_str, | |||||||
| { | { | ||||||
|     int errCode = UPNP_E_SUCCESS; |     int errCode = UPNP_E_SUCCESS; | ||||||
|     char *urlPath = NULL; |     char *urlPath = NULL; | ||||||
|     int hostlen = 0; |     size_t hostlen = 0; | ||||||
|     char *hoststr, |     char *hoststr, | ||||||
|      *temp; |      *temp; | ||||||
|  |  | ||||||
|     do { |     do { | ||||||
|         DBGONLY( UpnpPrintf( UPNP_INFO, HTTP, __FILE__, __LINE__, |         UpnpPrintf( UPNP_INFO, HTTP, __FILE__, __LINE__, | ||||||
|             "DOWNLOAD URL : %s\n", url_str ); |             "DOWNLOAD URL : %s\n", url_str ); | ||||||
|              ) |  | ||||||
|  |  | ||||||
|         if( ( errCode = http_FixStrUrl( ( char * )url_str, |         if( ( errCode = http_FixStrUrl( ( char * )url_str, | ||||||
|                                             strlen( url_str ), |             strlen( url_str ), url ) ) != UPNP_E_SUCCESS ) { | ||||||
|                                             url ) ) != UPNP_E_SUCCESS ) { |  | ||||||
|             break; |             break; | ||||||
|         } |         } | ||||||
|         // make msg |         // make msg | ||||||
|         membuffer_init( request ); |         membuffer_init( request ); | ||||||
|  |  | ||||||
|         urlPath = alloca( strlen( url_str ) + 1 ); |         urlPath = alloca( strlen( url_str ) + 1 ); | ||||||
|         if( !urlPath ) { |         if( !urlPath ) { | ||||||
|             errCode = UPNP_E_OUTOF_MEMORY; |             errCode = UPNP_E_OUTOF_MEMORY; | ||||||
| @@ -2185,9 +2114,7 @@ MakeGetMessageEx( const char *url_str, | |||||||
|         } |         } | ||||||
|  |  | ||||||
|         memset( urlPath, 0, strlen( url_str ) + 1 ); |         memset( urlPath, 0, strlen( url_str ) + 1 ); | ||||||
|  |  | ||||||
|         strcpy( urlPath, url_str ); |         strcpy( urlPath, url_str ); | ||||||
|  |  | ||||||
|         hoststr = strstr( urlPath, "//" ); |         hoststr = strstr( urlPath, "//" ); | ||||||
|         if( hoststr == NULL ) { |         if( hoststr == NULL ) { | ||||||
|             errCode = UPNP_E_INVALID_URL; |             errCode = UPNP_E_INVALID_URL; | ||||||
| @@ -2204,33 +2131,30 @@ MakeGetMessageEx( const char *url_str, | |||||||
|         *temp = '\0'; |         *temp = '\0'; | ||||||
|         hostlen = strlen( hoststr ); |         hostlen = strlen( hoststr ); | ||||||
|         *temp = '/'; |         *temp = '/'; | ||||||
|  |         UpnpPrintf( UPNP_INFO, HTTP, __FILE__, __LINE__, | ||||||
|         DBGONLY( UpnpPrintf( UPNP_INFO, HTTP, __FILE__, __LINE__, |             "HOSTNAME : %s Length : %"PRIzu"\n", | ||||||
|                              "HOSTNAME : %s Length : %d\n", hoststr, |             hoststr, hostlen ); | ||||||
|                              hostlen ); |  | ||||||
|              ) |  | ||||||
|  |  | ||||||
|         errCode = http_MakeMessage( |         errCode = http_MakeMessage( | ||||||
|                 request, 1, 1, |                 request, 1, 1, | ||||||
|                 "QsbcGDCUc", |                 "Q" "s" "bc" "GDCUc", | ||||||
|                 HTTPMETHOD_GET, |                 HTTPMETHOD_GET, url->pathquery.buff, url->pathquery.size, | ||||||
|                 url->pathquery.buff, url->pathquery.size, |                 "HOST: ", | ||||||
|                 "HOST: ", hoststr, hostlen, | 		hoststr, hostlen, | ||||||
|                 pRangeSpecifier ); |                 pRangeSpecifier ); | ||||||
|  |  | ||||||
|         if( errCode != 0 ) { |         if( errCode != 0 ) { | ||||||
|             DBGONLY( UpnpPrintf( UPNP_INFO, HTTP, __FILE__, __LINE__, |             UpnpPrintf( UPNP_INFO, HTTP, __FILE__, __LINE__, | ||||||
|                 "HTTP Makemessage failed\n" ); |                 "HTTP Makemessage failed\n" ); | ||||||
|                  ) |  | ||||||
|             membuffer_destroy( request ); |             membuffer_destroy( request ); | ||||||
|  |  | ||||||
|             return errCode; |             return errCode; | ||||||
|         } |         } | ||||||
|     } while( 0 ); |     } while( 0 ); | ||||||
|  |  | ||||||
|     DBGONLY( UpnpPrintf( UPNP_INFO, HTTP, __FILE__, __LINE__, |     UpnpPrintf( UPNP_INFO, HTTP, __FILE__, __LINE__, | ||||||
|         "HTTP Buffer:\n %s\n" "----------END--------\n", |         "HTTP Buffer:\n %s\n" "----------END--------\n", | ||||||
|         request->buf ); |         request->buf ); | ||||||
|          ) |  | ||||||
|  |  | ||||||
|     return errCode; |     return errCode; | ||||||
| } | } | ||||||
| @@ -2419,7 +2343,7 @@ http_OpenHttpGetEx( IN const char *url_str, | |||||||
| *	Description :	Returns the server information for the operating  | *	Description :	Returns the server information for the operating  | ||||||
| *		system | *		system | ||||||
| * | * | ||||||
| *	Return :	XINLINE void | *	Return :	UPNP_INLINE void | ||||||
| * | * | ||||||
| *	Note : | *	Note : | ||||||
| ************************************************************************/ | ************************************************************************/ | ||||||
|   | |||||||
| @@ -118,7 +118,7 @@ static xboolean gInitialized = FALSE; | |||||||
| * Returns:																 | * Returns:																 | ||||||
| *	 void																 | *	 void																 | ||||||
| ************************************************************************/ | ************************************************************************/ | ||||||
| static XINLINE void | static UPNP_INLINE void | ||||||
| init_table( IN const char *encoded_str, | init_table( IN const char *encoded_str, | ||||||
|             OUT const char *table[], |             OUT const char *table[], | ||||||
|             IN int tbl_size ) |             IN int tbl_size ) | ||||||
| @@ -144,7 +144,7 @@ init_table( IN const char *encoded_str, | |||||||
| * Returns:																 | * Returns:																 | ||||||
| *	 void																 | *	 void																 | ||||||
| ************************************************************************/ | ************************************************************************/ | ||||||
| static XINLINE void | static UPNP_INLINE void | ||||||
| init_tables( void ) | init_tables( void ) | ||||||
| { | { | ||||||
|     init_table( Http1xxStr, Http1xxCodes, NUM_1XX_CODES ); |     init_table( Http1xxStr, Http1xxCodes, NUM_1XX_CODES ); | ||||||
|   | |||||||
| @@ -39,6 +39,7 @@ | |||||||
| #include <fcntl.h> | #include <fcntl.h> | ||||||
| #ifndef UPNP_USE_BCBPP | #ifndef UPNP_USE_BCBPP | ||||||
| #ifndef UPNP_USE_MSVCPP | #ifndef UPNP_USE_MSVCPP | ||||||
|  |     #include <inttypes.h> | ||||||
|     #include <stdint.h> |     #include <stdint.h> | ||||||
| #endif | #endif | ||||||
| #endif | #endif | ||||||
| @@ -204,7 +205,7 @@ extern str_int_entry Http_Header_Names[NUM_HTTP_HEADER_NAMES]; | |||||||
| * Returns:																 | * Returns:																 | ||||||
| *	 void																 | *	 void																 | ||||||
| ************************************************************************/ | ************************************************************************/ | ||||||
| static XINLINE void | static UPNP_INLINE void | ||||||
| media_list_init( void ) | media_list_init( void ) | ||||||
| { | { | ||||||
|     int i; |     int i; | ||||||
| @@ -242,7 +243,7 @@ media_list_init( void ) | |||||||
| *	 0 on success;														 | *	 0 on success;														 | ||||||
| *	-1 on error															 | *	-1 on error															 | ||||||
| ************************************************************************/ | ************************************************************************/ | ||||||
| static XINLINE int | static UPNP_INLINE int | ||||||
| search_extension( IN const char *extension, | search_extension( IN const char *extension, | ||||||
|                   OUT const char **con_type, |                   OUT const char **con_type, | ||||||
|                   OUT const char **con_subtype ) |                   OUT const char **con_subtype ) | ||||||
| @@ -289,7 +290,7 @@ search_extension( IN const char *extension, | |||||||
| *	 0 - On Sucess														 | *	 0 - On Sucess														 | ||||||
| *	 UPNP_E_OUTOF_MEMORY - on memory allocation failures				 | *	 UPNP_E_OUTOF_MEMORY - on memory allocation failures				 | ||||||
| ************************************************************************/ | ************************************************************************/ | ||||||
| XINLINE int | UPNP_INLINE int | ||||||
| get_content_type( IN const char *filename, | get_content_type( IN const char *filename, | ||||||
|                   OUT DOMString * content_type ) |                   OUT DOMString * content_type ) | ||||||
| { | { | ||||||
| @@ -347,7 +348,7 @@ get_content_type( IN const char *filename, | |||||||
| * Returns:																 | * Returns:																 | ||||||
| *	 void																 | *	 void																 | ||||||
| ************************************************************************/ | ************************************************************************/ | ||||||
| static XINLINE void | static UPNP_INLINE void | ||||||
| glob_alias_init( void ) | glob_alias_init( void ) | ||||||
| { | { | ||||||
|     struct xml_alias_t *alias = &gAliasDoc; |     struct xml_alias_t *alias = &gAliasDoc; | ||||||
| @@ -369,7 +370,7 @@ glob_alias_init( void ) | |||||||
| * Returns:																 | * Returns:																 | ||||||
| *	 BOOLEAN															 | *	 BOOLEAN															 | ||||||
| ************************************************************************/ | ************************************************************************/ | ||||||
| static XINLINE xboolean | static UPNP_INLINE xboolean | ||||||
| is_valid_alias( IN const struct xml_alias_t *alias ) | is_valid_alias( IN const struct xml_alias_t *alias ) | ||||||
| { | { | ||||||
|     return alias->doc.buf != NULL; |     return alias->doc.buf != NULL; | ||||||
| @@ -636,11 +637,11 @@ get_file_info( IN const char *filename, | |||||||
|  |  | ||||||
|     rc = get_content_type( filename, &info->content_type ); |     rc = get_content_type( filename, &info->content_type ); | ||||||
|  |  | ||||||
|     DBGONLY( UpnpPrintf( UPNP_INFO, HTTP, __FILE__, __LINE__, |     UpnpPrintf( UPNP_INFO, HTTP, __FILE__, __LINE__, | ||||||
|         "file info: %s, length: %lld, last_mod=%s readable=%d\n", |         "file info: %s, length: %lld, last_mod=%s readable=%d\n", | ||||||
|         filename, (long long)info->file_length, |         filename, (long long)info->file_length, | ||||||
|         asctime( gmtime( &info->last_modified ) ), |         asctime( gmtime( &info->last_modified ) ), | ||||||
|                          info->is_readable ); ) |         info->is_readable ); | ||||||
|  |  | ||||||
|     return rc; |     return rc; | ||||||
| } | } | ||||||
| @@ -699,7 +700,7 @@ web_server_set_root_dir( IN const char *root_dir ) | |||||||
| *	TRUE - On Success													 | *	TRUE - On Success													 | ||||||
| *	FALSE if request is not an alias									 | *	FALSE if request is not an alias									 | ||||||
| ************************************************************************/ | ************************************************************************/ | ||||||
| static XINLINE xboolean | static UPNP_INLINE xboolean | ||||||
| get_alias( IN const char *request_file, | get_alias( IN const char *request_file, | ||||||
|            OUT struct xml_alias_t *alias, |            OUT struct xml_alias_t *alias, | ||||||
|            OUT struct File_Info *info ) |            OUT struct File_Info *info ) | ||||||
| @@ -990,7 +991,7 @@ CreateHTTPRangeResponseHeader( char *ByteRangeSpecifier, | |||||||
|             Instr->RangeOffset = FirstByte; |             Instr->RangeOffset = FirstByte; | ||||||
|             Instr->ReadSendSize = LastByte - FirstByte + 1; |             Instr->ReadSendSize = LastByte - FirstByte + 1; | ||||||
|             sprintf( Instr->RangeHeader, |             sprintf( Instr->RangeHeader, | ||||||
|                 "CONTENT-RANGE: bytes %lld-%lld/%lld\r\n", |                 "CONTENT-RANGE: bytes %"PRId64"-%"PRId64"/%"PRId64"\r\n", | ||||||
|                 (int64_t)FirstByte, |                 (int64_t)FirstByte, | ||||||
|                 (int64_t)LastByte, |                 (int64_t)LastByte, | ||||||
|                 (int64_t)FileLength );   //Data between two range. |                 (int64_t)FileLength );   //Data between two range. | ||||||
| @@ -999,7 +1000,7 @@ CreateHTTPRangeResponseHeader( char *ByteRangeSpecifier, | |||||||
|             Instr->RangeOffset = FirstByte; |             Instr->RangeOffset = FirstByte; | ||||||
|             Instr->ReadSendSize = FileLength - FirstByte; |             Instr->ReadSendSize = FileLength - FirstByte; | ||||||
|             sprintf( Instr->RangeHeader, |             sprintf( Instr->RangeHeader, | ||||||
|                      "CONTENT-RANGE: bytes %lld-%lld/%lld\r\n", |                      "CONTENT-RANGE: bytes %"PRId64"-%"PRId64"/%"PRId64"\r\n", | ||||||
|                      (int64_t)FirstByte, |                      (int64_t)FirstByte, | ||||||
|                      (int64_t)(FileLength - 1), |                      (int64_t)(FileLength - 1), | ||||||
|                      (int64_t)FileLength ); |                      (int64_t)FileLength ); | ||||||
| @@ -1008,14 +1009,14 @@ CreateHTTPRangeResponseHeader( char *ByteRangeSpecifier, | |||||||
|                 Instr->RangeOffset = 0; |                 Instr->RangeOffset = 0; | ||||||
|                 Instr->ReadSendSize = FileLength; |                 Instr->ReadSendSize = FileLength; | ||||||
|                 sprintf( Instr->RangeHeader, |                 sprintf( Instr->RangeHeader, | ||||||
|                          "CONTENT-RANGE: bytes 0-%lld/%lld\r\n", |                          "CONTENT-RANGE: bytes 0-%"PRId64"/%"PRId64"\r\n", | ||||||
|                          (int64_t)(FileLength - 1), |                          (int64_t)(FileLength - 1), | ||||||
|                          (int64_t)FileLength ); |                          (int64_t)FileLength ); | ||||||
|             } else { |             } else { | ||||||
|                 Instr->RangeOffset = FileLength - LastByte; |                 Instr->RangeOffset = FileLength - LastByte; | ||||||
|                 Instr->ReadSendSize = LastByte; |                 Instr->ReadSendSize = LastByte; | ||||||
|                 sprintf( Instr->RangeHeader, |                 sprintf( Instr->RangeHeader, | ||||||
|                          "CONTENT-RANGE: bytes %lld-%lld/%lld\r\n", |                          "CONTENT-RANGE: bytes %"PRId64"-%"PRId64"/%"PRId64"\r\n", | ||||||
|                          (int64_t)(FileLength - LastByte + 1), |                          (int64_t)(FileLength - LastByte + 1), | ||||||
|                          (int64_t)FileLength, |                          (int64_t)FileLength, | ||||||
|                          (int64_t)FileLength ); |                          (int64_t)FileLength ); | ||||||
| @@ -1206,7 +1207,7 @@ process_request( IN http_message_t * req, | |||||||
|     int resp_major, |     int resp_major, | ||||||
|       resp_minor; |       resp_minor; | ||||||
|     xboolean alias_grabbed; |     xboolean alias_grabbed; | ||||||
|     int dummy; |     size_t dummy; | ||||||
|     struct UpnpVirtualDirCallbacks *pVirtualDirCallback; |     struct UpnpVirtualDirCallbacks *pVirtualDirCallback; | ||||||
|  |  | ||||||
|     print_http_headers( req ); |     print_http_headers( req ); | ||||||
| @@ -1585,13 +1586,10 @@ http_RecvPostMessage( http_parser_t * parser, | |||||||
|                 } |                 } | ||||||
|             } else if( num_read == 0 ) { |             } else if( num_read == 0 ) { | ||||||
|                 if( ok_on_close ) { |                 if( ok_on_close ) { | ||||||
|                     DBGONLY( UpnpPrintf |                     UpnpPrintf( UPNP_INFO, HTTP, __FILE__, __LINE__, | ||||||
|                              ( UPNP_INFO, HTTP, __FILE__, __LINE__, |  | ||||||
|                         "<<< (RECVD) <<<\n%s\n-----------------\n", |                         "<<< (RECVD) <<<\n%s\n-----------------\n", | ||||||
|                         parser->msg.msg.buf ); |                         parser->msg.msg.buf ); | ||||||
|                              //print_http_headers( &parser->msg ); |                     print_http_headers( &parser->msg ); | ||||||
|                          ) |  | ||||||
|  |  | ||||||
|                     parser->position = POS_COMPLETE; |                     parser->position = POS_COMPLETE; | ||||||
|                 } else { |                 } else { | ||||||
|                     // partial msg |                     // partial msg | ||||||
| @@ -1759,9 +1757,8 @@ web_server_callback( IN http_parser_t * parser, | |||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     DBGONLY( UpnpPrintf( UPNP_INFO, HTTP, __FILE__, __LINE__, |     UpnpPrintf( UPNP_INFO, HTTP, __FILE__, __LINE__, | ||||||
|         "webserver: request processed...\n" ); |         "webserver: request processed...\n" ); | ||||||
|          ) |  | ||||||
|  |  | ||||||
|     membuffer_destroy( &headers ); |     membuffer_destroy( &headers ); | ||||||
|     membuffer_destroy( &filename ); |     membuffer_destroy( &filename ); | ||||||
|   | |||||||
| @@ -34,8 +34,11 @@ | |||||||
| ************************************************************************/ | ************************************************************************/ | ||||||
|  |  | ||||||
| #ifdef __FreeBSD__ | #ifdef __FreeBSD__ | ||||||
|  | #include <osreldate.h> | ||||||
|  | #if __FreeBSD_version < 601103 | ||||||
| #include <lwres/netdb.h> | #include <lwres/netdb.h> | ||||||
| #endif | #endif | ||||||
|  | #endif | ||||||
| #include "config.h" | #include "config.h" | ||||||
| #include "uri.h" | #include "uri.h" | ||||||
|  |  | ||||||
| @@ -157,7 +160,7 @@ is_escaped( const char *in ) | |||||||
| int | int | ||||||
| replace_escaped( char *in, | replace_escaped( char *in, | ||||||
|                  int index, |                  int index, | ||||||
|                  int *max ) |                  size_t *max ) | ||||||
| { | { | ||||||
|     int tempInt = 0; |     int tempInt = 0; | ||||||
|     char tempChar = 0; |     char tempChar = 0; | ||||||
| @@ -364,16 +367,20 @@ free_URL_list( URL_list * list ) | |||||||
| *		uri_type *in ;	URI object | *		uri_type *in ;	URI object | ||||||
| * | * | ||||||
| *	Description : Function useful in debugging for printing a parsed uri. | *	Description : Function useful in debugging for printing a parsed uri. | ||||||
| *		Compiled out with DBGONLY macro.  |  | ||||||
| * | * | ||||||
| *	Return : void ; | *	Return : void ; | ||||||
| * | * | ||||||
| *	Note : | *	Note : | ||||||
| ************************************************************************/ | ************************************************************************/ | ||||||
| DBGONLY( void print_uri( uri_type * in ) { | #ifdef DEBUG | ||||||
|  | void print_uri( uri_type *in ) | ||||||
|  | { | ||||||
|     print_token( &in->scheme ); |     print_token( &in->scheme ); | ||||||
|     print_token( &in->hostport.text ); |     print_token( &in->hostport.text ); | ||||||
|          print_token( &in->pathquery ); print_token( &in->fragment );} ) |     print_token( &in->pathquery ); | ||||||
|  |     print_token( &in->fragment ); | ||||||
|  | } | ||||||
|  | #endif | ||||||
|  |  | ||||||
| /************************************************************************ | /************************************************************************ | ||||||
| *	Function :	print_token | *	Function :	print_token | ||||||
| @@ -382,20 +389,23 @@ DBGONLY( void print_uri( uri_type * in ) { | |||||||
| *		token * in ;	token | *		token * in ;	token | ||||||
| * | * | ||||||
| *	Description : Function useful in debugging for printing a token. | *	Description : Function useful in debugging for printing a token. | ||||||
| *		Compiled out with DBGONLY macro.  |  | ||||||
| * | * | ||||||
| *	Return : void ; | *	Return : void ; | ||||||
| * | * | ||||||
| *	Note : | *	Note : | ||||||
| ************************************************************************/ | ************************************************************************/ | ||||||
| DBGONLY( void print_token( token * in ) { | #ifdef DEBUG | ||||||
|  | void print_token(token * in) | ||||||
|  | { | ||||||
|     int i = 0; |     int i = 0; | ||||||
|          printf( "Token Size : %d\n\'", in->size ); |     printf( "Token Size : %"PRIzu"\n\'", in->size ); | ||||||
|     for( i = 0; i < in->size; i++ ) { |     for( i = 0; i < in->size; i++ ) { | ||||||
|          putchar( in->buff[i] );} |         putchar( in->buff[i] ); | ||||||
|          putchar( '\'' ); putchar( '\n' );} |     } | ||||||
|  |     putchar( '\'' ); | ||||||
|  ) |     putchar( '\n' ); | ||||||
|  | } | ||||||
|  | #endif | ||||||
|  |  | ||||||
| /************************************************************************ | /************************************************************************ | ||||||
| *	Function :	token_string_casecmp | *	Function :	token_string_casecmp | ||||||
| @@ -414,8 +424,10 @@ DBGONLY( void print_token( token * in ) { | |||||||
| * | * | ||||||
| *	Note : | *	Note : | ||||||
| ************************************************************************/ | ************************************************************************/ | ||||||
|     int token_string_casecmp( token * in1, | int token_string_casecmp( | ||||||
|                               char *in2 ) { |     token * in1, | ||||||
|  |     char *in2 ) | ||||||
|  | { | ||||||
|     int in2_length = strlen( in2 ); |     int in2_length = strlen( in2 ); | ||||||
|  |  | ||||||
|     if( in1->size != in2_length ) |     if( in1->size != in2_length ) | ||||||
| @@ -611,14 +623,16 @@ parse_hostport( const char *in, | |||||||
|         int errCode = 0; |         int errCode = 0; | ||||||
|  |  | ||||||
|         //call gethostbyname_r (reentrant form of gethostbyname) |         //call gethostbyname_r (reentrant form of gethostbyname) | ||||||
| #if defined(WIN32) |         // TODO: Use autoconf to discover this rather than the | ||||||
|  |         // platform-specific stuff below | ||||||
|  | #if defined(WIN32) || defined(__CYGWIN__) | ||||||
|         h=gethostbyname(temp_host_name); |         h=gethostbyname(temp_host_name); | ||||||
| #elif defined(SPARC_SOLARIS) | #elif defined(SPARC_SOLARIS) | ||||||
|         errCode = gethostbyname_r( temp_host_name, |         errCode = gethostbyname_r( temp_host_name, | ||||||
|                                    &h, |                                    &h, | ||||||
|                                    temp_hostbyname_buff, |                                    temp_hostbyname_buff, | ||||||
|                                    BUFFER_SIZE, &errcode ); |                                    BUFFER_SIZE, &errcode ); | ||||||
| #elif defined(__FreeBSD__) | #elif defined(__FreeBSD__) && __FreeBSD_version < 601103 | ||||||
|         h = lwres_gethostbyname_r( temp_host_name, |         h = lwres_gethostbyname_r( temp_host_name, | ||||||
|                                    &h_buf, |                                    &h_buf, | ||||||
|                                    temp_hostbyname_buff, |                                    temp_hostbyname_buff, | ||||||
| @@ -731,7 +745,7 @@ parse_scheme( const char *in, | |||||||
| ************************************************************************/ | ************************************************************************/ | ||||||
| int | int | ||||||
| remove_escaped_chars( INOUT char *in, | remove_escaped_chars( INOUT char *in, | ||||||
|                       INOUT int *size ) |                       INOUT size_t *size ) | ||||||
| { | { | ||||||
|     int i = 0; |     int i = 0; | ||||||
|  |  | ||||||
| @@ -785,9 +799,8 @@ remove_dots( char *in, | |||||||
|         return UPNP_E_OUTOF_MEMORY; |         return UPNP_E_OUTOF_MEMORY; | ||||||
|  |  | ||||||
|     Segments[0] = NULL; |     Segments[0] = NULL; | ||||||
|     DBGONLY( UpnpPrintf |     UpnpPrintf( UPNP_ALL, API, __FILE__, __LINE__, | ||||||
|              ( UPNP_ALL, API, __FILE__, __LINE__, |         "REMOVE_DOTS: before: %s\n", in ); | ||||||
|                "REMOVE_DOTS: before: %s\n", in ) ); |  | ||||||
|     while( ( copyFrom < max ) && ( *copyFrom != '?' ) |     while( ( copyFrom < max ) && ( *copyFrom != '?' ) | ||||||
|            && ( *copyFrom != '#' ) ) { |            && ( *copyFrom != '#' ) ) { | ||||||
|  |  | ||||||
| @@ -832,9 +845,8 @@ remove_dots( char *in, | |||||||
|     } |     } | ||||||
|     ( *copyTo ) = 0; |     ( *copyTo ) = 0; | ||||||
|     free( Segments ); |     free( Segments ); | ||||||
|     DBGONLY( UpnpPrintf |     UpnpPrintf( UPNP_ALL, API, __FILE__, __LINE__, | ||||||
|              ( UPNP_ALL, API, __FILE__, __LINE__, |         "REMOVE_DOTS: after: %s\n", in ); | ||||||
|                "REMOVE_DOTS: after: %s\n", in ) ); |  | ||||||
|     return UPNP_E_SUCCESS; |     return UPNP_E_SUCCESS; | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -1067,7 +1079,7 @@ parse_uri( const char *in, | |||||||
| int | int | ||||||
| parse_uri_and_unescape( char *in, | parse_uri_and_unescape( char *in, | ||||||
|                         int max, |                         int max, | ||||||
|                         uri_type * out ) |                         uri_type *out ) | ||||||
| { | { | ||||||
|     int ret; |     int ret; | ||||||
|  |  | ||||||
|   | |||||||
| @@ -433,7 +433,7 @@ FindServiceControlURLPath( service_table * table, | |||||||
| * | * | ||||||
| *	Parameters : | *	Parameters : | ||||||
| *		service_info *service ;Service whose information is to be printed | *		service_info *service ;Service whose information is to be printed | ||||||
| *		Dbg_Level level ; Debug level specified to the print function | *		Upnp_LogLevel level ; Debug level specified to the print function | ||||||
| *		Dbg_Module module ;	Debug module specified to the print function | *		Dbg_Module module ;	Debug module specified to the print function | ||||||
| * | * | ||||||
| *	Description :	For debugging purposes prints information from the  | *	Description :	For debugging purposes prints information from the  | ||||||
| @@ -443,38 +443,54 @@ FindServiceControlURLPath( service_table * table, | |||||||
| * | * | ||||||
| *	Note : | *	Note : | ||||||
| ************************************************************************/ | ************************************************************************/ | ||||||
| DBGONLY( void printService( service_info * service, Dbg_Level level, | #ifdef DEBUG | ||||||
|                             Dbg_Module module ) { | void printService( | ||||||
|  |     service_info *service, | ||||||
|  |     Upnp_LogLevel level, | ||||||
|  |     Dbg_Module module ) | ||||||
|  | { | ||||||
|     if( service ) { |     if( service ) { | ||||||
|          if( service->serviceType ) |         if( service->serviceType ) { | ||||||
|             UpnpPrintf( level, module, __FILE__, __LINE__, |             UpnpPrintf( level, module, __FILE__, __LINE__, | ||||||
|                 "serviceType: %s\n", service->serviceType ); |                 "serviceType: %s\n", service->serviceType ); | ||||||
|          if( service->serviceId ) |         } | ||||||
|          UpnpPrintf( level, module, __FILE__, __LINE__, "serviceId: %s\n", |         if( service->serviceId ) { | ||||||
|                      service->serviceId ); if( service->SCPDURL ) |             UpnpPrintf( level, module, __FILE__, __LINE__, | ||||||
|          UpnpPrintf( level, module, __FILE__, __LINE__, "SCPDURL: %s\n", |                 "serviceId: %s\n", service->serviceId ); | ||||||
|                      service->SCPDURL ); if( service->controlURL ) |         } | ||||||
|          UpnpPrintf( level, module, __FILE__, __LINE__, "controlURL: %s\n", | 	if( service->SCPDURL ) { | ||||||
|                      service->controlURL ); if( service->eventURL ) |             UpnpPrintf( level, module, __FILE__, __LINE__, | ||||||
|          UpnpPrintf( level, module, __FILE__, __LINE__, "eventURL: %s\n", |                 "SCPDURL: %s\n", service->SCPDURL ); | ||||||
|                      service->eventURL ); if( service->UDN ) |         } | ||||||
|          UpnpPrintf( level, module, __FILE__, __LINE__, "UDN: %s\n\n", | 	if( service->controlURL ) { | ||||||
|                      service->UDN ); if( service->active ) |             UpnpPrintf( level, module, __FILE__, __LINE__, | ||||||
|  |                 "controlURL: %s\n", service->controlURL ); | ||||||
|  |         } | ||||||
|  | 	if( service->eventURL ) { | ||||||
|  |             UpnpPrintf( level, module, __FILE__, __LINE__, | ||||||
|  |                 "eventURL: %s\n", service->eventURL ); | ||||||
|  |         } | ||||||
|  | 	if( service->UDN ) { | ||||||
|  |             UpnpPrintf( level, module, __FILE__, __LINE__, | ||||||
|  |                 "UDN: %s\n\n", service->UDN ); | ||||||
|  |         } | ||||||
|  | 	if( service->active ) { | ||||||
|             UpnpPrintf( level, module, __FILE__, __LINE__, |             UpnpPrintf( level, module, __FILE__, __LINE__, | ||||||
|             "Service is active\n" ); |             "Service is active\n" ); | ||||||
|          else |         } else { | ||||||
|             UpnpPrintf( level, module, __FILE__, __LINE__, |             UpnpPrintf( level, module, __FILE__, __LINE__, | ||||||
|                      "Service is inactive\n" );} |             "Service is inactive\n" ); | ||||||
|         } |         } | ||||||
|  |     } | ||||||
|  ) | } | ||||||
|  | #endif | ||||||
|  |  | ||||||
| /************************************************************************ | /************************************************************************ | ||||||
| *	Function :	printServiceList | *	Function :	printServiceList | ||||||
| * | * | ||||||
| *	Parameters : | *	Parameters : | ||||||
| *		service_info *service ;	Service whose information is to be printed | *		service_info *service ;	Service whose information is to be printed | ||||||
| *		Dbg_Level level ;	Debug level specified to the print function | *		Upnp_LogLevel level ;	Debug level specified to the print function | ||||||
| *		Dbg_Module module ;	Debug module specified to the print function | *		Dbg_Module module ;	Debug module specified to the print function | ||||||
| * | * | ||||||
| *	Description :	For debugging purposes prints information of each  | *	Description :	For debugging purposes prints information of each  | ||||||
| @@ -484,43 +500,55 @@ DBGONLY( void printService( service_info * service, Dbg_Level level, | |||||||
| * | * | ||||||
| *	Note : | *	Note : | ||||||
| ************************************************************************/ | ************************************************************************/ | ||||||
|     DBGONLY( void printServiceList( service_info * service, | #ifdef DEBUG | ||||||
|                                     Dbg_Level level, | void printServiceList( | ||||||
|                                     Dbg_Module module ) { |     service_info * service, | ||||||
|  |     Upnp_LogLevel level, | ||||||
|  |     Dbg_Module module ) | ||||||
|  | { | ||||||
|     while( service ) { |     while( service ) { | ||||||
|              if( service->serviceType ) |         if( service->serviceType ) { | ||||||
|             UpnpPrintf( level, module, __FILE__, __LINE__, |             UpnpPrintf( level, module, __FILE__, __LINE__, | ||||||
|                 "serviceType: %s\n", service->serviceType ); |                 "serviceType: %s\n", service->serviceType ); | ||||||
|              if( service->serviceId ) |         } | ||||||
|  |         if( service->serviceId ) { | ||||||
|             UpnpPrintf( level, module, __FILE__, __LINE__, |             UpnpPrintf( level, module, __FILE__, __LINE__, | ||||||
|                 "serviceId: %s\n", service->serviceId ); |                 "serviceId: %s\n", service->serviceId ); | ||||||
|              if( service->SCPDURL ) |         } | ||||||
|  |         if( service->SCPDURL ) { | ||||||
|             UpnpPrintf( level, module, __FILE__, __LINE__, |             UpnpPrintf( level, module, __FILE__, __LINE__, | ||||||
|                 "SCPDURL: %s\n", service->SCPDURL ); |                 "SCPDURL: %s\n", service->SCPDURL ); | ||||||
|              if( service->controlURL ) |         } | ||||||
|  |         if( service->controlURL ) { | ||||||
|             UpnpPrintf( level, module, __FILE__, __LINE__, |             UpnpPrintf( level, module, __FILE__, __LINE__, | ||||||
|                 "controlURL: %s\n", service->controlURL ); |                 "controlURL: %s\n", service->controlURL ); | ||||||
|              if( service->eventURL ) |         } | ||||||
|  |         if( service->eventURL ) { | ||||||
|             UpnpPrintf( level, module, __FILE__, __LINE__, |             UpnpPrintf( level, module, __FILE__, __LINE__, | ||||||
|                 "eventURL: %s\n", service->eventURL ); |                 "eventURL: %s\n", service->eventURL ); | ||||||
|              if( service->UDN ) |         } | ||||||
|              UpnpPrintf( level, module, __FILE__, __LINE__, "UDN: %s\n\n", |         if( service->UDN ) { | ||||||
|                          service->UDN ); if( service->active ) |             UpnpPrintf( level, module, __FILE__, __LINE__, | ||||||
|  |                 "UDN: %s\n\n", service->UDN ); | ||||||
|  |         } | ||||||
|  |         if( service->active ) { | ||||||
|             UpnpPrintf( level, module, __FILE__, __LINE__, |             UpnpPrintf( level, module, __FILE__, __LINE__, | ||||||
|                 "Service is active\n" ); |                 "Service is active\n" ); | ||||||
|              else |         } else { | ||||||
|             UpnpPrintf( level, module, __FILE__, __LINE__, |             UpnpPrintf( level, module, __FILE__, __LINE__, | ||||||
|                 "Service is inactive\n" ); |                 "Service is inactive\n" ); | ||||||
|              service = service->next;} |  | ||||||
|         } |         } | ||||||
|  ) |         service = service->next; | ||||||
|  |     } | ||||||
|  | } | ||||||
|  | #endif | ||||||
|  |  | ||||||
| /************************************************************************ | /************************************************************************ | ||||||
| *	Function :	printServiceTable | *	Function :	printServiceTable | ||||||
| * | * | ||||||
| *	Parameters : | *	Parameters : | ||||||
| *		service_table * table ;	Service table to be printed | *		service_table * table ;	Service table to be printed | ||||||
| *		Dbg_Level level ;	Debug level specified to the print function | *		Upnp_LogLevel level ;	Debug level specified to the print function | ||||||
| *		Dbg_Module module ;	Debug module specified to the print function | *		Dbg_Module module ;	Debug module specified to the print function | ||||||
| * | * | ||||||
| *	Description :	For debugging purposes prints the URL base of the table | *	Description :	For debugging purposes prints the URL base of the table | ||||||
| @@ -531,15 +559,18 @@ DBGONLY( void printService( service_info * service, Dbg_Level level, | |||||||
| * | * | ||||||
| *	Note : | *	Note : | ||||||
| ************************************************************************/ | ************************************************************************/ | ||||||
|     DBGONLY( void printServiceTable( service_table * table, | #ifdef DEBUG | ||||||
|                                      Dbg_Level level, | void printServiceTable( | ||||||
|                                      Dbg_Module module ) { |     service_table * table, | ||||||
|  |     Upnp_LogLevel level, | ||||||
|  |     Dbg_Module module ) | ||||||
|  | { | ||||||
|     UpnpPrintf( level, module, __FILE__, __LINE__, |     UpnpPrintf( level, module, __FILE__, __LINE__, | ||||||
|         "URL_BASE: %s\n", table->URLBase ); |         "URL_BASE: %s\n", table->URLBase ); | ||||||
|     UpnpPrintf( level, module, __FILE__, __LINE__, |     UpnpPrintf( level, module, __FILE__, __LINE__, | ||||||
|         "Services: \n" ); |         "Services: \n" ); | ||||||
|     printServiceList( table->serviceList, level, module );} |     printServiceList( table->serviceList, level, module );} | ||||||
|  ) | #endif | ||||||
|  |  | ||||||
| /************************************************************************ | /************************************************************************ | ||||||
| *	Function :	freeService | *	Function :	freeService | ||||||
| @@ -554,7 +585,7 @@ DBGONLY( void printService( service_info * service, Dbg_Level level, | |||||||
| * | * | ||||||
| *	Note : | *	Note : | ||||||
| ************************************************************************/ | ************************************************************************/ | ||||||
|      void freeService( service_info * in ) | void freeService( service_info * in ) | ||||||
| { | { | ||||||
|     if( in ) { |     if( in ) { | ||||||
|         if( in->serviceType ) |         if( in->serviceType ) | ||||||
| @@ -849,12 +880,10 @@ getServiceList( IXML_Node * node, | |||||||
|                     ( ! |                     ( ! | ||||||
|                       ( current->controlURL = |                       ( current->controlURL = | ||||||
|                         resolve_rel_url( URLBase, tempDOMString ) ) ) ) { |                         resolve_rel_url( URLBase, tempDOMString ) ) ) ) { | ||||||
|                     DBGONLY( UpnpPrintf |                     UpnpPrintf( UPNP_INFO, GENA, __FILE__, __LINE__, | ||||||
|                              ( UPNP_INFO, GENA, __FILE__, __LINE__, |                         "BAD OR MISSING CONTROL URL" ); | ||||||
|                                "BAD OR MISSING CONTROL URL" ) ); |                     UpnpPrintf( UPNP_INFO, GENA, __FILE__, __LINE__, | ||||||
|                     DBGONLY( UpnpPrintf |                         "CONTROL URL SET TO NULL IN SERVICE INFO" ); | ||||||
|                              ( UPNP_INFO, GENA, __FILE__, __LINE__, |  | ||||||
|                                "CONTROL URL SET TO NULL IN SERVICE INFO" ) ); |  | ||||||
|                     current->controlURL = NULL; |                     current->controlURL = NULL; | ||||||
|                     fail = 0; |                     fail = 0; | ||||||
|                 } |                 } | ||||||
| @@ -870,12 +899,10 @@ getServiceList( IXML_Node * node, | |||||||
|                     ( ! |                     ( ! | ||||||
|                       ( current->eventURL = |                       ( current->eventURL = | ||||||
|                         resolve_rel_url( URLBase, tempDOMString ) ) ) ) { |                         resolve_rel_url( URLBase, tempDOMString ) ) ) ) { | ||||||
|                     DBGONLY( UpnpPrintf |                     UpnpPrintf( UPNP_INFO, GENA, __FILE__, __LINE__, | ||||||
|                              ( UPNP_INFO, GENA, __FILE__, __LINE__, |                         "BAD OR MISSING EVENT URL" ); | ||||||
|                                "BAD OR MISSING EVENT URL" ) ); |                     UpnpPrintf( UPNP_INFO, GENA, __FILE__, __LINE__, | ||||||
|                     DBGONLY( UpnpPrintf |                         "EVENT URL SET TO NULL IN SERVICE INFO" ); | ||||||
|                              ( UPNP_INFO, GENA, __FILE__, __LINE__, |  | ||||||
|                                "EVENT URL SET TO NULL IN SERVICE INFO" ) ); |  | ||||||
|                     current->eventURL = NULL; |                     current->eventURL = NULL; | ||||||
|                     fail = 0; |                     fail = 0; | ||||||
|                 } |                 } | ||||||
| @@ -1092,20 +1119,20 @@ addServiceTable( IXML_Node * node, | |||||||
| } | } | ||||||
|  |  | ||||||
| /************************************************************************ | /************************************************************************ | ||||||
| *	Function :	getServiceTable |  * Function : getServiceTable | ||||||
| * |  * | ||||||
| *	Parameters : |  * Parameters : | ||||||
| *		IXML_Node *node ;	XML node information |  * 	IXML_Node *node ;	XML node information | ||||||
| *		service_table *out ;	output parameter which will contain the  |  *	service_table *out ;	output parameter which will contain the | ||||||
| *							service list and URL  |  *				service list and URL | ||||||
| *		const char *DefaultURLBase ; Default base URL on which the URL  |  *	const char *DefaultURLBase ; Default base URL on which the URL | ||||||
| *							will be returned. |  *				will be returned. | ||||||
| * |  * | ||||||
| *	Description :	Retrieve service from the table |  * Description : Retrieve service from the table | ||||||
| * |  * | ||||||
| *	Return : int ; |  * Return : int ; | ||||||
| * |  * | ||||||
| *	Note : |  * Note : | ||||||
| ************************************************************************/ | ************************************************************************/ | ||||||
| int | int | ||||||
| getServiceTable( IXML_Node * node, | getServiceTable( IXML_Node * node, | ||||||
| @@ -1126,9 +1153,8 @@ getServiceTable( IXML_Node * node, | |||||||
|             } |             } | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         if( ( out->serviceList = getAllServiceList( root, out->URLBase, |         if( ( out->serviceList = getAllServiceList( | ||||||
|                                                     &out-> |             root, out->URLBase, &out->endServiceList ) ) ) { | ||||||
|                                                     endServiceList ) ) ) { |  | ||||||
|             return 1; |             return 1; | ||||||
|         } |         } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -171,7 +171,7 @@ memptr_cmp_nocase( IN memptr * m, | |||||||
| * | * | ||||||
| *	Note : | *	Note : | ||||||
| ************************************************************************/ | ************************************************************************/ | ||||||
| static XINLINE void | static UPNP_INLINE void | ||||||
| membuffer_initialize( INOUT membuffer * m ) | membuffer_initialize( INOUT membuffer * m ) | ||||||
| { | { | ||||||
|     m->buf = NULL; |     m->buf = NULL; | ||||||
|   | |||||||
| @@ -304,27 +304,6 @@ | |||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| /** @name DBGONLY |  | ||||||
|           The {\bf DBGONLY} macro allows code to be marked so that it  |  | ||||||
|           is only included in the DEBUG build and not the release.  To |  | ||||||
|           use this macro, put the code inside of the parentheses: |  | ||||||
|  |  | ||||||
|           {\tt DBGONLY(int i;)} |  | ||||||
|  |  | ||||||
|           This will cause a declaration of the integer {\tt i} only |  | ||||||
|           in the debug build. |  | ||||||
|   */ |  | ||||||
|  |  | ||||||
| //@{ |  | ||||||
| #ifdef DEBUG |  | ||||||
| #	define DBGONLY(x) x |  | ||||||
| #else |  | ||||||
| #	define DBGONLY(x)   |  | ||||||
| #endif |  | ||||||
| //@} |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| #undef  EXCLUDE_WEB_SERVER  | #undef  EXCLUDE_WEB_SERVER  | ||||||
| #undef  EXCLUDE_MINISERVER  | #undef  EXCLUDE_MINISERVER  | ||||||
| #ifdef  INTERNAL_WEB_SERVER | #ifdef  INTERNAL_WEB_SERVER | ||||||
| @@ -359,13 +338,6 @@ | |||||||
| #	define CLIENTONLY(x) | #	define CLIENTONLY(x) | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
| #ifdef INCLUDE_DEVICE_APIS |  | ||||||
| #	define DEVICEONLY(x) x |  | ||||||
| #else  |  | ||||||
| #	define DEVICEONLY(x)  |  | ||||||
| #endif |  | ||||||
|  |  | ||||||
| //@} | //@} | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  |  | ||||||
|   | |||||||
| @@ -89,25 +89,26 @@ | |||||||
| #define DEFAULT_TIMEOUT 1801 | #define DEFAULT_TIMEOUT 1801 | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| extern ithread_mutex_t GlobalClientSubscribeMutex; | extern ithread_mutex_t GlobalClientSubscribeMutex; | ||||||
|  |  | ||||||
| //Lock the subscription | // Lock the subscription | ||||||
| #define SubscribeLock() \ | #define SubscribeLock() \ | ||||||
| 	DBGONLY(UpnpPrintf(UPNP_INFO,GENA,__FILE__,__LINE__, \ | 	UpnpPrintf(UPNP_INFO, GENA, __FILE__, __LINE__, \ | ||||||
| 	"Trying Subscribe Lock"));  \ | 		"Trying Subscribe Lock");  \ | ||||||
| 	ithread_mutex_lock(&GlobalClientSubscribeMutex); \ | 	ithread_mutex_lock(&GlobalClientSubscribeMutex); \ | ||||||
| 	DBGONLY(UpnpPrintf(UPNP_INFO,GENA,__FILE__,__LINE__,"Subscribe Lock");) | 	UpnpPrintf(UPNP_INFO, GENA, __FILE__, __LINE__, \ | ||||||
|  | 		"Subscribe Lock"); | ||||||
|  |  | ||||||
| //Unlock the subscription | // Unlock the subscription | ||||||
| #define SubscribeUnlock() \ | #define SubscribeUnlock() \ | ||||||
| 	DBGONLY(UpnpPrintf(UPNP_INFO,GENA,__FILE__,__LINE__, \ | 	UpnpPrintf(UPNP_INFO, GENA, __FILE__, __LINE__, \ | ||||||
| 		"Trying Subscribe UnLock")); \ | 		"Trying Subscribe UnLock"); \ | ||||||
| 	ithread_mutex_unlock(&GlobalClientSubscribeMutex); \ | 	ithread_mutex_unlock(&GlobalClientSubscribeMutex); \ | ||||||
| 	DBGONLY(UpnpPrintf(UPNP_INFO,GENA,__FILE__,__LINE__,"Subscribe UnLock");) | 	UpnpPrintf(UPNP_INFO, GENA, __FILE__, __LINE__, \ | ||||||
|  | 		"Subscribe UnLock"); | ||||||
|  |  | ||||||
|  |  | ||||||
| //Structure to send NOTIFY message to all subscribed control points | // Structure to send NOTIFY message to all subscribed control points | ||||||
| typedef struct NOTIFY_THREAD_STRUCT { | typedef struct NOTIFY_THREAD_STRUCT { | ||||||
|   char * headers; |   char * headers; | ||||||
|   DOMString propertySet; |   DOMString propertySet; | ||||||
| @@ -161,11 +162,13 @@ EXTERN_C void genaCallback (IN http_parser_t *parser, | |||||||
| *	return UPNP_E_SUCCESS if service response is OK else  | *	return UPNP_E_SUCCESS if service response is OK else  | ||||||
| *	returns appropriate error | *	returns appropriate error | ||||||
| ***************************************************************************/ | ***************************************************************************/ | ||||||
| CLIENTONLY( | #ifdef INCLUDE_CLIENT_APIS | ||||||
| 	EXTERN_C int genaSubscribe(UpnpClient_Handle client_handle, | EXTERN_C int genaSubscribe( | ||||||
|  | 	UpnpClient_Handle client_handle, | ||||||
| 	char * PublisherURL, | 	char * PublisherURL, | ||||||
| 	int * TimeOut,  | 	int * TimeOut,  | ||||||
| 				Upnp_SID  out_sid );) | 	Upnp_SID  out_sid ); | ||||||
|  | #endif | ||||||
|  |  | ||||||
|  |  | ||||||
| /************************************************************************ | /************************************************************************ | ||||||
| @@ -184,8 +187,11 @@ CLIENTONLY( | |||||||
| *	return UPNP_E_SUCCESS if service response is OK else  | *	return UPNP_E_SUCCESS if service response is OK else  | ||||||
| *	returns appropriate error | *	returns appropriate error | ||||||
| ***************************************************************************/ | ***************************************************************************/ | ||||||
| CLIENTONLY(EXTERN_C int genaUnSubscribe(UpnpClient_Handle client_handle, | #ifdef INCLUDE_CLIENT_APIS | ||||||
| 		   const Upnp_SID in_sid);) | EXTERN_C int genaUnSubscribe( | ||||||
|  | 	UpnpClient_Handle client_handle, | ||||||
|  | 	const Upnp_SID in_sid); | ||||||
|  | #endif | ||||||
|  |  | ||||||
| /************************************************************************ | /************************************************************************ | ||||||
| * Function : genaUnregisterClient									 | * Function : genaUnregisterClient									 | ||||||
| @@ -202,8 +208,9 @@ CLIENTONLY(EXTERN_C int genaUnSubscribe(UpnpClient_Handle client_handle, | |||||||
| * Returns: int | * Returns: int | ||||||
| *	return UPNP_E_SUCCESS if successful else returns appropriate error | *	return UPNP_E_SUCCESS if successful else returns appropriate error | ||||||
| ***************************************************************************/ | ***************************************************************************/ | ||||||
| CLIENTONLY(EXTERN_C int genaUnregisterClient( | #ifdef INCLUDE_CLIENT_APIS | ||||||
| 			UpnpClient_Handle client_handle);) | EXTERN_C int genaUnregisterClient(UpnpClient_Handle client_handle); | ||||||
|  | #endif | ||||||
|  |  | ||||||
| //server | //server | ||||||
| /************************************************************************ | /************************************************************************ | ||||||
| @@ -218,8 +225,9 @@ CLIENTONLY(EXTERN_C int genaUnregisterClient( | |||||||
| * Returns: int | * Returns: int | ||||||
| *	returns UPNP_E_SUCCESS if successful else returns GENA_E_BAD_HANDLE | *	returns UPNP_E_SUCCESS if successful else returns GENA_E_BAD_HANDLE | ||||||
| ****************************************************************************/ | ****************************************************************************/ | ||||||
| DEVICEONLY(EXTERN_C int genaUnregisterDevice( | #ifdef INCLUDE_DEVICE_APIS | ||||||
| 				UpnpDevice_Handle device_handle);) | EXTERN_C int genaUnregisterDevice(UpnpDevice_Handle device_handle); | ||||||
|  | #endif | ||||||
|  |  | ||||||
|  |  | ||||||
| /************************************************************************ | /************************************************************************ | ||||||
| @@ -242,10 +250,12 @@ DEVICEONLY(EXTERN_C int genaUnregisterDevice( | |||||||
| *	return UPNP_E_SUCCESS if service response is OK else  | *	return UPNP_E_SUCCESS if service response is OK else  | ||||||
| *	returns appropriate error | *	returns appropriate error | ||||||
| ***************************************************************************/ | ***************************************************************************/ | ||||||
| CLIENTONLY(EXTERN_C int genaRenewSubscription( | #ifdef INCLUDE_CLIENT_APIS | ||||||
|  | EXTERN_C int genaRenewSubscription( | ||||||
| 	IN UpnpClient_Handle client_handle, | 	IN UpnpClient_Handle client_handle, | ||||||
| 	IN const Upnp_SID in_sid, | 	IN const Upnp_SID in_sid, | ||||||
| 							OUT int * TimeOut);) | 	OUT int * TimeOut); | ||||||
|  | #endif | ||||||
| /**************************************************************************** | /**************************************************************************** | ||||||
| *	Function :	genaNotifyAll | *	Function :	genaNotifyAll | ||||||
| * | * | ||||||
| @@ -265,13 +275,15 @@ CLIENTONLY(EXTERN_C int genaRenewSubscription( | |||||||
| *	Note : This function is similar to the genaNotifyAllExt. The only difference | *	Note : This function is similar to the genaNotifyAllExt. The only difference | ||||||
| *			is it takes event variable array instead of xml document. | *			is it takes event variable array instead of xml document. | ||||||
| ****************************************************************************/ | ****************************************************************************/ | ||||||
| DEVICEONLY(EXTERN_C int genaNotifyAll(UpnpDevice_Handle device_handle, | #ifdef INCLUDE_DEVICE_APIS | ||||||
|  | EXTERN_C int genaNotifyAll( | ||||||
|  | 	UpnpDevice_Handle device_handle, | ||||||
| 	char *UDN, | 	char *UDN, | ||||||
| 	char *servId, | 	char *servId, | ||||||
| 	char **VarNames, | 	char **VarNames, | ||||||
| 	char **VarValues, | 	char **VarValues, | ||||||
| 		    int var_count | 	int var_count); | ||||||
| 				      );) | #endif | ||||||
|  |  | ||||||
| /**************************************************************************** | /**************************************************************************** | ||||||
| * Function :	genaNotifyAllExt | * Function :	genaNotifyAllExt | ||||||
| @@ -290,8 +302,13 @@ DEVICEONLY(EXTERN_C int genaNotifyAll(UpnpDevice_Handle device_handle, | |||||||
| * Note : This function is similar to the genaNotifyAll. the only difference | * Note : This function is similar to the genaNotifyAll. the only difference | ||||||
| *	is it takes the document instead of event variable array | *	is it takes the document instead of event variable array | ||||||
| ****************************************************************************/ | ****************************************************************************/ | ||||||
| DEVICEONLY(EXTERN_C int genaNotifyAllExt(UpnpDevice_Handle device_handle,  | #ifdef INCLUDE_DEVICE_APIS | ||||||
| 		   char *UDN, char *servId,IN IXML_Document *PropSet);) | EXTERN_C int genaNotifyAllExt( | ||||||
|  | 	UpnpDevice_Handle device_handle,  | ||||||
|  | 	char *UDN, | ||||||
|  | 	char *servId, | ||||||
|  | 	IN IXML_Document *PropSet); | ||||||
|  | #endif | ||||||
|  |  | ||||||
| /**************************************************************************** | /**************************************************************************** | ||||||
| *	Function :	genaInitNotify | *	Function :	genaInitNotify | ||||||
| @@ -314,13 +331,15 @@ DEVICEONLY(EXTERN_C int genaNotifyAllExt(UpnpDevice_Handle device_handle, | |||||||
| *	Note : No other event will be sent to this control point before the  | *	Note : No other event will be sent to this control point before the  | ||||||
| *			intial state table dump. | *			intial state table dump. | ||||||
| ****************************************************************************/ | ****************************************************************************/ | ||||||
| DEVICEONLY(EXTERN_C int genaInitNotify(IN UpnpDevice_Handle device_handle, | #ifdef INCLUDE_DEVICE_APIS | ||||||
|  | EXTERN_C int genaInitNotify(IN UpnpDevice_Handle device_handle, | ||||||
| 	IN char *UDN, | 	IN char *UDN, | ||||||
| 	IN char *servId, | 	IN char *servId, | ||||||
| 	IN char **VarNames, | 	IN char **VarNames, | ||||||
| 	IN char **VarValues, | 	IN char **VarValues, | ||||||
| 	IN int var_count, | 	IN int var_count, | ||||||
| 				IN Upnp_SID sid);) | 	IN Upnp_SID sid); | ||||||
|  | #endif | ||||||
|  |  | ||||||
| /**************************************************************************** | /**************************************************************************** | ||||||
| *	Function :	genaInitNotifyExt | *	Function :	genaInitNotifyExt | ||||||
| @@ -342,12 +361,14 @@ DEVICEONLY(EXTERN_C int genaInitNotify(IN UpnpDevice_Handle device_handle, | |||||||
| *	Note : No other event will be sent to this control point before the  | *	Note : No other event will be sent to this control point before the  | ||||||
| *			intial state table dump. | *			intial state table dump. | ||||||
| ****************************************************************************/ | ****************************************************************************/ | ||||||
| DEVICEONLY(EXTERN_C  int genaInitNotifyExt( | #ifdef INCLUDE_DEVICE_APIS | ||||||
|  | EXTERN_C  int genaInitNotifyExt( | ||||||
| 	IN UpnpDevice_Handle device_handle,  | 	IN UpnpDevice_Handle device_handle,  | ||||||
| 	IN char *UDN,  | 	IN char *UDN,  | ||||||
| 	IN char *servId, | 	IN char *servId, | ||||||
| 	IN IXML_Document *PropSet,  | 	IN IXML_Document *PropSet,  | ||||||
| 		   IN Upnp_SID sid);) | 	IN Upnp_SID sid); | ||||||
|  | #endif | ||||||
|  |  | ||||||
|  |  | ||||||
| /************************************************************************ | /************************************************************************ | ||||||
|   | |||||||
| @@ -96,7 +96,7 @@ typedef struct SOCKET_BUFFER{ | |||||||
| //holds a pointer into a larger array | //holds a pointer into a larger array | ||||||
| typedef struct TOKEN { | typedef struct TOKEN { | ||||||
|    char * buff; |    char * buff; | ||||||
|   int size; |   size_t size; | ||||||
| } token; | } token; | ||||||
|  |  | ||||||
|  |  | ||||||
| @@ -214,37 +214,101 @@ EXTERN_C ssize_t readLine(int fd, char *out, int max, int *timeout); | |||||||
| EXTERN_C int remove_dots(char * in, int size); | EXTERN_C int remove_dots(char * in, int size); | ||||||
|  |  | ||||||
|  |  | ||||||
| DBGONLY(EXTERN_C void print_http_request(http_message | #ifdef DEBUG | ||||||
| 					 *message,Dbg_Level DLevel, | EXTERN_C void print_http_request( | ||||||
| 					 Dbg_Module Module,char *DbgFileName, | 	http_message *message, | ||||||
| 					 int DbgLineNo);); | 	Upnp_LogLevel DLevel, | ||||||
|  |  | ||||||
| DBGONLY(EXTERN_C void print_http_response(http_message *message, |  | ||||||
| 					  Dbg_Level DLevel, |  | ||||||
| 					  Dbg_Module Module,char *DbgFileName, |  | ||||||
| 					  int DbgLineNo);); |  | ||||||
|  |  | ||||||
| DBGONLY(EXTERN_C void print_token(  token * in, |  | ||||||
| 				    Dbg_Level DLevel, |  | ||||||
| 	Dbg_Module Module, | 	Dbg_Module Module, | ||||||
| 	char *DbgFileName, | 	char *DbgFileName, | ||||||
| 				    int DbgLineNo);); | 	int DbgLineNo); | ||||||
|  | #else | ||||||
| DBGONLY(EXTERN_C void print_status_line(http_status *in, | static inline void print_http_request( | ||||||
| 					Dbg_Level DLevel, | 	http_message *message, | ||||||
|  | 	Upnp_LogLevel DLevel, | ||||||
| 	Dbg_Module Module, | 	Dbg_Module Module, | ||||||
| 	char *DbgFileName, | 	char *DbgFileName, | ||||||
| 					int DbgLineNo);); | 	int DbgLineNo) {} | ||||||
|  | #endif | ||||||
|  |  | ||||||
| DBGONLY(EXTERN_C void print_request_line(http_request *in, | #ifdef DEBUG | ||||||
| 					 Dbg_Level DLevel, | EXTERN_C void print_http_response( | ||||||
| 					 Dbg_Module Module, | 	http_message *message, | ||||||
| 					 char *DbgFileName,int DbgLineNo)); | 	Upnp_LogLevel DLevel, | ||||||
|  |  | ||||||
| DBGONLY(EXTERN_C void print_uri( uri_type *in, |  | ||||||
| 				 Dbg_Level DLevel, |  | ||||||
| 	Dbg_Module Module, | 	Dbg_Module Module, | ||||||
| 	char *DbgFileName, | 	char *DbgFileName, | ||||||
| 				 int DbgLineNo);); | 	int DbgLineNo); | ||||||
|  | #else | ||||||
|  | static inline void print_http_response( | ||||||
|  | 	http_message *message, | ||||||
|  | 	Upnp_LogLevel DLevel, | ||||||
|  | 	Dbg_Module Module, | ||||||
|  | 	char *DbgFileName, | ||||||
|  | 	int DbgLineNo) {} | ||||||
|  | #endif | ||||||
|  |  | ||||||
|  | #ifdef DEBUG | ||||||
|  | EXTERN_C void print_token( | ||||||
|  | 	token *in, | ||||||
|  | 	Upnp_LogLevel DLevel, | ||||||
|  | 	Dbg_Module Module, | ||||||
|  | 	char *DbgFileName, | ||||||
|  | 	int DbgLineNo); | ||||||
|  | #else | ||||||
|  | static inline void print_token( | ||||||
|  | 	token *in, | ||||||
|  | 	Upnp_LogLevel DLevel, | ||||||
|  | 	Dbg_Module Module, | ||||||
|  | 	char *DbgFileName, | ||||||
|  | 	int DbgLineNo) {} | ||||||
|  | #endif | ||||||
|  |  | ||||||
|  | #ifdef DEBUG | ||||||
|  | EXTERN_C void print_status_line( | ||||||
|  | 	http_status *in, | ||||||
|  | 	Upnp_LogLevel DLevel, | ||||||
|  | 	Dbg_Module Module, | ||||||
|  | 	char *DbgFileName, | ||||||
|  | 	int DbgLineNo); | ||||||
|  | #else | ||||||
|  | static inline void print_status_line( | ||||||
|  | 	http_status *in, | ||||||
|  | 	Upnp_LogLevel DLevel, | ||||||
|  | 	Dbg_Module Module, | ||||||
|  | 	char *DbgFileName, | ||||||
|  | 	int DbgLineNo) {} | ||||||
|  | #endif | ||||||
|  |  | ||||||
|  | #ifdef DEBUG | ||||||
|  | EXTERN_C void print_request_line( | ||||||
|  | 	http_request *in, | ||||||
|  | 	Upnp_LogLevel DLevel, | ||||||
|  | 	Dbg_Module Module, | ||||||
|  | 	char *DbgFileName, | ||||||
|  | 	int DbgLineNo); | ||||||
|  | #else | ||||||
|  | static inline void print_request_line( | ||||||
|  | 	http_request *in, | ||||||
|  | 	Upnp_LogLevel DLevel, | ||||||
|  | 	Dbg_Module Module, | ||||||
|  | 	char *DbgFileName, | ||||||
|  | 	int DbgLineNo) {} | ||||||
|  | #endif | ||||||
|  |  | ||||||
|  | #ifdef DEBUG | ||||||
|  | EXTERN_C void print_uri( | ||||||
|  | 	uri_type *in, | ||||||
|  | 	Upnp_LogLevel DLevel, | ||||||
|  | 	Dbg_Module Module, | ||||||
|  | 	char *DbgFileName, | ||||||
|  | 	int DbgLineNo); | ||||||
|  | #else | ||||||
|  | static inline void print_uri( | ||||||
|  | 	uri_type *in, | ||||||
|  | 	Upnp_LogLevel DLevel, | ||||||
|  | 	Dbg_Module Module, | ||||||
|  | 	char *DbgFileName, | ||||||
|  | 	int DbgLineNo) {} | ||||||
|  | #endif | ||||||
|  |  | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|   | |||||||
| @@ -456,6 +456,8 @@ int raw_to_int( IN memptr* raw_value, int base ); | |||||||
| * | * | ||||||
| * Description: Find a substring from raw character string buffer | * Description: Find a substring from raw character string buffer | ||||||
| * | * | ||||||
|  | * Side effects: raw_value is transformed to lowercase. | ||||||
|  | * | ||||||
| * Returns: | * Returns: | ||||||
| *	 int - index at which the substring is found.						 | *	 int - index at which the substring is found.						 | ||||||
| ************************************************************************/ | ************************************************************************/ | ||||||
| @@ -486,7 +488,11 @@ const char* method_to_str( IN http_method_t method ); | |||||||
| * Returns: | * Returns: | ||||||
| *	 void | *	 void | ||||||
| ************************************************************************/ | ************************************************************************/ | ||||||
| void print_http_headers( IN http_message_t* hmsg ); | #ifdef DEBUG | ||||||
|  | void print_http_headers( IN http_message_t *hmsg ); | ||||||
|  | #else | ||||||
|  | static UPNP_INLINE void print_http_headers( IN http_message_t *hmsg ) {} | ||||||
|  | #endif | ||||||
|  |  | ||||||
| #ifdef __cplusplus | #ifdef __cplusplus | ||||||
| }		// extern "C" | }		// extern "C" | ||||||
| @@ -494,3 +500,4 @@ void print_http_headers( IN http_message_t* hmsg ); | |||||||
|  |  | ||||||
|  |  | ||||||
| #endif // GENLIB_NET_HTTP_HTTPPARSER_H | #endif // GENLIB_NET_HTTP_HTTPPARSER_H | ||||||
|  |  | ||||||
|   | |||||||
| @@ -51,8 +51,7 @@ typedef struct // memptr | |||||||
| // note: Total length/capacity should not exceed MAX_INT | // note: Total length/capacity should not exceed MAX_INT | ||||||
| typedef struct // membuffer | typedef struct // membuffer | ||||||
| { | { | ||||||
| 	char	*buf;			// mem buffer; must not write  | 	char	*buf;			// mem buffer; must not write beyond buf[length-1] (read/write) | ||||||
| 							//   beyond buf[length-1] (read/write) |  | ||||||
| 	size_t	length;			// length of buffer (read-only) | 	size_t	length;			// length of buffer (read-only) | ||||||
| 	size_t	capacity;		// total allocated memory (read-only) | 	size_t	capacity;		// total allocated memory (read-only) | ||||||
| 	size_t	size_inc;		// used to increase size; MUST be > 0; (read/write) | 	size_t	size_inc;		// used to increase size; MUST be > 0; (read/write) | ||||||
| @@ -148,8 +147,7 @@ int memptr_cmp_nocase( IN memptr* m, IN const char* s ); | |||||||
| * | * | ||||||
| *	Note : | *	Note : | ||||||
| ************************************************************************/ | ************************************************************************/ | ||||||
| int membuffer_set_size( INOUT membuffer* m,  | int membuffer_set_size( INOUT membuffer* m, IN size_t new_length ); | ||||||
| 			IN size_t new_length ); |  | ||||||
|  |  | ||||||
| /************************************************************************ | /************************************************************************ | ||||||
| *	Function :	membuffer_init | *	Function :	membuffer_init | ||||||
| @@ -200,8 +198,7 @@ void membuffer_destroy( INOUT membuffer* m ); | |||||||
| * | * | ||||||
| *	Note : | *	Note : | ||||||
| ************************************************************************/ | ************************************************************************/ | ||||||
| int membuffer_assign( INOUT membuffer* m, IN const void* buf,  | int membuffer_assign( INOUT membuffer* m, IN const void* buf, IN size_t buf_len ); | ||||||
| 					 IN size_t buf_len ); |  | ||||||
|  |  | ||||||
| /************************************************************************ | /************************************************************************ | ||||||
| *	Function :	membuffer_assign_str | *	Function :	membuffer_assign_str | ||||||
| @@ -237,8 +234,7 @@ int membuffer_assign_str( INOUT membuffer* m, IN const char* c_str ); | |||||||
| * | * | ||||||
| *	Note : | *	Note : | ||||||
| ************************************************************************/ | ************************************************************************/ | ||||||
| int membuffer_append( INOUT membuffer* m, IN const void* buf, | int membuffer_append( INOUT membuffer* m, IN const void* buf, IN size_t buf_len ); | ||||||
| 					 IN size_t buf_len ); |  | ||||||
|  |  | ||||||
| /************************************************************************ | /************************************************************************ | ||||||
| *	Function :	membuffer_append_str | *	Function :	membuffer_append_str | ||||||
| @@ -276,8 +272,7 @@ int membuffer_append_str( INOUT membuffer* m, IN const char* c_str ); | |||||||
| * | * | ||||||
| *	Note : | *	Note : | ||||||
| ************************************************************************/ | ************************************************************************/ | ||||||
| int membuffer_insert( INOUT membuffer* m, IN const void* buf,  | int membuffer_insert( INOUT membuffer* m, IN const void* buf, IN size_t buf_len, int index ); | ||||||
| 					 IN size_t buf_len, int index ); |  | ||||||
|  |  | ||||||
|  |  | ||||||
| /************************************************************************ | /************************************************************************ | ||||||
| @@ -298,8 +293,7 @@ int membuffer_insert( INOUT membuffer* m, IN const void* buf, | |||||||
| * | * | ||||||
| *	Note : | *	Note : | ||||||
| ************************************************************************/ | ************************************************************************/ | ||||||
| void membuffer_delete( INOUT membuffer* m, IN int index,  | void membuffer_delete( INOUT membuffer* m, IN int index, IN size_t num_bytes ); | ||||||
| 					 IN size_t num_bytes ); |  | ||||||
|  |  | ||||||
|  |  | ||||||
| /************************************************************************ | /************************************************************************ | ||||||
| @@ -336,8 +330,7 @@ char* membuffer_detach( INOUT membuffer* m ); | |||||||
| *	Note : 'new_buf' must be allocted using malloc or realloc so | *	Note : 'new_buf' must be allocted using malloc or realloc so | ||||||
| *		that it can be freed using free() | *		that it can be freed using free() | ||||||
| ************************************************************************/ | ************************************************************************/ | ||||||
| void membuffer_attach( INOUT membuffer* m, IN char* new_buf, | void membuffer_attach( INOUT membuffer* m, IN char* new_buf, IN size_t buf_len ); | ||||||
| 					   IN size_t buf_len ); |  | ||||||
| #ifdef __cplusplus | #ifdef __cplusplus | ||||||
| }		// extern "C" | }		// extern "C" | ||||||
| #endif	// __cplusplus | #endif	// __cplusplus | ||||||
|   | |||||||
| @@ -88,7 +88,11 @@ void SetHTTPGetCallback( MiniServerCallback callback ); | |||||||
| * | * | ||||||
| *	Note : | *	Note : | ||||||
| ************************************************************************/ | ************************************************************************/ | ||||||
|  | #ifdef INCLUDE_DEVICE_APIS | ||||||
| void SetSoapCallback( MiniServerCallback callback ); | void SetSoapCallback( MiniServerCallback callback ); | ||||||
|  | #else  | ||||||
|  | static inline void SetSoapCallback( MiniServerCallback callback ) {} | ||||||
|  | #endif | ||||||
|  |  | ||||||
| /************************************************************************ | /************************************************************************ | ||||||
| *	Function :	SetGenaCallback | *	Function :	SetGenaCallback | ||||||
|   | |||||||
| @@ -47,7 +47,7 @@ extern "C" { | |||||||
|  |  | ||||||
| #define SID_SIZE  41 | #define SID_SIZE  41 | ||||||
|  |  | ||||||
| DEVICEONLY( | #ifdef INCLUDE_DEVICE_APIS | ||||||
|  |  | ||||||
| typedef struct SUBSCRIPTION { | typedef struct SUBSCRIPTION { | ||||||
|   Upnp_SID sid; |   Upnp_SID sid; | ||||||
| @@ -73,6 +73,7 @@ typedef struct SERVICE_INFO { | |||||||
|   struct SERVICE_INFO	 *next; |   struct SERVICE_INFO	 *next; | ||||||
| } service_info; | } service_info; | ||||||
|  |  | ||||||
|  |  | ||||||
| typedef struct SERVICE_TABLE { | typedef struct SERVICE_TABLE { | ||||||
|   DOMString URLBase; |   DOMString URLBase; | ||||||
|   service_info *serviceList; |   service_info *serviceList; | ||||||
| @@ -253,7 +254,7 @@ service_info * FindServiceControlURLPath( service_table *table, | |||||||
| * | * | ||||||
| *	Parameters : | *	Parameters : | ||||||
| *		service_info *service ;Service whose information is to be printed | *		service_info *service ;Service whose information is to be printed | ||||||
| *		Dbg_Level level ; Debug level specified to the print function | *		Upnp_LogLevel level ; Debug level specified to the print function | ||||||
| *		Dbg_Module module ;	Debug module specified to the print function | *		Dbg_Module module ;	Debug module specified to the print function | ||||||
| * | * | ||||||
| *	Description :	For debugging purposes prints information from the  | *	Description :	For debugging purposes prints information from the  | ||||||
| @@ -263,16 +264,24 @@ service_info * FindServiceControlURLPath( service_table *table, | |||||||
| * | * | ||||||
| *	Note : | *	Note : | ||||||
| ************************************************************************/ | ************************************************************************/ | ||||||
| DBGONLY(void printService(service_info *service,Dbg_Level | #ifdef DEBUG | ||||||
| 				   level, | void printService( | ||||||
| 				   Dbg_Module module)); | 	service_info *service, | ||||||
|  | 	Upnp_LogLevel level, | ||||||
|  | 	Dbg_Module module); | ||||||
|  | #else | ||||||
|  | static UPNP_INLINE void printService( | ||||||
|  | 	service_info *service, | ||||||
|  | 	Upnp_LogLevel level, | ||||||
|  | 	Dbg_Module module) {} | ||||||
|  | #endif | ||||||
|  |  | ||||||
| /************************************************************************ | /************************************************************************ | ||||||
| *	Function :	printServiceList | *	Function :	printServiceList | ||||||
| * | * | ||||||
| *	Parameters : | *	Parameters : | ||||||
| *		service_info *service ;	Service whose information is to be printed | *		service_info *service ;	Service whose information is to be printed | ||||||
| *		Dbg_Level level ;	Debug level specified to the print function | *		Upnp_LogLevel level ;	Debug level specified to the print function | ||||||
| *		Dbg_Module module ;	Debug module specified to the print function | *		Dbg_Module module ;	Debug module specified to the print function | ||||||
| * | * | ||||||
| *	Description :	For debugging purposes prints information of each  | *	Description :	For debugging purposes prints information of each  | ||||||
| @@ -282,15 +291,24 @@ DBGONLY(void printService(service_info *service,Dbg_Level | |||||||
| * | * | ||||||
| *	Note : | *	Note : | ||||||
| ************************************************************************/ | ************************************************************************/ | ||||||
| DBGONLY(void printServiceList(service_info *service, | #ifdef DEBUG | ||||||
| 				       Dbg_Level level, Dbg_Module module)); | void printServiceList( | ||||||
|  | 	service_info *service, | ||||||
|  | 	Upnp_LogLevel level, | ||||||
|  | 	Dbg_Module module); | ||||||
|  | #else | ||||||
|  | static UPNP_INLINE void printServiceList( | ||||||
|  | 	service_info *service, | ||||||
|  | 	Upnp_LogLevel level, | ||||||
|  | 	Dbg_Module module) {} | ||||||
|  | #endif | ||||||
|  |  | ||||||
| /************************************************************************ | /************************************************************************ | ||||||
| *	Function :	printServiceTable | *	Function :	printServiceTable | ||||||
| * | * | ||||||
| *	Parameters : | *	Parameters : | ||||||
| *		service_table * table ;	Service table to be printed | *		service_table * table ;	Service table to be printed | ||||||
| *		Dbg_Level level ;	Debug level specified to the print function | *		Upnp_LogLevel level ;	Debug level specified to the print function | ||||||
| *		Dbg_Module module ;	Debug module specified to the print function | *		Dbg_Module module ;	Debug module specified to the print function | ||||||
| * | * | ||||||
| *	Description :	For debugging purposes prints the URL base of the table | *	Description :	For debugging purposes prints the URL base of the table | ||||||
| @@ -301,9 +319,17 @@ DBGONLY(void printServiceList(service_info *service, | |||||||
| * | * | ||||||
| *	Note : | *	Note : | ||||||
| ************************************************************************/ | ************************************************************************/ | ||||||
| DBGONLY(void printServiceTable(service_table * | #ifdef DEBUG | ||||||
| 					table,Dbg_Level | void printServiceTable( | ||||||
| 					level,Dbg_Module module)); | 	service_table *table, | ||||||
|  | 	Upnp_LogLevel level, | ||||||
|  | 	Dbg_Module module); | ||||||
|  | #else | ||||||
|  | static UPNP_INLINE void printServiceTable( | ||||||
|  | 	service_table *table, | ||||||
|  | 	Upnp_LogLevel level, | ||||||
|  | 	Dbg_Module module) {} | ||||||
|  | #endif | ||||||
|  |  | ||||||
| /************************************************************************ | /************************************************************************ | ||||||
| *	Function :	freeService | *	Function :	freeService | ||||||
| @@ -451,10 +477,11 @@ int getSubElement(const char *element_name, IXML_Node *node, | |||||||
| 		  IXML_Node **out); | 		  IXML_Node **out); | ||||||
|  |  | ||||||
|  |  | ||||||
| )	/* DEVICEONLY */ | #endif /* INCLUDE_DEVICE_APIS */ | ||||||
|  |  | ||||||
| #ifdef __cplusplus | #ifdef __cplusplus | ||||||
| } | } | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
| #endif /* _SERVICE_TABLE */ | #endif /* _SERVICE_TABLE */ | ||||||
|  |  | ||||||
|   | |||||||
| @@ -33,7 +33,7 @@ | |||||||
| #define SOAPLIB_H  | #define SOAPLIB_H  | ||||||
|  |  | ||||||
|  |  | ||||||
| //SOAP module API to be called in Upnp-Dk API | // SOAP module API to be called in Upnp-Dk API | ||||||
| /**************************************************************************** | /**************************************************************************** | ||||||
| * Function :	soap_device_callback | * Function :	soap_device_callback | ||||||
| * | * | ||||||
|   | |||||||
| @@ -211,8 +211,15 @@ int Make_Socket_NoBlocking (int sock); | |||||||
| * Returns: void * | * Returns: void * | ||||||
| *	1 if successful else appropriate error | *	1 if successful else appropriate error | ||||||
| ***************************************************************************/ | ***************************************************************************/ | ||||||
| void ssdp_handle_device_request( IN http_message_t* hmsg,  | #ifdef INCLUDE_DEVICE_APIS | ||||||
|  | void ssdp_handle_device_request( | ||||||
|  | 	IN http_message_t* hmsg,  | ||||||
| 	IN struct sockaddr_in* dest_addr ); | 	IN struct sockaddr_in* dest_addr ); | ||||||
|  | #else | ||||||
|  | static inline void ssdp_handle_device_request( | ||||||
|  | 	IN http_message_t* hmsg,  | ||||||
|  | 	IN struct sockaddr_in* dest_addr ) {} | ||||||
|  | #endif | ||||||
|  |  | ||||||
| /************************************************************************ | /************************************************************************ | ||||||
| * Function : ssdp_handle_ctrlpt_msg | * Function : ssdp_handle_ctrlpt_msg | ||||||
| @@ -234,7 +241,8 @@ void ssdp_handle_device_request( IN http_message_t* hmsg, | |||||||
| * Returns: void | * Returns: void | ||||||
| * | * | ||||||
| ***************************************************************************/ | ***************************************************************************/ | ||||||
| void ssdp_handle_ctrlpt_msg( IN http_message_t* hmsg,  | void ssdp_handle_ctrlpt_msg( | ||||||
|  | 	IN http_message_t* hmsg,  | ||||||
| 	IN struct sockaddr_in* dest_addr, | 	IN struct sockaddr_in* dest_addr, | ||||||
| 	IN xboolean timeout, | 	IN xboolean timeout, | ||||||
| 	IN void* cookie ); | 	IN void* cookie ); | ||||||
| @@ -326,12 +334,10 @@ int ssdp_request_type(IN char * cmd, OUT SsdpEvent * Evt); | |||||||
| * Function : SearchByTarget | * Function : SearchByTarget | ||||||
| * | * | ||||||
| * Parameters: | * Parameters: | ||||||
| *		IN int Mx:Number of seconds to wait, to collect all the  | *	IN int Mx:Number of seconds to wait, to collect all the	responses. | ||||||
| *					responses. |  | ||||||
| *	char *St: Search target. | *	char *St: Search target. | ||||||
| *	void *Cookie: cookie provided by control point application. This | *	void *Cookie: cookie provided by control point application. This | ||||||
| *						cokie will be returned to application in the  | *		cokie will be returned to application in the callback. | ||||||
| *						callback. |  | ||||||
| * | * | ||||||
| * Description: | * Description: | ||||||
| *	This function creates and send the search request for a specific URL. | *	This function creates and send the search request for a specific URL. | ||||||
| @@ -345,12 +351,11 @@ int SearchByTarget(IN int Mx, IN char *St, IN void *Cookie); | |||||||
| * Function : DeviceAdvertisement | * Function : DeviceAdvertisement | ||||||
| * | * | ||||||
| * Parameters: | * Parameters: | ||||||
| *	IN char * DevType : type of the device | *	IN char *DevType : type of the device | ||||||
| *	IN int RootDev: flag to indicate if the device is root device | *	IN int RootDev   : flag to indicate if the device is root device | ||||||
| *	IN char * nt : value of NT | *	IN char *Udn     : | ||||||
| *	IN char * usn : | *	IN char *Location: Location URL. | ||||||
| *	IN char * location :Location URL. | *	IN int Duration  : Service duration in sec. | ||||||
| *	IN int  duration :Service duration in sec. |  | ||||||
| * | * | ||||||
| * Description: | * Description: | ||||||
| *	This function creates the device advertisement request based on | *	This function creates the device advertisement request based on | ||||||
| @@ -359,8 +364,12 @@ int SearchByTarget(IN int Mx, IN char *St, IN void *Cookie); | |||||||
| * Returns: int | * Returns: int | ||||||
| *	UPNP_E_SUCCESS if successful else appropriate error | *	UPNP_E_SUCCESS if successful else appropriate error | ||||||
| ***************************************************************************/ | ***************************************************************************/ | ||||||
| int DeviceAdvertisement(IN char * DevType, int RootDev,char * Udn,  | int DeviceAdvertisement( | ||||||
| 						IN char * Location, IN int  Duration); | 	IN char *DevType, | ||||||
|  | 	IN int RootDev, | ||||||
|  | 	IN char *Udn,  | ||||||
|  | 	IN char *Location, | ||||||
|  | 	IN int Duration); | ||||||
|  |  | ||||||
|  |  | ||||||
| /************************************************************************ | /************************************************************************ | ||||||
| @@ -369,9 +378,9 @@ int DeviceAdvertisement(IN char * DevType, int RootDev,char * Udn, | |||||||
| * Parameters:	 | * Parameters:	 | ||||||
| *	IN char *DevType: Device Type. | *	IN char *DevType: Device Type. | ||||||
| *	IN int RootDev:1 means root device. | *	IN int RootDev:1 means root device. | ||||||
| *	IN char * Udn: Device UDN | *	IN char *Udn: Device UDN | ||||||
| *	IN char *_Server: | *	IN char *_Server: | ||||||
| *	IN char * Location: Location URL | *	IN char *Location: Location URL | ||||||
| *	IN int Duration :Device duration in sec. | *	IN int Duration :Device duration in sec. | ||||||
| * | * | ||||||
| * Description: | * Description: | ||||||
| @@ -381,12 +390,13 @@ int DeviceAdvertisement(IN char * DevType, int RootDev,char * Udn, | |||||||
| * Returns: int | * Returns: int | ||||||
| *	UPNP_E_SUCCESS if successful else appropriate error | *	UPNP_E_SUCCESS if successful else appropriate error | ||||||
| ***************************************************************************/ | ***************************************************************************/ | ||||||
| int DeviceShutdown( IN char * DevType,  | int DeviceShutdown( | ||||||
|  | 	IN char *DevType,  | ||||||
| 	IN int RootDev, | 	IN int RootDev, | ||||||
| 					IN char * Udn,  | 	IN char *Udn,  | ||||||
| 					IN char * _Server,  | 	IN char *_Server,  | ||||||
| 					IN char * Location,  | 	IN char *Location,  | ||||||
| 					IN int  Duration ); | 	IN int Duration); | ||||||
|  |  | ||||||
| /************************************************************************ | /************************************************************************ | ||||||
| * Function : DeviceReply | * Function : DeviceReply | ||||||
| @@ -395,10 +405,10 @@ int DeviceShutdown( IN char * DevType, | |||||||
| *	IN struct sockaddr_in * DestAddr:destination IP address. | *	IN struct sockaddr_in * DestAddr:destination IP address. | ||||||
| *	IN char *DevType: Device type | *	IN char *DevType: Device type | ||||||
| *	IN int RootDev: 1 means root device 0 means embedded device. | *	IN int RootDev: 1 means root device 0 means embedded device. | ||||||
| *	IN char * Udn: Device UDN | *	IN char *Udn: Device UDN | ||||||
| *	IN char * Location: Location of Device description document. | *	IN char *Location: Location of Device description document. | ||||||
| *	IN int Duration :Life time of this device. | *	IN int Duration :Life time of this device. | ||||||
|  | * | ||||||
| * Description: | * Description: | ||||||
| *	This function creates the reply packet based on the input parameter,  | *	This function creates the reply packet based on the input parameter,  | ||||||
| *	and send it to the client address given in its input parameter DestAddr. | *	and send it to the client address given in its input parameter DestAddr. | ||||||
| @@ -406,11 +416,12 @@ int DeviceShutdown( IN char * DevType, | |||||||
| * Returns: int | * Returns: int | ||||||
| *	UPNP_E_SUCCESS if successful else appropriate error | *	UPNP_E_SUCCESS if successful else appropriate error | ||||||
| ***************************************************************************/ | ***************************************************************************/ | ||||||
| int DeviceReply(IN struct sockaddr_in * DestAddr,  | int DeviceReply( | ||||||
|  | 	IN struct sockaddr_in * DestAddr,  | ||||||
| 	IN char *DevType,  | 	IN char *DevType,  | ||||||
| 	IN int RootDev,  | 	IN int RootDev,  | ||||||
| 				IN char * Udn,  | 	IN char *Udn,  | ||||||
| 				IN char * Location, IN int  Duration); | 	IN char *Location, IN int  Duration); | ||||||
|  |  | ||||||
| /************************************************************************ | /************************************************************************ | ||||||
| * Function : SendReply | * Function : SendReply | ||||||
| @@ -421,7 +432,7 @@ int DeviceReply(IN struct sockaddr_in * DestAddr, | |||||||
| *	IN int RootDev: 1 means root device 0 means embedded device. | *	IN int RootDev: 1 means root device 0 means embedded device. | ||||||
| *	IN char * Udn: Device UDN | *	IN char * Udn: Device UDN | ||||||
| *	IN char *_Server: | *	IN char *_Server: | ||||||
| *	IN char * Location: Location of Device description document. | *	IN char *Location: Location of Device description document. | ||||||
| *	IN int Duration :Life time of this device. | *	IN int Duration :Life time of this device. | ||||||
| *	IN int ByType: | *	IN int ByType: | ||||||
| * | * | ||||||
| @@ -432,11 +443,12 @@ int DeviceReply(IN struct sockaddr_in * DestAddr, | |||||||
| * Returns: int | * Returns: int | ||||||
| *	UPNP_E_SUCCESS if successful else appropriate error | *	UPNP_E_SUCCESS if successful else appropriate error | ||||||
| ***************************************************************************/ | ***************************************************************************/ | ||||||
| int SendReply(IN struct sockaddr_in * DestAddr,  | int SendReply( | ||||||
|  | 	IN struct sockaddr_in * DestAddr,  | ||||||
| 	IN char *DevType,  | 	IN char *DevType,  | ||||||
| 	IN int RootDev,  | 	IN int RootDev,  | ||||||
| 			  IN char * Udn,  | 	IN char *Udn,  | ||||||
| 			  IN char * Location,  | 	IN char *Location,  | ||||||
| 	IN int Duration,  | 	IN int Duration,  | ||||||
| 	IN int ByType ); | 	IN int ByType ); | ||||||
|  |  | ||||||
| @@ -448,18 +460,18 @@ int SendReply(IN struct sockaddr_in * DestAddr, | |||||||
| *	IN char *ServType: Service Type. | *	IN char *ServType: Service Type. | ||||||
| *	IN char * Location: Location of Device description document. | *	IN char * Location: Location of Device description document. | ||||||
| *	IN int Duration :Life time of this device. | *	IN int Duration :Life time of this device. | ||||||
|  | * | ||||||
| * Description: | * Description: | ||||||
| *	This function creates the advertisement packet based  | *	This function creates the advertisement packet based  | ||||||
| *	on the input parameter, and send it to the multicast channel. | *	on the input parameter, and send it to the multicast channel. | ||||||
|  |  | ||||||
| * | * | ||||||
| * Returns: int | * Returns: int | ||||||
| *	UPNP_E_SUCCESS if successful else appropriate error | *	UPNP_E_SUCCESS if successful else appropriate error | ||||||
| ***************************************************************************/ | ***************************************************************************/ | ||||||
| int ServiceAdvertisement( IN char * Udn,  | int ServiceAdvertisement( | ||||||
| 						 IN char * ServType, | 	IN char *Udn,  | ||||||
| 						 IN char * Location, | 	IN char *ServType, | ||||||
|  | 	IN char *Location, | ||||||
| 	IN int Duration); | 	IN int Duration); | ||||||
|  |  | ||||||
| /************************************************************************ | /************************************************************************ | ||||||
| @@ -467,35 +479,35 @@ int ServiceAdvertisement( IN char * Udn, | |||||||
| * | * | ||||||
| * Parameters:	 | * Parameters:	 | ||||||
| *	IN struct sockaddr_in *DestAddr: | *	IN struct sockaddr_in *DestAddr: | ||||||
| *	IN char * Udn: Device UDN | *	IN char *Udn: Device UDN | ||||||
| *	IN char *ServType: Service Type. | *	IN char *ServType: Service Type. | ||||||
| *	IN char *Server: Not used | *	IN char *Server: Not used | ||||||
| *	IN char * Location: Location of Device description document. | *	IN char *Location: Location of Device description document. | ||||||
| *	IN int Duration :Life time of this device. | *	IN int Duration :Life time of this device. | ||||||
|  | * | ||||||
| * Description: | * Description: | ||||||
| *	This function creates the advertisement packet based  | *	This function creates the advertisement packet based  | ||||||
| *	on the input parameter, and send it to the multicast channel. | *	on the input parameter, and send it to the multicast channel. | ||||||
|  |  | ||||||
| * | * | ||||||
| * Returns: int | * Returns: int | ||||||
| *	UPNP_E_SUCCESS if successful else appropriate error | *	UPNP_E_SUCCESS if successful else appropriate error | ||||||
| ***************************************************************************/ | ***************************************************************************/ | ||||||
| int ServiceReply(IN struct sockaddr_in *DestAddr,   | int ServiceReply( | ||||||
| 				 IN char * ServType,  | 	IN struct sockaddr_in *DestAddr,   | ||||||
| 				 IN char * Udn,  | 	IN char *ServType,  | ||||||
| 				 IN char * Location, | 	IN char *Udn,  | ||||||
|  | 	IN char *Location, | ||||||
| 	IN int Duration); | 	IN int Duration); | ||||||
|  |  | ||||||
| /************************************************************************ | /************************************************************************ | ||||||
| * Function : ServiceShutdown | * Function : ServiceShutdown | ||||||
| * | * | ||||||
| * Parameters: | * Parameters: | ||||||
| *	IN char * Udn: Device UDN | *	IN char *Udn: Device UDN | ||||||
| *	IN char *ServType: Service Type. | *	IN char *ServType: Service Type. | ||||||
| *	IN char * Location: Location of Device description document. | *	IN char *Location: Location of Device description document. | ||||||
| *	IN int Duration :Service duration in sec. | *	IN int Duration :Service duration in sec. | ||||||
|  | * | ||||||
| * Description: | * Description: | ||||||
| *	This function creates a HTTP service shutdown request packet  | *	This function creates a HTTP service shutdown request packet  | ||||||
| *	and sent it to the multicast channel through RequestHandler. | *	and sent it to the multicast channel through RequestHandler. | ||||||
| @@ -503,8 +515,10 @@ int ServiceReply(IN struct sockaddr_in *DestAddr, | |||||||
| * Returns: int | * Returns: int | ||||||
| *	UPNP_E_SUCCESS if successful else appropriate error | *	UPNP_E_SUCCESS if successful else appropriate error | ||||||
| ***************************************************************************/ | ***************************************************************************/ | ||||||
| int ServiceShutdown( IN char * Udn, IN char * ServType, | int ServiceShutdown( | ||||||
| 					IN char * Location, | 	IN char *Udn, | ||||||
|  | 	IN char *ServType, | ||||||
|  | 	IN char *Location, | ||||||
| 	IN int Duration); | 	IN int Duration); | ||||||
|  |  | ||||||
|  |  | ||||||
| @@ -521,13 +535,14 @@ int ServiceShutdown( IN char * Udn, IN char * ServType, | |||||||
| * Returns: void * | * Returns: void * | ||||||
| *	always return NULL | *	always return NULL | ||||||
| ***************************************************************************/ | ***************************************************************************/ | ||||||
| void * advertiseAndReplyThread(IN void * data); | void *advertiseAndReplyThread(IN void * data); | ||||||
|  |  | ||||||
| /************************************************************************ | /************************************************************************ | ||||||
| * Function : AdvertiseAndReply | * Function : AdvertiseAndReply | ||||||
| * | * | ||||||
| * Parameters: | * Parameters: | ||||||
| *	IN int AdFlag: -1 = Send shutdown, 0 = send reply,  | *	IN int AdFlag: -1 = Send shutdown, | ||||||
|  | *			0 = send reply,  | ||||||
| *			1 = Send Advertisement | *			1 = Send Advertisement | ||||||
| *	IN UpnpDevice_Handle Hnd: Device handle | *	IN UpnpDevice_Handle Hnd: Device handle | ||||||
| *	IN enum SsdpSearchType SearchType:Search type for sending replies | *	IN enum SsdpSearchType SearchType:Search type for sending replies | ||||||
| @@ -543,7 +558,8 @@ void * advertiseAndReplyThread(IN void * data); | |||||||
| * Returns: int | * Returns: int | ||||||
| *	UPNP_E_SUCCESS if successful else appropriate error | *	UPNP_E_SUCCESS if successful else appropriate error | ||||||
| ***************************************************************************/ | ***************************************************************************/ | ||||||
| int AdvertiseAndReply(IN int AdFlag,  | int AdvertiseAndReply( | ||||||
|  | 	IN int AdFlag,  | ||||||
| 	IN UpnpDevice_Handle Hnd,  | 	IN UpnpDevice_Handle Hnd,  | ||||||
| 	IN enum SsdpSearchType SearchType,  | 	IN enum SsdpSearchType SearchType,  | ||||||
| 	IN struct sockaddr_in *DestAddr, | 	IN struct sockaddr_in *DestAddr, | ||||||
|   | |||||||
| @@ -38,10 +38,9 @@ | |||||||
| #ifndef WIN32 | #ifndef WIN32 | ||||||
| 	#include <sys/socket.h> | 	#include <sys/socket.h> | ||||||
| #else | #else | ||||||
|  #define XINLINE |  | ||||||
|  |  | ||||||
| 	typedef int socklen_t; | 	typedef int socklen_t; | ||||||
| 	#define EAFNOSUPPORT 97 | 	#define EAFNOSUPPORT 97 | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
| #endif // GENLIB_NET_UNIXUTIL_H | #endif // GENLIB_NET_UNIXUTIL_H | ||||||
|  |  | ||||||
|   | |||||||
| @@ -71,33 +71,46 @@ struct Handle_Info | |||||||
|     Upnp_FunPtr  Callback; // Callback function pointer. |     Upnp_FunPtr  Callback; // Callback function pointer. | ||||||
|     char * Cookie; |     char * Cookie; | ||||||
|  |  | ||||||
|     DEVICEONLY(char  DescURL[LINE_SIZE];)   // URL for the use of SSDP |     // Device Only | ||||||
|     DEVICEONLY(char  DescXML[LINE_SIZE];)   // XML file path for device  | #ifdef INCLUDE_DEVICE_APIS | ||||||
|  |     char  DescURL[LINE_SIZE];   // URL for the use of SSDP | ||||||
|  |     char  DescXML[LINE_SIZE];   // XML file path for device  | ||||||
|                                 //description |                                 //description | ||||||
|  |  | ||||||
|     DEVICEONLY(int MaxAge;)                 // Advertisement timeout |     int MaxAge;                 // Advertisement timeout | ||||||
|     DEVICEONLY(IXML_Document *DescDocument;)     // Description parsed in  |     IXML_Document *DescDocument;// Description parsed in  | ||||||
|                                 //terms of DOM document  |                                 //terms of DOM document  | ||||||
|     DEVICEONLY(IXML_NodeList *DeviceList;)       // List of devices in the  |     IXML_NodeList *DeviceList;  // List of devices in the  | ||||||
|                                 //description document |                                 //description document | ||||||
|     DEVICEONLY(IXML_NodeList *ServiceList;)      // List of services in the  |     IXML_NodeList *ServiceList; // List of services in the  | ||||||
|                                 // description document |                                 // description document | ||||||
|     DEVICEONLY(service_table ServiceTable;) //table holding subscriptions and  |     service_table ServiceTable; //table holding subscriptions and  | ||||||
|                                 //URL information |                                 //URL information | ||||||
|     DEVICEONLY(int MaxSubscriptions;) |     int MaxSubscriptions; | ||||||
|     DEVICEONLY(int MaxSubscriptionTimeOut;) |     int MaxSubscriptionTimeOut; | ||||||
|  | #endif | ||||||
|       |       | ||||||
|        //Client only |     // Client only | ||||||
|     CLIENTONLY(client_subscription * ClientSubList;) //client subscription list | #ifdef INCLUDE_CLIENT_APIS | ||||||
|     CLIENTONLY(LinkedList SsdpSearchList;) // active ssdp searches    |     client_subscription *ClientSubList; //client subscription list | ||||||
|  |     LinkedList SsdpSearchList; // active ssdp searches    | ||||||
|  | #endif | ||||||
|     int   aliasInstalled;       // 0 = not installed; otherwise installed |     int   aliasInstalled;       // 0 = not installed; otherwise installed | ||||||
| } ; | }; | ||||||
|  |  | ||||||
| extern ithread_mutex_t GlobalHndMutex; | extern ithread_mutex_t GlobalHndMutex; | ||||||
| Upnp_Handle_Type GetHandleInfo(int Hnd, struct Handle_Info **HndInfo);  | Upnp_Handle_Type GetHandleInfo(int Hnd, struct Handle_Info **HndInfo);  | ||||||
|  |  | ||||||
| #define HandleLock()  DBGONLY(UpnpPrintf(UPNP_INFO,API,__FILE__,__LINE__,"Trying Lock")); ithread_mutex_lock(&GlobalHndMutex); DBGONLY(UpnpPrintf(UPNP_INFO,API,__FILE__,__LINE__,"LOCK")); | #define HandleLock()  \ | ||||||
| #define HandleUnlock() DBGONLY(UpnpPrintf(UPNP_INFO,API,__FILE__,__LINE__,"Trying Unlock")); ithread_mutex_unlock(&GlobalHndMutex); DBGONLY(UpnpPrintf(UPNP_INFO,API,__FILE__,__LINE__,"Unlock")); | 	UpnpPrintf(UPNP_INFO, API, __FILE__, __LINE__, "Trying Lock"); \ | ||||||
|  | 	ithread_mutex_lock(&GlobalHndMutex); \ | ||||||
|  | 	UpnpPrintf(UPNP_INFO, API, __FILE__, __LINE__, "LOCK"); | ||||||
|  |  | ||||||
|  | #define HandleUnlock() \ | ||||||
|  | 	UpnpPrintf(UPNP_INFO, API,__FILE__, __LINE__, "Trying Unlock"); \ | ||||||
|  | 	ithread_mutex_unlock(&GlobalHndMutex); \ | ||||||
|  | 	UpnpPrintf(UPNP_INFO, API, __FILE__, __LINE__, "Unlock"); | ||||||
|  |  | ||||||
| Upnp_Handle_Type GetClientHandleInfo(int *client_handle_out,  | Upnp_Handle_Type GetClientHandleInfo(int *client_handle_out,  | ||||||
|                                      struct Handle_Info **HndInfo); |                                      struct Handle_Info **HndInfo); | ||||||
| Upnp_Handle_Type GetDeviceHandleInfo(int *device_handle_out,  | Upnp_Handle_Type GetDeviceHandleInfo(int *device_handle_out,  | ||||||
| @@ -111,7 +124,7 @@ extern unsigned short LOCAL_PORT; | |||||||
| extern TimerThread gTimerThread; | extern TimerThread gTimerThread; | ||||||
| extern ThreadPool gRecvThreadPool; | extern ThreadPool gRecvThreadPool; | ||||||
| extern ThreadPool gSendThreadPool; | extern ThreadPool gSendThreadPool; | ||||||
|  | extern ThreadPool gMiniServerThreadPool; | ||||||
|  |  | ||||||
| typedef enum { | typedef enum { | ||||||
|     SUBSCRIBE, |     SUBSCRIBE, | ||||||
|   | |||||||
| @@ -87,7 +87,7 @@ enum uriType  { absolute, relative }; | |||||||
| *	holds a pointer into a larger array									*/ | *	holds a pointer into a larger array									*/ | ||||||
| typedef struct TOKEN { | typedef struct TOKEN { | ||||||
|   const char *buff; |   const char *buff; | ||||||
|   int size; |   size_t size; | ||||||
| } token; | } token; | ||||||
|  |  | ||||||
|  |  | ||||||
| @@ -124,7 +124,7 @@ typedef struct URL_LIST { | |||||||
| *	Parameters : | *	Parameters : | ||||||
| *		char * in ;	string of characters | *		char * in ;	string of characters | ||||||
| *		int index ;	index at which to start checking the characters | *		int index ;	index at which to start checking the characters | ||||||
| *		int *max ;	 | *		size_t *max ;	 | ||||||
| * | * | ||||||
| *	Description : Replaces an escaped sequence with its unescaped version  | *	Description : Replaces an escaped sequence with its unescaped version  | ||||||
| *		as in http://www.ietf.org/rfc/rfc2396.txt  (RFC explaining URIs) | *		as in http://www.ietf.org/rfc/rfc2396.txt  (RFC explaining URIs) | ||||||
| @@ -137,7 +137,7 @@ typedef struct URL_LIST { | |||||||
| *		string are shifted over, and NULL characters are placed at the  | *		string are shifted over, and NULL characters are placed at the  | ||||||
| *		end of the string. | *		end of the string. | ||||||
| ************************************************************************/ | ************************************************************************/ | ||||||
| int replace_escaped(char * in, int index, int *max); | int replace_escaped(char * in, int index, size_t *max); | ||||||
|  |  | ||||||
| /************************************************************************ | /************************************************************************ | ||||||
| *	Function :	copy_URL_list | *	Function :	copy_URL_list | ||||||
| @@ -182,13 +182,16 @@ void free_URL_list(URL_list * list); | |||||||
| *		uri_type *in ;	URI object | *		uri_type *in ;	URI object | ||||||
| * | * | ||||||
| *	Description : Function useful in debugging for printing a parsed uri. | *	Description : Function useful in debugging for printing a parsed uri. | ||||||
| *		Compiled out with DBGONLY macro.  |  | ||||||
| * | * | ||||||
| *	Return : void ; | *	Return : void ; | ||||||
| * | * | ||||||
| *	Note : | *	Note : | ||||||
| ************************************************************************/ | ************************************************************************/ | ||||||
| DBGONLY(void print_uri( uri_type *in);) | #ifdef DEBUG | ||||||
|  | void print_uri(uri_type *in); | ||||||
|  | #else | ||||||
|  | static UPNP_INLINE void print_uri(uri_type *in) {} | ||||||
|  | #endif | ||||||
|  |  | ||||||
| /************************************************************************ | /************************************************************************ | ||||||
| *	Function :	print_token | *	Function :	print_token | ||||||
| @@ -197,13 +200,16 @@ DBGONLY(void print_uri( uri_type *in);) | |||||||
| *		token * in ;	 | *		token * in ;	 | ||||||
| * | * | ||||||
| *	Description : Function useful in debugging for printing a token. | *	Description : Function useful in debugging for printing a token. | ||||||
| *		Compiled out with DBGONLY macro.  |  | ||||||
| * | * | ||||||
| *	Return : void ; | *	Return : void ; | ||||||
| * | * | ||||||
| *	Note : | *	Note : | ||||||
| ************************************************************************/ | ************************************************************************/ | ||||||
| void print_token(  token * in); | #ifdef DEBUG | ||||||
|  | void print_token(token *in); | ||||||
|  | #else | ||||||
|  | static UPNP_INLINE void print_token(token * in) {} | ||||||
|  | #endif | ||||||
|  |  | ||||||
| /************************************************************************ | /************************************************************************ | ||||||
| *	Function :	token_string_casecmp | *	Function :	token_string_casecmp | ||||||
| @@ -303,7 +309,7 @@ int parse_hostport(const char *in, int max, hostport_type *out ); | |||||||
| * | * | ||||||
| *	Parameters : | *	Parameters : | ||||||
| *		INOUT char *in ;	string of characters to be modified | *		INOUT char *in ;	string of characters to be modified | ||||||
| *		INOUT int *size ;	size limit for the number of characters | *		INOUT size_t *size ;	size limit for the number of characters | ||||||
| * | * | ||||||
| *	Description : removes http escaped characters such as: "%20" and  | *	Description : removes http escaped characters such as: "%20" and  | ||||||
| *		replaces them with their character representation. i.e.  | *		replaces them with their character representation. i.e.  | ||||||
| @@ -315,7 +321,7 @@ int parse_hostport(const char *in, int max, hostport_type *out ); | |||||||
| * | * | ||||||
| *	Note : | *	Note : | ||||||
| ************************************************************************/ | ************************************************************************/ | ||||||
| int remove_escaped_chars(char *in,int *size); | int remove_escaped_chars(char *in, size_t *size); | ||||||
|  |  | ||||||
| /************************************************************************ | /************************************************************************ | ||||||
| *	Function :	remove_dots | *	Function :	remove_dots | ||||||
|   | |||||||
| @@ -47,12 +47,6 @@ | |||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  |  | ||||||
| #ifdef NO_DEBUG |  | ||||||
| #define DBG(x) |  | ||||||
| #else |  | ||||||
| #define DBG(x) x |  | ||||||
| #endif |  | ||||||
|  |  | ||||||
| #define GEMD_OUT_OF_MEMORY -1 | #define GEMD_OUT_OF_MEMORY -1 | ||||||
| #define EVENT_TIMEDOUT -2 | #define EVENT_TIMEDOUT -2 | ||||||
| #define EVENT_TERMINATE	-3 | #define EVENT_TERMINATE	-3 | ||||||
| @@ -142,14 +136,10 @@ void linecopylen( OUT char dest[LINE_SIZE], IN const char* src, IN size_t srclen | |||||||
| #endif | #endif | ||||||
|  |  | ||||||
| ////////////////////////////////// | ////////////////////////////////// | ||||||
|  |  | ||||||
| // C specific | // C specific | ||||||
| #ifndef __cplusplus | #ifndef __cplusplus | ||||||
|  |  | ||||||
| #ifndef WIN32 | #ifdef WIN32 | ||||||
|  #define		XINLINE inline |  | ||||||
| #else |  | ||||||
|  |  | ||||||
| 	#ifndef S_ISREG | 	#ifndef S_ISREG | ||||||
| 		#define S_ISREG(m) (((m) & S_IFMT) == S_IFREG) | 		#define S_ISREG(m) (((m) & S_IFMT) == S_IFREG) | ||||||
| 	#endif | 	#endif | ||||||
| @@ -163,10 +153,11 @@ void linecopylen( OUT char dest[LINE_SIZE], IN const char* src, IN size_t srclen | |||||||
| 	#define strcasecmp stricmp | 	#define strcasecmp stricmp | ||||||
| 	#define strncasecmp strnicmp | 	#define strncasecmp strnicmp | ||||||
|  |  | ||||||
|  #define sleep Sleep | 	#define sleep(a) Sleep((a)*1000) | ||||||
| 	#define usleep(a) Sleep((a)/1000) | 	#define usleep(a) Sleep((a)/1000) | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
| #endif // __cplusplus | #endif // __cplusplus | ||||||
|  |  | ||||||
| #endif /* GENLIB_UTIL_UTIL_H */ | #endif /* GENLIB_UTIL_UTIL_H */ | ||||||
|  |  | ||||||
|   | |||||||
| @@ -244,7 +244,7 @@ get_node_value( IN IXML_Node * node ) | |||||||
| * | * | ||||||
| *	Note : | *	Note : | ||||||
| ****************************************************************************/ | ****************************************************************************/ | ||||||
| static XINLINE int | static UPNP_INLINE int | ||||||
| get_host_and_path( IN char *ctrl_url, | get_host_and_path( IN char *ctrl_url, | ||||||
|                    OUT const memptr *host, |                    OUT const memptr *host, | ||||||
|                    OUT const memptr *path, |                    OUT const memptr *path, | ||||||
| @@ -277,7 +277,7 @@ get_host_and_path( IN char *ctrl_url, | |||||||
| * | * | ||||||
| *	Note : | *	Note : | ||||||
| ****************************************************************************/ | ****************************************************************************/ | ||||||
| static XINLINE int | static UPNP_INLINE int | ||||||
| get_action_name( IN char *action, | get_action_name( IN char *action, | ||||||
|                  OUT memptr * name ) |                  OUT memptr * name ) | ||||||
| { | { | ||||||
| @@ -303,7 +303,7 @@ get_action_name( IN char *action, | |||||||
| * | * | ||||||
| *	Note : | *	Note : | ||||||
| ****************************************************************************/ | ****************************************************************************/ | ||||||
| static XINLINE int | static UPNP_INLINE int | ||||||
| add_man_header( INOUT membuffer * headers ) | add_man_header( INOUT membuffer * headers ) | ||||||
| { | { | ||||||
|     char *soap_action_hdr; |     char *soap_action_hdr; | ||||||
| @@ -611,17 +611,16 @@ SoapSendAction( IN char *action_url, | |||||||
|     char *xml_end = |     char *xml_end = | ||||||
|         "</s:Body>\r\n" |         "</s:Body>\r\n" | ||||||
|         "</s:Envelope>\r\n\r\n"; |         "</s:Envelope>\r\n\r\n"; | ||||||
|     int xml_start_len; |     size_t xml_start_len; | ||||||
|     int xml_end_len; |     size_t xml_end_len; | ||||||
|     int action_str_len; |     size_t action_str_len; | ||||||
|  |  | ||||||
|     *response_node = NULL;      // init |     *response_node = NULL;      // init | ||||||
|  |  | ||||||
|     err_code = UPNP_E_OUTOF_MEMORY; // default error |     err_code = UPNP_E_OUTOF_MEMORY; // default error | ||||||
|  |  | ||||||
|     DBGONLY( UpnpPrintf( UPNP_INFO, SOAP, __FILE__, __LINE__, |     UpnpPrintf( UPNP_INFO, SOAP, __FILE__, __LINE__, | ||||||
|         "Inside SoapSendAction():" ); |         "Inside SoapSendAction():" ); | ||||||
|          ) |  | ||||||
|     // init |     // init | ||||||
|     membuffer_init( &request ); |     membuffer_init( &request ); | ||||||
|     membuffer_init( &responsename ); |     membuffer_init( &responsename ); | ||||||
| @@ -642,11 +641,12 @@ SoapSendAction( IN char *action_url, | |||||||
|         goto error_handler; |         goto error_handler; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     DBGONLY( UpnpPrintf( UPNP_INFO, SOAP, __FILE__, __LINE__, |     UpnpPrintf( UPNP_INFO, SOAP, __FILE__, __LINE__, | ||||||
|         "path=%.*s, hostport=%.*s\n", |         "path=%.*s, hostport=%.*s\n", | ||||||
|                          url.pathquery.size, url.pathquery.buff, |         (int)url.pathquery.size, | ||||||
|                          url.hostport.text.size, |         url.pathquery.buff, | ||||||
|                          url.hostport.text.buff ); ) |         (int)url.hostport.text.size, | ||||||
|  |         url.hostport.text.buff ); | ||||||
|  |  | ||||||
|     xml_start_len = strlen( xml_start ); |     xml_start_len = strlen( xml_start ); | ||||||
|     xml_end_len = strlen( xml_end ); |     xml_end_len = strlen( xml_end ); | ||||||
| @@ -693,7 +693,7 @@ SoapSendAction( IN char *action_url, | |||||||
|         err_code = ret_code; |         err_code = ret_code; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|   error_handler: | error_handler: | ||||||
|     ixmlFreeDOMString( action_str ); |     ixmlFreeDOMString( action_str ); | ||||||
|     membuffer_destroy( &request ); |     membuffer_destroy( &request ); | ||||||
|     membuffer_destroy( &responsename ); |     membuffer_destroy( &responsename ); | ||||||
| @@ -757,22 +757,21 @@ SoapSendActionEx( IN char *action_url, | |||||||
|     char *xml_end = |     char *xml_end = | ||||||
|         "</s:Body>\r\n" |         "</s:Body>\r\n" | ||||||
|         "</s:Envelope>\r\n"; |         "</s:Envelope>\r\n"; | ||||||
|     int xml_start_len; |     size_t xml_start_len; | ||||||
|     int xml_header_start_len; |     size_t xml_header_start_len; | ||||||
|     int xml_header_str_len; |     size_t xml_header_str_len; | ||||||
|     int xml_header_end_len; |     size_t xml_header_end_len; | ||||||
|     int xml_body_start_len; |     size_t xml_body_start_len; | ||||||
|     int action_str_len; |     size_t action_str_len; | ||||||
|     int xml_end_len; |     size_t xml_end_len; | ||||||
|     off_t content_length; |     off_t content_length; | ||||||
|  |  | ||||||
|     *response_node = NULL;      // init |     *response_node = NULL;      // init | ||||||
|  |  | ||||||
|     err_code = UPNP_E_OUTOF_MEMORY; // default error |     err_code = UPNP_E_OUTOF_MEMORY; // default error | ||||||
|  |  | ||||||
|     DBGONLY( UpnpPrintf( UPNP_INFO, SOAP, __FILE__, __LINE__, |     UpnpPrintf( UPNP_INFO, SOAP, __FILE__, __LINE__, | ||||||
|         "Inside SoapSendActionEx():" ); |         "Inside SoapSendActionEx():" ); | ||||||
|          ) |  | ||||||
|     // init |     // init | ||||||
|     membuffer_init( &request ); |     membuffer_init( &request ); | ||||||
|     membuffer_init( &responsename ); |     membuffer_init( &responsename ); | ||||||
| @@ -798,11 +797,12 @@ SoapSendActionEx( IN char *action_url, | |||||||
|         goto error_handler; |         goto error_handler; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     DBGONLY( UpnpPrintf( UPNP_INFO, SOAP, __FILE__, __LINE__, |     UpnpPrintf( UPNP_INFO, SOAP, __FILE__, __LINE__, | ||||||
|         "path=%.*s, hostport=%.*s\n", |         "path=%.*s, hostport=%.*s\n", | ||||||
|                          url.pathquery.size, url.pathquery.buff, |         (int)url.pathquery.size, | ||||||
|                          url.hostport.text.size, |         url.pathquery.buff, | ||||||
|                          url.hostport.text.buff ); ) |         (int)url.hostport.text.size, | ||||||
|  |         url.hostport.text.buff ); | ||||||
|  |  | ||||||
|     xml_start_len = strlen( xml_start ); |     xml_start_len = strlen( xml_start ); | ||||||
|     xml_body_start_len = strlen( xml_body_start ); |     xml_body_start_len = strlen( xml_body_start ); | ||||||
| @@ -821,7 +821,7 @@ SoapSendActionEx( IN char *action_url, | |||||||
|         xml_body_start_len + action_str_len + xml_end_len; |         xml_body_start_len + action_str_len + xml_end_len; | ||||||
|     if (http_MakeMessage( |     if (http_MakeMessage( | ||||||
|         &request, 1, 1, |         &request, 1, 1, | ||||||
|         "q" "N" "s" "sssbsc" "Uc" "bbbbbbb", |         "q" "N" "s" "sssbsc" "Uc" "b" "b" "b" "b" "b" "b" "b", | ||||||
|         SOAPMETHOD_POST, &url, |         SOAPMETHOD_POST, &url, | ||||||
|         content_length, |         content_length, | ||||||
|         ContentTypeHeader, |         ContentTypeHeader, | ||||||
|   | |||||||
| @@ -85,7 +85,7 @@ const char *ContentTypeHeader = | |||||||
| *		0 if successful else returns appropriate error. | *		0 if successful else returns appropriate error. | ||||||
| *	Note : | *	Note : | ||||||
| ****************************************************************************/ | ****************************************************************************/ | ||||||
| static XINLINE int | static UPNP_INLINE int | ||||||
| get_request_type( IN http_message_t * request, | get_request_type( IN http_message_t * request, | ||||||
|                   OUT memptr * action_name ) |                   OUT memptr * action_name ) | ||||||
| { | { | ||||||
| @@ -262,7 +262,7 @@ send_error_response( IN SOCKINFO * info, | |||||||
| * | * | ||||||
| *	Note : | *	Note : | ||||||
| ****************************************************************************/ | ****************************************************************************/ | ||||||
| static XINLINE void | static UPNP_INLINE void | ||||||
| send_var_query_response( IN SOCKINFO * info, | send_var_query_response( IN SOCKINFO * info, | ||||||
|                          IN const char *var_value, |                          IN const char *var_value, | ||||||
|                          IN http_message_t * hmsg ) |                          IN http_message_t * hmsg ) | ||||||
| @@ -326,12 +326,12 @@ send_var_query_response( IN SOCKINFO * info, | |||||||
| *	Description :	This function separates the action node from  | *	Description :	This function separates the action node from  | ||||||
| *	the root DOM node. | *	the root DOM node. | ||||||
| * | * | ||||||
| *	Return :	static XINLINE int | *	Return :	static UPNP_INLINE int | ||||||
| *		0 if successful, or -1 if fails. | *		0 if successful, or -1 if fails. | ||||||
| * | * | ||||||
| *	Note : | *	Note : | ||||||
| ****************************************************************************/ | ****************************************************************************/ | ||||||
| static XINLINE int | static UPNP_INLINE int | ||||||
| get_action_node( IN IXML_Document * TempDoc, | get_action_node( IN IXML_Document * TempDoc, | ||||||
|                  IN char *NodeName, |                  IN char *NodeName, | ||||||
|                  OUT IXML_Document ** RespNode ) |                  OUT IXML_Document ** RespNode ) | ||||||
| @@ -344,11 +344,10 @@ get_action_node( IN IXML_Document * TempDoc, | |||||||
|     int ret_code = -1;          // error, by default |     int ret_code = -1;          // error, by default | ||||||
|     IXML_NodeList *nl = NULL; |     IXML_NodeList *nl = NULL; | ||||||
|  |  | ||||||
|     DBGONLY( UpnpPrintf( UPNP_INFO, SOAP, __FILE__, __LINE__, |     UpnpPrintf( UPNP_INFO, SOAP, __FILE__, __LINE__, | ||||||
|         "get_action_node(): node name =%s\n ", NodeName ); |         "get_action_node(): node name =%s\n ", NodeName ); | ||||||
|          ) |  | ||||||
|  |  | ||||||
|         * RespNode = NULL; |     *RespNode = NULL; | ||||||
|  |  | ||||||
|     // Got the Envelope node here |     // Got the Envelope node here | ||||||
|     EnvpNode = ixmlNode_getFirstChild( ( IXML_Node * ) TempDoc ); |     EnvpNode = ixmlNode_getFirstChild( ( IXML_Node * ) TempDoc ); | ||||||
| @@ -682,7 +681,7 @@ get_device_info( IN http_message_t * request, | |||||||
| * | * | ||||||
| *	Note : | *	Note : | ||||||
| ****************************************************************************/ | ****************************************************************************/ | ||||||
| static XINLINE void | static UPNP_INLINE void | ||||||
| send_action_response( IN SOCKINFO * info, | send_action_response( IN SOCKINFO * info, | ||||||
|                       IN IXML_Document * action_resp, |                       IN IXML_Document * action_resp, | ||||||
|                       IN http_message_t * request ) |                       IN http_message_t * request ) | ||||||
| @@ -738,15 +737,15 @@ send_action_response( IN SOCKINFO * info, | |||||||
|                                  xml_response, strlen( xml_response ), |                                  xml_response, strlen( xml_response ), | ||||||
|                                  end_body, strlen( end_body ) ); |                                  end_body, strlen( end_body ) ); | ||||||
|  |  | ||||||
|     DBGONLY( if( ret_code != 0 ) { |     if( ret_code != 0 ) { | ||||||
|         UpnpPrintf( UPNP_INFO, SOAP, __FILE__, __LINE__, |         UpnpPrintf( UPNP_INFO, SOAP, __FILE__, __LINE__, | ||||||
|             "Failed to send response: err code = %d\n", |             "Failed to send response: err code = %d\n", | ||||||
|                          ret_code );} |             ret_code ); | ||||||
|      ) |     } | ||||||
|  |  | ||||||
|     err_code = 0; |     err_code = 0; | ||||||
|  |  | ||||||
|   error_handler: | error_handler: | ||||||
|     ixmlFreeDOMString( xml_response ); |     ixmlFreeDOMString( xml_response ); | ||||||
|     membuffer_destroy( &headers ); |     membuffer_destroy( &headers ); | ||||||
|     if( err_code != 0 ) { |     if( err_code != 0 ) { | ||||||
| @@ -770,7 +769,7 @@ send_action_response( IN SOCKINFO * info, | |||||||
| *		returns 0 if successful else returns -1. | *		returns 0 if successful else returns -1. | ||||||
| *	Note : | *	Note : | ||||||
| ****************************************************************************/ | ****************************************************************************/ | ||||||
| static XINLINE int | static UPNP_INLINE int | ||||||
| get_var_name( IN IXML_Document * TempDoc, | get_var_name( IN IXML_Document * TempDoc, | ||||||
|               OUT char *VarName ) |               OUT char *VarName ) | ||||||
| { | { | ||||||
| @@ -814,14 +813,13 @@ get_var_name( IN IXML_Document * TempDoc, | |||||||
|     Temp = ixmlNode_getNodeValue( VarNode ); |     Temp = ixmlNode_getNodeValue( VarNode ); | ||||||
|     linecopy( VarName, Temp ); |     linecopy( VarName, Temp ); | ||||||
|  |  | ||||||
|     DBGONLY( UpnpPrintf( UPNP_INFO, SOAP, __FILE__, __LINE__, |     UpnpPrintf( UPNP_INFO, SOAP, __FILE__, __LINE__, | ||||||
|         "Received query for variable  name %s\n", |         "Received query for variable  name %s\n", | ||||||
|         VarName ); |         VarName ); | ||||||
|          ) |  | ||||||
|  |  | ||||||
|     ret_val = 0;            // success |     ret_val = 0;            // success | ||||||
|  |  | ||||||
|   error_handler: | error_handler: | ||||||
|     return ret_val; |     return ret_val; | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -842,7 +840,7 @@ get_var_name( IN IXML_Document * TempDoc, | |||||||
| * | * | ||||||
| *	Note : | *	Note : | ||||||
| ****************************************************************************/ | ****************************************************************************/ | ||||||
| static XINLINE void | static UPNP_INLINE void | ||||||
| handle_query_variable( IN SOCKINFO * info, | handle_query_variable( IN SOCKINFO * info, | ||||||
|                        IN http_message_t * request, |                        IN http_message_t * request, | ||||||
|                        IN IXML_Document * xml_doc ) |                        IN IXML_Document * xml_doc ) | ||||||
| @@ -878,8 +876,8 @@ handle_query_variable( IN SOCKINFO * info, | |||||||
|     // send event |     // send event | ||||||
|     soap_event_callback( UPNP_CONTROL_GET_VAR_REQUEST, &variable, cookie ); |     soap_event_callback( UPNP_CONTROL_GET_VAR_REQUEST, &variable, cookie ); | ||||||
|  |  | ||||||
|     DBGONLY( UpnpPrintf( UPNP_INFO, SOAP, __FILE__, __LINE__, |     UpnpPrintf( UPNP_INFO, SOAP, __FILE__, __LINE__, | ||||||
|                          "Return from callback for var request\n" ) ); |         "Return from callback for var request\n" ); | ||||||
|  |  | ||||||
|     // validate, and handle result |     // validate, and handle result | ||||||
|     if( variable.CurrentVal == NULL ) { |     if( variable.CurrentVal == NULL ) { | ||||||
| @@ -968,8 +966,8 @@ handle_invoke_action( IN SOCKINFO * info, | |||||||
|     action.ErrCode = UPNP_E_SUCCESS; |     action.ErrCode = UPNP_E_SUCCESS; | ||||||
|     action.CtrlPtIPAddr = info->foreign_ip_addr; |     action.CtrlPtIPAddr = info->foreign_ip_addr; | ||||||
|  |  | ||||||
|     DBGONLY( UpnpPrintf( UPNP_INFO, SOAP, __FILE__, __LINE__, |     UpnpPrintf( UPNP_INFO, SOAP, __FILE__, __LINE__, | ||||||
|                          "Calling Callback\n" ) ); |                          "Calling Callback\n" ); | ||||||
|  |  | ||||||
|     soap_event_callback( UPNP_CONTROL_ACTION_REQUEST, &action, cookie ); |     soap_event_callback( UPNP_CONTROL_ACTION_REQUEST, &action, cookie ); | ||||||
|  |  | ||||||
|   | |||||||
| @@ -125,16 +125,16 @@ ssdp_handle_ctrlpt_msg( IN http_message_t * hmsg, | |||||||
|  |  | ||||||
|     // we are assuming that there can be only one client supported at a time |     // we are assuming that there can be only one client supported at a time | ||||||
|  |  | ||||||
|     HandleLock(  ); |     HandleLock(); | ||||||
|  |  | ||||||
|     if( GetClientHandleInfo( &handle, &ctrlpt_info ) != HND_CLIENT ) { |     if( GetClientHandleInfo( &handle, &ctrlpt_info ) != HND_CLIENT ) { | ||||||
|         HandleUnlock(  ); |         HandleUnlock(); | ||||||
|         return; |         return; | ||||||
|     } |     } | ||||||
|     // copy |     // copy | ||||||
|     ctrlpt_callback = ctrlpt_info->Callback; |     ctrlpt_callback = ctrlpt_info->Callback; | ||||||
|     ctrlpt_cookie = ctrlpt_info->Cookie; |     ctrlpt_cookie = ctrlpt_info->Cookie; | ||||||
|     HandleUnlock(  ); |     HandleUnlock(); | ||||||
|  |  | ||||||
|     // search timeout |     // search timeout | ||||||
|     if( timeout ) { |     if( timeout ) { | ||||||
| @@ -268,9 +268,9 @@ ssdp_handle_ctrlpt_msg( IN http_message_t * hmsg, | |||||||
|             return;             // bad reply |             return;             // bad reply | ||||||
|         } |         } | ||||||
|         //check each current search |         //check each current search | ||||||
|         HandleLock(  ); |         HandleLock(); | ||||||
|         if( GetClientHandleInfo( &handle, &ctrlpt_info ) != HND_CLIENT ) { |         if( GetClientHandleInfo( &handle, &ctrlpt_info ) != HND_CLIENT ) { | ||||||
|             HandleUnlock(  ); |             HandleUnlock(); | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|         node = ListHead( &ctrlpt_info->SsdpSearchList ); |         node = ListHead( &ctrlpt_info->SsdpSearchList ); | ||||||
| @@ -344,7 +344,7 @@ ssdp_handle_ctrlpt_msg( IN http_message_t * hmsg, | |||||||
|             node = ListNext( &ctrlpt_info->SsdpSearchList, node ); |             node = ListNext( &ctrlpt_info->SsdpSearchList, node ); | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         HandleUnlock(  ); |         HandleUnlock(); | ||||||
|         //ctrlpt_callback( UPNP_DISCOVERY_SEARCH_RESULT, ¶m, cookie ); |         //ctrlpt_callback( UPNP_DISCOVERY_SEARCH_RESULT, ¶m, cookie ); | ||||||
|     } |     } | ||||||
| } | } | ||||||
| @@ -365,7 +365,9 @@ ssdp_handle_ctrlpt_msg( IN http_message_t * hmsg, | |||||||
| * Returns: void | * Returns: void | ||||||
| * | * | ||||||
| ***************************************************************************/ | ***************************************************************************/ | ||||||
| static XINLINE void | #warning There are currently no uses of the function 'process_reply()' in the code. | ||||||
|  | #warning 'process_reply()' is a good candidate for removal. | ||||||
|  | static UPNP_INLINE void | ||||||
| process_reply( IN char *request_buf, | process_reply( IN char *request_buf, | ||||||
|                IN int buf_len, |                IN int buf_len, | ||||||
|                IN struct sockaddr_in *dest_addr, |                IN struct sockaddr_in *dest_addr, | ||||||
| @@ -456,13 +458,13 @@ searchExpired( void *arg ) | |||||||
|     void *cookie = NULL; |     void *cookie = NULL; | ||||||
|     int found = 0; |     int found = 0; | ||||||
|  |  | ||||||
|     HandleLock(  ); |     HandleLock(); | ||||||
|  |  | ||||||
|     //remove search target from search list |     //remove search target from search list | ||||||
|  |  | ||||||
|     if( GetClientHandleInfo( &handle, &ctrlpt_info ) != HND_CLIENT ) { |     if( GetClientHandleInfo( &handle, &ctrlpt_info ) != HND_CLIENT ) { | ||||||
|         free( id ); |         free( id ); | ||||||
|         HandleUnlock(  ); |         HandleUnlock(); | ||||||
|         return; |         return; | ||||||
|     } |     } | ||||||
|  |  | ||||||
| @@ -483,7 +485,7 @@ searchExpired( void *arg ) | |||||||
|         } |         } | ||||||
|         node = ListNext( &ctrlpt_info->SsdpSearchList, node ); |         node = ListNext( &ctrlpt_info->SsdpSearchList, node ); | ||||||
|     } |     } | ||||||
|     HandleUnlock(  ); |     HandleUnlock(); | ||||||
|  |  | ||||||
|     if( found ) { |     if( found ) { | ||||||
|         ctrlpt_callback( UPNP_DISCOVERY_SEARCH_TIMEOUT, NULL, cookie ); |         ctrlpt_callback( UPNP_DISCOVERY_SEARCH_TIMEOUT, NULL, cookie ); | ||||||
| @@ -536,9 +538,8 @@ SearchByTarget( IN int Mx, | |||||||
|     if( ReqBuf == NULL ) |     if( ReqBuf == NULL ) | ||||||
|         return UPNP_E_OUTOF_MEMORY; |         return UPNP_E_OUTOF_MEMORY; | ||||||
|  |  | ||||||
|     DBGONLY( UpnpPrintf( UPNP_INFO, SSDP, __FILE__, __LINE__, |     UpnpPrintf( UPNP_INFO, SSDP, __FILE__, __LINE__, | ||||||
|         ">>> SSDP SEND >>>\n%s\n", ReqBuf ); |         ">>> SSDP SEND >>>\n%s\n", ReqBuf ); | ||||||
|          ) |  | ||||||
|  |  | ||||||
|     timeTillRead = Mx; |     timeTillRead = Mx; | ||||||
|  |  | ||||||
| @@ -559,9 +560,9 @@ SearchByTarget( IN int Mx, | |||||||
|     FD_SET( gSsdpReqSocket, &wrSet ); |     FD_SET( gSsdpReqSocket, &wrSet ); | ||||||
|  |  | ||||||
|     //add search criteria to list |     //add search criteria to list | ||||||
|     HandleLock(  ); |     HandleLock(); | ||||||
|     if( GetClientHandleInfo( &handle, &ctrlpt_info ) != HND_CLIENT ) { |     if( GetClientHandleInfo( &handle, &ctrlpt_info ) != HND_CLIENT ) { | ||||||
|         HandleUnlock(  ); |         HandleUnlock(); | ||||||
|         free( ReqBuf ); |         free( ReqBuf ); | ||||||
|         return UPNP_E_INTERNAL_ERROR; |         return UPNP_E_INTERNAL_ERROR; | ||||||
|     } |     } | ||||||
| @@ -582,33 +583,30 @@ SearchByTarget( IN int Mx, | |||||||
|     newArg->timeoutEventId = ( *id ); |     newArg->timeoutEventId = ( *id ); | ||||||
|  |  | ||||||
|     ListAddTail( &ctrlpt_info->SsdpSearchList, newArg ); |     ListAddTail( &ctrlpt_info->SsdpSearchList, newArg ); | ||||||
|     HandleUnlock(  ); |     HandleUnlock(); | ||||||
|  |  | ||||||
|     setsockopt( gSsdpReqSocket, IPPROTO_IP, IP_MULTICAST_IF, |     setsockopt( gSsdpReqSocket, IPPROTO_IP, IP_MULTICAST_IF, | ||||||
|                 ( char * )&addr, sizeof( addr ) ); |                 ( char * )&addr, sizeof( addr ) ); | ||||||
|  |  | ||||||
|     if( select( gSsdpReqSocket + 1, NULL, &wrSet, NULL, NULL ) |     if( select( gSsdpReqSocket + 1, NULL, &wrSet, NULL, NULL ) | ||||||
|         == UPNP_SOCKETERROR ) { |         == UPNP_SOCKETERROR ) { | ||||||
|         DBGONLY( if( errno == EBADF ) { |         if( errno == EBADF ) { | ||||||
|             UpnpPrintf( UPNP_INFO, SSDP, __FILE__, __LINE__, |             UpnpPrintf( UPNP_INFO, SSDP, __FILE__, __LINE__, | ||||||
|                 "SSDP_LIB :RequestHandler:An invalid file descriptor" |                 "SSDP_LIB :RequestHandler:An invalid file descriptor" | ||||||
|                              " was givenin one of the sets. \n" );} |                 " was givenin one of the sets. \n" ); | ||||||
|                  else |         } else if( errno == EINTR ) { | ||||||
|                  if( errno == EINTR ) { |  | ||||||
|             UpnpPrintf( UPNP_INFO, SSDP, __FILE__, __LINE__, |             UpnpPrintf( UPNP_INFO, SSDP, __FILE__, __LINE__, | ||||||
|                 "SSDP_LIB :RequestHandler:  A non blocked " |                 "SSDP_LIB :RequestHandler:  A non blocked " | ||||||
|                              "signal was caught.    \n" );} |                 "signal was caught.    \n" ); | ||||||
|                  else |         } else if( errno == EINVAL ) { | ||||||
|                  if( errno == EINVAL ) { |  | ||||||
|             UpnpPrintf( UPNP_INFO, SSDP, __FILE__, __LINE__, |             UpnpPrintf( UPNP_INFO, SSDP, __FILE__, __LINE__, | ||||||
|                              "SSDP_LIB :RequestHandler: n is negative.  \n" );} |                 "SSDP_LIB :RequestHandler: n is negative.  \n" ); | ||||||
|                  else |         } else if( errno == ENOMEM ) { | ||||||
|                  if( errno == ENOMEM ) { |  | ||||||
|             UpnpPrintf( UPNP_INFO, SSDP, __FILE__, __LINE__, |             UpnpPrintf( UPNP_INFO, SSDP, __FILE__, __LINE__, | ||||||
|                 "SSDP_LIB : RequestHandler:select was unable to " |                 "SSDP_LIB : RequestHandler:select was unable to " | ||||||
|                              "allocate memory for internal tables.\n" );} |                 "allocate memory for internal tables.\n" ); | ||||||
|  ) |         } | ||||||
| shutdown( gSsdpReqSocket, SD_BOTH ); | 	shutdown( gSsdpReqSocket, SD_BOTH ); | ||||||
|         UpnpCloseSocket( gSsdpReqSocket ); |         UpnpCloseSocket( gSsdpReqSocket ); | ||||||
|         free( ReqBuf ); |         free( ReqBuf ); | ||||||
|         return UPNP_E_INTERNAL_ERROR; |         return UPNP_E_INTERNAL_ERROR; | ||||||
|   | |||||||
| @@ -95,6 +95,7 @@ advertiseAndReplyThread( IN void *data ) | |||||||
| * Returns: void * | * Returns: void * | ||||||
| *	1 if successful else appropriate error | *	1 if successful else appropriate error | ||||||
| ***************************************************************************/ | ***************************************************************************/ | ||||||
|  | #ifdef INCLUDE_DEVICE_APIS | ||||||
| void | void | ||||||
| ssdp_handle_device_request( IN http_message_t * hmsg, | ssdp_handle_device_request( IN http_message_t * hmsg, | ||||||
|                             IN struct sockaddr_in *dest_addr ) |                             IN struct sockaddr_in *dest_addr ) | ||||||
| @@ -135,16 +136,16 @@ ssdp_handle_device_request( IN http_message_t * hmsg, | |||||||
|         return;                 // bad ST header |         return;                 // bad ST header | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     HandleLock(  ); |     HandleLock(); | ||||||
|     // device info |     // device info | ||||||
|     if( GetDeviceHandleInfo( &handle, &dev_info ) != HND_DEVICE ) { |     if( GetDeviceHandleInfo( &handle, &dev_info ) != HND_DEVICE ) { | ||||||
|         HandleUnlock(  ); |         HandleUnlock(); | ||||||
|         return;                 // no info found |         return;                 // no info found | ||||||
|     } |     } | ||||||
|     maxAge = dev_info->MaxAge; |     maxAge = dev_info->MaxAge; | ||||||
|     HandleUnlock(  ); |     HandleUnlock(); | ||||||
|  |  | ||||||
|     DBGONLY( UpnpPrintf( UPNP_PACKET, API, __FILE__, __LINE__, |     UpnpPrintf( UPNP_PACKET, API, __FILE__, __LINE__, | ||||||
|         "ssdp_handle_device_request with Cmd %d SEARCH\n", |         "ssdp_handle_device_request with Cmd %d SEARCH\n", | ||||||
|         event.Cmd ); |         event.Cmd ); | ||||||
|     UpnpPrintf( UPNP_PACKET, API, __FILE__, __LINE__, |     UpnpPrintf( UPNP_PACKET, API, __FILE__, __LINE__, | ||||||
| @@ -156,7 +157,7 @@ ssdp_handle_device_request( IN http_message_t * hmsg, | |||||||
|     UpnpPrintf( UPNP_PACKET, API, __FILE__, __LINE__, |     UpnpPrintf( UPNP_PACKET, API, __FILE__, __LINE__, | ||||||
|         "DeviceUuid   =  %s\n", event.UDN ); |         "DeviceUuid   =  %s\n", event.UDN ); | ||||||
|     UpnpPrintf( UPNP_PACKET, API, __FILE__, __LINE__, |     UpnpPrintf( UPNP_PACKET, API, __FILE__, __LINE__, | ||||||
|                          "ServiceType =  %s\n", event.ServiceType ); ) |         "ServiceType =  %s\n", event.ServiceType ); | ||||||
|  |  | ||||||
|     threadArg = |     threadArg = | ||||||
|         ( SsdpSearchReply * ) malloc( sizeof( SsdpSearchReply ) ); |         ( SsdpSearchReply * ) malloc( sizeof( SsdpSearchReply ) ); | ||||||
| @@ -185,11 +186,12 @@ ssdp_handle_device_request( IN http_message_t * hmsg, | |||||||
|         mx = 1; |         mx = 1; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     replyTime = rand(  ) % mx; |     replyTime = rand() % mx; | ||||||
|  |  | ||||||
|     TimerThreadSchedule( &gTimerThread, replyTime, REL_SEC, &job, |     TimerThreadSchedule( &gTimerThread, replyTime, REL_SEC, &job, | ||||||
|                          SHORT_TERM, NULL ); |                          SHORT_TERM, NULL ); | ||||||
| } | } | ||||||
|  | #endif | ||||||
|  |  | ||||||
| /************************************************************************ | /************************************************************************ | ||||||
| * Function : NewRequestHandler									 | * Function : NewRequestHandler									 | ||||||
| @@ -220,9 +222,9 @@ NewRequestHandler( IN struct sockaddr_in *DestAddr, | |||||||
|  |  | ||||||
|     ReplySock = socket( AF_INET, SOCK_DGRAM, 0 ); |     ReplySock = socket( AF_INET, SOCK_DGRAM, 0 ); | ||||||
|     if( ReplySock == UPNP_INVALID_SOCKET ) { |     if( ReplySock == UPNP_INVALID_SOCKET ) { | ||||||
|         DBGONLY( UpnpPrintf( UPNP_INFO, SSDP, __FILE__, __LINE__, |         UpnpPrintf( UPNP_INFO, SSDP, __FILE__, __LINE__, | ||||||
|             "SSDP_LIB: New Request Handler:" |             "SSDP_LIB: New Request Handler:" | ||||||
|                              "Error in socket operation !!!\n" ) ); |             "Error in socket operation !!!\n" ); | ||||||
|  |  | ||||||
|         return UPNP_E_OUTOF_SOCKET; |         return UPNP_E_OUTOF_SOCKET; | ||||||
|     } |     } | ||||||
| @@ -247,10 +249,9 @@ NewRequestHandler( IN struct sockaddr_in *DestAddr, | |||||||
|         // So, NUM_COPY has been changed from 2 to 1. |         // So, NUM_COPY has been changed from 2 to 1. | ||||||
|         NumCopy = 0; |         NumCopy = 0; | ||||||
|         while( NumCopy < NUM_COPY ) { |         while( NumCopy < NUM_COPY ) { | ||||||
|             DBGONLY( UpnpPrintf( UPNP_INFO, SSDP, __FILE__, __LINE__, |             UpnpPrintf( UPNP_INFO, SSDP, __FILE__, __LINE__, | ||||||
|                 ">>> SSDP SEND >>>\n%s\n", |                 ">>> SSDP SEND >>>\n%s\n", | ||||||
|                 *( RqPacket + Index ) ); |                 *( RqPacket + Index ) ); | ||||||
|                  ) |  | ||||||
|             rc = sendto( ReplySock, *( RqPacket + Index ), |             rc = sendto( ReplySock, *( RqPacket + Index ), | ||||||
|                          strlen( *( RqPacket + Index ) ), |                          strlen( *( RqPacket + Index ) ), | ||||||
|                          0, ( struct sockaddr * )DestAddr, socklen ); |                          0, ( struct sockaddr * )DestAddr, socklen ); | ||||||
| @@ -388,9 +389,8 @@ DeviceAdvertisement( IN char *DevType, | |||||||
|     char *msgs[3]; |     char *msgs[3]; | ||||||
|     int ret_code; |     int ret_code; | ||||||
|  |  | ||||||
|     DBGONLY( UpnpPrintf( UPNP_INFO, SSDP, __FILE__, __LINE__, |     UpnpPrintf( UPNP_INFO, SSDP, __FILE__, __LINE__, | ||||||
|         "In function SendDeviceAdvertisemenrt\n" ); |         "In function SendDeviceAdvertisemenrt\n" ); | ||||||
|          ) |  | ||||||
|  |  | ||||||
|     DestAddr.sin_family = AF_INET; |     DestAddr.sin_family = AF_INET; | ||||||
|     DestAddr.sin_addr.s_addr = inet_addr( SSDP_IP ); |     DestAddr.sin_addr.s_addr = inet_addr( SSDP_IP ); | ||||||
| @@ -783,8 +783,8 @@ DeviceShutdown( IN char *DevType, | |||||||
|                              Mil_Usn, Location, Duration, &msgs[0] ); |                              Mil_Usn, Location, Duration, &msgs[0] ); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     DBGONLY( UpnpPrintf( UPNP_INFO, SSDP, __FILE__, __LINE__, |     UpnpPrintf( UPNP_INFO, SSDP, __FILE__, __LINE__, | ||||||
|                          "In function DeviceShutdown\n" ); ) |         "In function DeviceShutdown\n" ); | ||||||
|     // both root and sub-devices need to send these two messages |     // both root and sub-devices need to send these two messages | ||||||
|     CreateServicePacket( MSGTYPE_SHUTDOWN, Udn, Udn, |     CreateServicePacket( MSGTYPE_SHUTDOWN, Udn, Udn, | ||||||
|                          Location, Duration, &msgs[1] ); |                          Location, Duration, &msgs[1] ); | ||||||
|   | |||||||
| @@ -91,7 +91,7 @@ CLIENTONLY( SOCKET gSsdpReqSocket = 0; | |||||||
| * Returns: int | * Returns: int | ||||||
| *	UPNP_E_SUCCESS if successful else appropriate error | *	UPNP_E_SUCCESS if successful else appropriate error | ||||||
| ***************************************************************************/ | ***************************************************************************/ | ||||||
|      int AdvertiseAndReply( IN int AdFlag, | int AdvertiseAndReply( IN int AdFlag, | ||||||
|                        IN UpnpDevice_Handle Hnd, |                        IN UpnpDevice_Handle Hnd, | ||||||
|                        IN enum SsdpSearchType SearchType, |                        IN enum SsdpSearchType SearchType, | ||||||
|                        IN struct sockaddr_in *DestAddr, |                        IN struct sockaddr_in *DestAddr, | ||||||
| @@ -115,14 +115,14 @@ CLIENTONLY( SOCKET gSsdpReqSocket = 0; | |||||||
|     const DOMString tmpStr; |     const DOMString tmpStr; | ||||||
|     char SERVER[200]; |     char SERVER[200]; | ||||||
|  |  | ||||||
|     DBGONLY( const DOMString dbgStr; |     const DOMString dbgStr; | ||||||
|     UpnpPrintf( UPNP_ALL, API, __FILE__, __LINE__, |     UpnpPrintf( UPNP_ALL, API, __FILE__, __LINE__, | ||||||
|         "Inside AdvertiseAndReply with AdFlag = %d\n", |         "Inside AdvertiseAndReply with AdFlag = %d\n", | ||||||
|                          AdFlag ); ) |         AdFlag ); | ||||||
|  |  | ||||||
|         HandleLock(  ); |     HandleLock(); | ||||||
|     if( GetHandleInfo( Hnd, &SInfo ) != HND_DEVICE ) { |     if( GetHandleInfo( Hnd, &SInfo ) != HND_DEVICE ) { | ||||||
|         HandleUnlock(  ); |         HandleUnlock(); | ||||||
|         return UPNP_E_INVALID_HANDLE; |         return UPNP_E_INVALID_HANDLE; | ||||||
|     } |     } | ||||||
|     defaultExp = SInfo->MaxAge; |     defaultExp = SInfo->MaxAge; | ||||||
| @@ -139,24 +139,20 @@ CLIENTONLY( SOCKET gSsdpReqSocket = 0; | |||||||
|     // parse the device list and send advertisements/replies  |     // parse the device list and send advertisements/replies  | ||||||
|     for( i = 0;; i++ ) { |     for( i = 0;; i++ ) { | ||||||
|  |  | ||||||
|         DBGONLY( UpnpPrintf( UPNP_ALL, API, __FILE__, __LINE__, |         UpnpPrintf( UPNP_ALL, API, __FILE__, __LINE__, | ||||||
|                              "Entering new device list with i = %d\n\n", |             "Entering new device list with i = %d\n\n", i ); | ||||||
|                              i ); |  | ||||||
|              ) |  | ||||||
|  |  | ||||||
|         tmpNode = ixmlNodeList_item( SInfo->DeviceList, i ); |         tmpNode = ixmlNodeList_item( SInfo->DeviceList, i ); | ||||||
|         if( tmpNode == NULL ) { |         if( tmpNode == NULL ) { | ||||||
|             DBGONLY( UpnpPrintf( UPNP_ALL, API, __FILE__, __LINE__, |             UpnpPrintf( UPNP_ALL, API, __FILE__, __LINE__, | ||||||
|                                  "Exiting new device list with i = %d\n\n", |                 "Exiting new device list with i = %d\n\n", i ); | ||||||
|                                  i ); |  | ||||||
|                  ) |  | ||||||
|             break; |             break; | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         DBGONLY( dbgStr = ixmlNode_getNodeName( tmpNode ); |         dbgStr = ixmlNode_getNodeName( tmpNode ); | ||||||
|                  UpnpPrintf( UPNP_INFO, API, __FILE__, __LINE__, |                  UpnpPrintf( UPNP_INFO, API, __FILE__, __LINE__, | ||||||
|                      "Extracting device type once for %s\n", |                      "Extracting device type once for %s\n", | ||||||
|                              dbgStr ); ) |                      dbgStr ); | ||||||
|             // extract device type  |             // extract device type  | ||||||
|             ixmlNodeList_free( nodeList ); |             ixmlNodeList_free( nodeList ); | ||||||
|         nodeList = NULL; |         nodeList = NULL; | ||||||
| @@ -167,13 +163,12 @@ CLIENTONLY( SOCKET gSsdpReqSocket = 0; | |||||||
|             continue; |             continue; | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         DBGONLY( dbgStr = ixmlNode_getNodeName( tmpNode ); |         dbgStr = ixmlNode_getNodeName( tmpNode ); | ||||||
|         UpnpPrintf( UPNP_ALL, API, __FILE__, __LINE__, |         UpnpPrintf( UPNP_ALL, API, __FILE__, __LINE__, | ||||||
|                              "Extracting UDN for %s\n", dbgStr ); ) |             "Extracting UDN for %s\n", dbgStr ); | ||||||
|  |  | ||||||
|             DBGONLY( UpnpPrintf( UPNP_ALL, API, __FILE__, __LINE__, |         UpnpPrintf( UPNP_ALL, API, __FILE__, __LINE__, | ||||||
|             "Extracting device type\n" ); |             "Extracting device type\n" ); | ||||||
|              ) |  | ||||||
|  |  | ||||||
|         tmpNode2 = ixmlNodeList_item( nodeList, 0 ); |         tmpNode2 = ixmlNodeList_item( nodeList, 0 ); | ||||||
|         if( tmpNode2 == NULL ) { |         if( tmpNode2 == NULL ) { | ||||||
| @@ -184,9 +179,8 @@ CLIENTONLY( SOCKET gSsdpReqSocket = 0; | |||||||
|             continue; |             continue; | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         DBGONLY( UpnpPrintf( UPNP_ALL, API, __FILE__, __LINE__, |         UpnpPrintf( UPNP_ALL, API, __FILE__, __LINE__, | ||||||
|             "Extracting device type \n" ); |             "Extracting device type \n" ); | ||||||
|              ) |  | ||||||
|  |  | ||||||
|         tmpStr = ixmlNode_getNodeValue( textNode ); |         tmpStr = ixmlNode_getNodeValue( textNode ); | ||||||
|         if( tmpStr == NULL ) { |         if( tmpStr == NULL ) { | ||||||
| @@ -198,47 +192,41 @@ CLIENTONLY( SOCKET gSsdpReqSocket = 0; | |||||||
|             continue; |             continue; | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         DBGONLY( UpnpPrintf( UPNP_ALL, API, __FILE__, __LINE__, |         UpnpPrintf( UPNP_ALL, API, __FILE__, __LINE__, | ||||||
|             "Extracting device type = %s\n", devType ); |             "Extracting device type = %s\n", devType ); | ||||||
|         if( tmpNode == NULL ) { |         if( tmpNode == NULL ) { | ||||||
|             UpnpPrintf( UPNP_ALL, API, __FILE__, __LINE__, |             UpnpPrintf( UPNP_ALL, API, __FILE__, __LINE__, | ||||||
|                              "TempNode is NULL\n" );} |                 "TempNode is NULL\n" ); | ||||||
|  | 	} | ||||||
|         dbgStr = ixmlNode_getNodeName( tmpNode ); |         dbgStr = ixmlNode_getNodeName( tmpNode ); | ||||||
|         UpnpPrintf( UPNP_ALL, API, __FILE__, __LINE__, |         UpnpPrintf( UPNP_ALL, API, __FILE__, __LINE__, | ||||||
|                              "Extracting UDN for %s\n", dbgStr ); ) |             "Extracting UDN for %s\n", dbgStr ); | ||||||
|         // extract UDN  |         // extract UDN  | ||||||
|         ixmlNodeList_free( nodeList ); |         ixmlNodeList_free( nodeList ); | ||||||
|         nodeList = NULL; |         nodeList = NULL; | ||||||
|         nodeList = ixmlElement_getElementsByTagName( ( IXML_Element * ) |         nodeList = ixmlElement_getElementsByTagName( ( IXML_Element * ) | ||||||
|                                                      tmpNode, "UDN" ); |                                                      tmpNode, "UDN" ); | ||||||
|         if( nodeList == NULL ) { |         if( nodeList == NULL ) { | ||||||
|  |             UpnpPrintf( UPNP_CRITICAL, API, __FILE__, | ||||||
|             DBGONLY( UpnpPrintf( UPNP_CRITICAL, API, __FILE__, |  | ||||||
|                 __LINE__, "UDN not found!!!\n" ); |                 __LINE__, "UDN not found!!!\n" ); | ||||||
|                  ) |  | ||||||
|                 continue; |                 continue; | ||||||
|         } |         } | ||||||
|         tmpNode2 = ixmlNodeList_item( nodeList, 0 ); |         tmpNode2 = ixmlNodeList_item( nodeList, 0 ); | ||||||
|         if( tmpNode2 == NULL ) { |         if( tmpNode2 == NULL ) { | ||||||
|  |             UpnpPrintf( UPNP_CRITICAL, API, __FILE__, | ||||||
|             DBGONLY( UpnpPrintf( UPNP_CRITICAL, API, __FILE__, |  | ||||||
|                 __LINE__, "UDN not found!!!\n" ); |                 __LINE__, "UDN not found!!!\n" ); | ||||||
|                  ) |  | ||||||
|             continue; |             continue; | ||||||
|         } |         } | ||||||
|         textNode = ixmlNode_getFirstChild( tmpNode2 ); |         textNode = ixmlNode_getFirstChild( tmpNode2 ); | ||||||
|         if( textNode == NULL ) { |         if( textNode == NULL ) { | ||||||
|  |             UpnpPrintf( UPNP_CRITICAL, API, __FILE__, | ||||||
|             DBGONLY( UpnpPrintf( UPNP_CRITICAL, API, __FILE__, |  | ||||||
|                 __LINE__, "UDN not found!!!\n" ); |                 __LINE__, "UDN not found!!!\n" ); | ||||||
|                  ) |  | ||||||
|             continue; |             continue; | ||||||
|         } |         } | ||||||
|         tmpStr = ixmlNode_getNodeValue( textNode ); |         tmpStr = ixmlNode_getNodeValue( textNode ); | ||||||
|         if( tmpStr == NULL ) { |         if( tmpStr == NULL ) { | ||||||
|             DBGONLY( UpnpPrintf( UPNP_CRITICAL, API, __FILE__, __LINE__, |             UpnpPrintf( UPNP_CRITICAL, API, __FILE__, __LINE__, | ||||||
|                 "UDN not found!!!!\n" ); |                 "UDN not found!!!!\n" ); | ||||||
|                  ) |  | ||||||
|                 continue; |                 continue; | ||||||
|         } |         } | ||||||
|         strcpy( UDNstr, tmpStr ); |         strcpy( UDNstr, tmpStr ); | ||||||
| @@ -246,9 +234,8 @@ CLIENTONLY( SOCKET gSsdpReqSocket = 0; | |||||||
|             continue; |             continue; | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         DBGONLY( UpnpPrintf( UPNP_INFO, API, __FILE__, __LINE__, |         UpnpPrintf( UPNP_INFO, API, __FILE__, __LINE__, | ||||||
|             "Sending UDNStr = %s \n", UDNstr ); |             "Sending UDNStr = %s \n", UDNstr ); | ||||||
|              ) |  | ||||||
|             if( AdFlag ) { |             if( AdFlag ) { | ||||||
|             // send the device advertisement  |             // send the device advertisement  | ||||||
|             if( AdFlag == 1 ) { |             if( AdFlag == 1 ) { | ||||||
| @@ -278,22 +265,16 @@ CLIENTONLY( SOCKET gSsdpReqSocket = 0; | |||||||
|                     { |                     { | ||||||
|                         if( DeviceUDN != NULL && strlen( DeviceUDN ) != 0 ) { |                         if( DeviceUDN != NULL && strlen( DeviceUDN ) != 0 ) { | ||||||
|                             if( strcasecmp( DeviceUDN, UDNstr ) ) { |                             if( strcasecmp( DeviceUDN, UDNstr ) ) { | ||||||
|                                 DBGONLY( UpnpPrintf |                                 UpnpPrintf( UPNP_INFO, API, __FILE__, __LINE__, | ||||||
|                                          ( UPNP_INFO, API, __FILE__, |  | ||||||
|                                            __LINE__, |  | ||||||
|                                     "DeviceUDN=%s and search " |                                     "DeviceUDN=%s and search " | ||||||
|                                     "UDN=%s did not match\n", |                                     "UDN=%s did not match\n", | ||||||
|                                     UDNstr, DeviceUDN ); |                                     UDNstr, DeviceUDN ); | ||||||
|                                      ) |  | ||||||
|                                     break; |                                     break; | ||||||
|                             } else { |                             } else { | ||||||
|                                 DBGONLY( UpnpPrintf |                                 UpnpPrintf( UPNP_INFO, API, __FILE__, __LINE__, | ||||||
|                                          ( UPNP_INFO, API, __FILE__, |  | ||||||
|                                            __LINE__, |  | ||||||
|                                     "DeviceUDN=%s and search " |                                     "DeviceUDN=%s and search " | ||||||
|                                     "UDN=%s MATCH\n", UDNstr, |                                     "UDN=%s MATCH\n", UDNstr, | ||||||
|                                     DeviceUDN ); |                                     DeviceUDN ); | ||||||
|                                      ) |  | ||||||
|                                     SendReply( DestAddr, devType, 0, |                                     SendReply( DestAddr, devType, 0, | ||||||
|                                                UDNstr, SInfo->DescURL, |                                                UDNstr, SInfo->DescURL, | ||||||
|                                                defaultExp, 0 ); |                                                defaultExp, 0 ); | ||||||
| @@ -306,24 +287,17 @@ CLIENTONLY( SOCKET gSsdpReqSocket = 0; | |||||||
|                         if( !strncasecmp |                         if( !strncasecmp | ||||||
|                             ( DeviceType, devType, |                             ( DeviceType, devType, | ||||||
|                               strlen( DeviceType ) ) ) { |                               strlen( DeviceType ) ) ) { | ||||||
|                             DBGONLY( UpnpPrintf |                             UpnpPrintf( UPNP_INFO, API, __FILE__, __LINE__, | ||||||
|                                      ( UPNP_INFO, API, __FILE__, __LINE__, |  | ||||||
|                                 "DeviceType=%s and search devType=%s MATCH\n", |                                 "DeviceType=%s and search devType=%s MATCH\n", | ||||||
|                                 devType, DeviceType ); |                                 devType, DeviceType ); | ||||||
|                                  ) |  | ||||||
|                             SendReply( DestAddr, devType, 0, UDNstr, |                             SendReply( DestAddr, devType, 0, UDNstr, | ||||||
|                                        SInfo->DescURL, defaultExp, 1 ); |                                        SInfo->DescURL, defaultExp, 1 ); | ||||||
|                         } |                         } else { | ||||||
|  |                             UpnpPrintf( UPNP_INFO, API, __FILE__, __LINE__, | ||||||
|                         DBGONLY( |  | ||||||
|                                     else |  | ||||||
|                                     UpnpPrintf( UPNP_INFO, API, __FILE__, |  | ||||||
|                                                 __LINE__, |  | ||||||
|                                 "DeviceType=%s and search devType=%s" |                                 "DeviceType=%s and search devType=%s" | ||||||
|                                 " DID NOT MATCH\n", |                                 " DID NOT MATCH\n", | ||||||
|                                 devType, DeviceType ); |                                 devType, DeviceType ); | ||||||
|                              ) | 			} | ||||||
|  |  | ||||||
|                         break; |                         break; | ||||||
|                     } |                     } | ||||||
|                 default: |                 default: | ||||||
| @@ -332,9 +306,8 @@ CLIENTONLY( SOCKET gSsdpReqSocket = 0; | |||||||
|         } |         } | ||||||
|         // send service advertisements for services corresponding  |         // send service advertisements for services corresponding  | ||||||
|         // to the same device  |         // to the same device  | ||||||
|         DBGONLY( UpnpPrintf( UPNP_INFO, API, __FILE__, __LINE__, |         UpnpPrintf( UPNP_INFO, API, __FILE__, __LINE__, | ||||||
|             "Sending service Advertisement\n" ); |             "Sending service Advertisement\n" ); | ||||||
|              ) |  | ||||||
|  |  | ||||||
|         tmpNode = ixmlNodeList_item( SInfo->ServiceList, i ); |         tmpNode = ixmlNodeList_item( SInfo->ServiceList, i ); | ||||||
|         if( tmpNode == NULL ) { |         if( tmpNode == NULL ) { | ||||||
| @@ -345,9 +318,8 @@ CLIENTONLY( SOCKET gSsdpReqSocket = 0; | |||||||
|         nodeList = ixmlElement_getElementsByTagName( ( IXML_Element * ) |         nodeList = ixmlElement_getElementsByTagName( ( IXML_Element * ) | ||||||
|                                                      tmpNode, "service" ); |                                                      tmpNode, "service" ); | ||||||
|         if( nodeList == NULL ) { |         if( nodeList == NULL ) { | ||||||
|             DBGONLY( UpnpPrintf( UPNP_INFO, API, __FILE__, __LINE__, |             UpnpPrintf( UPNP_INFO, API, __FILE__, __LINE__, | ||||||
|                 "Service not found 3\n" ); |                 "Service not found 3\n" ); | ||||||
|                  ) |  | ||||||
|             continue; |             continue; | ||||||
|         } |         } | ||||||
|         for( j = 0;; j++ ) { |         for( j = 0;; j++ ) { | ||||||
| @@ -357,15 +329,11 @@ CLIENTONLY( SOCKET gSsdpReqSocket = 0; | |||||||
|  |  | ||||||
|             ixmlNodeList_free( tmpNodeList ); |             ixmlNodeList_free( tmpNodeList ); | ||||||
|             tmpNodeList = NULL; |             tmpNodeList = NULL; | ||||||
|             tmpNodeList = ixmlElement_getElementsByTagName( ( IXML_Element |             tmpNodeList = ixmlElement_getElementsByTagName( | ||||||
|                                                               * ) tmpNode, |                 ( IXML_Element *)tmpNode, "serviceType" ); | ||||||
|                                                             "serviceType" ); |  | ||||||
|  |  | ||||||
|             if( tmpNodeList == NULL ) { |             if( tmpNodeList == NULL ) { | ||||||
|                 DBGONLY( UpnpPrintf |                 UpnpPrintf( UPNP_CRITICAL, API, __FILE__, __LINE__, | ||||||
|                          ( UPNP_CRITICAL, API, __FILE__, __LINE__, |  | ||||||
|                     "ServiceType not found \n" ); |                     "ServiceType not found \n" ); | ||||||
|                      ) |  | ||||||
|                     continue; |                     continue; | ||||||
|             } |             } | ||||||
|             tmpNode2 = ixmlNodeList_item( tmpNodeList, 0 ); |             tmpNode2 = ixmlNodeList_item( tmpNodeList, 0 ); | ||||||
| @@ -386,19 +354,16 @@ CLIENTONLY( SOCKET gSsdpReqSocket = 0; | |||||||
|                 continue; |                 continue; | ||||||
|             } |             } | ||||||
|  |  | ||||||
|             DBGONLY( UpnpPrintf( UPNP_INFO, API, __FILE__, __LINE__, |             UpnpPrintf( UPNP_INFO, API, __FILE__, __LINE__, | ||||||
|                 "ServiceType = %s\n", servType ); |                 "ServiceType = %s\n", servType ); | ||||||
|                  ) |  | ||||||
|             if( AdFlag ) { |             if( AdFlag ) { | ||||||
|                 if( AdFlag == 1 ) { |                 if( AdFlag == 1 ) { | ||||||
|                     ServiceAdvertisement( UDNstr, servType, |                     ServiceAdvertisement( UDNstr, servType, | ||||||
|                                           SInfo->DescURL, Exp ); |                                           SInfo->DescURL, Exp ); | ||||||
|                 } else          // AdFlag == -1 |                 } else {         // AdFlag == -1 | ||||||
|                 { |  | ||||||
|                     ServiceShutdown( UDNstr, servType, |                     ServiceShutdown( UDNstr, servType, | ||||||
|                                      SInfo->DescURL, Exp ); |                                      SInfo->DescURL, Exp ); | ||||||
|                 } |                 } | ||||||
|  |  | ||||||
|             } else { |             } else { | ||||||
|                 switch ( SearchType ) { |                 switch ( SearchType ) { | ||||||
|                     case SSDP_ALL: |                     case SSDP_ALL: | ||||||
| @@ -433,9 +398,8 @@ CLIENTONLY( SOCKET gSsdpReqSocket = 0; | |||||||
|         ixmlNodeList_free( nodeList ); |         ixmlNodeList_free( nodeList ); | ||||||
|         nodeList = NULL; |         nodeList = NULL; | ||||||
|     } |     } | ||||||
|     DBGONLY( UpnpPrintf( UPNP_ALL, API, __FILE__, __LINE__, |     UpnpPrintf( UPNP_ALL, API, __FILE__, __LINE__, | ||||||
|         "Exiting AdvertiseAndReply : \n" ); |         "Exiting AdvertiseAndReply : \n" ); | ||||||
|          ) |  | ||||||
|  |  | ||||||
|     HandleUnlock(  ); |     HandleUnlock(  ); | ||||||
|  |  | ||||||
| @@ -677,7 +641,7 @@ free_ssdp_event_handler_data( void *the_data ) | |||||||
| * Returns: xboolean | * Returns: xboolean | ||||||
| *	returns TRUE if msg is valid else FALSE | *	returns TRUE if msg is valid else FALSE | ||||||
| ***************************************************************************/ | ***************************************************************************/ | ||||||
| static XINLINE xboolean | static UPNP_INLINE xboolean | ||||||
| valid_ssdp_msg( IN http_message_t * hmsg ) | valid_ssdp_msg( IN http_message_t * hmsg ) | ||||||
| { | { | ||||||
|     memptr hdr_value; |     memptr hdr_value; | ||||||
| @@ -719,7 +683,7 @@ valid_ssdp_msg( IN http_message_t * hmsg ) | |||||||
| * Returns: int | * Returns: int | ||||||
| *	0 if successful -1 if error | *	0 if successful -1 if error | ||||||
| ***************************************************************************/ | ***************************************************************************/ | ||||||
| static XINLINE int | static UPNP_INLINE int | ||||||
| start_event_handler( void *Data ) | start_event_handler( void *Data ) | ||||||
| { | { | ||||||
|  |  | ||||||
| @@ -733,18 +697,16 @@ start_event_handler( void *Data ) | |||||||
|     if( status == PARSE_FAILURE ) { |     if( status == PARSE_FAILURE ) { | ||||||
|         if( parser->msg.method != HTTPMETHOD_NOTIFY || |         if( parser->msg.method != HTTPMETHOD_NOTIFY || | ||||||
|             !parser->valid_ssdp_notify_hack ) { |             !parser->valid_ssdp_notify_hack ) { | ||||||
|             DBGONLY( UpnpPrintf( UPNP_INFO, SSDP, __FILE__, __LINE__, |             UpnpPrintf( UPNP_INFO, SSDP, __FILE__, __LINE__, | ||||||
|                 "SSDP recvd bad msg code = %d\n", |                 "SSDP recvd bad msg code = %d\n", | ||||||
|                 status ); |                 status ); | ||||||
|                  ) |  | ||||||
|             // ignore bad msg, or not enuf mem |             // ignore bad msg, or not enuf mem | ||||||
|             goto error_handler; |             goto error_handler; | ||||||
|         } |         } | ||||||
|         // valid notify msg |         // valid notify msg | ||||||
|     } else if( status != PARSE_SUCCESS ) { |     } else if( status != PARSE_SUCCESS ) { | ||||||
|         DBGONLY( UpnpPrintf( UPNP_INFO, SSDP, __FILE__, __LINE__, |         UpnpPrintf( UPNP_INFO, SSDP, __FILE__, __LINE__, | ||||||
|             "SSDP recvd bad msg code = %d\n", status ); |             "SSDP recvd bad msg code = %d\n", status ); | ||||||
|              ) |  | ||||||
|  |  | ||||||
|         goto error_handler; |         goto error_handler; | ||||||
|     } |     } | ||||||
| @@ -784,14 +746,10 @@ ssdp_event_handler_thread( void *the_data ) | |||||||
|     // send msg to device or ctrlpt |     // send msg to device or ctrlpt | ||||||
|     if( ( hmsg->method == HTTPMETHOD_NOTIFY ) || |     if( ( hmsg->method == HTTPMETHOD_NOTIFY ) || | ||||||
|         ( hmsg->request_method == HTTPMETHOD_MSEARCH ) ) { |         ( hmsg->request_method == HTTPMETHOD_MSEARCH ) ) { | ||||||
|  |  | ||||||
|         CLIENTONLY( ssdp_handle_ctrlpt_msg( hmsg, &data->dest_addr, |         CLIENTONLY( ssdp_handle_ctrlpt_msg( hmsg, &data->dest_addr, | ||||||
|                                             FALSE, NULL ); |                                             FALSE, NULL );); | ||||||
|              ); |  | ||||||
|     } else { |     } else { | ||||||
|  |         ssdp_handle_device_request( hmsg, &data->dest_addr ); | ||||||
|         DEVICEONLY( ssdp_handle_device_request( hmsg, &data->dest_addr ); |  | ||||||
|              ); |  | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     // free data |     // free data | ||||||
| @@ -863,19 +821,16 @@ readFromSSDPSocket( SOCKET socket ) | |||||||
|     if( byteReceived > 0 ) { |     if( byteReceived > 0 ) { | ||||||
|  |  | ||||||
|         requestBuf[byteReceived] = '\0'; |         requestBuf[byteReceived] = '\0'; | ||||||
|         DBGONLY( UpnpPrintf( UPNP_INFO, SSDP, |         UpnpPrintf( UPNP_INFO, SSDP, | ||||||
|                              __FILE__, __LINE__, |                              __FILE__, __LINE__, | ||||||
|                              "Received response !!!  " |                              "Received response !!!  " | ||||||
|                              "%s From host %s \n", |                              "%s From host %s \n", | ||||||
|                              requestBuf, |                              requestBuf, | ||||||
|                              inet_ntoa( clientAddr.sin_addr ) ); |                              inet_ntoa( clientAddr.sin_addr ) ); | ||||||
|              ) |  | ||||||
|  |  | ||||||
|             DBGONLY( UpnpPrintf( UPNP_PACKET, SSDP, |         UpnpPrintf( UPNP_PACKET, SSDP, __FILE__, __LINE__, | ||||||
|                                  __FILE__, __LINE__, |  | ||||||
|             "Received multicast packet:" |             "Received multicast packet:" | ||||||
|             "\n %s\n", requestBuf ); |             "\n %s\n", requestBuf ); | ||||||
|              ) |  | ||||||
|         //add thread pool job to handle request |         //add thread pool job to handle request | ||||||
|         if( data != NULL ) { |         if( data != NULL ) { | ||||||
|             data->parser.msg.msg.length += byteReceived; |             data->parser.msg.msg.length += byteReceived; | ||||||
| @@ -891,7 +846,6 @@ readFromSSDPSocket( SOCKET socket ) | |||||||
|                 free_ssdp_event_handler_data( data ); |                 free_ssdp_event_handler_data( data ); | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|  |  | ||||||
|     } else { |     } else { | ||||||
|         free_ssdp_event_handler_data( data ); |         free_ssdp_event_handler_data( data ); | ||||||
|     } |     } | ||||||
| @@ -926,9 +880,9 @@ get_ssdp_sockets( MiniServerSockArray * out ) | |||||||
|  |  | ||||||
|     CLIENTONLY( if( ( ssdpReqSock = socket( AF_INET, SOCK_DGRAM, 0 ) ) |     CLIENTONLY( if( ( ssdpReqSock = socket( AF_INET, SOCK_DGRAM, 0 ) ) | ||||||
|                     == UPNP_INVALID_SOCKET ) { |                     == UPNP_INVALID_SOCKET ) { | ||||||
|                 DBGONLY( UpnpPrintf( UPNP_CRITICAL, |                 UpnpPrintf( UPNP_CRITICAL, | ||||||
|                     SSDP, __FILE__, __LINE__, |                     SSDP, __FILE__, __LINE__, | ||||||
|                                      "Error in socket operation !!!\n" ); ) |                     "Error in socket operation !!!\n" ); | ||||||
|                 return UPNP_E_OUTOF_SOCKET;} |                 return UPNP_E_OUTOF_SOCKET;} | ||||||
|                 setsockopt( ssdpReqSock, |                 setsockopt( ssdpReqSock, | ||||||
|                             IPPROTO_IP, |                             IPPROTO_IP, | ||||||
| @@ -938,10 +892,9 @@ get_ssdp_sockets( MiniServerSockArray * out ) | |||||||
|  |  | ||||||
|         if( ( ssdpSock = socket( AF_INET, SOCK_DGRAM, 0 ) ) |         if( ( ssdpSock = socket( AF_INET, SOCK_DGRAM, 0 ) ) | ||||||
|             == UPNP_INVALID_SOCKET ) { |             == UPNP_INVALID_SOCKET ) { | ||||||
|             DBGONLY( UpnpPrintf( UPNP_CRITICAL, |             UpnpPrintf( UPNP_CRITICAL, | ||||||
|                 SSDP, __FILE__, __LINE__, |                 SSDP, __FILE__, __LINE__, | ||||||
|                 "Error in socket operation !!!\n" ); |                 "Error in socket operation !!!\n" ); | ||||||
|                  ) |  | ||||||
|             CLIENTONLY( shutdown( ssdpReqSock, SD_BOTH ) ); |             CLIENTONLY( shutdown( ssdpReqSock, SD_BOTH ) ); | ||||||
|             CLIENTONLY( UpnpCloseSocket( ssdpReqSock ) ); |             CLIENTONLY( UpnpCloseSocket( ssdpReqSock ) ); | ||||||
|             return UPNP_E_OUTOF_SOCKET; |             return UPNP_E_OUTOF_SOCKET; | ||||||
| @@ -951,10 +904,9 @@ get_ssdp_sockets( MiniServerSockArray * out ) | |||||||
|     if( setsockopt( ssdpSock, SOL_SOCKET, SO_REUSEADDR, |     if( setsockopt( ssdpSock, SOL_SOCKET, SO_REUSEADDR, | ||||||
|                     ( char * )&onOff, sizeof( onOff ) ) != 0 ) { |                     ( char * )&onOff, sizeof( onOff ) ) != 0 ) { | ||||||
|  |  | ||||||
|         DBGONLY( UpnpPrintf( UPNP_CRITICAL, |         UpnpPrintf( UPNP_CRITICAL, | ||||||
|             SSDP, __FILE__, __LINE__, |             SSDP, __FILE__, __LINE__, | ||||||
|             "Error in set reuse addr !!!\n" ); |             "Error in set reuse addr !!!\n" ); | ||||||
|              ) |  | ||||||
|         CLIENTONLY( shutdown( ssdpReqSock, SD_BOTH ) ); |         CLIENTONLY( shutdown( ssdpReqSock, SD_BOTH ) ); | ||||||
|         CLIENTONLY( UpnpCloseSocket( ssdpReqSock ) ); |         CLIENTONLY( UpnpCloseSocket( ssdpReqSock ) ); | ||||||
|         shutdown( ssdpSock, SD_BOTH ); |         shutdown( ssdpSock, SD_BOTH ); | ||||||
| @@ -966,10 +918,9 @@ get_ssdp_sockets( MiniServerSockArray * out ) | |||||||
|     if( setsockopt( ssdpSock, SOL_SOCKET, SO_REUSEPORT, |     if( setsockopt( ssdpSock, SOL_SOCKET, SO_REUSEPORT, | ||||||
|                     ( char * )&onOff, sizeof( onOff ) ) != 0 ) { |                     ( char * )&onOff, sizeof( onOff ) ) != 0 ) { | ||||||
|  |  | ||||||
|         DBGONLY( UpnpPrintf( UPNP_CRITICAL, |         UpnpPrintf( UPNP_CRITICAL, | ||||||
|             SSDP, __FILE__, __LINE__, |             SSDP, __FILE__, __LINE__, | ||||||
|             "Error in set reuse port !!!\n" ); |             "Error in set reuse port !!!\n" ); | ||||||
|              ) |  | ||||||
|         CLIENTONLY( shutdown( ssdpReqSock, SD_BOTH ) ); |         CLIENTONLY( shutdown( ssdpReqSock, SD_BOTH ) ); | ||||||
|         CLIENTONLY( UpnpCloseSocket( ssdpReqSock ) ); |         CLIENTONLY( UpnpCloseSocket( ssdpReqSock ) ); | ||||||
|         shutdown( ssdpSock, SD_BOTH ); |         shutdown( ssdpSock, SD_BOTH ); | ||||||
| @@ -986,10 +937,9 @@ get_ssdp_sockets( MiniServerSockArray * out ) | |||||||
|     if( bind |     if( bind | ||||||
|         ( ssdpSock, ( struct sockaddr * )&ssdpAddr, |         ( ssdpSock, ( struct sockaddr * )&ssdpAddr, | ||||||
|           sizeof( ssdpAddr ) ) != 0 ) { |           sizeof( ssdpAddr ) ) != 0 ) { | ||||||
|         DBGONLY( UpnpPrintf |         UpnpPrintf( UPNP_CRITICAL, | ||||||
|                  ( UPNP_CRITICAL, SSDP, __FILE__, __LINE__, |             SSDP, __FILE__, __LINE__, | ||||||
|             "Error in binding !!!\n" ); |             "Error in binding !!!\n" ); | ||||||
|              ) |  | ||||||
|             shutdown( ssdpSock, SD_BOTH ); |             shutdown( ssdpSock, SD_BOTH ); | ||||||
|         UpnpCloseSocket( ssdpSock ); |         UpnpCloseSocket( ssdpSock ); | ||||||
|         CLIENTONLY( shutdown( ssdpReqSock, SD_BOTH ) ); |         CLIENTONLY( shutdown( ssdpReqSock, SD_BOTH ) ); | ||||||
| @@ -1003,10 +953,9 @@ get_ssdp_sockets( MiniServerSockArray * out ) | |||||||
|     if( setsockopt( ssdpSock, IPPROTO_IP, IP_ADD_MEMBERSHIP, |     if( setsockopt( ssdpSock, IPPROTO_IP, IP_ADD_MEMBERSHIP, | ||||||
|                     ( char * )&ssdpMcastAddr, |                     ( char * )&ssdpMcastAddr, | ||||||
|                     sizeof( struct ip_mreq ) ) != 0 ) { |                     sizeof( struct ip_mreq ) ) != 0 ) { | ||||||
|         DBGONLY( UpnpPrintf |         UpnpPrintf( UPNP_CRITICAL, | ||||||
|                  ( UPNP_CRITICAL, SSDP, __FILE__, __LINE__, |             SSDP, __FILE__, __LINE__, | ||||||
|             "Error in joining" " multicast group !!!\n" ); |             "Error in joining" " multicast group !!!\n" ); | ||||||
|              ) |  | ||||||
|         shutdown( ssdpSock, SD_BOTH ); |         shutdown( ssdpSock, SD_BOTH ); | ||||||
|         CLIENTONLY( shutdown( ssdpReqSock, SD_BOTH ) ); |         CLIENTONLY( shutdown( ssdpReqSock, SD_BOTH ) ); | ||||||
|         UpnpCloseSocket( ssdpSock ); |         UpnpCloseSocket( ssdpSock ); | ||||||
| @@ -1019,8 +968,8 @@ get_ssdp_sockets( MiniServerSockArray * out ) | |||||||
|     addr.s_addr = inet_addr(LOCAL_HOST); |     addr.s_addr = inet_addr(LOCAL_HOST); | ||||||
|     if (setsockopt(ssdpSock, IPPROTO_IP, IP_MULTICAST_IF, |     if (setsockopt(ssdpSock, IPPROTO_IP, IP_MULTICAST_IF, | ||||||
|                    (char *)&addr, sizeof addr) != 0) { |                    (char *)&addr, sizeof addr) != 0) { | ||||||
|         DBGONLY(UpnpPrintf( UPNP_INFO, SSDP, __FILE__, __LINE__, |         UpnpPrintf( UPNP_INFO, SSDP, __FILE__, __LINE__, | ||||||
|                             "Couldn't set multicast interface.\n" )); |             "Couldn't set multicast interface.\n" ); | ||||||
|         /* This is probably not a critical error, so let's continue. */ |         /* This is probably not a critical error, so let's continue. */ | ||||||
|     } |     } | ||||||
|  |  | ||||||
| @@ -1029,10 +978,9 @@ get_ssdp_sockets( MiniServerSockArray * out ) | |||||||
|                 IP_MULTICAST_TTL, &ttl, sizeof( ttl ) ); |                 IP_MULTICAST_TTL, &ttl, sizeof( ttl ) ); | ||||||
|     if( setsockopt( ssdpSock, SOL_SOCKET, SO_BROADCAST, |     if( setsockopt( ssdpSock, SOL_SOCKET, SO_BROADCAST, | ||||||
|                     ( char * )&option, sizeof( option ) ) != 0 ) { |                     ( char * )&option, sizeof( option ) ) != 0 ) { | ||||||
|         DBGONLY( UpnpPrintf( UPNP_CRITICAL, |         UpnpPrintf( UPNP_CRITICAL, | ||||||
|             SSDP, __FILE__, __LINE__, |             SSDP, __FILE__, __LINE__, | ||||||
|             "Error in setting broadcast !!!\n" ); |             "Error in setting broadcast !!!\n" ); | ||||||
|              ) |  | ||||||
|         shutdown( ssdpSock, SD_BOTH ); |         shutdown( ssdpSock, SD_BOTH ); | ||||||
|         CLIENTONLY( shutdown( ssdpReqSock, SD_BOTH ) ); |         CLIENTONLY( shutdown( ssdpReqSock, SD_BOTH ) ); | ||||||
|         UpnpCloseSocket( ssdpSock ); |         UpnpCloseSocket( ssdpSock ); | ||||||
|   | |||||||
| @@ -62,7 +62,7 @@ | |||||||
| * | * | ||||||
| *	Note : | *	Note : | ||||||
| ************************************************************************/ | ************************************************************************/ | ||||||
| static XINLINE void | static UPNP_INLINE void | ||||||
| addrToString( IN const struct sockaddr_in *addr, | addrToString( IN const struct sockaddr_in *addr, | ||||||
|               OUT char ipaddr_port[] ) |               OUT char ipaddr_port[] ) | ||||||
| { | { | ||||||
| @@ -87,7 +87,7 @@ addrToString( IN const struct sockaddr_in *addr, | |||||||
| * | * | ||||||
| *	Note : 'newAlias' should be freed using free() | *	Note : 'newAlias' should be freed using free() | ||||||
| ************************************************************************/ | ************************************************************************/ | ||||||
| static XINLINE int | static UPNP_INLINE int | ||||||
| calc_alias( IN const char *alias, | calc_alias( IN const char *alias, | ||||||
|             IN const char *rootPath, |             IN const char *rootPath, | ||||||
|             OUT char **newAlias ) |             OUT char **newAlias ) | ||||||
| @@ -148,7 +148,7 @@ calc_alias( IN const char *alias, | |||||||
| * | * | ||||||
| *	Note : | *	Note : | ||||||
| ************************************************************************/ | ************************************************************************/ | ||||||
| static XINLINE int | static UPNP_INLINE int | ||||||
| calc_descURL( IN const char *ipPortStr, | calc_descURL( IN const char *ipPortStr, | ||||||
|               IN const char *alias, |               IN const char *alias, | ||||||
|               OUT char descURL[LINE_SIZE] ) |               OUT char descURL[LINE_SIZE] ) | ||||||
| @@ -168,9 +168,8 @@ calc_descURL( IN const char *ipPortStr, | |||||||
|     strcat( descURL, ipPortStr ); |     strcat( descURL, ipPortStr ); | ||||||
|     strcat( descURL, alias ); |     strcat( descURL, alias ); | ||||||
|  |  | ||||||
|     DBGONLY( UpnpPrintf( UPNP_INFO, API, __FILE__, __LINE__, |     UpnpPrintf( UPNP_INFO, API, __FILE__, __LINE__, | ||||||
|         "desc url: %s\n", descURL ); |         "desc url: %s\n", descURL ); | ||||||
|          ) |  | ||||||
|  |  | ||||||
|     return UPNP_E_SUCCESS; |     return UPNP_E_SUCCESS; | ||||||
| } | } | ||||||
| @@ -408,18 +407,16 @@ configure_urlbase( INOUT IXML_Document * doc, | |||||||
|         goto error_handler; |         goto error_handler; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     DBGONLY( UpnpPrintf( UPNP_INFO, API, __FILE__, __LINE__, |     UpnpPrintf( UPNP_INFO, API, __FILE__, __LINE__, | ||||||
|         "desc url: %s\n", docURL ); |         "desc url: %s\n", docURL ); | ||||||
|          ) |     UpnpPrintf( UPNP_INFO, API, __FILE__, __LINE__, | ||||||
|         DBGONLY( UpnpPrintf( UPNP_INFO, API, __FILE__, __LINE__, |  | ||||||
|         "doc = %s\n", xml_str ); |         "doc = %s\n", xml_str ); | ||||||
|          ) |  | ||||||
|     // store in web server |     // store in web server | ||||||
|     err_code = |     err_code = | ||||||
|         web_server_set_alias( new_alias, xml_str, strlen( xml_str ), |         web_server_set_alias( new_alias, xml_str, strlen( xml_str ), | ||||||
|                               last_modified ); |                               last_modified ); | ||||||
|  |  | ||||||
|   error_handler: | error_handler: | ||||||
|     free( root_path ); |     free( root_path ); | ||||||
|     free( new_alias ); |     free( new_alias ); | ||||||
|  |  | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user