From 351d14734fb2ab8ecf3891a0e9b7addcee3972af Mon Sep 17 00:00:00 2001 From: wangyu Date: Fri, 4 Aug 2017 04:22:16 +0800 Subject: [PATCH] fixed anti_replay dead loop --- common.cpp | 18 ++++++++++++++++-- log.h | 2 ++ main.cpp | 22 ++++++++++++---------- 3 files changed, 30 insertions(+), 12 deletions(-) diff --git a/common.cpp b/common.cpp index 1bd35e1..d0f3bd9 100644 --- a/common.cpp +++ b/common.cpp @@ -51,23 +51,37 @@ char * my_ntoa(uint32_t ip) void init_random_number_fd() { + random_number_fd=open("/dev/urandom",O_RDONLY); + if(random_number_fd==-1) { mylog(log_fatal,"error open /dev/urandom\n"); exit(-1); } + setnonblocking(random_number_fd); } uint64_t get_true_random_number_64() { uint64_t ret; - read(random_number_fd,&ret,sizeof(ret)); + int size=read(random_number_fd,&ret,sizeof(ret)); + if(size!=sizeof(ret)) + { + mylog(log_fatal,"get random number failed\n",size); + exit(-1); + } + return ret; } uint32_t get_true_random_number() { uint32_t ret; - read(random_number_fd,&ret,sizeof(ret)); + int size=read(random_number_fd,&ret,sizeof(ret)); + if(size!=sizeof(ret)) + { + mylog(log_fatal,"get random number failed\n",size); + exit(-1); + } return ret; } uint32_t get_true_random_number_nz() //nz for non-zero diff --git a/log.h b/log.h index 784ca93..d2e4e62 100755 --- a/log.h +++ b/log.h @@ -87,6 +87,8 @@ extern int enable_log_color; //#define mylog(__first_argu__dummy_abcde__,...) printf(__VA_ARGS__) +//#define mylog(__first_argu__dummy_abcde__,...) {;} + void log0(const char * file,const char * function,int line,int level,const char* str, ...); void log_bare(int level,const char* str, ...); diff --git a/main.cpp b/main.cpp index fbdaaaf..5cfd36c 100755 --- a/main.cpp +++ b/main.cpp @@ -54,7 +54,7 @@ struct anti_replay_t { disabled=0; max_packet_received=0; - anti_replay_seq=get_true_random_number(); + anti_replay_seq=get_true_random_number_64()/10;//random first seq //memset(window,0,sizeof(window)); //not necessary } void re_init() @@ -86,7 +86,7 @@ struct anti_replay_t } else { - for (uint32_t i=max_packet_received+1;ianti_replay.is_vaild(h_seq) != 1) { - mylog(log_warn,"dropped replay packet\n"); + mylog(log_debug,"dropped replay packet\n"); return -1; } @@ -1086,10 +1086,7 @@ int client_on_timer(conn_info_t &conn_info) //for client { conn_info.state.client_current_state=client_tcp_handshake; mylog(log_info,"state changed from client_idle to client_tcp_handshake\n"); - send_info.psh = 0; - send_info.syn = 1; - send_info.ack = 0; - send_info.ts_ack =0; + } conn_info.last_state_time=get_current_time(); conn_info.last_resent_time=0; @@ -1112,8 +1109,12 @@ int client_on_timer(conn_info_t &conn_info) //for client { if (conn_info.last_resent_time == 0) { - send_info.ack_seq = recv_info.seq + 1; - //send_info.ts_ack = recv_info.ts; + send_info.psh = 0; + send_info.syn = 1; + send_info.ack = 0; + send_info.ts_ack =0; + send_info.seq=get_true_random_number(); + send_info.ack_seq=get_true_random_number(); } } @@ -1283,7 +1284,7 @@ int server_on_timer_multi(conn_info_t &conn_info) conn_info.last_hb_sent_time=get_current_time(); - mylog(log_trace,"heart beat sent<%x,%x>\n",conn_info.my_id,conn_info.oppsite_id); + mylog(log_debug,"heart beat sent<%x,%x>\n",conn_info.my_id,conn_info.oppsite_id); } else { @@ -1513,6 +1514,7 @@ int server_on_raw_recv_multi() send_info.psh = 0; send_info.syn = 1; send_info.ack = 1; + send_info.ts_ack=recv_info.ts; mylog(log_info,"received syn,sent syn ack back\n"); send_raw0(raw_info, 0, 0);