14 #define CHANNEL_OBJECT_PRIVATE 
   18 #include "core/or/channelpadding.h" 
   39 STATIC int64_t channelpadding_compute_time_until_pad_for_netflow(
channel_t *);
 
   64 #define TOR_MSEC_PER_SEC 1000 
   65 #define TOR_USEC_PER_MSEC 1000 
   70 #define TOR_HOUSEKEEPING_CALLBACK_MSEC 1000 
   75 #define TOR_HOUSEKEEPING_CALLBACK_SLACK_MSEC 100 
   82 #define CHANNEL_IS_CLIENT(chan, options) \ 
   83   (!public_server_mode((options)) || channel_is_client(chan) || \ 
   84       !connection_or_digest_is_known_relay((chan)->identity_digest)) 
   95 #define DFLT_NETFLOW_INACTIVE_KEEPALIVE_LOW 1500 
   96 #define DFLT_NETFLOW_INACTIVE_KEEPALIVE_HIGH 9500 
   97 #define DFLT_NETFLOW_INACTIVE_KEEPALIVE_MIN 0 
   98 #define DFLT_NETFLOW_INACTIVE_KEEPALIVE_MAX 60000 
  100       DFLT_NETFLOW_INACTIVE_KEEPALIVE_LOW,
 
  101       DFLT_NETFLOW_INACTIVE_KEEPALIVE_MIN,
 
  102       DFLT_NETFLOW_INACTIVE_KEEPALIVE_MAX);
 
  104       DFLT_NETFLOW_INACTIVE_KEEPALIVE_HIGH,
 
  106       DFLT_NETFLOW_INACTIVE_KEEPALIVE_MAX);
 
  108 #define DFLT_NETFLOW_REDUCED_KEEPALIVE_LOW 9000 
  109 #define DFLT_NETFLOW_REDUCED_KEEPALIVE_HIGH 14000 
  110 #define DFLT_NETFLOW_REDUCED_KEEPALIVE_MIN 0 
  111 #define DFLT_NETFLOW_REDUCED_KEEPALIVE_MAX 60000 
  114         DFLT_NETFLOW_REDUCED_KEEPALIVE_LOW,
 
  115         DFLT_NETFLOW_REDUCED_KEEPALIVE_MIN,
 
  116         DFLT_NETFLOW_REDUCED_KEEPALIVE_MAX);
 
  120         DFLT_NETFLOW_REDUCED_KEEPALIVE_HIGH,
 
  122         DFLT_NETFLOW_REDUCED_KEEPALIVE_MAX);
 
  124 #define CONNTIMEOUT_RELAYS_DFLT (60*60)  
  125 #define CONNTIMEOUT_RELAYS_MIN 60 
  126 #define CONNTIMEOUT_RELAYS_MAX (7*24*60*60)  
  129         CONNTIMEOUT_RELAYS_DFLT,
 
  130         CONNTIMEOUT_RELAYS_MIN,
 
  131         CONNTIMEOUT_RELAYS_MAX);
 
  133 #define CIRCTIMEOUT_CLIENTS_DFLT (30*60)  
  134 #define CIRCTIMEOUT_CLIENTS_MIN 60 
  135 #define CIRCTIMEOUT_CLIENTS_MAX (24*60*60)  
  138         CIRCTIMEOUT_CLIENTS_DFLT,
 
  139         CIRCTIMEOUT_CLIENTS_MIN,
 
  140         CIRCTIMEOUT_CLIENTS_MAX);
 
  150                             CHANNELPADDING_SOS_PARAM,
 
  151                             CHANNELPADDING_SOS_DEFAULT, 0, 1);
 
  179   if (low_timeout == 0 && low_timeout == high_timeout)
 
  186     high_timeout = 
MAX(high_timeout, chan->padding_timeout_high_ms);
 
  189   if (low_timeout == high_timeout)
 
  235   return low_timeout + 
MAX(X1, X2);
 
  246                 const channelpadding_negotiate_t *pad_vars)
 
  248   if (pad_vars->version != 0) {
 
  249     static ratelim_t version_limit = RATELIM_INIT(600);
 
  252            "Got a PADDING_NEGOTIATE cell with an unknown version. Ignoring.");
 
  263     static ratelim_t relay_limit = RATELIM_INIT(600);
 
  266            "Got a PADDING_NEGOTIATE from relay at %s (%s). " 
  267            "This should not happen.",
 
  273   chan->
