public inbox for development@lists.ipfire.org
 help / color / mirror / Atom feed
* [PATCH] dnsmasq 276test8: last patch from upstream (005)
@ 2016-02-13 20:21 Matthias Fischer
  0 siblings, 0 replies; only message in thread
From: Matthias Fischer @ 2016-02-13 20:21 UTC (permalink / raw)
  To: development

[-- Attachment #1: Type: text/plain, Size: 3542 bytes --]

Fixes floating point exeption (IPv6 only).

Signed-off-by: Matthias Fischer <matthias.fischer(a)ipfire.org>
---
 lfs/dnsmasq                                        |  1 +
 ...-zero_when_dhcp-range_is_a_whole_slash_64.patch | 59 ++++++++++++++++++++++
 2 files changed, 60 insertions(+)
 create mode 100644 src/patches/dnsmasq/005-Avoid_divide-by-zero_when_dhcp-range_is_a_whole_slash_64.patch

diff --git a/lfs/dnsmasq b/lfs/dnsmasq
index 67e6a61..6417a75 100644
--- a/lfs/dnsmasq
+++ b/lfs/dnsmasq
@@ -77,6 +77,7 @@ $(TARGET) : $(patsubst %,$(DIR_DL)/%,$(objects))
 	cd $(DIR_APP) && patch -Np1 -i $(DIR_SRC)/src/patches/dnsmasq/002-Make_names_of_ARP_script_actions_consistent.patch
 	cd $(DIR_APP) && patch -Np1 -i $(DIR_SRC)/src/patches/dnsmasq/003-Fix_breakage_in_ARP_code_when_IPV6_support_not_compiled_in.patch
 	cd $(DIR_APP) && patch -Np1 -i $(DIR_SRC)/src/patches/dnsmasq/004-Avoid_losing_timer_when_deleting_a_RA_context.patch
+	cd $(DIR_APP) && patch -Np1 -i $(DIR_SRC)/src/patches/dnsmasq/005-Avoid_divide-by-zero_when_dhcp-range_is_a_whole_slash_64.patch
 	cd $(DIR_APP) && patch -Np1 -i $(DIR_SRC)/src/patches/dnsmasq-Add-support-to-read-ISC-DHCP-lease-file.patch
 
 	cd $(DIR_APP) && sed -i src/config.h \
diff --git a/src/patches/dnsmasq/005-Avoid_divide-by-zero_when_dhcp-range_is_a_whole_slash_64.patch b/src/patches/dnsmasq/005-Avoid_divide-by-zero_when_dhcp-range_is_a_whole_slash_64.patch
new file mode 100644
index 0000000..acf1180
--- /dev/null
+++ b/src/patches/dnsmasq/005-Avoid_divide-by-zero_when_dhcp-range_is_a_whole_slash_64.patch
@@ -0,0 +1,59 @@
+From fdc97e13836ba83a6091b7eac79ba8ec40f1ddb9 Mon Sep 17 00:00:00 2001
+From: Simon Kelley <simon(a)thekelleys.org.uk>
+Date: Sat, 13 Feb 2016 17:47:17 +0000
+Subject: [PATCH] Avoid divide-by-zero when dhcp-range is a whole /64
+
+---
+ CHANGELOG   |   11 +++++++----
+ src/dhcp6.c |   11 ++++++++++-
+ 2 files changed, 17 insertions(+), 5 deletions(-)
+
+diff --git a/CHANGELOG b/CHANGELOG
+index 5feb47c..14354f2 100644
+--- a/CHANGELOG
++++ b/CHANGELOG
+@@ -40,12 +40,15 @@ version 2.76
+ 
+ 	    Extend --add-mac to allow a new encoding of the MAC address 
+ 	    as base64, by configurting --add-mac=base64
+-
++ 
+ 	    Add --add-cpe-id option.
+ 
+-	
+-	    
+-	
++            Don't crash with divide-by-zero if an IPv6 dhcp-range
++	    is declared as a whole /64.
++	    (ie xx::0 to xx::ffff:ffff:ffff:ffff) 
++	    Thanks to Laurent Bendel for spotting this problem.
++
++
+ version 2.75
+             Fix reversion on 2.74 which caused 100% CPU use when a 
+ 	    dhcp-script is configured. Thanks to Adrian Davey for
+diff --git a/src/dhcp6.c b/src/dhcp6.c
+index 7269fd2..93a359e 100644
+--- a/src/dhcp6.c
++++ b/src/dhcp6.c
+@@ -434,7 +434,16 @@ struct dhcp_context *address6_allocate(struct dhcp_context *context,  unsigned c
+ 	    /* seed is largest extant lease addr in this context */
+ 	    start = lease_find_max_addr6(c) + serial;
+ 	  else
+-	    start = addr6part(&c->start6) + ((j + c->addr_epoch) % (1 + addr6part(&c->end6) - addr6part(&c->start6)));
++	    {
++	      u64 range = 1 + addr6part(&c->end6) - addr6part(&c->start6);
++	      u64 offset = j + c->addr_epoch;
++
++	      /* don't divide by zero if range is whole 2^64 */
++	      if (range != 0)
++		offset = offset % range;
++
++	      start = addr6part(&c->start6) + offset;
++	    }
+ 
+ 	  /* iterate until we find a free address. */
+ 	  addr = start;
+-- 
+1.7.10.4
+
-- 
2.7.1


^ permalink raw reply	[flat|nested] only message in thread

only message in thread, other threads:[~2016-02-13 20:21 UTC | newest]

Thread overview: (only message) (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2016-02-13 20:21 [PATCH] dnsmasq 276test8: last patch from upstream (005) Matthias Fischer

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox