Browse Source

[libmicrohttpd] Patches for Windows version of libmicrohttpd
From:
Gerrit Telkamp <[email protected]>
To:
[email protected]
Date:
Today 11:42:30
Attachments:
libmicrohttpd-windows.patch

It was a bit tricky to build libmicrohttpd (SVN trunk) for Windows.
I'm using the newest MSYS/MinGW environment (GCC 4.5.1).
I've optimized the autoconf feature, so this should be easier in future.
Please find enclosed my patches.

In detail:
1- libmicrohttpd needs the "PlibC" library under Windows (libplibc.a).
Methods of PlibC are referenced by src/daemon/daemon.c.
autoconf assumes that PlibC is installed on the Build environment and
does not check this.
If PlibC is not installed, the pthreads check (see "acinclude.m4") will
fail and stops with the wrong error message "Your system is not
supporting pthreads". This is very confusing.

The patch includes an additional check for PlibC, before pthreads is
used. The check is only done under cygwin and mingw environments.

Furthermore, an older version of plibc.h was in the include directory.
This gives some problems if you are using a newer version of the PlibC
library. So I propose to exclude src/include/plibc.h from the SVN

Files affected:
acinclude.m4 (modified)
configure.ac (modified)
src/include/plibc.h (deleted)

2- setsockopt() uses a different parameter type under Windows ("optval"
is const char). This caused an error when src/daemon/daemon.c was compiled.

The patch enclosed includes a different call of the setsockopt() on
Windows machines.
Important: IPV6_V6ONLY is not available on Windows machines < Windows 7!
So this parameter is "0". But there is a TODO comment, maybe someone has
an idea how to solve this on Windows XP machines.

Files affected:
src/daemon/daemon.c (modified)

I have tested the patch on a MinGW / MSYS environment only.

Best regards

Gerrit.

libmicrohttpd-windows.patch

Christian Grothoff 15 năm trước cách đây
mục cha
commit
02dc5b39a1
5 tập tin đã thay đổi với 148 bổ sung76 xóa
  1. 1 0
      AUTHORS
  2. 3 0
      ChangeLog
  3. 113 70
      acinclude.m4
  4. 15 5
      configure.ac
  5. 16 1
      src/daemon/daemon.c

+ 1 - 0
AUTHORS

@@ -24,6 +24,7 @@ Mike Crowe <[email protected]>
 John Muth <[email protected]>
 Geoffrey McRae <[email protected]>
 Piotr Grzybowski <[email protected]>
+Gerrit Telkamp <[email protected]>
 
 Documentation contributions also came from:
 Marco Maggi <[email protected]>

+ 3 - 0
ChangeLog

@@ -1,3 +1,6 @@
+Thu Aug 19 13:26:00 CEST 2010
+	Patches for Windows to ease compilation trouble. -GT/CG
+
 Sat Aug 14 15:43:30 CEST 2010
 	Fixed small, largely hypothetical leaks. 
 	Reduced calls to strlen for header processing. -CG

+ 113 - 70
acinclude.m4

