Send connman mailing list submissions to
        [email protected]

To subscribe or unsubscribe via the World Wide Web, visit
        https://lists.01.org/mailman/listinfo/connman
or, via email, send a message with subject or body 'help' to
        [email protected]

You can reach the person managing the list at
        [email protected]

When replying, please edit your Subject line so it is more specific
than "Re: Contents of connman digest..."


Today's Topics:

   1. [PATCH] dhcpv6: use correct dhcp renew time when valid
      life-time is infinity. (Feng Wang)


----------------------------------------------------------------------

Message: 1
Date: Tue, 28 Jun 2016 14:34:27 -0700
From: Feng Wang <[email protected]>
To: [email protected]
Subject: [PATCH] dhcpv6: use correct dhcp renew time when valid
        life-time is infinity.
Message-ID: <[email protected]>

Based on RFC 3315, 22.6, the valid life-time is infinite when its
value is 0xffffffff. In the g_dhcpv6_client_get_timeouts, the expire
data type is time_t. If time_t is uint32, the last_request time plus
0xffffffff will wrapover so that expire time is smaller than current
time. Thus the dhcpv6 will restart immediately(dhcpv6_restart called).
---
 gdhcp/client.c | 9 +++++++--
 src/dhcpv6.c   | 6 +++++-
 2 files changed, 12 insertions(+), 3 deletions(-)

diff --git a/gdhcp/client.c b/gdhcp/client.c
index 9012b38..2be3982 100644
--- a/gdhcp/client.c
+++ b/gdhcp/client.c
@@ -835,8 +835,13 @@ int g_dhcpv6_client_get_timeouts(GDHCPClient *dhcp_client,
        if (started)
                *started = dhcp_client->last_request;
 
-       if (expire)
-               *expire = dhcp_client->last_request + dhcp_client->expire;
+       if (expire) {
+               if (dhcp_client->expire == 0xffffffff)
+                       /* RFC3315 22.6 infinite valid-lifetime */
+                       *expire = 0xffffffff;
+               else
+                       *expire = dhcp_client->last_request + 
dhcp_client->expire;
+       }
 
        return 0;
 }
diff --git a/src/dhcpv6.c b/src/dhcpv6.c
index 9e21040..cd5733a 100644
--- a/src/dhcpv6.c
+++ b/src/dhcpv6.c
@@ -1195,7 +1195,7 @@ static int check_restart(struct connman_dhcpv6 *dhcp)
                                NULL, &expired);
        current = time(NULL);
 
-       if (current >= expired) {
+       if (current >= expired && expired != 0xffffffff) {
                DBG("expired by %d secs", (int)(current - expired));
 
                g_timeout_add(0, dhcpv6_restart, dhcp);
@@ -1442,6 +1442,10 @@ int __connman_dhcpv6_start_renew(struct connman_network 
*network,
                /* RFC 3315, 22.4
                 * Client can choose the timeout.
                 */
+               if (expired == 0xffffffff) {
+                   /* RFC 3315, 22.6 infinite valid-lifetime */
+                   return 0;
+               }
                T1 = (expired - started) / 2;
                T2 = (expired - started) / 10 * 8;
        }
-- 
2.8.0.rc3.226.g39d4020



------------------------------

Subject: Digest Footer

_______________________________________________
connman mailing list
[email protected]
https://lists.01.org/mailman/listinfo/connman


------------------------------

End of connman Digest, Vol 8, Issue 33
**************************************

Reply via email to