Skip to content

Commit 6abacdf

Browse files
authored
Merge pull request #169 from Jahor/fix_dhcp_expiration
Fix timeout handling in DHCP lease renewal
2 parents c63bf6b + f66343a commit 6abacdf

File tree

1 file changed

+26
-16
lines changed

1 file changed

+26
-16
lines changed

adafruit_wiznet5k/adafruit_wiznet5k_dhcp.py

+26-16
Original file line numberDiff line numberDiff line change
@@ -26,10 +26,9 @@
2626

2727

2828
import gc
29-
import time
3029
from random import randint
3130
from micropython import const
32-
from adafruit_ticks import ticks_ms, ticks_diff, ticks_add
31+
from adafruit_ticks import ticks_ms, ticks_diff, ticks_add, ticks_less
3332
from adafruit_wiznet5k.adafruit_wiznet5k_debug import ( # pylint: disable=ungrouped-imports
3433
debug_msg,
3534
)
@@ -152,7 +151,6 @@ def __init__(
152151
# DHCP state machine
153152
self._dhcp_state = _STATE_INIT
154153
self._transaction_id = randint(1, 0x7FFFFFFF)
155-
self._start_time = 0.0
156154
self._start_ticks = 0
157155
self._blocking = False
158156
self._renew = None
@@ -165,9 +163,12 @@ def __init__(
165163
self.dns_server_ip = _UNASSIGNED_IP_ADDR
166164

167165
# Lease expiry times
168-
self._t1 = 0
169-
self._t2 = 0
170-
self._lease = 0
166+
self._t1_timeout = 0
167+
self._t2_timeout = 0
168+
self._lease_timeout = 0
169+
self._t1 = None
170+
self._t2 = None
171+
self._lease = None
171172

172173
# Host name
173174
mac_string = "".join("{:02X}".format(o) for o in mac_address)
@@ -210,8 +211,10 @@ def _dsm_reset(self) -> None:
210211
self.dns_server_ip = _UNASSIGNED_IP_ADDR
211212
self._renew = None
212213
self._increment_transaction_id()
213-
self._start_time = time.monotonic()
214214
self._start_ticks = ticks_ms()
215+
self._lease = None
216+
self._t1 = None
217+
self._t2 = None
215218

216219
def _increment_transaction_id(self) -> None:
217220
"""Increment the transaction ID and roll over from 0x7fffffff to 0."""
@@ -289,11 +292,14 @@ def _process_messaging_states(self, *, message_type: int):
289292
self._dhcp_state = _STATE_INIT
290293
elif message_type == _DHCP_ACK:
291294
debug_msg("Message is ACK, setting FSM state to BOUND.", self._debug)
292-
self._t1 = ticks_add(self._start_ticks, self._lease // 2)
293-
self._t2 = ticks_diff(
294-
ticks_add(self._start_ticks, self._lease), self._lease // 8
295+
lease = self._lease or 60
296+
self._lease_timeout = ticks_add(self._start_ticks, lease * 1000)
297+
self._t1_timeout = ticks_add(
298+
self._start_ticks, (self._t1 or (lease // 2)) * 1000
299+
)
300+
self._t2_timeout = ticks_add(
301+
self._start_ticks, (self._t2 or (lease - lease // 8)) * 1000
295302
)
296-
self._lease = ticks_add(self._lease, self._start_ticks)
297303
self._increment_transaction_id()
298304
if not self._renew:
299305
self._eth.ifconfig = (
@@ -391,16 +397,16 @@ def _dhcp_state_machine(self, *, blocking: bool = False) -> None:
391397
while True:
392398
if self._dhcp_state == _STATE_BOUND:
393399
now = ticks_ms()
394-
if ticks_diff(now, self._t1) < 0:
400+
if ticks_less(now, self._t1_timeout):
395401
debug_msg("No timers have expired. Exiting FSM.", self._debug)
396402
return
397-
if ticks_diff(now, self._lease) > 0:
403+
if ticks_less(self._lease_timeout, now):
398404
debug_msg(
399405
"Lease has expired, switching state to INIT.", self._debug
400406
)
401407
self._blocking = True
402408
self._dhcp_state = _STATE_INIT
403-
elif ticks_diff(now, self._t2) > 0:
409+
elif ticks_less(self._t2_timeout, now):
404410
debug_msg(
405411
"T2 has expired, switching state to REBINDING.", self._debug
406412
)
@@ -414,16 +420,20 @@ def _dhcp_state_machine(self, *, blocking: bool = False) -> None:
414420
if self._dhcp_state == _STATE_RENEWING:
415421
debug_msg("FSM state is RENEWING.", self._debug)
416422
self._renew = "renew"
417-
self._start_time = time.monotonic()
418423
self._start_ticks = ticks_ms()
424+
self._lease = None
425+
self._t1 = None
426+
self._t2 = None
419427
self._dhcp_state = _STATE_REQUESTING
420428

421429
if self._dhcp_state == _STATE_REBINDING:
422430
debug_msg("FSM state is REBINDING.", self._debug)
423431
self._renew = "rebind"
424432
self.dhcp_server_ip = _BROADCAST_SERVER_ADDR
425-
self._start_time = time.monotonic()
426433
self._start_ticks = ticks_ms()
434+
self._lease = None
435+
self._t1 = None
436+
self._t2 = None
427437
self._dhcp_state = _STATE_REQUESTING
428438

429439
if self._dhcp_state == _STATE_INIT:

0 commit comments

Comments
 (0)