New package for ISC DHCP4, provides a DHCPd, client, relay and "omshell" 
for live-reconfiguration.

binaries are statically linked as BIND export libs are not usable with BIND 
itself, nonetheless, SquashFS fortunately does a pretty good job of cutting 
down the image size these would otherwise add; inserting into JFFS2 is 
considerably more space-consuming.

Index: feeds/packages/net/dhcp4/files/dhclient6.init
===================================================================
--- feeds/packages/net/dhcp4/files/dhclient6.init	(revision 0)
+++ feeds/packages/net/dhcp4/files/dhclient6.init	(revision 0)
@@ -0,0 +1,33 @@
+#!/bin/sh /etc/rc.common
+START=60
+
+lease_file=/var/dhclient6.leases
+config_file=/etc/dhclient6.conf
+pid_file=/var/run/dhclient6.pid
+script_file=/usr/sbin/dhclient-script
+
+start() {
+	echo Starting isc-dhclient
+
+	/usr/sbin/dhclient -q -nw -6 -cf $config_file -lf $lease_file -pf $pid_file -sf $script_file `/sbin/uci get network.wan.ifname`
+	
+	if [ $? -ne 0 ]; then
+		echo "  isc-dhclient failed to start"
+	fi
+}
+
+stop() {
+	echo Stopping isc-dhclient
+	if [ -e $pid_file ]; then
+		kill -9 `cat $pid_file`
+
+		if [ $? -ne 0 ]; then
+			echo "  PID " `cat $pid_file` not found
+			echo "  Is the DHCP client running?"
+		fi
+	
+		rm $pid_file
+	else
+		echo "  $pid_file not found"
+	fi
+}
Index: feeds/packages/net/dhcp4/files/dhclient6.conf
===================================================================
--- feeds/packages/net/dhcp4/files/dhclient6.conf	(revision 0)
+++ feeds/packages/net/dhcp4/files/dhclient6.conf	(revision 0)
@@ -0,0 +1,2 @@
+option dhcp6.softwire code 54 = ip6-address;
+also request dhcp6.softwire;
Index: feeds/packages/net/dhcp4/files/dhcpd.init
===================================================================
--- feeds/packages/net/dhcp4/files/dhcpd.init	(revision 0)
+++ feeds/packages/net/dhcp4/files/dhcpd.init	(revision 0)
@@ -0,0 +1,37 @@
+#!/bin/sh /etc/rc.common
+START=65
+
+lease_file=/var/dhcpd.leases
+config_file=/etc/dhcpd.conf
+pid_file=/var/run/dhcpd.pid
+
+start() {
+	echo Starting isc-dhcpd
+
+	if [ ! -e $lease_file ]; then
+		echo "  Creating $lease_file"
+		touch $lease_file
+	fi
+	
+	/usr/sbin/dhcpd -q -cf $config_file -lf $lease_file -pf $pid_file
+	
+	if [ $? -ne 0 ]; then
+		echo "  isc-dhcpd failed to start"
+	fi
+}
+
+stop() {
+	echo Stopping isc-dhcpd
+	if [ -e $pid_file ]; then
+		kill -9 `cat $pid_file`
+
+		if [ $? -ne 0 ]; then
+			echo "  PID " `cat $pid_file` not found
+			echo "  Is the DHCP server running?"
+		fi
+	
+		rm $pid_file
+	else
+		echo "  $pid_file not found"
+	fi
+}
Index: feeds/packages/net/dhcp4/files/dhcpd.conf
===================================================================
--- feeds/packages/net/dhcp4/files/dhcpd.conf	(revision 0)
+++ feeds/packages/net/dhcp4/files/dhcpd.conf	(revision 0)
@@ -0,0 +1,13 @@
+# dhcpd.conf
+
+authoritative;
+
+default-lease-time 3600;
+max-lease-time 86400;
+
+option domain-name-servers 192.168.1.1;
+
+subnet 192.168.1.0 netmask 255.255.255.0 {
+  range 192.168.1.10 192.168.1.50;
+  option routers 192.168.1.1;
+}
Index: feeds/packages/net/dhcp4/files/dhcpd6.init
===================================================================
--- feeds/packages/net/dhcp4/files/dhcpd6.init	(revision 0)
+++ feeds/packages/net/dhcp4/files/dhcpd6.init	(revision 0)
@@ -0,0 +1,37 @@
+#!/bin/sh /etc/rc.common
+START=65
+
+lease_file=/var/dhcpd6.leases
+config_file=/etc/dhcpd6.conf
+pid_file=/var/run/dhcpd6.pid
+
+start() {
+	echo Starting isc-dhcpd
+
+	if [ ! -e $lease_file ]; then
+		echo "  Creating $lease_file"
+		touch $lease_file
+	fi
+	
+	/usr/sbin/dhcpd -q -6 -cf $config_file -lf $lease_file -pf $pid_file
+	
+	if [ $? -ne 0 ]; then
+		echo "  isc-dhcpd failed to start"
+	fi
+}
+
+stop() {
+	echo Stopping isc-dhcpd
+	if [ -e $pid_file ]; then
+		kill -9 `cat $pid_file`
+
+		if [ $? -ne 0 ]; then
+			echo "  PID " `cat $pid_file` not found
+			echo "  Is the DHCP server running?"
+		fi
+	
+		rm $pid_file
+	else
+		echo "  $pid_file not found"
+	fi
+}
Index: feeds/packages/net/dhcp4/files/dhcpd6.conf
===================================================================
--- feeds/packages/net/dhcp4/files/dhcpd6.conf	(revision 0)
+++ feeds/packages/net/dhcp4/files/dhcpd6.conf	(revision 0)
@@ -0,0 +1,30 @@
+# dhcpd6.conf
+
+authoritative;
+
+default-lease-time 3600;
+max-lease-time 86400;
+
+# Enable RFC 5007 support
+#allow leasequery;
+
+# Global definitions for name server address(es) and domain search list
+#option dhcp6.name-servers 3ffe:501:ffff:100:200:ff:fe00:3f3e;
+#option dhcp6.domain-search "test.example.com","example.com";
+
+# Set preference to 255 (maximum) in order to avoid waiting for
+# additional servers when there is only one
+#option dhcp6.preference 255;
+
+# Server side command to enable rapid-commit (2 packet exchange)
+#option dhcp6.rapid-commit;
+
+# The delay before information-request refresh
+#  (minimum is 10 minutes, maximum one day, default is to not refresh)
+#  (set to 6 hours)
+#option dhcp6.info-refresh-time 3600;
+
+subnet6 3ffe:501:ffff:101::/64 {
+	# Use the whole /64 prefix for clients
+	range6 3ffe:501:ffff:101:: /64;
+}
Index: feeds/packages/net/dhcp4/files/dhclient-script
===================================================================
--- feeds/packages/net/dhcp4/files/dhclient-script	(revision 0)
+++ feeds/packages/net/dhcp4/files/dhclient-script	(revision 0)
@@ -0,0 +1,281 @@
+#!/bin/sh
+
+make_resolv_conf() {
+  if [ x"$new_domain_name_servers" != x ]; then
+    cat /dev/null > /etc/resolv.conf.dhclient
+    chmod 644 /etc/resolv.conf.dhclient
+    if [ x"$new_domain_search" != x ]; then
+      echo search $new_domain_search >> /etc/resolv.conf.dhclient
+    elif [ x"$new_domain_name" != x ]; then
+      # Note that the DHCP 'Domain Name Option' is really just a domain
+      # name, and that this practice of using the domain name option as
+      # a search path is both nonstandard and deprecated.
+      echo search $new_domain_name >> /etc/resolv.conf.dhclient
+    fi
+    for nameserver in $new_domain_name_servers; do
+      echo nameserver $nameserver >>/etc/resolv.conf.dhclient
+    done
+
+  elif [ "x${new_dhcp6_name_servers}" != x ] ; then
+    cat /dev/null > /etc/resolv.conf.dhclient6
+    chmod 644 /etc/resolv.conf.dhclient6
+
+    if [ "x${new_dhcp6_domain_search}" != x ] ; then
+      echo search ${new_dhcp6_domain_search} >> /etc/resolv.conf.dhclient6
+    fi
+    for nameserver in ${new_dhcp6_name_servers} ; do
+      echo nameserver ${nameserver} >> /etc/resolv.conf.dhclient6
+    done
+  fi
+
+  # if both v4 and v6 clients are running, concatenate results
+  cat /etc/resolv.conf.* > /etc/resolv.conf
+}
+
+# Must be used on exit.   Invokes the local dhcp client exit hooks, if any.
+exit_with_hooks() {
+  exit_status=$1
+  if [ -f /etc/dhclient-exit-hooks ]; then
+    . /etc/dhclient-exit-hooks
+  fi
+# probably should do something with exit status of the local script
+  exit $exit_status
+}
+
+# Invoke the local dhcp client enter hooks, if they exist.
+if [ -f /etc/dhclient-enter-hooks ]; then
+  exit_status=0
+  . /etc/dhclient-enter-hooks
+  # allow the local script to abort processing of this state
+  # local script must set exit_status variable to nonzero.
+  if [ $exit_status -ne 0 ]; then
+    exit $exit_status
+  fi
+fi
+
+###
+### DHCPv4 Handlers
+###
+
+if [ x$new_broadcast_address != x ]; then
+  new_broadcast_arg="broadcast $new_broadcast_address"
+fi
+if [ x$new_subnet_mask != x ]; then
+  new_subnet_arg="netmask $new_subnet_mask"
+fi
+if [ x$alias_subnet_mask != x ]; then
+  alias_subnet_arg="netmask $alias_subnet_mask"
+fi
+
+if [ x$reason = xMEDIUM ]; then
+  # Linux doesn't do mediums (ok, ok, media).
+  exit_with_hooks 0
+fi
+
+if [ x$reason = xPREINIT ]; then
+  if [ x$alias_ip_address != x ]; then
+    # Bring down alias interface. Its routes will disappear too.
+    ifconfig $interface:0- 0.0.0.0
+  fi
+  ifconfig $interface 0.0.0.0 up
+
+  # We need to give the kernel some time to get the interface up.
+  sleep 1
+
+  exit_with_hooks 0
+fi
+
+if [ x$reason = xARPCHECK ] || [ x$reason = xARPSEND ]; then
+  exit_with_hooks 0
+fi
+  
+if [ x$reason = xBOUND ] || [ x$reason = xRENEW ] || \
+   [ x$reason = xREBIND ] || [ x$reason = xREBOOT ]; then
+  current_hostname=`hostname`
+  if [ x$current_hostname = x ] || \
+     [ x$current_hostname = x$old_host_name ]; then
+    if [ x$current_hostname = x ] || \
+       [ x$new_host_name != x$old_host_name ]; then
+      hostname $new_host_name
+    fi
+  fi
+    
+  if [ x$old_ip_address != x ] && [ x$alias_ip_address != x ] && \
+		[ x$alias_ip_address != x$old_ip_address ]; then
+    # Possible new alias. Remove old alias.
+    ifconfig $interface:0- 0.0.0.0
+  fi
+  if [ x$old_ip_address != x ] && [ x$old_ip_address != x$new_ip_address ]; then
+    # IP address changed. Bringing down the interface will delete all routes,
+    # and clear the ARP cache.
+    ifconfig $interface 0.0.0.0 down
+
+  fi
+  if [ x$old_ip_address = x ] || [ x$old_ip_address != x$new_ip_address ] || \
+     [ x$reason = xBOUND ] || [ x$reason = xREBOOT ]; then
+
+    ifconfig $interface $new_ip_address $new_subnet_arg \
+							$new_broadcast_arg
+    for router in $new_routers; do
+      if [ "x$new_subnet_mask" = "x255.255.255.255" ] ; then
+	route add -host $router dev $interface
+      fi
+      route add default gw $router
+    done
+  fi
+  if [ x$new_ip_address != x$alias_ip_address ] && [ x$alias_ip_address != x ];
+   then
+    ifconfig $interface:0- 0.0.0.0
+    ifconfig $interface:0 $alias_ip_address $alias_subnet_arg
+    route add -host $alias_ip_address $interface:0
+  fi
+  make_resolv_conf
+  exit_with_hooks 0
+fi
+
+if [ x$reason = xEXPIRE ] || [ x$reason = xFAIL ] || [ x$reason = xRELEASE ] \
+   || [ x$reason = xSTOP ]; then
+  if [ x$alias_ip_address != x ]; then
+    # Turn off alias interface.
+    ifconfig $interface:0- 0.0.0.0
+  fi
+  if [ x$old_ip_address != x ]; then
+    # Shut down interface, which will delete routes and clear arp cache.
+    ifconfig $interface 0.0.0.0 down
+  fi
+  if [ x$alias_ip_address != x ]; then
+    ifconfig $interface:0 $alias_ip_address $alias_subnet_arg
+    route add -host $alias_ip_address $interface:0
+  fi
+
+  # remove v4 dns configuration for this interface
+  rm /etc/resolv.conf.dhclient
+  cat /etc/resolv.conf.* > /etc/resolv.conf
+
+  exit_with_hooks 0
+fi
+
+if [ x$reason = xTIMEOUT ]; then
+  if [ x$alias_ip_address != x ]; then
+    ifconfig $interface:0- 0.0.0.0
+  fi
+  ifconfig $interface $new_ip_address $new_subnet_arg \
+					$new_broadcast_arg
+  set $new_routers
+  if ping -q -c 1 $1; then
+    if [ x$new_ip_address != x$alias_ip_address ] && \
+			[ x$alias_ip_address != x ]; then
+      ifconfig $interface:0 $alias_ip_address $alias_subnet_arg
+      route add -host $alias_ip_address dev $interface:0
+    fi
+    for router in $new_routers; do
+      if [ "x$new_subnet_mask" = "x255.255.255.255" ] ; then
+	route add -host $router dev $interface
+      fi
+      route add default gw $router
+    done
+    make_resolv_conf
+    exit_with_hooks 0
+  fi
+  ifconfig $interface 0.0.0.0 down
+  exit_with_hooks 1
+fi
+
+###
+### DHCPv6 Handlers
+###
+
+if [ x$reason = xPREINIT6 ]; then
+  # Ensure interface is up.
+  ifconfig ${interface} up
+
+  # Remove any stale addresses from aborted clients.
+  ip -f inet6 addr flush dev ${interface} scope global
+
+  exit_with_hooks 0
+fi
+
+if [ x${old_ip6_prefix} != x ] || [ x${new_ip6_prefix} != x ] ; then
+    echo Prefix ${reason} old=${old_ip6_prefix} new=${new_ip6_prefix}
+
+    exit_with_hooks 0
+fi
+
+if [ x$reason = xBOUND6 ]; then
+  if [ x${new_ip6_address} = x ] || [ x${new_ip6_prefixlen} = x ] ; then
+    exit_with_hooks 2;
+  fi
+
+  ifconfig ${interface} add ${new_ip6_address}/${new_ip6_prefixlen}
+
+  # Check for nameserver options.
+  make_resolv_conf
+
+### <<
+  # Set up softwire tunnel
+  if [ x${new_dhcp6_softwire} != x ] ; then
+    /etc/init.d/dhclient stop
+    ifconfig ${interface} 0.0.0.0
+    ip -6 tunnel add tun0 mode ipip6 \
+	remote ${new_dhcp6_softwire} \
+	local ${new_ip6_address} \
+	dev ${interface} encaplimit none
+    ip link set tun0 up
+    ip route add default dev tun0
+  fi
+### >>
+
+  exit_with_hooks 0
+fi
+
+if [ x$reason = xRENEW6 ] || [ x$reason = xREBIND6 ]; then
+  if [ x${new_ip6_address} = x ] || [ x${new_ip6_prefixlen} = x ] ; then
+    exit_with_hooks 2;
+  fi
+
+  ifconfig ${interface} add ${new_ip6_address}/${new_ip6_prefixlen}
+
+  # Make sure nothing has moved around on us.
+
+  # Nameservers/domains/etc.
+  if [ "x${new_dhcp6_name_servers}" != "x${old_dhcp6_name_servers}" ] ||
+     [ "x${new_dhcp6_domain_search}" != "x${old_dhcp6_domain_search}" ] ; then
+    make_resolv_conf
+  fi
+
+  exit_with_hooks 0
+fi
+
+if [ x$reason = xDEPREF6 ]; then
+  if [ x${new_ip6_address} = x ] ; then
+    exit_with_hooks 2;
+  fi
+
+  # Busybox ifconfig has no way to communicate this to the kernel, so ignore it
+
+  exit_with_hooks 0
+fi
+
+if [ x$reason = xEXPIRE6 -o x$reason = xRELEASE6 -o x$reason = xSTOP6 ]; then
+  if [ x${old_ip6_address} = x ] || [ x${old_ip6_prefixlen} = x ] ; then
+    exit_with_hooks 2;
+  fi
+
+  ifconfig ${interface} del ${old_ip6_address}/${old_ip6_prefixlen}
+
+  # remove v6 dns configuration for this interface
+  rm /etc/resolv.conf.dhclient6
+  cat /etc/resolv.conf.* > /etc/resolv.conf
+
+### <<
+  # Tear down softwire tunnel
+  if [ x${old_dhcp6_softwire} != x ] ; then
+    ip link set tun0 down
+    ip tunnel del tun0
+  fi
+### >>
+
+  exit_with_hooks 0
+fi
+
+exit_with_hooks 0

