GNUnet 0.25.2-1-g44a9a8846
 
Loading...
Searching...
No Matches
GNUNET_BANDWIDTH_Tracker Struct Reference

Struct to track available bandwidth. More...

#include <gnunet_bandwidth_lib.h>

Collaboration diagram for GNUNET_BANDWIDTH_Tracker:
[legend]

Data Fields

void * update_cb_cls
 Closure for update_cb.
 
GNUNET_BANDWIDTH_TrackerUpdateCallback update_cb
 Function we call if the tracker's bandwidth is increased and a previously returned timeout might now expire earlier.
 
void * excess_cb_cls
 Closure for excess_cb.
 
GNUNET_BANDWIDTH_ExcessNotificationCallback excess_cb
 Function we call if the tracker is about to throw away bandwidth due to excess (max carry exceeded).
 
int64_t consumption_since_last_update__
 Number of bytes consumed since we last updated the tracker.
 
struct GNUNET_SCHEDULER_Taskexcess_task
 Task scheduled to call the excess_cb once we have reached the maximum bandwidth the tracker can hold.
 
struct GNUNET_TIME_Absolute last_update__
 Time when we last updated the tracker.
 
uint32_t available_bytes_per_s__
 Bandwidth limit to enforce in bytes per second.
 
uint32_t max_carry_s__
 Maximum number of seconds over which bandwidth may "accumulate".
 

Detailed Description

Struct to track available bandwidth.

Combines a time stamp with a number of bytes transmitted, a quota and a maximum amount that carries over. Not opaque so that it can be inlined into data structures (reducing malloc-ing); however, values should not be accessed directly by clients (hence the '__').

Definition at line 94 of file gnunet_bandwidth_lib.h.

Field Documentation

◆ update_cb_cls

void* GNUNET_BANDWIDTH_Tracker::update_cb_cls

◆ update_cb

GNUNET_BANDWIDTH_TrackerUpdateCallback GNUNET_BANDWIDTH_Tracker::update_cb

Function we call if the tracker's bandwidth is increased and a previously returned timeout might now expire earlier.

Definition at line 105 of file gnunet_bandwidth_lib.h.

Referenced by GNUNET_BANDWIDTH_tracker_init2(), GNUNET_BANDWIDTH_tracker_notification_stop(), and GNUNET_BANDWIDTH_tracker_update_quota().

◆ excess_cb_cls

void* GNUNET_BANDWIDTH_Tracker::excess_cb_cls

Closure for excess_cb.

Definition at line 110 of file gnunet_bandwidth_lib.h.

Referenced by excess_trigger(), GNUNET_BANDWIDTH_tracker_init2(), and GNUNET_BANDWIDTH_tracker_notification_stop().

◆ excess_cb

GNUNET_BANDWIDTH_ExcessNotificationCallback GNUNET_BANDWIDTH_Tracker::excess_cb

Function we call if the tracker is about to throw away bandwidth due to excess (max carry exceeded).

Definition at line 116 of file gnunet_bandwidth_lib.h.

Referenced by excess_trigger(), GNUNET_BANDWIDTH_tracker_init2(), GNUNET_BANDWIDTH_tracker_notification_stop(), and update_excess().

◆ consumption_since_last_update__

int64_t GNUNET_BANDWIDTH_Tracker::consumption_since_last_update__

Number of bytes consumed since we last updated the tracker.

Definition at line 121 of file gnunet_bandwidth_lib.h.

Referenced by GNUNET_BANDWIDTH_tracker_consume(), GNUNET_BANDWIDTH_tracker_get_available(), GNUNET_BANDWIDTH_tracker_init2(), update_excess(), and update_tracker().

◆ excess_task

struct GNUNET_SCHEDULER_Task* GNUNET_BANDWIDTH_Tracker::excess_task

Task scheduled to call the excess_cb once we have reached the maximum bandwidth the tracker can hold.

Definition at line 127 of file gnunet_bandwidth_lib.h.

Referenced by excess_trigger(), GNUNET_BANDWIDTH_tracker_notification_stop(), and update_excess().

◆ last_update__

struct GNUNET_TIME_Absolute GNUNET_BANDWIDTH_Tracker::last_update__

Time when we last updated the tracker.

Definition at line 132 of file gnunet_bandwidth_lib.h.

Referenced by GNUNET_BANDWIDTH_tracker_get_available(), GNUNET_BANDWIDTH_tracker_init2(), update_excess(), and update_tracker().

◆ available_bytes_per_s__

uint32_t GNUNET_BANDWIDTH_Tracker::available_bytes_per_s__

◆ max_carry_s__

uint32_t GNUNET_BANDWIDTH_Tracker::max_carry_s__

Maximum number of seconds over which bandwidth may "accumulate".

Note that additionally, we also always allow at least GNUNET_MAX_MESSAGE_SIZE to accumulate.

Definition at line 144 of file gnunet_bandwidth_lib.h.

Referenced by GNUNET_BANDWIDTH_tracker_init2(), update_excess(), and update_tracker().


The documentation for this struct was generated from the following file: