mirror of
https://github.com/markqvist/Reticulum.git
synced 2025-01-18 16:30:33 +00:00
Improved resource transfer timing
This commit is contained in:
parent
2331f1ea3e
commit
8cefa4b2a9
@ -188,8 +188,11 @@ class Resource:
|
|||||||
resource.consecutive_completed_height = -1
|
resource.consecutive_completed_height = -1
|
||||||
|
|
||||||
previous_window = resource.link.get_last_resource_window()
|
previous_window = resource.link.get_last_resource_window()
|
||||||
|
previous_eifr = resource.link.get_last_resource_eifr()
|
||||||
if previous_window:
|
if previous_window:
|
||||||
resource.window = previous_window
|
resource.window = previous_window
|
||||||
|
if previous_eifr:
|
||||||
|
resource.previous_eifr = previous_eifr
|
||||||
|
|
||||||
if not resource.link.has_incoming_resource(resource):
|
if not resource.link.has_incoming_resource(resource):
|
||||||
resource.link.register_incoming_resource(resource)
|
resource.link.register_incoming_resource(resource)
|
||||||
@ -213,7 +216,6 @@ class Resource:
|
|||||||
|
|
||||||
except Exception as e:
|
except Exception as e:
|
||||||
RNS.log("Could not decode resource advertisement, dropping resource", RNS.LOG_DEBUG)
|
RNS.log("Could not decode resource advertisement, dropping resource", RNS.LOG_DEBUG)
|
||||||
RNS.trace_exception(e) # TODO: Remove debug
|
|
||||||
return None
|
return None
|
||||||
|
|
||||||
# Create a resource for transmission to a remote destination
|
# Create a resource for transmission to a remote destination
|
||||||
@ -295,6 +297,9 @@ class Resource:
|
|||||||
self.req_sent = 0
|
self.req_sent = 0
|
||||||
self.req_resp_rtt_rate = 0
|
self.req_resp_rtt_rate = 0
|
||||||
self.rtt_rxd_bytes_at_part_req = 0
|
self.rtt_rxd_bytes_at_part_req = 0
|
||||||
|
self.req_data_rtt_rate = 0
|
||||||
|
self.eifr = None
|
||||||
|
self.previous_eifr = None
|
||||||
self.fast_rate_rounds = 0
|
self.fast_rate_rounds = 0
|
||||||
self.very_slow_rate_rounds = 0
|
self.very_slow_rate_rounds = 0
|
||||||
self.request_id = request_id
|
self.request_id = request_id
|
||||||
@ -465,6 +470,22 @@ class Resource:
|
|||||||
|
|
||||||
self.watchdog_job()
|
self.watchdog_job()
|
||||||
|
|
||||||
|
def update_eifr(self):
|
||||||
|
if self.rtt == None:
|
||||||
|
rtt = self.link.rtt
|
||||||
|
else:
|
||||||
|
rtt = self.rtt
|
||||||
|
|
||||||
|
if self.req_data_rtt_rate != 0:
|
||||||
|
expected_inflight_rate = self.req_data_rtt_rate*8
|
||||||
|
else:
|
||||||
|
if self.previous_eifr != None:
|
||||||
|
expected_inflight_rate = self.previous_eifr
|
||||||
|
else:
|
||||||
|
expected_inflight_rate = self.link.establishment_cost*8 / rtt
|
||||||
|
|
||||||
|
self.eifr = expected_inflight_rate
|
||||||
|
|
||||||
def watchdog_job(self):
|
def watchdog_job(self):
|
||||||
thread = threading.Thread(target=self.__watchdog_job)
|
thread = threading.Thread(target=self.__watchdog_job)
|
||||||
thread.daemon = True
|
thread.daemon = True
|
||||||
@ -479,7 +500,6 @@ class Resource:
|
|||||||
sleep(0.025)
|
sleep(0.025)
|
||||||
|
|
||||||
sleep_time = None
|
sleep_time = None
|
||||||
|
|
||||||
if self.status == Resource.ADVERTISED:
|
if self.status == Resource.ADVERTISED:
|
||||||
sleep_time = (self.adv_sent+self.timeout+Resource.PROCESSING_GRACE)-time.time()
|
sleep_time = (self.adv_sent+self.timeout+Resource.PROCESSING_GRACE)-time.time()
|
||||||
if sleep_time < 0:
|
if sleep_time < 0:
|
||||||
@ -503,17 +523,16 @@ class Resource:
|
|||||||
|
|
||||||
elif self.status == Resource.TRANSFERRING:
|
elif self.status == Resource.TRANSFERRING:
|
||||||
if not self.initiator:
|
if not self.initiator:
|
||||||
|
|
||||||
if self.rtt == None:
|
|
||||||
rtt = self.link.rtt
|
|
||||||
else:
|
|
||||||
rtt = self.rtt
|
|
||||||
|
|
||||||
window_remaining = self.outstanding_parts
|
|
||||||
|
|
||||||
retries_used = self.max_retries - self.retries_left
|
retries_used = self.max_retries - self.retries_left
|
||||||
extra_wait = retries_used * Resource.PER_RETRY_DELAY
|
extra_wait = retries_used * Resource.PER_RETRY_DELAY
|
||||||
sleep_time = self.last_activity + (rtt*(self.part_timeout_factor+window_remaining)) + Resource.RETRY_GRACE_TIME + extra_wait - time.time()
|
|
||||||
|
self.update_eifr()
|
||||||
|
expected_tof_remaining = (self.outstanding_parts*self.sdu*8)/self.eifr
|
||||||
|
|
||||||
|
if self.req_resp_rtt_rate != 0:
|
||||||
|
sleep_time = self.last_activity + self.part_timeout_factor*expected_tof_remaining + Resource.RETRY_GRACE_TIME + extra_wait - time.time()
|
||||||
|
else:
|
||||||
|
sleep_time = self.last_activity + self.part_timeout_factor*((3*self.sdu)/self.eifr) + Resource.RETRY_GRACE_TIME + extra_wait - time.time()
|
||||||
|
|
||||||
if sleep_time < 0:
|
if sleep_time < 0:
|
||||||
if self.retries_left > 0:
|
if self.retries_left > 0:
|
||||||
@ -564,7 +583,7 @@ class Resource:
|
|||||||
sleep_time = 0.001
|
sleep_time = 0.001
|
||||||
|
|
||||||
if sleep_time == 0:
|
if sleep_time == 0:
|
||||||
RNS.log("Warning! Link watchdog sleep time of 0!", RNS.LOG_WARNING)
|
RNS.log("Warning! Link watchdog sleep time of 0!", RNS.LOG_DEBUG)
|
||||||
if sleep_time == None or sleep_time < 0:
|
if sleep_time == None or sleep_time < 0:
|
||||||
RNS.log("Timing error, cancelling resource transfer.", RNS.LOG_ERROR)
|
RNS.log("Timing error, cancelling resource transfer.", RNS.LOG_ERROR)
|
||||||
self.cancel()
|
self.cancel()
|
||||||
@ -781,6 +800,7 @@ class Resource:
|
|||||||
|
|
||||||
if rtt != 0:
|
if rtt != 0:
|
||||||
self.req_data_rtt_rate = req_transferred/rtt
|
self.req_data_rtt_rate = req_transferred/rtt
|
||||||
|
self.update_eifr()
|
||||||
self.rtt_rxd_bytes_at_part_req = self.rtt_rxd_bytes
|
self.rtt_rxd_bytes_at_part_req = self.rtt_rxd_bytes
|
||||||
|
|
||||||
if self.req_data_rtt_rate > Resource.RATE_FAST and self.fast_rate_rounds < Resource.FAST_RATE_THRESHOLD:
|
if self.req_data_rtt_rate > Resource.RATE_FAST and self.fast_rate_rounds < Resource.FAST_RATE_THRESHOLD:
|
||||||
|
Loading…
Reference in New Issue
Block a user