Property changes on: feeds/packages/net/dhcp4/files/dhclient-script
___________________________________________________________________
Added: svn:executable
   + *

Index: feeds/packages/net/dhcp4/files/dhclient.init
===================================================================
--- feeds/packages/net/dhcp4/files/dhclient.init	(revision 0)
+++ feeds/packages/net/dhcp4/files/dhclient.init	(revision 0)
@@ -0,0 +1,33 @@
+#!/bin/sh /etc/rc.common
+START=60
+
+lease_file=/var/dhclient.leases
+config_file=/etc/dhclient.conf
+pid_file=/var/run/dhclient.pid
+script_file=/usr/sbin/dhclient-script
+
+start() {
+	echo Starting isc-dhclient
+
+	/usr/sbin/dhclient -q -nw -cf $config_file -lf $lease_file -pf $pid_file -sf $script_file `/sbin/uci get network.wan.ifname`
+	
+	if [ $? -ne 0 ]; then
+		echo "  isc-dhclient failed to start"
+	fi
+}
+
+stop() {
+	echo Stopping isc-dhclient
+	if [ -e $pid_file ]; then
+		kill -9 `cat $pid_file`
+
+		if [ $? -ne 0 ]; then
+			echo "  PID " `cat $pid_file` not found
+			echo "  Is the DHCP client running?"
+		fi
+	
+		rm $pid_file
+	else
+		echo "  $pid_file not found"
+	fi
+}
Index: feeds/packages/net/dhcp4/patches/001-bind-exports-fix-make.patch
===================================================================
--- feeds/packages/net/dhcp4/patches/001-bind-exports-fix-make.patch	(revision 0)
+++ feeds/packages/net/dhcp4/patches/001-bind-exports-fix-make.patch	(revision 0)
@@ -0,0 +1,28 @@
+--- a/bind/Makefile	2011-11-28 23:08:15.000000000 +0000
++++ b/bind/Makefile	2011-12-17 16:27:20.784433502 +0000
+@@ -49,13 +49,16 @@
+ 
+ # Build the export libraries
+ 	@echo Building BIND Export libraries - this takes some time.
++	@(cd ${bindsrcdir}/lib/export/dns ; \
++	  echo building gen using ${BUILD_CC} in `pwd` ; \
++	  $(MAKE) CC=${BUILD_CC} CFLAGS="-O2" LIBS="" gen)
+ 	@(cd ${bindsrcdir}/lib/export ; \
+ 	  echo building in `pwd` ; \
+ 	  MAKE=${GMAKE} ${GMAKE} > ${binddir}/build.log)
+ 
+ 	@echo Installing BIND Export libraries to ${binddir}.
+ 	@(cd ${bindsrcdir}/lib/export ; \
+-	  MAKE=${GMAKE} ${GMAKE} install > ${binddir}/install.log)
++	  $(MAKE) DESTDIR="" install > ${binddir}/install.log)
+ 
+ clean:
+ 	@echo Cleaning BIND export library.
+@@ -64,6 +67,7 @@
+ 
+ # Include the following so that this Makefile is happy when the parent
+ # tries to use them.
++install-exec:
+ 
+ distdir:
+ 
Index: feeds/packages/net/dhcp4/Config.in
===================================================================
--- feeds/packages/net/dhcp4/Config.in	(revision 0)
+++ feeds/packages/net/dhcp4/Config.in	(revision 0)
@@ -0,0 +1,7 @@
+config DHCP4_ENABLE_IPV6
+	bool "Enable IPv6 capabilities (DHCPv6)"
+	depends on PACKAGE_kmod-ipv6 && PACKAGE_dhcp4
+	default y
+	help
+	  Enables IPv6 features in all built DHCP4 packages
+
Index: feeds/packages/net/dhcp4/Makefile
===================================================================
--- feeds/packages/net/dhcp4/Makefile	(revision 0)
+++ feeds/packages/net/dhcp4/Makefile	(revision 0)
@@ -0,0 +1,176 @@
+#
+# Copyright (C) 2006-2008 OpenWrt.org
+#
+# This is free software, licensed under the GNU General Public License v2.
+# See /LICENSE for more information.
+#
+# This makefile is loosely based on a version for 4.1.0 that was designed to be OpenWRT friendly.
+#
+# $Id: Makefile 1 2011-12-17 17:42:34Z Olipro $
+
+include $(TOPDIR)/rules.mk
+
+PKG_NAME:=dhcp
+PKG_VERSION:=4.2.3-P1
+PKG_RELEASE:=1
+
+PKG_SOURCE:=$(PKG_NAME)-$(PKG_VERSION).tar.gz
+PKG_SOURCE_URL:=ftp://ftp.isc.org/isc/dhcp/$(PKG_VERSION)
+PKG_MD5SUM:=04599f1557a5cafd10d7745267a68c8b
+
+PKG_FIXUP:=libtool
+PKG_BUILD_PARALLEL:=1
+
+include $(INCLUDE_DIR)/package.mk
+
+define Package/dhcp4/Default
+  SECTION:=net
+  CATEGORY:=Network
+  URL:=http://www.isc.org/
+endef
+
+define Package/dhcp4
+  $(call Package/dhcp4/Default)
+  TITLE:=ISC DHCP-${PKG_VERSION}
+#  PKG_HOST_ONLY:=1
+  MENU:=1
+endef
+
+define Package/dhcp4/config
+  source "$(SOURCE)/Config.in"
+endef
+
+define Package/dhcp4/description
+-
+	This is the latest available version of the ISC DHCP suite. Generally speaking, you are unlikely
+	to have any need of this application; it has a considerably larger filesize than dnsmasq and thus
+	you should only be selecting this package because you need features only available in this suite.
+	
+endef
+
+define Package/dhcp4-relay
+  $(call Package/dhcp4/Default)
+  DEPENDS:=@PACKAGE_dhcp4
+  TITLE:=ISC DHCP Relay
+endef
+
+define Package/dhcp4-relay/description
+The DHCP relay agent is for relaying DHCP messages between separate network segments.
+	
+	This is the latest available version of the ISC DHCP suite. Generally speaking, you are unlikely
+	to have any need of this application; it has a considerably larger filesize than dnsmasq and thus
+	you should only be selecting this package because you need features only available in this suite.
+	
+endef
+
+define Package/dhcp4-server
+  $(call Package/dhcp4/Default)
+  DEPENDS:=@PACKAGE_dhcp4
+  TITLE:=ISC DHCP Server
+endef
+
+define Package/dhcp4-server/description
+The ISC DHCP server provides comprehensive DHCP configuration and functionality for network
+hosts that have a complimentary DHCP client running.
+	
+	This is the latest available version of the ISC DHCP suite. Generally speaking, you are unlikely
+	to have any need of this application; it has a considerably larger filesize than dnsmasq and thus
+	you should only be selecting this package because you need features only available in this suite.
+	
+endef
+
+define Package/dhcp4-client
+  $(call Package/dhcp4/Default)
+  DEPENDS:=@PACKAGE_dhcp4
+  TITLE:=ISC DHCP Client
+endef
+
+define Package/dhcp4-client/description
+The ISC DHCP client receives configuration information from a DHCP server and configures the host
+accordingly.
+	
+	This is the latest available version of the ISC DHCP suite. Generally speaking, you are unlikely
+	to have any need of this application; it has a considerably larger filesize than dnsmasq and thus
+	you should only be selecting this package because you need features only available in this suite.
+	
+endef
+
+define Package/dhcp4-omshell
+  $(call Package/dhcp4/Default)
+  DEPENDS:=@PACKAGE_dhcp4
+  TITLE:=ISC DHCP OmShell
+endef
+
+define Package/dhcp4-omshell/description
+The ISC OmShell utility enables you to change the configuration of a running DHCP instance
+without having to endure the hassle of manually modifying the configuration file then
+killing and restarting it.
+	
+	This is the latest available version of the ISC DHCP suite. Generally speaking, you are unlikely
+	to have any need of this application; it has a considerably larger filesize than dnsmasq and thus
+	you should only be selecting this package because you need features only available in this suite.
+	
+endef
+
+CONFIGURE_ARGS += ac_cv_file__dev_random=yes --disable-tracing --enable-paranoia --disable-dependency-tracking
+ifeq ($(CONFIG_DHCP4_ENABLE_IPV6),y)
+  CONFIGURE_ARGS += --enable-dhcpv6
+else
+  CONFIGURE_ARGS += --disable-dhcpv6
+endif
+
+
+define Build/Compile
+	$(MAKE) -C $(PKG_BUILD_DIR) \
+		DESTDIR="$(PKG_INSTALL_DIR)" \
+		CROSS_COMPILE="$(GNU_TARGET_NAME)" BUILD_CC="$(HOSTCC)" CC="$(TARGET_CC)" host_alias="$(GNU_TARGET_NAME)" target_alias="$(GNU_TARGET_NAME)" build_alias="$(GNU_HOST_NAME)" \
+		ac_cv_file__dev_random=yes \
+		all install-exec
+endef
+
+define Package/dhcp4/install
+
+endef
+
+define Package/dhcp4-relay/install
+	$(INSTALL_DIR) $(1)/usr/sbin
+	$(INSTALL_BIN) $(PKG_INSTALL_DIR)/usr/sbin/dhcrelay $(1)/usr/sbin/
+endef
+
+define Package/dhcp4-server/install
+	$(INSTALL_DIR) $(1)/usr/sbin
+#	$(INSTALL_DIR) $(1)/usr/lib
+	$(INSTALL_DIR) $(1)/etc/init.d
+	$(INSTALL_BIN) $(PKG_INSTALL_DIR)/usr/sbin/dhcpd $(1)/usr/sbin/
+#Libs appear to be unnecessary
+#	$(INSTALL_DATA) $(PKG_INSTALL_DIR)/usr/lib/*.a $(1)/usr/lib
+	$(INSTALL_BIN) ./files/dhcpd.init $(1)/etc/init.d/dhcpd
+	$(INSTALL_BIN) ./files/dhcpd.conf $(1)/etc
+ifeq ($(CONFIG_DHCP4_ENABLE_IPV6),y)
+	$(INSTALL_BIN) ./files/dhcpd6.init $(1)/etc/init.d/dhcpd6
+	$(INSTALL_BIN) ./files/dhcpd6.conf $(1)/etc
+endif
+endef
+
+define Package/dhcp4-client/install
+	$(INSTALL_DIR) $(1)/usr/sbin
+	$(INSTALL_DIR) $(1)/etc/init.d
+	$(INSTALL_BIN) $(PKG_INSTALL_DIR)/usr/sbin/dhclient $(1)/usr/sbin/
+	$(INSTALL_BIN) ./files/dhclient-script $(1)/usr/sbin/
+	$(INSTALL_BIN) ./files/dhclient.init $(1)/etc/init.d/dhclient
+ifeq ($(CONFIG_DHCP4_ENABLE_IPV6),y)
+	$(INSTALL_BIN) ./files/dhclient6.init $(1)/etc/init.d/dhclient6
+	$(INSTALL_BIN) ./files/dhclient6.conf $(1)/etc
+endif
+endef
+
+define Package/dhcp4-omshell/install
+	$(INSTALL_DIR) $(1)/usr/bin
+	$(INSTALL_BIN) $(PKG_INSTALL_DIR)/usr/bin/omshell $(1)/usr/bin/
+endef
+
+$(eval $(call BuildPackage,dhcp4))
+$(eval $(call BuildPackage,dhcp4-relay))
+$(eval $(call BuildPackage,dhcp4-server))
+$(eval $(call BuildPackage,dhcp4-client))
+$(eval $(call BuildPackage,dhcp4-omshell))

Attachment: signature.asc
Description: This is a digitally signed message part.

_______________________________________________
openwrt-devel mailing list
[email protected]
https://lists.openwrt.org/mailman/listinfo/openwrt-devel

Reply via email to