summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorPeter Volkov <pva@gentoo.org>2008-08-13 04:36:23 +0000
committerPeter Volkov <pva@gentoo.org>2008-08-13 04:36:23 +0000
commit34e2e411ad1819e2db7279d4a39ef3228e2cdd97 (patch)
tree2dce417ef028908f74946c610bf370b35b1cbfe8 /net-firewall/ebtables
parentVerbump (diff)
downloadgentoo-2-34e2e411ad1819e2db7279d4a39ef3228e2cdd97.tar.gz
gentoo-2-34e2e411ad1819e2db7279d4a39ef3228e2cdd97.tar.bz2
gentoo-2-34e2e411ad1819e2db7279d4a39ef3228e2cdd97.zip
Fixed bug #233190, thank Suertreus for report. Also make ebtables respect LDFLAGS.
(Portage version: 2.2_rc7/cvs/Linux 2.6.22-ovz005 i686)
Diffstat (limited to 'net-firewall/ebtables')
-rw-r--r--net-firewall/ebtables/ChangeLog11
-rw-r--r--net-firewall/ebtables/ebtables-2.0.8.2-r1.ebuild50
-rw-r--r--net-firewall/ebtables/files/ebtables-v2.0.8-2-LDFLAGS.diff54
-rw-r--r--net-firewall/ebtables/files/ebtables-v2.0.8-2-ethertype-DESTDIR-mkdir.patch40
4 files changed, 154 insertions, 1 deletions
diff --git a/net-firewall/ebtables/ChangeLog b/net-firewall/ebtables/ChangeLog
index b30db41fdf52..7eb8032ef437 100644
--- a/net-firewall/ebtables/ChangeLog
+++ b/net-firewall/ebtables/ChangeLog
@@ -1,6 +1,15 @@
# ChangeLog for net-firewall/ebtables
# Copyright 2000-2008 Gentoo Foundation; Distributed under the GPL v2
-# $Header: /var/cvsroot/gentoo-x86/net-firewall/ebtables/ChangeLog,v 1.23 2008/05/11 11:04:49 pva Exp $
+# $Header: /var/cvsroot/gentoo-x86/net-firewall/ebtables/ChangeLog,v 1.24 2008/08/13 04:36:22 pva Exp $
+
+*ebtables-2.0.8.2-r1 (13 Aug 2008)
+
+ 13 Aug 2008; Peter Volkov <pva@gentoo.org>
+ +files/ebtables-v2.0.8-2-LDFLAGS.diff,
+ +files/ebtables-v2.0.8-2-ethertype-DESTDIR-mkdir.patch,
+ +ebtables-2.0.8.2-r1.ebuild:
+ Fixed bug #233190, thank Suertreus for report. Also make ebtables respect
+ LDFLAGS.
11 May 2008; Peter Volkov <pva@gentoo.org>
-files/ebtables-2.0.8.1-fix-textrel.patch,
diff --git a/net-firewall/ebtables/ebtables-2.0.8.2-r1.ebuild b/net-firewall/ebtables/ebtables-2.0.8.2-r1.ebuild
new file mode 100644
index 000000000000..95801e10f808
--- /dev/null
+++ b/net-firewall/ebtables/ebtables-2.0.8.2-r1.ebuild
@@ -0,0 +1,50 @@
+# Copyright 1999-2008 Gentoo Foundation
+# Distributed under the terms of the GNU General Public License v2
+# $Header: /var/cvsroot/gentoo-x86/net-firewall/ebtables/ebtables-2.0.8.2-r1.ebuild,v 1.1 2008/08/13 04:36:22 pva Exp $
+
+inherit versionator eutils toolchain-funcs multilib flag-o-matic
+
+MY_PV=$(replace_version_separator 3 '-' )
+MY_P="${PN}-v${MY_PV}"
+
+DESCRIPTION="Utility that enables basic Ethernet frame filtering on a Linux bridge, MAC NAT and brouting."
+SRC_URI="mirror://sourceforge/${PN}/${MY_P}.tar.gz"
+HOMEPAGE="http://ebtables.sourceforge.net/"
+KEYWORDS="~amd64 ~ppc ~x86"
+IUSE=""
+LICENSE="GPL-2"
+SLOT="0"
+
+S=${WORKDIR}/${MY_P}
+
+src_unpack() {
+ unpack ${A}
+ cd "${S}"
+
+ # Enchance ebtables-save to take table names as parameters bug #189315
+ epatch "${FILESDIR}"/${PN}-2.0.8.1-ebt-save.diff
+ epatch "${FILESDIR}"/${PN}-v2.0.8-2-LDFLAGS.diff
+ epatch "${FILESDIR}"/${PN}-v2.0.8-2-ethertype-DESTDIR-mkdir.patch
+
+ sed -i -e "s,^MANDIR:=.*,MANDIR:=/usr/share/man," \
+ -e "s,^BINDIR:=.*,BINDIR:=/sbin," \
+ -e "s,^INITDIR:=.*,INITDIR:=/usr/share/doc/${PF}," \
+ -e "s,^SYSCONFIGDIR:=.*,SYSCONFIGDIR:=/usr/share/doc/${PF}," \
+ -e "s,^LIBDIR:=.*,LIBDIR:=/$(get_libdir)/\$(PROGNAME)," Makefile
+ sed -i -e "s,^CC:=.*,CC:=$(tc-getCC)," Makefile
+}
+
+src_compile() {
+ # This package uses _init functions to initialise extensions. With
+ # --as-needed this will not work.
+ append-ldflags -Wl,--no-as-needed
+ emake || die "emake failed"
+}
+
+src_install() {
+ make DESTDIR="${D}" install || die
+ dodoc ChangeLog THANKS
+ keepdir /var/lib/ebtables/
+ newinitd "${FILESDIR}"/ebtables.initd ebtables
+ newconfd "${FILESDIR}"/ebtables.confd ebtables
+}
diff --git a/net-firewall/ebtables/files/ebtables-v2.0.8-2-LDFLAGS.diff b/net-firewall/ebtables/files/ebtables-v2.0.8-2-LDFLAGS.diff
new file mode 100644
index 000000000000..f5ccb9375dbe
--- /dev/null
+++ b/net-firewall/ebtables/files/ebtables-v2.0.8-2-LDFLAGS.diff
@@ -0,0 +1,54 @@
+=== modified file 'Makefile'
+--- Makefile 2008-08-12 12:30:44 +0000
++++ Makefile 2008-08-12 12:30:56 +0000
+@@ -18,7 +18,6 @@
+ CFLAGS:=-Wall -Wunused
+ CFLAGS_SH_LIB:=-fPIC
+ CC:=gcc
+-LD:=ld
+
+ ifeq ($(shell uname -m),sparc64)
+ CFLAGS+=-DEBT_MIN_ALIGN=8 -DKERNEL_64_USERSPACE_32
+@@ -85,10 +84,10 @@
+
+ .PHONY: libebtc
+ libebtc: $(OBJECTS2)
+- $(LD) -shared -soname libebtc.so -o libebtc.so -lc $(OBJECTS2)
++ $(CC) -shared $(LDFLAGS) -Wl,-soname=libebtc.so -o libebtc.so -lc $(OBJECTS2)
+
+ ebtables: $(OBJECTS) ebtables-standalone.o libebtc
+- $(CC) $(CFLAGS) $(CFLAGS_SH_LIB) -o $@ ebtables-standalone.o -I$(KERNEL_INCLUDES) -L. -Lextensions -lebtc $(EXT_LIBSI) \
++ $(CC) $(CFLAGS) $(CFLAGS_SH_LIB) $(LDFLAGS) -o $@ ebtables-standalone.o -I$(KERNEL_INCLUDES) -L. -Lextensions -lebtc $(EXT_LIBSI) \
+ -Wl,-rpath,$(LIBDIR)
+
+ ebtablesu: ebtablesu.c
+@@ -105,7 +104,7 @@
+ $(CC) $(CFLAGS) $(PROGSPECS) -c $< -o $@ -I$(KERNEL_INCLUDES)
+
+ ebtables-restore: $(OBJECTS) ebtables-restore.o libebtc
+- $(CC) $(CFLAGS) -o $@ ebtables-restore.o -I$(KERNEL_INCLUDES) -L. -Lextensions -lebtc $(EXT_LIBSI) \
++ $(CC) $(CFLAGS) $(LDFLAGS) -o $@ ebtables-restore.o -I$(KERNEL_INCLUDES) -L. -Lextensions -lebtc $(EXT_LIBSI) \
+ -Wl,-rpath,$(LIBDIR)
+
+ .PHONY: daemon
+
+=== modified file 'extensions/Makefile'
+--- extensions/Makefile 2008-08-12 12:30:44 +0000
++++ extensions/Makefile 2008-08-12 12:30:45 +0000
+@@ -11,13 +11,13 @@
+ EXT_LIBSI+=$(foreach T,$(EXT_TABLES), -lebtable_$(T))
+
+ extensions/ebt_%.so: extensions/ebt_%.o
+- $(CC) -shared -o $@ -lc $< -nostartfiles
++ $(CC) $(LDFLAGS) -shared -o $@ -lc $< -nostartfiles
+
+ extensions/libebt_%.so: extensions/ebt_%.so
+ mv $< $@
+
+ extensions/ebtable_%.so: extensions/ebtable_%.o
+- $(CC) -shared -o $@ -lc $< -nostartfiles
++ $(CC) $(LDFLAGS) -shared -o $@ -lc $< -nostartfiles
+
+ extensions/libebtable_%.so: extensions/ebtable_%.so
+ mv $< $@
+
diff --git a/net-firewall/ebtables/files/ebtables-v2.0.8-2-ethertype-DESTDIR-mkdir.patch b/net-firewall/ebtables/files/ebtables-v2.0.8-2-ethertype-DESTDIR-mkdir.patch
new file mode 100644
index 000000000000..310454087ee1
--- /dev/null
+++ b/net-firewall/ebtables/files/ebtables-v2.0.8-2-ethertype-DESTDIR-mkdir.patch
@@ -0,0 +1,40 @@
+=== modified file 'Makefile'
+--- Makefile 2008-08-13 04:20:07 +0000
++++ Makefile 2008-08-13 04:28:51 +0000
+@@ -153,10 +153,13 @@
+ .PHONY: scripts
+ scripts: ebtables-save ebtables.sysv ebtables-config
+ cat ebtables-save | sed 's/__EXEC_PATH__/$(tmp1)/g' > ebtables-save_
++ mkdir -p $(DESTDIR)$(BINDIR)
+ install -m 0755 -o root -g root ebtables-save_ $(DESTDIR)$(BINDIR)/ebtables-save
+ cat ebtables.sysv | sed 's/__EXEC_PATH__/$(tmp1)/g' | sed 's/__SYSCONFIG__/$(tmp2)/g' > ebtables.sysv_
++ mkdir -p $(DESTDIR)$(INITDIR)
+ install -m 0755 -o root -g root ebtables.sysv_ $(DESTDIR)$(INITDIR)/ebtables
+ cat ebtables-config | sed 's/__SYSCONFIG__/$(tmp2)/g' > ebtables-config_
++ mkdir -p $(DESTDIR)$(SYSCONFIGDIR)
+ install -m 0600 -o root -g root ebtables-config_ $(DESTDIR)$(SYSCONFIGDIR)/ebtables-config
+ rm -f ebtables-save_ ebtables.sysv_ ebtables-config_
+
+@@ -166,9 +169,9 @@
+ install -m 0644 -o root -g root ebtables.8_ $(DESTDIR)$@
+ rm -f ebtables.8_
+
+-$(ETHERTYPESFILE): ethertypes
+- mkdir -p $(DESTDIR)$(@D)
+- install -m 0644 -o root -g root $< $(DESTDIR)$@
++$(DESTDIR)$(ETHERTYPESFILE): ethertypes
++ mkdir -p $(@D)
++ install -m 0644 -o root -g root $< $@
+
+ .PHONY: exec
+ exec: ebtables ebtables-restore
+@@ -177,7 +180,7 @@
+ install -m 0755 -o root -g root ebtables-restore $(DESTDIR)$(BINDIR)/ebtables-restore
+
+ .PHONY: install
+-install: $(MANDIR)/man8/ebtables.8 $(ETHERTYPESFILE) exec scripts
++install: $(MANDIR)/man8/ebtables.8 $(DESTDIR)$(ETHERTYPESFILE) exec scripts
+ mkdir -p $(DESTDIR)$(LIBDIR)
+ install -m 0755 extensions/*.so $(DESTDIR)$(LIBDIR)
+ install -m 0755 *.so $(DESTDIR)$(LIBDIR)
+