@@ -1,75 +1,118 @@
+AC_DEFUN([CHECK_PLIBC],
+[
+    # On windows machines, check if PlibC is available. First try without -plibc
+    AC_TRY_LINK(
+    [
+        #include <plibc.h>
+    ],[
+        plibc_init("", "");
+    ],[
+        AC_MSG_RESULT(yes)
+        PLIBC_CPPFLAGS=
+        PLIBC_LDFLAGS=
+        PLIBC_LIBS=
+    ],[
+
+        # now with -plibc
+        AC_CHECK_LIB(plibc,plibc_init,
+        [
+            PLIBC_CPPFLAGS=
+            PLIBC_LDFLAGS=
+            PLIBC_LIBS=-lplibc
+        ],[
+            AC_MSG_CHECKING(if PlibC is installed)
+            save_CPPFLAGS="$CPPFLAGS"
+            CPPFLAGS="$CPPFLAGS -plibc"
+            AC_TRY_LINK(
+            [
+                #include <plibc.h>
+            ],[
+                plibc_init("", "");
+            ],[
+                AC_MSG_RESULT(yes)
+                PLIBC_CPPFLAGS=-plibc
+                PLIBC_LDFLAGS=-plibc
+                PLIBC_LIBS=
+            ],[
+                AC_MSG_ERROR([PlibC is not available on your windows machine!])
+            ])
+        ])
+    ])
+    CPPFLAGS="$save_CPPFLAGS"
+])
+
 # See: http://gcc.gnu.org/ml/gcc/2000-05/msg01141.html
 AC_DEFUN([CHECK_PTHREAD],
 [
-        # first try without -pthread
-        AC_TRY_LINK(
-		[
-			#include <pthread.h>
-		],[
-			pthread_create(0,0,0,0);
-		],[
-			AC_MSG_RESULT(yes)
-			PTHREAD_CPPFLAGS=
-			PTHREAD_LDFLAGS=
-			PTHREAD_LIBS=
-		],[
-        # now with -pthread        
-	AC_CHECK_LIB(pthread,pthread_create,
-	[
-		PTHREAD_CPPFLAGS=
-		PTHREAD_LDFLAGS=
-		PTHREAD_LIBS=-lpthread
-	],[
-		AC_MSG_CHECKING(if compiler supports -pthread)
-		save_CPPFLAGS="$CPPFLAGS"
-		CPPFLAGS="$CPPFLAGS -pthread"
-		AC_TRY_LINK(
-		[
-			#include <pthread.h>
-		],[
-			pthread_create(0,0,0,0);
-		],[
-			AC_MSG_RESULT(yes)
-			PTHREAD_CPPFLAGS=-pthread
-			PTHREAD_LDFLAGS=-pthread
-			PTHREAD_LIBS=
-		],[
-			AC_MSG_RESULT(no)
-			AC_MSG_CHECKING(if compiler supports -pthreads)
-			save_CPPFLAGS="$CPPFLAGS"
-			CPPFLAGS="$save_CPPFLAGS -pthreads"
-			AC_TRY_LINK(
-			[
-				#include <pthread.h>
-			],[
-				pthread_create(0,0,0,0);
-			],[
-				AC_MSG_RESULT(yes)
-				PTHREAD_CPPFLAGS=-pthreads
-				PTHREAD_LDFLAGS=-pthreads
-				PTHREAD_LIBS=
-			],[
-				AC_MSG_RESULT(no)
-				AC_MSG_CHECKING(if compiler supports -threads)
-				save_CPPFLAGS="$CPPFLAGS"
-				CPPFLAGS="$save_CPPFLAGS -threads"
-				AC_TRY_LINK(
-				[
-					#include <pthread.h>
-				],[
-					pthread_create(0,0,0,0);
-				],[
-					AC_MSG_RESULT(yes)
-					PTHREAD_CPPFLAGS=-threads
-					PTHREAD_LDFLAGS=-threads
-					PTHREAD_LIBS=
-				],[
-					AC_MSG_ERROR([Your system is not supporting pthreads!])
-				])
-			])
-		])
-		CPPFLAGS="$save_CPPFLAGS"
-	])
-         
+    # first try without -pthread
+    AC_TRY_LINK(
+    [
+        #include <pthread.h>
+    ],[
+        pthread_create(0,0,0,0);
+    ],[
+        AC_MSG_RESULT(yes)
+        PTHREAD_CPPFLAGS=
+        PTHREAD_LDFLAGS=
+        PTHREAD_LIBS=
+    ],[
+
+        # now with -pthread
+        AC_CHECK_LIB(pthread,pthread_create,
+        [
+            PTHREAD_CPPFLAGS=
+            PTHREAD_LDFLAGS=
+            PTHREAD_LIBS=-lpthread
+        ],[
+            AC_MSG_CHECKING(if compiler supports -pthread)
+            save_CPPFLAGS="$CPPFLAGS"
+            CPPFLAGS="$CPPFLAGS -pthread"
+            AC_TRY_LINK(
+            [
+                #include <pthread.h>
+            ],[
+                pthread_create(0,0,0,0);
+            ],[
+                AC_MSG_RESULT(yes)
+                PTHREAD_CPPFLAGS=-pthread
+                PTHREAD_LDFLAGS=-pthread
+                PTHREAD_LIBS=
+            ],[
+                AC_MSG_RESULT(no)
+                AC_MSG_CHECKING(if compiler supports -pthreads)
+                save_CPPFLAGS="$CPPFLAGS"
+                CPPFLAGS="$save_CPPFLAGS -pthreads"
+                AC_TRY_LINK(
+                [
+                    #include <pthread.h>
+                ],[
+                    pthread_create(0,0,0,0);
+                ],[
+                    AC_MSG_RESULT(yes)
+                    PTHREAD_CPPFLAGS=-pthreads
+                    PTHREAD_LDFLAGS=-pthreads
+                    PTHREAD_LIBS=
+                ],[
+                    AC_MSG_RESULT(no)
+                    AC_MSG_CHECKING(if compiler supports -threads)
+                    save_CPPFLAGS="$CPPFLAGS"
+                    CPPFLAGS="$save_CPPFLAGS -threads"
+                    AC_TRY_LINK(
+                    [
+                        #include <pthread.h>
+                    ],[
+                        pthread_create(0,0,0,0);
+                    ],[
+                        AC_MSG_RESULT(yes)
+                        PTHREAD_CPPFLAGS=-threads
+                        PTHREAD_LDFLAGS=-threads
+                        PTHREAD_LIBS=
+                    ],[
+                        AC_MSG_ERROR([Your system is not supporting pthreads!])
+                    ])
+                ])
+            ])
+            CPPFLAGS="$save_CPPFLAGS"
         ])
+    ])
 ])

+ 15 - 5
configure.ac

@@ -72,6 +72,8 @@ then
  CFLAGS="-fno-strict-aliasing $CFLAGS"
 fi
 
+# for pkg-config
+MHD_LIBDEPS=""
 
 # Check system type
 case "$host_os" in
@@ -115,12 +117,24 @@ netbsd*)
      AC_DEFINE_UNQUOTED(CYGWIN,1,[This is a Cygwin system])
      AM_CONDITIONAL(HAVE_GNU_LD, false)    
      LDFLAGS="$LDFLAGS -no-undefined"
+     # check if PlibC is available
+     CHECK_PLIBC
+     LIBS="$PLIBC_LIBS $LIBS"
+     AC_SUBST(PLIBC_LIBS)
+     AC_SUBST(PLIBC_LDFLAGS)
+     AC_SUBST(PLIBC_CPPFLAGS)
      ;;
 *mingw*)
      AC_DEFINE_UNQUOTED(MINGW,1,[This is a MinGW system])
      AC_DEFINE_UNQUOTED(WINDOWS,1,[This is a Windows system])
