-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathtcp_flow.h
106 lines (89 loc) · 2.93 KB
/
tcp_flow.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
//
// tcp_flow.h
// PacketTraceExplorer
//
// Created by Junxian Huang on 12/1/12.
// Copyright (c) 2012 Junxian Huang. All rights reserved.
//
#ifndef __PacketTraceExplorer__tcp_flow__
#define __PacketTraceExplorer__tcp_flow__
#include "util.h"
#include "def.h"
const int SEQ_INDEX_MAX = 6;
const int ACK_INDEX_MAX = SEQ_INDEX_MAX / 2; //1 ACK 2 Data PKTs
class tcp_flow {
public:
u_int svr_ip;
u_int clt_ip;
u_short svr_port;
u_short clt_port;
double actual_ts;
double gval;
u_int u_int_start;
double double_start;
int promotion_delay;
u_int window_scale;
u_int window_initial_size;
u_int window_size;
double unaffected_time;
double target;
double bwstep;
double last_time;
double last_throughput;
double start_time;
double first_byte_time; //first byte from server to client
double last_byte_time; //last byte from server to client
double end_time;
double idle_time;
double syn_rtt, syn_ack_rtt;
double idle_time_before_syn;
short si; //circular seq index 0 - 19, point to the current last element
short sx; // point to the current first index
u_int seq_down[SEQ_INDEX_MAX]; //circular arrary, seq_down[si] is the last packet
double seq_ts[SEQ_INDEX_MAX]; //corresponding time
short ai; //circular ack index 0 - 9
short ax; // point to the current first index
u_int ack_down[ACK_INDEX_MAX]; //circular arrary
double ack_ts[ACK_INDEX_MAX]; //corresponding time
bool has_ts_option_clt;
bool has_ts_option_svr;
uint64 total_down_payloads;
uint64 total_up_payloads;
uint64 bytes_in_fly;
uint64 max_bytes_in_fly;
uint64 packet_count;
uint64 dup_ack_count;
uint64 outorder_seq_count;
double total_bw;
int sample_count;
double first_bw;
u_short dup_ack_count_current;
u_short slow_start_count; // start from 1 initial slow start
double last_dupack_time;
u_int bytes_after_dupack;
//HTTP analysis
u_short http_request_count;
string content_type;
string user_agent;
string host;
u_int total_content_length;
tcp_flow();
//called during init or any abnormal happens
void reset_seq();
void reset_ack();
//functions for BW estimation
void update_seq(u_int seq, u_short payload_len, double ts);
void update_ack(u_int ack, u_short payload_len, double ts, double _actual_ts);
//functions for RTT analysis
void update_seq_x(u_int seq, u_short payload_len, double ts);
void update_ack_x(u_int ack, u_short payload_len, double _actual_ts);
//test with start_ai and ai
bool bw_estimate(short start_ai);
short find_seq_by_ack(u_int ack, short start, short end);
short get_si_next(short c);
short get_si_previous(short c);
short get_ai_next(short c);
short get_ai_previous(short c);
void print(u_short processed_flags);
};
#endif /* defined(__PacketTraceExplorer__tcp_flow__) */