summaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorLuis Saavedra <luis94855510@gmail.com>2012-03-20 20:13:33 (GMT)
committerLuis Saavedra <luis94855510@gmail.com>2012-03-20 20:13:33 (GMT)
commit60b0da738c102fa5b80c1919cf8201154f1db6c7 (patch)
tree85d18022710f0c505604272bed5ab83577da6934 /src
parent4258844ae3006ab8d15aff6c7115fce492588c06 (diff)
downloadmxe-60b0da738c102fa5b80c1919cf8201154f1db6c7.zip
mxe-60b0da738c102fa5b80c1919cf8201154f1db6c7.tar.gz
mxe-60b0da738c102fa5b80c1919cf8201154f1db6c7.tar.bz2
simplication of winpcap build rules
Diffstat (limited to 'src')
-rw-r--r--src/winpcap-1-fixes.patch181
-rw-r--r--src/winpcap.mk19
2 files changed, 171 insertions, 29 deletions
diff --git a/src/winpcap-1-fixes.patch b/src/winpcap-1-fixes.patch
index e261044..7f79bf7 100644
--- a/src/winpcap-1-fixes.patch
+++ b/src/winpcap-1-fixes.patch
@@ -3,18 +3,153 @@ See doc/index.html for further information.
Contains ad hoc patches for cross building.
-From ae2d9b90df55a6c1ba801675a81723ceb8377e62 Mon Sep 17 00:00:00 2001
-From: mingw-cross-env
-Date: Sun, 27 Mar 2011 23:49:46 +0200
-Subject: [PATCH] remove obsolete -mno-cygwin
-
-
-diff --git a/wpcap/PRJ/GNUmakefile b/wpcap/PRJ/GNUmakefile
-index ccf3677..8313b4c 100644
---- a/wpcap/PRJ/GNUmakefile
-+++ b/wpcap/PRJ/GNUmakefile
-@@ -32,7 +32,7 @@ CFLAGS = -I ../libpcap -I ../libpcap/bpf -I ../libpcap/lbl \
- -DHAVE_REMOTE -DHAVE_AIRPCAP_API \
+diff -ur a/packetNtx/Dll/Packet32.c b/packetNtx/Dll/Packet32.c
+--- a/packetNtx/Dll/Packet32.c 2008-11-18 12:17:42.000000000 -0300
++++ b/packetNtx/Dll/Packet32.c 2012-03-20 10:36:30.724465335 -0300
+@@ -44,11 +44,11 @@
+ //
+ #define _CRT_SECURE_NO_WARNINGS
+
+-#include <packet32.h>
+-#include <StrSafe.h>
++#include <Packet32.h>
++#include <strsafe.h>
+
+ #include "Packet32-Int.h"
+-#include "..\driver\ioctls.h"
++#include "../driver/ioctls.h"
+
+ #ifdef HAVE_WANPACKET_API
+ #include "wanpacket/wanpacket.h"
+@@ -98,8 +98,8 @@
+
+ #include <windows.h>
+ #include <windowsx.h>
+-#include <Iphlpapi.h>
+-#include <IPIfCons.h>
++#include <iphlpapi.h>
++#include <ipifcons.h>
+
+ #include <WpcapNames.h>
+
+diff -ur a/wpcap/libpcap/inet.c b/wpcap/libpcap/inet.c
+--- a/wpcap/libpcap/inet.c 2009-10-07 01:20:04.000000000 -0400
++++ b/wpcap/libpcap/inet.c 2012-03-20 10:38:56.920472410 -0300
+@@ -804,7 +804,7 @@
+ while(NAdapts--)
+ {
+ strcpy((char*)tUstr, tAstr);
+- (char*)tUstr += strlen(tAstr) + 1;;
++ tUstr += strlen(tAstr) + 1;;
+ tAstr += strlen(tAstr) + 1;
+ }
+
+diff -ur a/wpcap/libpcap/Win32/Src/gai_strerror.c b/wpcap/libpcap/Win32/Src/gai_strerror.c
+--- a/wpcap/libpcap/Win32/Src/gai_strerror.c 2009-10-07 01:19:58.000000000 -0400
++++ b/wpcap/libpcap/Win32/Src/gai_strerror.c 2012-03-20 10:41:17.604479218 -0300
+@@ -1,83 +1 @@
+-/*
+- * Copyright (C) 1995, 1996, 1997, and 1998 WIDE Project.
+- * All rights reserved.
+- *
+- * 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. Neither the name of the project 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 PROJECT 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 THE PROJECT 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 <sys/cdefs.h>
+-
+-__FBSDID("$FreeBSD: /repoman/r/ncvs/src/lib/libc/net/gai_strerror.c,v 1.1 2005/04/06 12:45:51 ume Exp $");
+-
+-*/
+-
+-#ifdef WIN32
+-
+-#include <ws2tcpip.h>
+-
+-#else
+-
+-#include <netdb.h>
+-
+-#endif
+-
+-/* Entries EAI_ADDRFAMILY (1) and EAI_NODATA (7) are obsoleted, but left */
+-/* for backward compatibility with userland code prior to 2553bis-02 */
+-static char *ai_errlist[] = {
+- "Success", /* 0 */
+- "Address family for hostname not supported", /* 1 */
+- "Temporary failure in name resolution", /* EAI_AGAIN */
+- "Invalid value for ai_flags", /* EAI_BADFLAGS */
+- "Non-recoverable failure in name resolution", /* EAI_FAIL */
+- "ai_family not supported", /* EAI_FAMILY */
+- "Memory allocation failure", /* EAI_MEMORY */
+- "No address associated with hostname", /* 7 */
+- "hostname nor servname provided, or not known", /* EAI_NONAME */
+- "servname not supported for ai_socktype", /* EAI_SERVICE */
+- "ai_socktype not supported", /* EAI_SOCKTYPE */
+- "System error returned in errno", /* EAI_SYSTEM */
+- "Invalid value for hints", /* EAI_BADHINTS */
+- "Resolved protocol is unknown" /* EAI_PROTOCOL */
+-};
+-
+-#ifndef EAI_MAX
+-#define EAI_MAX (sizeof(ai_errlist)/sizeof(ai_errlist[0]))
+-#endif
+-
+-/* on MingW, gai_strerror is available.
+- We need to compile gai_strerrorA only for Cygwin
+- */
+-#ifndef gai_strerror
+-
+-char *
+-WSAAPI gai_strerrorA(int ecode)
+-{
+- if (ecode >= 0 && ecode < EAI_MAX)
+- return ai_errlist[ecode];
+- return "Unknown error";
+-}
+-
+-#endif /* gai_strerror */
+\ No hay ningún carácter de nueva línea al final del archivo
++/* already handled by <ws2tcpip.h> */
+diff -ur a/wpcap/PRJ/GNUmakefile b/wpcap/PRJ/GNUmakefile
+--- a/wpcap/PRJ/GNUmakefile 2009-07-24 08:03:00.000000000 -0400
++++ b/wpcap/PRJ/GNUmakefile 2012-03-20 10:40:51.208477942 -0300
+@@ -22,17 +22,17 @@
+
+ CFLAGS = -I ../libpcap -I ../libpcap/bpf -I ../libpcap/lbl \
+ -I ../libpcap/Win32/Include -I../libpcap/Win32/Include/ipv6kit \
+- -I ../../common -I ../Win32-Extensions \
++ -I ../../Common -I ../Win32-Extensions \
+ -I ../../../Airpcap_DevPack/include \
+ -DLIBPCAP_EXPORTS -DYY_NEVER_INTERACTIVE -Dyylval=pcap_lval \
+ -DHAVE_STRERROR -DNEED_ADDRINFO_H -DINET6 -DWIN32 \
+ -DSIZEOF_CHAR=1 -DSIZEOF_SHORT=2 -DSIZEOF_INT=4 -DSIZEOF_LONG_LONG=8 -DWPCAP -D'_U_=' \
+ -DHAVE_SNPRINTF -DHAVE_VSNPRINTF \
+ -DSIZEOF_LONG_LONG=8 \
+- -DHAVE_REMOTE -DHAVE_AIRPCAP_API \
++ -DHAVE_REMOTE \
-DHAVE_TC_API \
-DHAVE_ADDRINFO \
- -mno-cygwin -shared ${OPTFLAGS}
@@ -22,6 +157,22 @@ index ccf3677..8313b4c 100644
LDFLAGS = -Wl,--out-implib,../lib/libwpcap.a
LIBS = -L ../../${PACKET_DIR}/DLL/Project -lPacket -lws2_32
OBJS = ../libpcap/bpf/net/bpf_filter.o \
---
-1.7.4.1
-
+@@ -88,3 +88,6 @@
+ ${LEX} ${LFLAGS} -t $< >$*.c
+ .c.o:
+ ${CC} ${CFLAGS} -o $*.o -c $<
++libwpcap.a: ${OBJS}
++ ${AR} rc $@ ${OBJS}
++ ${RANLIB} $@
+diff -ur a/wpcap/Win32-Extensions/Win32-Extensions.c b/wpcap/Win32-Extensions/Win32-Extensions.c
+--- a/wpcap/Win32-Extensions/Win32-Extensions.c 2008-05-20 13:25:00.000000000 -0400
++++ b/wpcap/Win32-Extensions/Win32-Extensions.c 2012-03-20 10:38:40.184471601 -0300
+@@ -33,7 +33,7 @@
+
+
+ #include "pcap-int.h"
+-#include <packet32.h>
++#include <Packet32.h>
+
+ #ifdef HAVE_REMOTE
+ #include <pcap-remote.h>
diff --git a/src/winpcap.mk b/src/winpcap.mk
index 2416a46..968f5e7 100644
--- a/src/winpcap.mk
+++ b/src/winpcap.mk
@@ -19,11 +19,7 @@ define $(PKG)_UPDATE
endef
define $(PKG)_BUILD
- $(SED) -i '/#include/ s,\\,/,g' '$(1)/packetNtx/Dll/Packet32.c'
- $(SED) -i 's,#include <packet32\.h>,#include <Packet32.h>,' '$(1)/packetNtx/Dll/Packet32.c'
- $(SED) -i 's,#include <StrSafe\.h>,#include <strsafe.h>,' '$(1)/packetNtx/Dll/Packet32.c'
- $(SED) -i 's,#include <Iphlpapi\.h>,#include <iphlpapi.h>,' '$(1)/packetNtx/Dll/Packet32.c'
- $(SED) -i 's,#include <IPIfCons\.h>,#include <ipifcons.h>,' '$(1)/packetNtx/Dll/Packet32.c'
+ # build
cd '$(1)' && $(TARGET)-gcc -ICommon -IpacketNtx/Dll -O -c '$(1)/packetNtx/Dll/Packet32.c'
$(TARGET)-ar rc '$(1)/libpacket.a' '$(1)/Packet32.o'
$(TARGET)-ranlib '$(1)/libpacket.a'
@@ -31,15 +27,10 @@ define $(PKG)_BUILD
$(INSTALL) -m644 '$(1)/Common'/*.h '$(PREFIX)/$(TARGET)/include/'
$(INSTALL) -d '$(PREFIX)/$(TARGET)/lib'
$(INSTALL) -m644 '$(1)/libpacket.a' '$(PREFIX)/$(TARGET)/lib/'
- mv '$(1)/wpcap/libpcap/Win32/Include/ip6_misc.h' '$(1)/wpcap/libpcap/Win32/Include/IP6_misc.h'
- $(SED) -i 's,#include <packet32\.h>,#include <Packet32.h>,' '$(1)/wpcap/Win32-Extensions/Win32-Extensions.c'
- $(SED) -i 's,(char\*)tUstr +=,tUstr +=,' '$(1)/wpcap/libpcap/inet.c'
- $(SED) -i 's,-DHAVE_AIRPCAP_API,,' '$(1)/wpcap/PRJ/GNUmakefile'
- $(SED) -i 's,/common,/Common,' '$(1)/wpcap/PRJ/GNUmakefile'
- echo -e 'libwpcap.a: $${OBJS}' >> '$(1)/wpcap/PRJ/GNUmakefile'
- echo -e '\t$${AR} rc $$@ $${OBJS}' >> '$(1)/wpcap/PRJ/GNUmakefile'
- echo -e '\t$${RANLIB} $$@' >> '$(1)/wpcap/PRJ/GNUmakefile'
- echo '/* already handled by <ws2tcpip.h> */' > '$(1)/wpcap/libpcap/Win32/Src/gai_strerror.c'
+
+ mv '$(1)/wpcap/libpcap/Win32/Include/ip6_misc.h' '$(1)/file.tmp'
+ mv '$(1)/file.tmp' '$(1)/wpcap/libpcap/Win32/Include/IP6_misc.h'
+
CC='$(TARGET)-gcc' \
AR='$(TARGET)-ar' \
RANLIB='$(TARGET)-ranlib' \