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

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

For details see:
http://thekelleys.org.uk/gitweb/?p=dnsmasq.git;a=commit;h=a18bf3149a9a2d41cf2c5b56908bc3d5c44f6d34

Signed-off-by: Matthias Fischer <matthias.fischer(a)ipfire.org>
---
 lfs/dnsmasq                                        |  1 +
 ...d_losing_timer_when_deleting_a_RA_context.patch | 68 ++++++++++++++++++++++
 2 files changed, 69 insertions(+)
 create mode 100644 src/patches/dnsmasq/004-Avoid_losing_timer_when_deleting_a_RA_context.patch

diff --git a/lfs/dnsmasq b/lfs/dnsmasq
index b9ddf12..67e6a61 100644
--- a/lfs/dnsmasq
+++ b/lfs/dnsmasq
@@ -76,6 +76,7 @@ $(TARGET) : $(patsubst %,$(DIR_DL)/%,$(objects))
 	cd $(DIR_APP) && patch -Np1 -i $(DIR_SRC)/src/patches/dnsmasq/001-Fix_FTBFS_on_illumos.patch
 	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-Add-support-to-read-ISC-DHCP-lease-file.patch
 
 	cd $(DIR_APP) && sed -i src/config.h \
diff --git a/src/patches/dnsmasq/004-Avoid_losing_timer_when_deleting_a_RA_context.patch b/src/patches/dnsmasq/004-Avoid_losing_timer_when_deleting_a_RA_context.patch
new file mode 100644
index 0000000..3396312
--- /dev/null
+++ b/src/patches/dnsmasq/004-Avoid_losing_timer_when_deleting_a_RA_context.patch
@@ -0,0 +1,68 @@
+From a18bf3149a9a2d41cf2c5b56908bc3d5c44f6d34 Mon Sep 17 00:00:00 2001
+From: S L <sl4ever(a)gmail.com>
+Date: Fri, 12 Feb 2016 17:36:20 +0000
+Subject: [PATCH] Avoid losing timer when deleting a RA context.
+
+---
+ src/radv.c |   19 ++++++++++++++-----
+ 1 file changed, 14 insertions(+), 5 deletions(-)
+
+diff --git a/src/radv.c b/src/radv.c
+index 5c5382f..749b666 100644
+--- a/src/radv.c
++++ b/src/radv.c
+@@ -28,11 +28,12 @@
+ 
+ struct ra_param {
+   time_t now;
+-  int ind, managed, other, found_context, first, adv_router;
++  int ind, managed, other, first, adv_router;
+   char *if_name;
+   struct dhcp_netid *tags;
+   struct in6_addr link_local, link_global, ula;
+   unsigned int glob_pref_time, link_pref_time, ula_pref_time, adv_interval, prio;
++  struct dhcp_context *found_context;
+ };
+ 
+ struct search_param {
+@@ -251,7 +252,7 @@ static void send_ra_alias(time_t now, int iface, char *iface_name, struct in6_ad
+   parm.ind = iface;
+   parm.managed = 0;
+   parm.other = 0;
+-  parm.found_context = 0;
++  parm.found_context = NULL;
+   parm.adv_router = 0;
+   parm.if_name = iface_name;
+   parm.first = 1;
+@@ -308,8 +309,14 @@ static void send_ra_alias(time_t now, int iface, char *iface_name, struct in6_ad
+ 	  unsigned int old = difftime(now, context->address_lost_time);
+ 	  
+ 	  if (old > context->saved_valid)
+-	    {
++	    { 
+ 	      /* We've advertised this enough, time to go */
++	     
++	      /* If this context held the timeout, and there's another context in use
++		 transfer the timeout there. */
++	      if (context->ra_time != 0 && parm.found_context && parm.found_context->ra_time == 0)
++		new_timeout(parm.found_context, iface_name, now);
++	      
+ 	      *up = context->next;
+ 	      free(context);
+ 	    }
+@@ -636,8 +643,10 @@ static int add_prefixes(struct in6_addr *local,  int prefix,
+                     off_link = (context->flags & CONTEXT_RA_OFF_LINK);
+ 		  }
+ 
+-		param->first = 0;	
+-		param->found_context = 1;
++		param->first = 0;
++		/* found_context is the _last_ one we found, so if there's 
++		   more than one, it's not the first. */
++		param->found_context = context;
+ 	      }
+ 
+ 	  /* configured time is ceiling */
+-- 
+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  7:35 UTC | newest]

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

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