-     LDFLAGS="$LDFLAGS -no-undefined -Wl,--export-all-symbols -lws2_32 -lplibc"
+     LDFLAGS="$LDFLAGS -no-undefined -Wl,--export-all-symbols -lws2_32"
      AM_CONDITIONAL(HAVE_GNU_LD, true)    
+     # check if PlibC is available
+     CHECK_PLIBC
+     LIBS="$PLIBC_LIBS $LIBS"
+     AC_SUBST(PLIBC_LIBS)
+     AC_SUBST(PLIBC_LDFLAGS)
+     AC_SUBST(PLIBC_CPPFLAGS)
      ;;
 *openedition*)
      AC_DEFINE_UNQUOTED(OS390,1,[This is a OS/390 system])
@@ -133,10 +147,6 @@ netbsd*)
 ;;
 esac
 
-
-# for pkg-config
-MHD_LIBDEPS=""
-
 CHECK_PTHREAD
 LIBS="$PTHREAD_LIBS $LIBS"
 AC_SUBST(PTHREAD_LIBS)

+ 16 - 1
src/daemon/daemon.c

@@ -1642,10 +1642,25 @@ MHD_start_daemon_va (unsigned int options,
 
       if ((options & MHD_USE_IPv6) != 0)
 	{
+#ifdef IPPROTO_IPV6
+#ifdef IPV6_V6ONLY
+	  /* Note: "IPV6_V6ONLY" is declared by Windows Vista ff., see "IPPROTO_IPV6 Socket Options" 
+	     (http://msdn.microsoft.com/en-us/library/ms738574%28v=VS.85%29.aspx); 
+	     and may also be missing on older POSIX systems; good luck if you have any of those,
+	     your IPv6 socket may then also bind against IPv4... */
+#ifndef WINDOWS
 	  const int on = 1;
 	  setsockopt (socket_fd, 
 		      IPPROTO_IPV6, IPV6_V6ONLY, 
-		      &on, sizeof (on));      
+		      &on, sizeof (on));
+#else
+	  const char on = 1;
+	  setsockopt (socket_fd, 
+		      IPPROTO_IPV6, IPV6_V6ONLY, 
+		      &on, sizeof (on));
+#endif
+#endif
+#endif
 	}
       if (BIND (socket_fd, servaddr, addrlen) == -1)
 	{