2019-04-24 14:23:41 +00:00
|
|
|
#pragma once
|
|
|
|
#include <sys/socket.h>
|
|
|
|
#include <stdlib.h>
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <errno.h>
|
|
|
|
#include <string.h>
|
|
|
|
#include "evt_core.h"
|
|
|
|
#include "algo_utils.h"
|
2019-05-27 15:32:00 +00:00
|
|
|
#include "capture_traffic.h"
|
2019-04-24 14:23:41 +00:00
|
|
|
#include "url.h"
|
|
|
|
#include "utils.h"
|
|
|
|
#include "packet.h"
|
|
|
|
|
2019-05-27 15:32:00 +00:00
|
|
|
struct algo_params {
|
|
|
|
uint8_t is_waiting_bootstrap;
|
2019-09-06 13:28:42 +00:00
|
|
|
char *algo_name, *capture_file, *algo_specific_params;
|
2019-05-27 15:32:00 +00:00
|
|
|
int links, fresh_data, redundant_data;
|
|
|
|
};
|
|
|
|
|
|
|
|
struct algo_ctx;
|
|
|
|
typedef void (*algo_init)(struct evt_core_ctx* ctx, struct algo_ctx* app_ctx, struct algo_params* ap);
|
|
|
|
typedef int (*algo_ctx_on_buffer)(struct evt_core_ctx* ctx, struct evt_core_fdinfo* fdinfo, struct buffer_packet* bp);
|
|
|
|
typedef int (*algo_ctx_on_event)(struct evt_core_ctx* ctx, struct evt_core_fdinfo* fdinfo);
|
|
|
|
|
|
|
|
typedef void (*algo_ctx_free_misc)(void*);
|
|
|
|
|
|
|
|
struct algo_desc {
|
|
|
|
char* name;
|
|
|
|
algo_init init;
|
|
|
|
algo_ctx_on_buffer on_stream;
|
|
|
|
algo_ctx_on_buffer on_datagram;
|
|
|
|
algo_ctx_on_event on_err;
|
|
|
|
};
|
|
|
|
|
|
|
|
struct algo_ctx {
|
|
|
|
struct algo_desc* desc;
|
|
|
|
uint8_t link_count;
|
|
|
|
uint8_t is_rdy;
|
|
|
|
struct algo_params ap;
|
|
|
|
int ref_count;
|
2019-09-06 09:20:17 +00:00
|
|
|
uint64_t udp_rcv, udp_sent, cell_rcv, cell_sent;
|
2019-05-27 15:32:00 +00:00
|
|
|
struct capture_ctx cap;
|
|
|
|
struct buffer_resources br;
|
|
|
|
void* misc; // Additional structures
|
|
|
|
algo_ctx_free_misc free_misc; // Fx ptr to free misc
|
|
|
|
};
|
|
|
|
|
2019-04-24 14:23:41 +00:00
|
|
|
void algo_naive_init(struct evt_core_ctx* ctx, struct algo_ctx* app_ctx, struct algo_params* ap);
|
|
|
|
int algo_naive_on_stream(struct evt_core_ctx* ctx, struct evt_core_fdinfo* fdinfo, struct buffer_packet* bp);
|
|
|
|
int algo_naive_on_datagram(struct evt_core_ctx* ctx, struct evt_core_fdinfo* fdinfo, struct buffer_packet* bp);
|
|
|
|
int algo_naive_on_err(struct evt_core_ctx *ctx, struct evt_core_fdinfo *fdinfo);
|
|
|
|
|
2019-05-06 12:23:14 +00:00
|
|
|
void algo_dup2_init(struct evt_core_ctx* ctx, struct algo_ctx* app_ctx, struct algo_params* ap);
|
|
|
|
int algo_dup2_on_stream(struct evt_core_ctx* ctx, struct evt_core_fdinfo* fdinfo, struct buffer_packet* bp);
|
|
|
|
int algo_dup2_on_datagram(struct evt_core_ctx* ctx, struct evt_core_fdinfo* fdinfo, struct buffer_packet* bp);
|
|
|
|
int algo_dup2_on_err(struct evt_core_ctx *ctx, struct evt_core_fdinfo *fdinfo);
|
|
|
|
|
2019-08-09 15:01:28 +00:00
|
|
|
void algo_thunder_init(struct evt_core_ctx* ctx, struct algo_ctx* app_ctx, struct algo_params* ap);
|
|
|
|
int algo_thunder_on_stream(struct evt_core_ctx* ctx, struct evt_core_fdinfo* fdinfo, struct buffer_packet* bp);
|
|
|
|
int algo_thunder_on_datagram(struct evt_core_ctx* ctx, struct evt_core_fdinfo* fdinfo, struct buffer_packet* bp);
|
|
|
|
int algo_thunder_on_err(struct evt_core_ctx *ctx, struct evt_core_fdinfo *fdinfo);
|
|
|
|
|
2019-04-24 14:23:41 +00:00
|
|
|
static struct algo_desc available_algo[] = {
|
|
|
|
{
|
|
|
|
.name = "naive",
|
|
|
|
.init = algo_naive_init,
|
|
|
|
.on_stream = algo_naive_on_stream,
|
|
|
|
.on_datagram = algo_naive_on_datagram,
|
|
|
|
.on_err = algo_naive_on_err
|
|
|
|
},
|
|
|
|
{
|
|
|
|
.name = "dup2",
|
2019-05-06 12:23:14 +00:00
|
|
|
.init = algo_dup2_init,
|
|
|
|
.on_stream = algo_dup2_on_stream,
|
|
|
|
.on_datagram = algo_dup2_on_datagram,
|
|
|
|
.on_err = algo_dup2_on_err
|
2019-08-09 15:01:28 +00:00
|
|
|
},
|
|
|
|
{
|
|
|
|
.name = "thunder",
|
|
|
|
.init = algo_thunder_init,
|
|
|
|
.on_stream = algo_thunder_on_stream,
|
|
|
|
.on_datagram = algo_thunder_on_datagram,
|
|
|
|
.on_err = algo_thunder_on_err
|
2019-04-24 14:23:41 +00:00
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
void algo_main_init(struct evt_core_ctx* evt, struct algo_params* ap);
|
|
|
|
|
|
|
|
int main_on_tcp_co(struct evt_core_ctx* ctx, struct evt_core_fdinfo* fdinfo);
|
|
|
|
int main_on_tcp_read(struct evt_core_ctx* ctx, struct evt_core_fdinfo* fdinfo);
|
|
|
|
int main_on_udp_read(struct evt_core_ctx* ctx, struct evt_core_fdinfo* fdinfo);
|
|
|
|
int main_on_tcp_write(struct evt_core_ctx* ctx, struct evt_core_fdinfo* fdinfo);
|
|
|
|
int main_on_udp_write (struct evt_core_ctx* ctx, struct evt_core_fdinfo* fdinfo);
|
|
|
|
int main_on_timer(struct evt_core_ctx* ctx, struct evt_core_fdinfo* fdinfo);
|
|
|
|
int main_on_err(struct evt_core_ctx* ctx, struct evt_core_fdinfo* fdinfo);
|
2019-09-16 12:40:58 +00:00
|
|
|
|
|
|
|
//@FIXME UGLY
|
|
|
|
|
|
|
|
// A Tor cell size is 512 bytes but handle only 498 bytes of data
|
|
|
|
#define TOR_CELL_SIZE 498
|
|
|
|
#define MAX_LINKS 64
|
|
|
|
|
|
|
|
struct thunder_ctx {
|
|
|
|
uint16_t recv_id;
|
|
|
|
uint16_t emit_id;
|
|
|
|
uint8_t selected_link;
|
|
|
|
uint8_t total_links;
|
2019-09-16 22:03:48 +00:00
|
|
|
uint8_t to_increment[MAX_LINKS];
|
2019-09-16 12:40:58 +00:00
|
|
|
uint64_t delta_t_per_link[MAX_LINKS];
|
|
|
|
uint64_t rcv_delta_t_per_link[MAX_LINKS];
|
|
|
|
uint64_t received_pkts_on_link[MAX_LINKS];
|
|
|
|
uint64_t sent_pkts_on_link[MAX_LINKS];
|
|
|
|
uint64_t blacklisted[MAX_LINKS];
|
|
|
|
int64_t estimated_sent[MAX_LINKS];
|
|
|
|
size_t monit_pkt_size;
|
|
|
|
int64_t allowed_jitter_ms;
|
2019-09-16 13:39:16 +00:00
|
|
|
struct timespec prev_link_time, prev_rcv_link_time, start_time;
|
2019-09-16 12:40:58 +00:00
|
|
|
};
|
|
|
|
void get_estimation(struct thunder_ctx* thunderc, int64_t* sorted_estimation, uint64_t* sorted_occurencies);
|