padding_enabled = (pad_vars->command == CHANNELPADDING_COMMAND_START);
 
  278                                      pad_vars->ito_low_ms);
 
  282                                       pad_vars->ito_high_ms);
 
  285          "Negotiated padding=%d, lo=%d, hi=%d on %"PRIu64,
 
  287          chan->padding_timeout_high_ms,
 
  302   channelpadding_negotiate_t disable;
 
  306   tor_assert(BASE_CHAN_TO_TLS(chan)->conn->link_proto >=
 
  307              MIN_LINK_PROTO_FOR_CHANNEL_PADDING);
 
  309   memset(&cell, 0, 
sizeof(
cell_t));
 
  310   memset(&disable, 0, 
sizeof(channelpadding_negotiate_t));
 
  311   cell.
command = CELL_PADDING_NEGOTIATE;
 
  313   channelpadding_negotiate_set_command(&disable, CHANNELPADDING_COMMAND_STOP);
 
  319   if (chan->write_cell(chan, &cell) == 1)
 
  333                                    uint16_t high_timeout)
 
  335   channelpadding_negotiate_t enable;
 
  339   tor_assert(BASE_CHAN_TO_TLS(chan)->conn->link_proto >=
 
  340              MIN_LINK_PROTO_FOR_CHANNEL_PADDING);
 
  342   memset(&cell, 0, 
sizeof(
cell_t));
 
  343   memset(&enable, 0, 
sizeof(channelpadding_negotiate_t));
 
  344   cell.
command = CELL_PADDING_NEGOTIATE;
 
  346   channelpadding_negotiate_set_command(&enable, CHANNELPADDING_COMMAND_START);
 
  347   channelpadding_negotiate_set_ito_low_ms(&enable, low_timeout);
 
  348   channelpadding_negotiate_set_ito_high_ms(&enable, high_timeout);
 
  354   if (chan->write_cell(chan, &cell) == 1)
 
  376            "Scheduled a netflow padding cell, but connection already closed.");
 
  395     monotime_coarse_t now;
 
  396     monotime_coarse_get(&now);
 
  399         "Sending netflow keepalive on %"PRIu64
" to %s (%s) after " 
  400         "%"PRId64
" ms. Delta %"PRId64
"ms",
 
  414   memset(&cell, 0, 
sizeof(cell));
 
  416   chan->write_cell(chan, &cell);
 
  431   channel_t *chan = channel_handle_get((
struct channel_handle_t*)args);
 
  432   (void)timer; (void)when;
 
  434   if (chan && CHANNEL_CAN_HANDLE_CELLS(chan)) {
 
  438                OR_CONNECTION_MAGIC);
 
  444             "Channel closed while waiting for timer.");
 
  458 static channelpadding_decision_t
 
  467     return CHANNELPADDING_PADDING_SENT;
 
  470   timeout.tv_sec = in_ms/TOR_MSEC_PER_SEC;
 
  471   timeout.tv_usec = (in_ms%TOR_USEC_PER_MSEC)*TOR_USEC_PER_MSEC;
 
  490   return CHANNELPADDING_PADDING_SCHEDULED;
 
  507 #define CHANNELPADDING_TIME_LATER -1 
  508 #define CHANNELPADDING_TIME_DISABLED -2 
  510 channelpadding_compute_time_until_pad_for_netflow(
channel_t *chan)
 
  512   monotime_coarse_t now;
 
  513   monotime_coarse_get(&now);
 
  522     int32_t padding_timeout =
 
  525     if (!padding_timeout)
 
  526       return CHANNELPADDING_TIME_DISABLED;
 
  533   const int64_t ms_till_pad =
 
  542   if (ms_till_pad > DFLT_NETFLOW_INACTIVE_KEEPALIVE_MAX) {
 
  545         "Channel padding timeout scheduled %"PRId64
"ms in the future. " 
  546         "Did the monotonic clock just jump?",
 
  566 #define NETFLOW_MISSED_WINDOW (150000 - DFLT_NETFLOW_INACTIVE_KEEPALIVE_HIGH) 
  567     if (ms_till_pad < 0) {
 
  568       int severity = (ms_till_pad < -NETFLOW_MISSED_WINDOW)
 
  571               "Channel padding timeout scheduled %"PRId64
"ms in the past. ",
 
  603 #define CONNTIMEOUT_CLIENTS_BASE 180  
  604     timeout = CONNTIMEOUT_CLIENTS_BASE
 
  705          "Reduced padding on channel %"PRIu64
": lo=%d, hi=%d",
 
  720 channelpadding_decision_t
 
  727     return CHANNELPADDING_WONTPAD;
 
  731       return CHANNELPADDING_WONTPAD;
 
  732   } 
else if (chan->
channel_usage != CHANNEL_USED_FOR_USER_TRAFFIC) {
 
  733     return CHANNELPADDING_WONTPAD;
 
  737     return CHANNELPADDING_PADDING_ALREADY_SCHEDULED;
 
  744     return CHANNELPADDING_WONTPAD;
 
  747   if (hs_service_allow_non_anonymous_connection(options) &&
 
  754     return CHANNELPADDING_WONTPAD;
 
  762     int is_client_channel = 0;
 
  765        is_client_channel = 1;
 
  772       int64_t pad_time_ms =
 
  773           channelpadding_compute_time_until_pad_for_netflow(chan);
 
  775       if (pad_time_ms == CHANNELPADDING_TIME_DISABLED) {
 
  776         return CHANNELPADDING_WONTPAD;
 
  779         return CHANNELPADDING_PADLATER;
 
  781         if (BUG(pad_time_ms > INT_MAX)) {
 
  782           pad_time_ms = INT_MAX;
 
  794       return CHANNELPADDING_WONTPAD;
 
  797     return CHANNELPADDING_PADLATER;
 
const char * hex_str(const char *from, size_t fromlen)
Fixed-size cell structure.
const char * channel_describe_peer(channel_t *chan)
Header file for channel.c.
static uint64_t total_timers_pending
void channelpadding_disable_padding_on_channel(channel_t *chan)
static int consensus_nf_ito_high
int channelpadding_get_circuits_available_timeout(void)
static int consensus_nf_pad_before_usage
unsigned int channelpadding_get_channel_idle_timeout(const channel_t *chan, int is_canonical)
static int consensus_nf_ito_low
int channelpadding_send_enable_command(channel_t *chan, uint16_t low_timeout, uint16_t high_timeout)
#define TOR_HOUSEKEEPING_CALLBACK_SLACK_MSEC
static void channelpadding_send_padding_cell_for_callback(channel_t *chan)
#define TOR_HOUSEKEEPING_CALLBACK_MSEC
static channelpadding_decision_t channelpadding_schedule_padding(channel_t *chan, int in_ms)
STATIC int channelpadding_send_disable_command(channel_t *)
int channelpadding_update_padding_for_channel(channel_t *chan, const channelpadding_negotiate_t *pad_vars)
channelpadding_decision_t channelpadding_decide_to_pad_channel(channel_t *chan)
static int consensus_nf_pad_single_onion
static int consensus_nf_conntimeout_clients
static void channelpadding_send_padding_callback(tor_timer_t *timer, void *args, const struct monotime_t *when)
void channelpadding_new_consensus_params(const networkstatus_t *ns)
void channelpadding_reduce_padding_on_channel(channel_t *chan)
static int consensus_nf_ito_low_reduced
static int consensus_nf_ito_high_reduced
static int consensus_nf_conntimeout_relays
static int consensus_nf_pad_relays
#define CHANNELPADDING_TIME_LATER
#define CHANNEL_IS_CLIENT(chan, options)
STATIC int32_t channelpadding_get_netflow_inactive_timeout_ms(const channel_t *)
Header file for channeltls.c.
unsigned int circuitmux_num_cells(circuitmux_t *cmux)
Functions and types for monotonic times.
const or_options_t * get_options(void)
Header file for config.c.
void assert_connection_ok(connection_t *conn, time_t now)
Header file for connection.c.
int connection_or_digest_is_known_relay(const char *id_digest)
Header file for connection_or.c.
Common functions for using (pseudo-)random number generators.
int crypto_rand_int(unsigned int max)
Header file containing service data for the HS subsystem.
#define log_fn(severity, domain, args,...)
#define log_fn_ratelim(ratelim, severity, domain, args,...)
Header file for mainloop.c.
int32_t networkstatus_get_param(const networkstatus_t *ns, const char *param_name, int32_t default_val, int32_t min_val, int32_t max_val)
Header file for networkstatus.c.
Master header file for Tor-specific functionality.
#define CELL_PAYLOAD_SIZE
void rep_hist_padding_count_timers(uint64_t num_timers)
Header file for rephist.c.
Header file for router.c.
Header file for routermode.c.
uint8_t payload[CELL_PAYLOAD_SIZE]
uint16_t padding_timeout_low_ms
monotime_coarse_t next_padding_time
unsigned int padding_enabled
char identity_digest[DIGEST_LEN]
uint64_t global_identifier
channel_usage_info_t channel_usage
struct channel_handle_t * timer_handle
unsigned int pending_padding_callback
monotime_coarse_t timestamp_xfer
unsigned int currently_padding
struct tor_timer_t * padding_timer
int(* has_queued_writes)(channel_t *)
int ReducedConnectionPadding
int CircuitsAvailableTimeout
void timer_set_cb(tor_timer_t *t, timer_cb_fn_t cb, void *arg)
void timer_schedule(tor_timer_t *t, const struct timeval *tv)
tor_timer_t * timer_new(timer_cb_fn_t cb, void *arg)
#define tor_fragile_assert()