mirror of
				https://github.com/wangyu-/udp2raw.git
				synced 2025-10-25 23:35:35 +08:00 
			
		
		
		
	Compare commits
	
		
			46 Commits
		
	
	
		
			master
			...
			b1748a2fd8
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|  | b1748a2fd8 | ||
|  | 4623f878e0 | ||
|  | b6c6813d41 | ||
|  | 9045264d37 | ||
|  | 4e6e1e6a97 | ||
|  | e42f0e5732 | ||
|  | f49e6adedf | ||
|  | d1a9bcc4fb | ||
|  | bc8bd8c2f8 | ||
|  | ca16c3a5e6 | ||
|  | 7abe19c7d9 | ||
|  | f3f528e866 | ||
|  | ec6fad552b | ||
|  | 87b878a09e | ||
|  | e66eddd1d5 | ||
|  | ec416515f3 | ||
|  | d12e540830 | ||
|  | e7eecc8ef2 | ||
|  | 82ba4f7d1b | ||
|  | e5ecd33ec4 | ||
|  | 9217e0e9e6 | ||
|  | 87b0db8862 | ||
|  | 8ceaf27eda | ||
|  | 9f9e8caff6 | ||
|  | 74f3eb90a7 | ||
|  | 38286d5c5b | ||
|  | ec849322d7 | ||
|  | b98a467eed | ||
|  | 25d3323427 | ||
|  | b8e9095135 | ||
|  | 026f97687a | ||
|  | f2f90a9a15 | ||
|  | cf23f4d656 | ||
|  | 59819db2dd | ||
|  | cc6ea766c4 | ||
|  | 509156fc14 | ||
|  | cb9059bf3b | ||
|  | 07e2e695a6 | ||
|  | e8daf7c263 | ||
|  | 5f907e32d7 | ||
|  | 0e37c1fea4 | ||
|  | 606bbec351 | ||
|  | 3fc23f5cf6 | ||
|  | f3c8f70f47 | ||
|  | 6c27502757 | ||
|  | 5a51248cb0 | 
							
								
								
									
										4
									
								
								.clang-format
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										4
									
								
								.clang-format
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,4 @@ | |||||||
|  | SortIncludes: false | ||||||
|  | BasedOnStyle: Google | ||||||
|  | ColumnLimit: 0 | ||||||
|  | IndentWidth: 4 | ||||||
							
								
								
									
										35
									
								
								CMakeLists.txt
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										35
									
								
								CMakeLists.txt
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,35 @@ | |||||||
|  | #note: experimental | ||||||
|  | #      currently only used for generating `compile_commands.json` for clangd. | ||||||
|  | #      to build this project, it's suggested to use `makefile` instead | ||||||
|  |  | ||||||
|  | cmake_minimum_required(VERSION 3.7) | ||||||
|  | project(udp2raw) | ||||||
|  | set(CMAKE_EXPORT_COMPILE_COMMANDS ON) | ||||||
|  |  | ||||||
|  | set(CMAKE_CXX_STANDARD 11) | ||||||
|  |  | ||||||
|  | set(SOURCE_FILES | ||||||
|  |         main.cpp  | ||||||
|  |         lib/md5.cpp | ||||||
|  |         lib/pbkdf2-sha1.cpp | ||||||
|  |         lib/pbkdf2-sha256.cpp | ||||||
|  |         encrypt.cpp | ||||||
|  |         log.cpp | ||||||
|  |         network.cpp | ||||||
|  |         common.cpp | ||||||
|  |         connection.cpp | ||||||
|  |         misc.cpp | ||||||
|  |         fd_manager.cpp | ||||||
|  |         client.cpp | ||||||
|  |         server.cpp | ||||||
|  |         lib/aes_faster_c/aes.cpp | ||||||
|  |         lib/aes_faster_c/wrapper.cpp | ||||||
|  |         my_ev.cpp | ||||||
|  | ) | ||||||
|  | set(CMAKE_CXX_FLAGS "-Wall -Wextra -Wno-unused-variable -Wno-unused-parameter -Wno-missing-field-initializers -O2 -g -fsanitize=address,undefined") | ||||||
|  |  | ||||||
|  | add_executable(udp2raw ${SOURCE_FILES}) | ||||||
|  | target_link_libraries(udp2raw rt) | ||||||
|  | target_link_libraries(udp2raw pthread) | ||||||
|  | include_directories(SYSTEM "libev") | ||||||
|  | include_directories(".") | ||||||
							
								
								
									
										13
									
								
								Dockerfile
									
									
									
									
									
								
							
							
						
						
									
										13
									
								
								Dockerfile
									
									
									
									
									
								
							| @@ -1,13 +0,0 @@ | |||||||
| FROM alpine:3.6 as builder |  | ||||||
|  |  | ||||||
| WORKDIR / |  | ||||||
|  |  | ||||||
| RUN apk add --no-cache git  build-base linux-headers && \ |  | ||||||
|  git clone https://github.com/wangyu-/udp2raw-tunnel.git  && \ |  | ||||||
|  cd udp2raw-tunnel && \ |  | ||||||
|  make dynamic |  | ||||||
|  |  | ||||||
| FROM alpine:3.6 |  | ||||||
| RUN apk add --no-cache libstdc++ iptables |  | ||||||
| COPY --from=builder /udp2raw-tunnel/udp2raw_dynamic /bin/ |  | ||||||
| ENTRYPOINT [ "/bin/udp2raw_dynamic" ] |  | ||||||
| @@ -1,6 +1 @@ | |||||||
| For English speaking user: | English Only. | ||||||
| https://github.com/wangyu-/UDPspeeder/wiki/Issue-Guide |  | ||||||
|  |  | ||||||
| 中文用户请看: |  | ||||||
| https://github.com/wangyu-/UDPspeeder/wiki/发Issue前请看 |  | ||||||
| (否则Issue可能被忽略,或被直接关掉) |  | ||||||
|   | |||||||
							
								
								
									
										91
									
								
								README.md
									
									
									
									
									
								
							
							
						
						
									
										91
									
								
								README.md
									
									
									
									
									
								
							| @@ -1,42 +1,44 @@ | |||||||
| # Udp2raw-tunnel | # Udp2raw-tunnel | ||||||
|  |  | ||||||
|  |  | ||||||
| A Tunnel which turns UDP Traffic into Encrypted FakeTCP/UDP/ICMP Traffic by using Raw Socket, helps you Bypass UDP FireWalls(or Unstable UDP Environment). It can defend Replay-Attack and supports Multiplexing. It also acts as a Connection Stabilizer. | A Tunnel which turns UDP Traffic into Encrypted FakeTCP/UDP/ICMP Traffic by using Raw Socket, helps you Bypass UDP FireWalls(or Unstable UDP Environment). | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| When used alone,udp2raw tunnels only UDP traffic. Nevertheless,if you used udp2raw + any UDP-based VPN together,you can tunnel any traffic(include TCP/UDP/ICMP),currently OpenVPN/L2TP/ShadowVPN and [tinyfecVPN](https://github.com/wangyu-/tinyfecVPN) are confirmed to be supported. | When used alone,udp2raw tunnels only UDP traffic. Nevertheless,if you used udp2raw + any UDP-based VPN together,you can tunnel any traffic(include TCP/UDP/ICMP),currently OpenVPN/L2TP/ShadowVPN and [tinyfecVPN](https://github.com/wangyu-/tinyfecVPN) are confirmed to be supported. | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| [简体中文](/doc/README.zh-cn.md)(内容更丰富) |  | ||||||
|  |  | ||||||
|  | or | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| [udp2raw wiki](https://github.com/wangyu-/udp2raw-tunnel/wiki) | [udp2raw wiki](https://github.com/wangyu-/udp2raw-tunnel/wiki) | ||||||
|  |  | ||||||
|  | [简体中文](/doc/README.zh-cn.md) | ||||||
|  |  | ||||||
|  |  | ||||||
| # Support Platforms | # Support Platforms | ||||||
| Linux host (including desktop Linux,Android phone/tablet,OpenWRT router,or Raspberry PI) with root access. | Linux host (including desktop Linux,Android phone/tablet,OpenWRT router,or Raspberry PI) with root account or cap_net_raw capability. | ||||||
|  |  | ||||||
| For Windows and MacOS users, use the udp2raw in [this repo](https://github.com/wangyu-/udp2raw-multiplatform). | For Windows and MacOS users, use the udp2raw in [this repo](https://github.com/wangyu-/udp2raw-multiplatform). | ||||||
|  |  | ||||||
| <del>For Windows and MacOS You can run udp2raw inside [this](https://github.com/wangyu-/udp2raw-tunnel/releases/download/20171108.0/lede-17.01.2-x86_virtual_machine_image.zip) 7.5mb virtual machine image(make sure network adapter runs at bridged mode).</del> |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| # Features | # Features | ||||||
| ### Send/Receive UDP Packets with ICMP/FakeTCP/UDP headers | ### Send/Receive UDP Packets with ICMP/FakeTCP/UDP headers | ||||||
| ICMP/FakeTCP headers help you bypass UDP blocking, UDP QOS or improper UDP NAT behavior on some ISPs. In ICMP header mode,udp2raw works like an ICMP tunnel. | ICMP/FakeTCP headers help you bypass UDP blocking, UDP QOS or improper UDP NAT behavior on some ISPs. In ICMP header mode,udp2raw works like an ICMP tunnel. | ||||||
|  |  | ||||||
| UDP headers are also supported. In UDP header mode, it behaves just like a normal UDP tunnel, and you can just make use of the other features (such as encryption, anti-replay, or connection stalization). | UDP headers are also supported. In UDP header mode, it behaves just like a normal UDP tunnel, and you can just make use of the other features (such as encryption, anti-replay, or connection stabilization). | ||||||
|  |  | ||||||
| ### Simulated TCP with Real-time/Out-of-Order Delivery | ### Simulated TCP with Real-time/Out-of-Order Delivery | ||||||
| In FakeTCP header mode,udp2raw simulates 3-way handshake while establishing a connection,simulates seq and ack_seq while data transferring. It also simulates following TCP options: `MSS`, `sackOk`, `TS`, `TS_ack`, `wscale`.Firewalls will regard FakeTCP as a TCP connection, but its essentially UDP: it supports real-time/out-of-order delivery(just as normal UDP does), no congestion control or re-transmission. So there wont be any TCP over TCP problem when using OpenVPN. | In FakeTCP header mode,udp2raw simulates 3-way handshake while establishing a connection,simulates seq and ack_seq while data transferring. It also simulates a few TCP options such as: `MSS`, `sackOk`, `TS`, `TS_ack`, `wscale`. Firewalls will regard FakeTCP as a TCP connection, but its essentially UDP: it supports real-time/out-of-order delivery(just as normal UDP does), no congestion control or re-transmission. So there wont be any TCP over TCP problem when using OpenVPN. | ||||||
|  |  | ||||||
| ### Encryption, Anti-Replay | ### Encryption, Anti-Replay | ||||||
| * Encrypt your traffic with AES-128-CBC. | * Encrypt your traffic with AES-128-CBC. | ||||||
| * Protect data integrity by HMAC-SHA1 (or weaker MD5/CRC32). | * Protect data integrity by HMAC-SHA1 (or weaker MD5/CRC32). | ||||||
| * Defense replay attack with an anti-replay window, smiliar to IPSec and OpenVPN. | * Defense replay attack with anti-replay window. | ||||||
|  |  | ||||||
| ### Failure Dectection & Stablization (Connection Recovery) | [Notes on encryption](https://github.com/wangyu-/udp2raw-tunnel/wiki/Notes-on-encryption) | ||||||
|  |  | ||||||
|  | ### Failure Dectection & Stabilization (Connection Recovery) | ||||||
| Conection failures are detected by heartbeats. If timed-out, client will automatically change port number and reconnect. If reconnection is successful, the previous connection will be recovered, and all existing UDP conversations will stay vaild. | Conection failures are detected by heartbeats. If timed-out, client will automatically change port number and reconnect. If reconnection is successful, the previous connection will be recovered, and all existing UDP conversations will stay vaild. | ||||||
|  |  | ||||||
| For example, if you use udp2raw + OpenVPN, OpenVPN won't lose connection after any reconnect, **even if network cable is re-plugged or WiFi access point is changed**. | For example, if you use udp2raw + OpenVPN, OpenVPN won't lose connection after any reconnect, **even if network cable is re-plugged or WiFi access point is changed**. | ||||||
| @@ -79,9 +81,9 @@ Assume your UDP is blocked or being QOS-ed or just poorly supported. Assume your | |||||||
| Now,an encrypted raw tunnel has been established between client and server through TCP port 4096. Connecting to UDP port 3333 at the client side is equivalent to connecting to port 7777 at the server side. No UDP traffic will be exposed. | Now,an encrypted raw tunnel has been established between client and server through TCP port 4096. Connecting to UDP port 3333 at the client side is equivalent to connecting to port 7777 at the server side. No UDP traffic will be exposed. | ||||||
|  |  | ||||||
| ### Note | ### Note | ||||||
| To run on Android, check [Android_Guide](/doc/android_guide.md) | To run on Android, check [Android_Guide](https://github.com/wangyu-/udp2raw/wiki/Android-Guide) | ||||||
|  |  | ||||||
| `-a` option automatically adds an iptables rule (or a few iptables rules) for you, udp2raw relys on this iptables rule to work stably. Be aware you dont forget `-a` (its a common mistake). If you dont want udp2raw to add iptables rule automatically, you can add it manually(take a look at `-g` option) and omit `-a`. | `-a` option automatically adds an iptables rule (or a few iptables rules) for you, udp2raw relies on this iptables rule to work stably. Be aware you dont forget `-a` (its a common mistake). If you dont want udp2raw to add iptables rule automatically, you can add it manually(take a look at `-g` option) and omit `-a`. | ||||||
|  |  | ||||||
|  |  | ||||||
| # Advanced Topic | # Advanced Topic | ||||||
| @@ -218,63 +220,6 @@ raw_mode: faketcp  cipher_mode: aes128cbc  auth_mode: md5 | |||||||
|  |  | ||||||
| (reverse speed was simliar and not uploaded) | (reverse speed was simliar and not uploaded) | ||||||
|  |  | ||||||
| # Application |  | ||||||
| ## Tunneling any traffic via raw traffic by using udp2raw +openvpn |  | ||||||
|  |  | ||||||
| 1. Bypasses UDP block/UDP QOS |  | ||||||
|  |  | ||||||
| 2. No TCP over TCP problem (TCP over TCP problem http://sites.inka.de/bigred/devel/tcp-tcp.html ,https://community.openvpn.net/openvpn/ticket/2 ) |  | ||||||
|  |  | ||||||
| 3. OpenVpn over ICMP also becomes a choice |  | ||||||
|  |  | ||||||
| 4. Supports almost any UDP-based VPN |  | ||||||
|  |  | ||||||
| More details at [openvpn+udp2raw_guide](https://github.com/wangyu-/udp2raw-tunnel/wiki/udp2raw-openvpn-config-guide) |  | ||||||
| ## Speed-up tcp connection via raw traffic by using udp2raw+kcptun |  | ||||||
| kcptun is a tcp connection speed-up program,it speeds-up tcp connection by using kcp protocol on-top of udp.by using udp2raw,you can use kcptun while udp is QoSed or blocked. |  | ||||||
| (kcptun, https://github.com/xtaci/kcptun) |  | ||||||
|  |  | ||||||
| ## Speed-up tcp connection via raw traffic by using udp2raw+finalspeed |  | ||||||
| finalspeed is a tcp connection speed-up program similiar to kcptun,it speeds-up tcp connection by using kcp protocol on-top of udp or tcp.but its tcp mode doesnt support openvz,you can bypass this problem if you use udp2raw+finalspeed together,and icmp mode also becomes avaliable. |  | ||||||
|  |  | ||||||
| # How to build |  | ||||||
| read [build_guide](/doc/build_guide.md) |  | ||||||
|  |  | ||||||
| # Other |  | ||||||
| ### Easier installation on ArchLinux |  | ||||||
| ``` |  | ||||||
| yaourt -S udp2raw-tunnel # or |  | ||||||
| pacaur -S udp2raw-tunnel |  | ||||||
| ``` |  | ||||||
|  |  | ||||||
| # Related work |  | ||||||
| ### kcptun-raw |  | ||||||
| udp2raw was inspired by kcptun-raw,which modified kcptun to support tcp mode. |  | ||||||
|  |  | ||||||
| https://github.com/Chion82/kcptun-raw |  | ||||||
| ### relayRawSocket |  | ||||||
| kcptun-raw was inspired by relayRawSocket. A simple  udp to raw tunnel,wrote in python |  | ||||||
|  |  | ||||||
| https://github.com/linhua55/some_kcptun_tools/tree/master/relayRawSocket |  | ||||||
| ### kcpraw |  | ||||||
| another project of kcptun with tcp mode |  | ||||||
|  |  | ||||||
| https://github.com/ccsexyz/kcpraw |  | ||||||
|  |  | ||||||
| ### icmptunnel |  | ||||||
| Transparently tunnel your IP traffic through ICMP echo and reply packets. |  | ||||||
|  |  | ||||||
| https://github.com/DhavalKapil/icmptunnel |  | ||||||
|  |  | ||||||
| ### Tcp Minion |  | ||||||
| Tcp Minion is a project which modifid the code of tcp stack in kernel,and implemented real-time out-order udp packet delivery through this modified tcp stack.I failed to find the implementation,but there are some papers avaliable: |  | ||||||
|  |  | ||||||
| https://arxiv.org/abs/1103.0463 |  | ||||||
|  |  | ||||||
| http://korz.cs.yale.edu/2009/tng/papers/pfldnet10.pdf |  | ||||||
|  |  | ||||||
| https://pdfs.semanticscholar.org/9e6f/e2306f4385b4eb5416d1fcab16e9361d6ba3.pdf |  | ||||||
|  |  | ||||||
| # wiki | # wiki | ||||||
|  |  | ||||||
| Check wiki for more info: | Check wiki for more info: | ||||||
|   | |||||||
							
								
								
									
										570
									
								
								client.cpp
									
									
									
									
									
								
							
							
						
						
									
										570
									
								
								client.cpp
									
									
									
									
									
								
							| @@ -7,6 +7,17 @@ | |||||||
| #include "encrypt.h" | #include "encrypt.h" | ||||||
| #include "fd_manager.h" | #include "fd_manager.h" | ||||||
|  |  | ||||||
|  | #ifdef UDP2RAW_MP | ||||||
|  | u32_t detect_interval = 1500; | ||||||
|  | u64_t laste_detect_time = 0; | ||||||
|  |  | ||||||
|  | int use_udp_for_detection = 0; | ||||||
|  | int use_tcp_for_detection = 1; | ||||||
|  |  | ||||||
|  | extern pcap_t *pcap_handle; | ||||||
|  |  | ||||||
|  | extern int pcap_captured_full_len; | ||||||
|  | #endif | ||||||
|  |  | ||||||
| int client_on_timer(conn_info_t &conn_info)  // for client. called when a timer is ready in epoll | int client_on_timer(conn_info_t &conn_info)  // for client. called when a timer is ready in epoll | ||||||
| { | { | ||||||
| @@ -20,22 +31,76 @@ int client_on_timer(conn_info_t &conn_info) //for client. called when a timer is | |||||||
|  |  | ||||||
|     mylog(log_trace, "<client_on_timer,send_info.ts_ack= %u>\n", send_info.ts_ack); |     mylog(log_trace, "<client_on_timer,send_info.ts_ack= %u>\n", send_info.ts_ack); | ||||||
|  |  | ||||||
| 	if(raw_info.disabled) | #ifdef UDP2RAW_MP | ||||||
| 	{ |     // mylog(log_debug,"pcap cnt :%d\n",pcap_cnt); | ||||||
|  |     if (send_with_pcap && !pcap_header_captured) { | ||||||
|  |         if (get_current_time() - laste_detect_time > detect_interval) { | ||||||
|  |             laste_detect_time = get_current_time(); | ||||||
|  |         } else { | ||||||
|  |             return 0; | ||||||
|  |         } | ||||||
|  |         /* | ||||||
|  |                         struct sockaddr_in remote_addr_in={0}; | ||||||
|  |  | ||||||
|  |                         socklen_t slen = sizeof(sockaddr_in); | ||||||
|  |                         int port=get_true_random_number()%65534+1; | ||||||
|  |                         remote_addr_in.sin_family = AF_INET; | ||||||
|  |                         remote_addr_in.sin_port = htons(port); | ||||||
|  |                         remote_addr_in.sin_addr.s_addr = remote_ip_uint32;*/ | ||||||
|  |         int port = get_true_random_number() % 65534 + 1; | ||||||
|  |         address_t tmp_addr = remote_addr; | ||||||
|  |         tmp_addr.set_port(port); | ||||||
|  |  | ||||||
|  |         if (use_udp_for_detection) { | ||||||
|  |             int new_udp_fd = socket(tmp_addr.get_type(), SOCK_DGRAM, IPPROTO_UDP); | ||||||
|  |             if (new_udp_fd < 0) { | ||||||
|  |                 mylog(log_warn, "create new_udp_fd error\n"); | ||||||
|  |                 return -1; | ||||||
|  |             } | ||||||
|  |             setnonblocking(new_udp_fd); | ||||||
|  |             u64_t tmp = get_true_random_number(); | ||||||
|  |  | ||||||
|  |             int ret = sendto(new_udp_fd, (char *)(&tmp), sizeof(tmp), 0, (struct sockaddr *)&tmp_addr.inner, tmp_addr.get_len()); | ||||||
|  |             if (ret == -1) { | ||||||
|  |                 mylog(log_warn, "sendto() failed\n"); | ||||||
|  |             } | ||||||
|  |             sock_close(new_udp_fd); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         if (use_tcp_for_detection) { | ||||||
|  |             static int last_tcp_fd = -1; | ||||||
|  |  | ||||||
|  |             int new_tcp_fd = socket(tmp_addr.get_type(), SOCK_STREAM, IPPROTO_TCP); | ||||||
|  |             if (new_tcp_fd < 0) { | ||||||
|  |                 mylog(log_warn, "create new_tcp_fd error\n"); | ||||||
|  |                 return -1; | ||||||
|  |             } | ||||||
|  |             setnonblocking(new_tcp_fd); | ||||||
|  |             connect(new_tcp_fd, (struct sockaddr *)&tmp_addr.inner, tmp_addr.get_len()); | ||||||
|  |             if (last_tcp_fd != -1) | ||||||
|  |                 sock_close(last_tcp_fd); | ||||||
|  |             last_tcp_fd = new_tcp_fd; | ||||||
|  |             // close(new_tcp_fd); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         mylog(log_info, "waiting for a use-able packet to be captured\n"); | ||||||
|  |  | ||||||
|  |         return 0; | ||||||
|  |     } | ||||||
|  | #endif | ||||||
|  |     if (raw_info.disabled) { | ||||||
|         conn_info.state.client_current_state = client_idle; |         conn_info.state.client_current_state = client_idle; | ||||||
|         conn_info.my_id = get_true_random_number_nz(); |         conn_info.my_id = get_true_random_number_nz(); | ||||||
|  |  | ||||||
|         mylog(log_info, "state back to client_idle\n"); |         mylog(log_info, "state back to client_idle\n"); | ||||||
|     } |     } | ||||||
|  |  | ||||||
| 	if(conn_info.state.client_current_state==client_idle) |     if (conn_info.state.client_current_state == client_idle) { | ||||||
| 	{ |  | ||||||
|         raw_info.rst_received = 0; |         raw_info.rst_received = 0; | ||||||
|         raw_info.disabled = 0; |         raw_info.disabled = 0; | ||||||
|  |  | ||||||
|         fail_time_counter++; |         fail_time_counter++; | ||||||
| 		if(max_fail_time>0&&fail_time_counter>max_fail_time) |         if (max_fail_time > 0 && fail_time_counter > max_fail_time) { | ||||||
| 		{ |  | ||||||
|             mylog(log_fatal, "max_fail_time exceed\n"); |             mylog(log_fatal, "max_fail_time exceed\n"); | ||||||
|             myexit(-1); |             myexit(-1); | ||||||
|         } |         } | ||||||
| @@ -43,14 +108,10 @@ int client_on_timer(conn_info_t &conn_info) //for client. called when a timer is | |||||||
|         conn_info.blob->anti_replay.re_init(); |         conn_info.blob->anti_replay.re_init(); | ||||||
|         conn_info.my_id = get_true_random_number_nz();  /// todo no need to do this everytime |         conn_info.my_id = get_true_random_number_nz();  /// todo no need to do this everytime | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|         address_t tmp_addr; |         address_t tmp_addr; | ||||||
|         // u32_t new_ip=0; |         // u32_t new_ip=0; | ||||||
| 		if(!force_source_ip) |         if (!force_source_ip) { | ||||||
| 		{ |             if (get_src_adress2(tmp_addr, remote_addr) != 0) { | ||||||
| 			if(get_src_adress2(tmp_addr,remote_addr)!=0) |  | ||||||
| 			{ |  | ||||||
|                 mylog(log_warn, "get_src_adress() failed\n"); |                 mylog(log_warn, "get_src_adress() failed\n"); | ||||||
|                 return -1; |                 return -1; | ||||||
|             } |             } | ||||||
| @@ -68,55 +129,42 @@ int client_on_timer(conn_info_t &conn_info) //for client. called when a timer is | |||||||
|                     send_info.src_ip=new_ip; |                     send_info.src_ip=new_ip; | ||||||
|             }*/ |             }*/ | ||||||
|  |  | ||||||
| 		} |         } else { | ||||||
| 		else |  | ||||||
| 		{ |  | ||||||
|             tmp_addr = source_addr; |             tmp_addr = source_addr; | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         send_info.new_src_ip.from_address_t(tmp_addr); |         send_info.new_src_ip.from_address_t(tmp_addr); | ||||||
|  |  | ||||||
| 		if (force_source_port == 0) |         if (force_source_port == 0) { | ||||||
| 		{ |  | ||||||
|             send_info.src_port = client_bind_to_a_new_port2(bind_fd, tmp_addr); |             send_info.src_port = client_bind_to_a_new_port2(bind_fd, tmp_addr); | ||||||
| 		} |         } else { | ||||||
| 		else |  | ||||||
| 		{ |  | ||||||
|             send_info.src_port = source_port; |             send_info.src_port = source_port; | ||||||
|         } |         } | ||||||
|  |  | ||||||
| 		if (raw_mode == mode_icmp) |         if (raw_mode == mode_icmp) { | ||||||
| 		{ |  | ||||||
|             send_info.dst_port = send_info.src_port; |             send_info.dst_port = send_info.src_port; | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         mylog(log_info, "using port %d\n", send_info.src_port); |         mylog(log_info, "using port %d\n", send_info.src_port); | ||||||
|         init_filter(send_info.src_port); |         init_filter(send_info.src_port); | ||||||
|  |  | ||||||
| 		if(raw_mode==mode_icmp||raw_mode==mode_udp) |         if (raw_mode == mode_icmp || raw_mode == mode_udp) { | ||||||
| 		{ |  | ||||||
|             conn_info.state.client_current_state = client_handshake1; |             conn_info.state.client_current_state = client_handshake1; | ||||||
|  |  | ||||||
|             mylog(log_info, "state changed from client_idle to client_pre_handshake\n"); |             mylog(log_info, "state changed from client_idle to client_pre_handshake\n"); | ||||||
|         } |         } | ||||||
| 		if(raw_mode==mode_faketcp) |         if (raw_mode == mode_faketcp) { | ||||||
| 		{ |             if (use_tcp_dummy_socket) { | ||||||
| 			if(use_tcp_dummy_socket) |  | ||||||
| 			{ |  | ||||||
|                 setnonblocking(bind_fd); |                 setnonblocking(bind_fd); | ||||||
|                 int ret = connect(bind_fd, (struct sockaddr *)&remote_addr.inner, remote_addr.get_len()); |                 int ret = connect(bind_fd, (struct sockaddr *)&remote_addr.inner, remote_addr.get_len()); | ||||||
|                 mylog(log_debug, "ret=%d,errno=%s, %d %s\n", ret, get_sock_error(), bind_fd, remote_addr.get_str()); |                 mylog(log_debug, "ret=%d,errno=%s, %d %s\n", ret, get_sock_error(), bind_fd, remote_addr.get_str()); | ||||||
|                 // mylog(log_info,"ret=%d,errno=,%d %s\n",ret,bind_fd,remote_addr.get_str()); |                 // mylog(log_info,"ret=%d,errno=,%d %s\n",ret,bind_fd,remote_addr.get_str()); | ||||||
|                 conn_info.state.client_current_state = client_tcp_handshake_dummy; |                 conn_info.state.client_current_state = client_tcp_handshake_dummy; | ||||||
|                 mylog(log_info, "state changed from client_idle to client_tcp_handshake_dummy\n"); |                 mylog(log_info, "state changed from client_idle to client_tcp_handshake_dummy\n"); | ||||||
| 			} |             } else { | ||||||
| 			else |  | ||||||
| 			{ |  | ||||||
|  |  | ||||||
|                 conn_info.state.client_current_state = client_tcp_handshake; |                 conn_info.state.client_current_state = client_tcp_handshake; | ||||||
|                 mylog(log_info, "state changed from client_idle to client_tcp_handshake\n"); |                 mylog(log_info, "state changed from client_idle to client_tcp_handshake\n"); | ||||||
|             } |             } | ||||||
|  |  | ||||||
|         } |         } | ||||||
|         conn_info.last_state_time = get_current_time(); |         conn_info.last_state_time = get_current_time(); | ||||||
|         conn_info.last_hb_sent_time = 0; |         conn_info.last_hb_sent_time = 0; | ||||||
| @@ -125,20 +173,14 @@ int client_on_timer(conn_info_t &conn_info) //for client. called when a timer is | |||||||
|     if (conn_info.state.client_current_state == client_tcp_handshake)  // send and resend syn |     if (conn_info.state.client_current_state == client_tcp_handshake)  // send and resend syn | ||||||
|     { |     { | ||||||
|         assert(raw_mode == mode_faketcp); |         assert(raw_mode == mode_faketcp); | ||||||
| 		if (get_current_time() - conn_info.last_state_time > client_handshake_timeout) |         if (get_current_time() - conn_info.last_state_time > client_handshake_timeout) { | ||||||
| 		{ |  | ||||||
|             conn_info.state.client_current_state = client_idle; |             conn_info.state.client_current_state = client_idle; | ||||||
|             mylog(log_info, "state back to client_idle from client_tcp_handshake\n"); |             mylog(log_info, "state back to client_idle from client_tcp_handshake\n"); | ||||||
|             return 0; |             return 0; | ||||||
|  |  | ||||||
| 		} |         } else if (get_current_time() - conn_info.last_hb_sent_time > client_retry_interval) { | ||||||
| 		else if (get_current_time() - conn_info.last_hb_sent_time > client_retry_interval) |             if (raw_mode == mode_faketcp) { | ||||||
| 		{ |                 if (conn_info.last_hb_sent_time == 0) { | ||||||
|  |  | ||||||
| 			if (raw_mode == mode_faketcp) |  | ||||||
| 			{ |  | ||||||
| 				if (conn_info.last_hb_sent_time == 0) |  | ||||||
| 				{ |  | ||||||
|                     send_info.psh = 0; |                     send_info.psh = 0; | ||||||
|                     send_info.syn = 1; |                     send_info.syn = 1; | ||||||
|                     send_info.ack = 0; |                     send_info.ack = 0; | ||||||
| @@ -153,40 +195,27 @@ int client_on_timer(conn_info_t &conn_info) //for client. called when a timer is | |||||||
|             conn_info.last_hb_sent_time = get_current_time(); |             conn_info.last_hb_sent_time = get_current_time(); | ||||||
|             mylog(log_info, "(re)sent tcp syn\n"); |             mylog(log_info, "(re)sent tcp syn\n"); | ||||||
|             return 0; |             return 0; | ||||||
| 		} |         } else { | ||||||
| 		else |  | ||||||
| 		{ |  | ||||||
|             return 0; |             return 0; | ||||||
|         } |         } | ||||||
|         return 0; |         return 0; | ||||||
| 	} |     } else if (conn_info.state.client_current_state == client_tcp_handshake_dummy) { | ||||||
| 	else if(conn_info.state.client_current_state==client_tcp_handshake_dummy) |  | ||||||
| 	{ |  | ||||||
|         assert(raw_mode == mode_faketcp); |         assert(raw_mode == mode_faketcp); | ||||||
| 		if (get_current_time() - conn_info.last_state_time > client_handshake_timeout) |         if (get_current_time() - conn_info.last_state_time > client_handshake_timeout) { | ||||||
| 		{ |  | ||||||
|             conn_info.state.client_current_state = client_idle; |             conn_info.state.client_current_state = client_idle; | ||||||
|             mylog(log_info, "state back to client_idle from client_tcp_handshake_dummy\n"); |             mylog(log_info, "state back to client_idle from client_tcp_handshake_dummy\n"); | ||||||
|             return 0; |             return 0; | ||||||
|  |  | ||||||
|         } |         } | ||||||
| 	} |     } else if (conn_info.state.client_current_state == client_handshake1)  // send and resend handshake1 | ||||||
| 	else if(conn_info.state.client_current_state==client_handshake1)//send and resend handshake1 |  | ||||||
| 	{ |  | ||||||
| 		if(get_current_time()-conn_info.last_state_time>client_handshake_timeout) |  | ||||||
|     { |     { | ||||||
|  |         if (get_current_time() - conn_info.last_state_time > client_handshake_timeout) { | ||||||
|             conn_info.state.client_current_state = client_idle; |             conn_info.state.client_current_state = client_idle; | ||||||
|             mylog(log_info, "state back to client_idle from client_handshake1\n"); |             mylog(log_info, "state back to client_idle from client_handshake1\n"); | ||||||
|             return 0; |             return 0; | ||||||
|  |  | ||||||
| 		} |         } else if (get_current_time() - conn_info.last_hb_sent_time > client_retry_interval) { | ||||||
| 		else if(get_current_time()-conn_info.last_hb_sent_time>client_retry_interval) |             if (raw_mode == mode_faketcp) { | ||||||
| 		{ |                 if (conn_info.last_hb_sent_time == 0) { | ||||||
|  |  | ||||||
| 			if(raw_mode==mode_faketcp) |  | ||||||
| 			{ |  | ||||||
| 				if(conn_info.last_hb_sent_time==0) |  | ||||||
| 				{ |  | ||||||
|                     send_info.seq++; |                     send_info.seq++; | ||||||
|                     send_info.ack_seq = recv_info.seq + 1; |                     send_info.ack_seq = recv_info.seq + 1; | ||||||
|                     send_info.ts_ack = recv_info.ts; |                     send_info.ts_ack = recv_info.ts; | ||||||
| @@ -203,10 +232,7 @@ int client_on_timer(conn_info_t &conn_info) //for client. called when a timer is | |||||||
|                 send_handshake(raw_info, conn_info.my_id, 0, const_id); |                 send_handshake(raw_info, conn_info.my_id, 0, const_id); | ||||||
|  |  | ||||||
|                 send_info.seq += raw_info.send_info.data_len; |                 send_info.seq += raw_info.send_info.data_len; | ||||||
| 			} |             } else { | ||||||
| 			else |  | ||||||
| 			{ |  | ||||||
|  |  | ||||||
|                 send_handshake(raw_info, conn_info.my_id, 0, const_id); |                 send_handshake(raw_info, conn_info.my_id, 0, const_id); | ||||||
|                 if (raw_mode == mode_icmp) |                 if (raw_mode == mode_icmp) | ||||||
|                     send_info.my_icmp_seq++; |                     send_info.my_icmp_seq++; | ||||||
| @@ -215,27 +241,18 @@ int client_on_timer(conn_info_t &conn_info) //for client. called when a timer is | |||||||
|             conn_info.last_hb_sent_time = get_current_time(); |             conn_info.last_hb_sent_time = get_current_time(); | ||||||
|             mylog(log_info, "(re)sent handshake1\n"); |             mylog(log_info, "(re)sent handshake1\n"); | ||||||
|             return 0; |             return 0; | ||||||
| 		} |         } else { | ||||||
| 		else |  | ||||||
| 		{ |  | ||||||
|             return 0; |             return 0; | ||||||
|         } |         } | ||||||
|         return 0; |         return 0; | ||||||
| 	} |     } else if (conn_info.state.client_current_state == client_handshake2) { | ||||||
| 	else if(conn_info.state.client_current_state==client_handshake2) |         if (get_current_time() - conn_info.last_state_time > client_handshake_timeout) { | ||||||
| 	{ |  | ||||||
| 		if(get_current_time()-conn_info.last_state_time>client_handshake_timeout) |  | ||||||
| 		{ |  | ||||||
|             conn_info.state.client_current_state = client_idle; |             conn_info.state.client_current_state = client_idle; | ||||||
|             mylog(log_info, "state back to client_idle from client_handshake2\n"); |             mylog(log_info, "state back to client_idle from client_handshake2\n"); | ||||||
|             return 0; |             return 0; | ||||||
| 		} |         } else if (get_current_time() - conn_info.last_hb_sent_time > client_retry_interval) { | ||||||
| 		else if(get_current_time()-conn_info.last_hb_sent_time>client_retry_interval) |             if (raw_mode == mode_faketcp) { | ||||||
| 		{ |                 if (conn_info.last_hb_sent_time == 0) { | ||||||
| 			if(raw_mode==mode_faketcp) |  | ||||||
| 			{ |  | ||||||
| 				if(conn_info.last_hb_sent_time==0) |  | ||||||
| 				{ |  | ||||||
|                     send_info.ack_seq = recv_info.seq + raw_info.recv_info.data_len; |                     send_info.ack_seq = recv_info.seq + raw_info.recv_info.data_len; | ||||||
|                     send_info.ts_ack = recv_info.ts; |                     send_info.ts_ack = recv_info.ts; | ||||||
|                     raw_info.reserved_send_seq = send_info.seq; |                     raw_info.reserved_send_seq = send_info.seq; | ||||||
| @@ -244,10 +261,7 @@ int client_on_timer(conn_info_t &conn_info) //for client. called when a timer is | |||||||
|                 send_handshake(raw_info, conn_info.my_id, conn_info.oppsite_id, const_id); |                 send_handshake(raw_info, conn_info.my_id, conn_info.oppsite_id, const_id); | ||||||
|                 send_info.seq += raw_info.send_info.data_len; |                 send_info.seq += raw_info.send_info.data_len; | ||||||
|  |  | ||||||
| 			} |             } else { | ||||||
| 			else |  | ||||||
| 			{ |  | ||||||
|  |  | ||||||
|                 send_handshake(raw_info, conn_info.my_id, conn_info.oppsite_id, const_id); |                 send_handshake(raw_info, conn_info.my_id, conn_info.oppsite_id, const_id); | ||||||
|                 if (raw_mode == mode_icmp) |                 if (raw_mode == mode_icmp) | ||||||
|                     send_info.my_icmp_seq++; |                     send_info.my_icmp_seq++; | ||||||
| @@ -256,41 +270,31 @@ int client_on_timer(conn_info_t &conn_info) //for client. called when a timer is | |||||||
|             mylog(log_info, "(re)sent handshake2\n"); |             mylog(log_info, "(re)sent handshake2\n"); | ||||||
|             return 0; |             return 0; | ||||||
|  |  | ||||||
| 		} |         } else { | ||||||
| 		else |  | ||||||
| 		{ |  | ||||||
|             return 0; |             return 0; | ||||||
|         } |         } | ||||||
|         return 0; |         return 0; | ||||||
| 	} |     } else if (conn_info.state.client_current_state == client_ready) { | ||||||
| 	else if(conn_info.state.client_current_state==client_ready) |  | ||||||
| 	{ |  | ||||||
|         fail_time_counter = 0; |         fail_time_counter = 0; | ||||||
|         mylog(log_trace, "time %llu,%llu\n", get_current_time(), conn_info.last_state_time); |         mylog(log_trace, "time %llu,%llu\n", get_current_time(), conn_info.last_state_time); | ||||||
|  |  | ||||||
| 		if(get_current_time()-conn_info.last_hb_recv_time>client_conn_timeout) |         if (get_current_time() - conn_info.last_hb_recv_time > client_conn_timeout) { | ||||||
| 		{ |  | ||||||
|             conn_info.state.client_current_state = client_idle; |             conn_info.state.client_current_state = client_idle; | ||||||
|             conn_info.my_id = get_true_random_number_nz(); |             conn_info.my_id = get_true_random_number_nz(); | ||||||
|             mylog(log_info, "state back to client_idle from  client_ready bc of server-->client direction timeout\n"); |             mylog(log_info, "state back to client_idle from  client_ready bc of server-->client direction timeout\n"); | ||||||
|             return 0; |             return 0; | ||||||
|         } |         } | ||||||
|  |  | ||||||
| 		if(get_current_time()- conn_info.last_oppsite_roller_time>client_conn_uplink_timeout) |         if (get_current_time() - conn_info.last_oppsite_roller_time > client_conn_uplink_timeout) { | ||||||
| 		{ |  | ||||||
|             conn_info.state.client_current_state = client_idle; |             conn_info.state.client_current_state = client_idle; | ||||||
|             conn_info.my_id = get_true_random_number_nz(); |             conn_info.my_id = get_true_random_number_nz(); | ||||||
|             mylog(log_info, "state back to client_idle from  client_ready bc of client-->server direction timeout\n"); |             mylog(log_info, "state back to client_idle from  client_ready bc of client-->server direction timeout\n"); | ||||||
|         } |         } | ||||||
|  |  | ||||||
|  |         if (get_current_time() - conn_info.last_hb_sent_time < heartbeat_interval) { | ||||||
| 		if(get_current_time()-conn_info.last_hb_sent_time<heartbeat_interval) |  | ||||||
| 		{ |  | ||||||
|             return 0; |             return 0; | ||||||
|         } |         } | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|         mylog(log_debug, "heartbeat sent <%x,%x>\n", conn_info.oppsite_id, conn_info.my_id); |         mylog(log_debug, "heartbeat sent <%x,%x>\n", conn_info.oppsite_id, conn_info.my_id); | ||||||
|  |  | ||||||
|         if (hb_mode == 0) |         if (hb_mode == 0) | ||||||
| @@ -299,27 +303,22 @@ int client_on_timer(conn_info_t &conn_info) //for client. called when a timer is | |||||||
|             send_safer(conn_info, 'h', hb_buf, hb_len); |             send_safer(conn_info, 'h', hb_buf, hb_len); | ||||||
|         conn_info.last_hb_sent_time = get_current_time(); |         conn_info.last_hb_sent_time = get_current_time(); | ||||||
|         return 0; |         return 0; | ||||||
| 	} |     } else { | ||||||
| 	else |  | ||||||
| 	{ |  | ||||||
|         mylog(log_fatal, "unknown state,this shouldnt happen.\n"); |         mylog(log_fatal, "unknown state,this shouldnt happen.\n"); | ||||||
|         myexit(-1); |         myexit(-1); | ||||||
|     } |     } | ||||||
|     return 0; |     return 0; | ||||||
| } | } | ||||||
| int client_on_raw_recv_hs2_or_ready(conn_info_t &conn_info,char type,char *data,int data_len) | int client_on_raw_recv_hs2_or_ready(conn_info_t &conn_info, char type, char *data, int data_len) { | ||||||
| { |  | ||||||
|     packet_info_t &send_info = conn_info.raw_info.send_info; |     packet_info_t &send_info = conn_info.raw_info.send_info; | ||||||
|     packet_info_t &recv_info = conn_info.raw_info.recv_info; |     packet_info_t &recv_info = conn_info.raw_info.recv_info; | ||||||
|  |  | ||||||
|     if(!recv_info.new_src_ip.equal(send_info.new_dst_ip)||recv_info.src_port!=send_info.dst_port) |     if (!recv_info.new_src_ip.equal(send_info.new_dst_ip) || recv_info.src_port != send_info.dst_port) { | ||||||
|     { |  | ||||||
|         mylog(log_warn, "unexpected adress %s %s %d %d,this shouldnt happen.\n", recv_info.new_src_ip.get_str1(), send_info.new_dst_ip.get_str2(), recv_info.src_port, send_info.dst_port); |         mylog(log_warn, "unexpected adress %s %s %d %d,this shouldnt happen.\n", recv_info.new_src_ip.get_str1(), send_info.new_dst_ip.get_str2(), recv_info.src_port, send_info.dst_port); | ||||||
|         return -1; |         return -1; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     if(conn_info.state.client_current_state==client_handshake2) |     if (conn_info.state.client_current_state == client_handshake2) { | ||||||
|     { |  | ||||||
|         mylog(log_info, "changed state from to client_handshake2 to client_ready\n"); |         mylog(log_info, "changed state from to client_handshake2 to client_ready\n"); | ||||||
|         conn_info.state.client_current_state = client_ready; |         conn_info.state.client_current_state = client_ready; | ||||||
|         conn_info.last_hb_sent_time = 0; |         conn_info.last_hb_sent_time = 0; | ||||||
| @@ -327,14 +326,11 @@ int client_on_raw_recv_hs2_or_ready(conn_info_t &conn_info,char type,char *data, | |||||||
|         conn_info.last_oppsite_roller_time = conn_info.last_hb_recv_time; |         conn_info.last_oppsite_roller_time = conn_info.last_hb_recv_time; | ||||||
|         client_on_timer(conn_info); |         client_on_timer(conn_info); | ||||||
|     } |     } | ||||||
|     if(data_len>=0&&type=='h') |     if (data_len >= 0 && type == 'h') { | ||||||
|     { |  | ||||||
|         mylog(log_debug, "[hb]heart beat received,oppsite_roller=%d\n", int(conn_info.oppsite_roller)); |         mylog(log_debug, "[hb]heart beat received,oppsite_roller=%d\n", int(conn_info.oppsite_roller)); | ||||||
|         conn_info.last_hb_recv_time = get_current_time(); |         conn_info.last_hb_recv_time = get_current_time(); | ||||||
|         return 0; |         return 0; | ||||||
|     } |     } else if (data_len >= int(sizeof(u32_t)) && type == 'd') { | ||||||
|     else if(data_len>= int( sizeof(u32_t))&&type=='d') |  | ||||||
|     { |  | ||||||
|         mylog(log_trace, "received a data from fake tcp,len:%d\n", data_len); |         mylog(log_trace, "received a data from fake tcp,len:%d\n", data_len); | ||||||
|  |  | ||||||
|         if (hb_mode == 0) |         if (hb_mode == 0) | ||||||
| @@ -344,8 +340,7 @@ int client_on_raw_recv_hs2_or_ready(conn_info_t &conn_info,char type,char *data, | |||||||
|         memcpy(&tmp_conv_id, &data[0], sizeof(tmp_conv_id)); |         memcpy(&tmp_conv_id, &data[0], sizeof(tmp_conv_id)); | ||||||
|         tmp_conv_id = ntohl(tmp_conv_id); |         tmp_conv_id = ntohl(tmp_conv_id); | ||||||
|  |  | ||||||
|         if(!conn_info.blob->conv_manager.c.is_conv_used(tmp_conv_id)) |         if (!conn_info.blob->conv_manager.c.is_conv_used(tmp_conv_id)) { | ||||||
|         { |  | ||||||
|             mylog(log_info, "unknow conv %d,ignore\n", tmp_conv_id); |             mylog(log_info, "unknow conv %d,ignore\n", tmp_conv_id); | ||||||
|             return 0; |             return 0; | ||||||
|         } |         } | ||||||
| @@ -362,17 +357,13 @@ int client_on_raw_recv_hs2_or_ready(conn_info_t &conn_info,char type,char *data, | |||||||
|  |  | ||||||
|         // tmp_sockaddr.sin_port= htons(uint16_t((u64<<32u)>>32u)); |         // tmp_sockaddr.sin_port= htons(uint16_t((u64<<32u)>>32u)); | ||||||
|  |  | ||||||
|  |  | ||||||
|         int ret = sendto(udp_fd, data + sizeof(u32_t), data_len - (sizeof(u32_t)), 0, (struct sockaddr *)&tmp_addr.inner, tmp_addr.get_len()); |         int ret = sendto(udp_fd, data + sizeof(u32_t), data_len - (sizeof(u32_t)), 0, (struct sockaddr *)&tmp_addr.inner, tmp_addr.get_len()); | ||||||
|  |  | ||||||
|         if(ret<0) |         if (ret < 0) { | ||||||
|         { |  | ||||||
|             mylog(log_warn, "sento returned %d,%s,%02x,%s\n", ret, get_sock_error(), int(tmp_addr.get_type()), tmp_addr.get_str()); |             mylog(log_warn, "sento returned %d,%s,%02x,%s\n", ret, get_sock_error(), int(tmp_addr.get_type()), tmp_addr.get_str()); | ||||||
|             // perror("ret<0"); |             // perror("ret<0"); | ||||||
|         } |         } | ||||||
|     } |     } else { | ||||||
|     else |  | ||||||
|     { |  | ||||||
|         mylog(log_warn, "unknown packet,this shouldnt happen.\n"); |         mylog(log_warn, "unknown packet,this shouldnt happen.\n"); | ||||||
|         return -1; |         return -1; | ||||||
|     } |     } | ||||||
| @@ -380,45 +371,44 @@ int client_on_raw_recv_hs2_or_ready(conn_info_t &conn_info,char type,char *data, | |||||||
| } | } | ||||||
| int client_on_raw_recv(conn_info_t &conn_info)  // called when raw fd received a packet. | int client_on_raw_recv(conn_info_t &conn_info)  // called when raw fd received a packet. | ||||||
| { | { | ||||||
| 	char* data;int data_len; |     char *data; | ||||||
|  |     int data_len; | ||||||
|     packet_info_t &send_info = conn_info.raw_info.send_info; |     packet_info_t &send_info = conn_info.raw_info.send_info; | ||||||
|     packet_info_t &recv_info = conn_info.raw_info.recv_info; |     packet_info_t &recv_info = conn_info.raw_info.recv_info; | ||||||
|  |  | ||||||
|     raw_info_t &raw_info = conn_info.raw_info; |     raw_info_t &raw_info = conn_info.raw_info; | ||||||
|  |  | ||||||
|     mylog(log_trace, "<client_on_raw_recv,send_info.ts_ack= %u>\n", send_info.ts_ack); |     mylog(log_trace, "<client_on_raw_recv,send_info.ts_ack= %u>\n", send_info.ts_ack); | ||||||
| 	if(pre_recv_raw_packet()<0) return -1; |  | ||||||
|  |  | ||||||
| 	if(conn_info.state.client_current_state==client_idle ) | #ifdef UDP2RAW_LINUX | ||||||
| 	{ |     if (pre_recv_raw_packet() < 0) return -1; | ||||||
|  | #endif | ||||||
|  |  | ||||||
|  |     if (conn_info.state.client_current_state == client_idle) { | ||||||
|         discard_raw_packet(); |         discard_raw_packet(); | ||||||
|         // recv(raw_recv_fd, 0,0, 0  ); |         // recv(raw_recv_fd, 0,0, 0  ); | ||||||
| 	} |     } else if (conn_info.state.client_current_state == client_tcp_handshake || conn_info.state.client_current_state == client_tcp_handshake_dummy)  // received syn ack | ||||||
| 	else if(conn_info.state.client_current_state==client_tcp_handshake||conn_info.state.client_current_state==client_tcp_handshake_dummy)//received syn ack |  | ||||||
|     { |     { | ||||||
|         assert(raw_mode == mode_faketcp); |         assert(raw_mode == mode_faketcp); | ||||||
| 		if(recv_raw0(raw_info,data,data_len)<0) |         if (recv_raw0(raw_info, data, data_len) < 0) { | ||||||
| 		{ |  | ||||||
|             return -1; |             return -1; | ||||||
|         } |         } | ||||||
| 		if(!recv_info.new_src_ip.equal(send_info.new_dst_ip)||recv_info.src_port!=send_info.dst_port) |         if (data_len >= max_data_len + 1) { | ||||||
| 		{ |             mylog(log_debug, "data_len=%d >= max_data_len+1,ignored", data_len); | ||||||
|  |             return -1; | ||||||
|  |         } | ||||||
|  |         if (!recv_info.new_src_ip.equal(send_info.new_dst_ip) || recv_info.src_port != send_info.dst_port) { | ||||||
|             mylog(log_debug, "unexpected adress %s %s %d %d\n", recv_info.new_src_ip.get_str1(), send_info.new_dst_ip.get_str2(), recv_info.src_port, send_info.dst_port); |             mylog(log_debug, "unexpected adress %s %s %d %d\n", recv_info.new_src_ip.get_str1(), send_info.new_dst_ip.get_str2(), recv_info.src_port, send_info.dst_port); | ||||||
|             return -1; |             return -1; | ||||||
|         } |         } | ||||||
| 		if(data_len==0&&raw_info.recv_info.syn==1&&raw_info.recv_info.ack==1) |         if (data_len == 0 && raw_info.recv_info.syn == 1 && raw_info.recv_info.ack == 1) { | ||||||
| 		{ |             if (conn_info.state.client_current_state == client_tcp_handshake) { | ||||||
| 			if(conn_info.state.client_current_state==client_tcp_handshake) |                 if (recv_info.ack_seq != send_info.seq + 1) { | ||||||
| 			{ |  | ||||||
| 				if(recv_info.ack_seq!=send_info.seq+1) |  | ||||||
| 				{ |  | ||||||
|                     mylog(log_debug, "seq ack_seq mis match\n"); |                     mylog(log_debug, "seq ack_seq mis match\n"); | ||||||
|                     return -1; |                     return -1; | ||||||
|                 } |                 } | ||||||
|                 mylog(log_info, "state changed from client_tcp_handshake to client_handshake1\n"); |                 mylog(log_info, "state changed from client_tcp_handshake to client_handshake1\n"); | ||||||
| 			} |             } else { | ||||||
| 			else |  | ||||||
| 			{ |  | ||||||
|                 send_info.seq = recv_info.ack_seq - 1; |                 send_info.seq = recv_info.ack_seq - 1; | ||||||
|                 mylog(log_info, "state changed from client_tcp_dummy to client_handshake1\n"); |                 mylog(log_info, "state changed from client_tcp_dummy to client_handshake1\n"); | ||||||
|                 // send_info.ack_seq=recv_info.seq+1; |                 // send_info.ack_seq=recv_info.seq+1; | ||||||
| @@ -429,27 +419,21 @@ int client_on_raw_recv(conn_info_t &conn_info) //called when raw fd received a p | |||||||
|             conn_info.last_hb_sent_time = 0; |             conn_info.last_hb_sent_time = 0; | ||||||
|             client_on_timer(conn_info); |             client_on_timer(conn_info); | ||||||
|             return 0; |             return 0; | ||||||
| 		} |         } else { | ||||||
| 		else |  | ||||||
| 		{ |  | ||||||
|             mylog(log_debug, "unexpected packet type,expected:syn ack\n"); |             mylog(log_debug, "unexpected packet type,expected:syn ack\n"); | ||||||
|             return -1; |             return -1; | ||||||
|         } |         } | ||||||
| 	} |     } else if (conn_info.state.client_current_state == client_handshake1)  // recevied respond of handshake1 | ||||||
| 	else if(conn_info.state.client_current_state==client_handshake1)//recevied respond of handshake1 |  | ||||||
| 	{ |  | ||||||
| 		if(recv_bare(raw_info,data,data_len)!=0) |  | ||||||
|     { |     { | ||||||
|  |         if (recv_bare(raw_info, data, data_len) != 0) { | ||||||
|             mylog(log_debug, "recv_bare failed!\n"); |             mylog(log_debug, "recv_bare failed!\n"); | ||||||
|             return -1; |             return -1; | ||||||
|         } |         } | ||||||
| 		if(!recv_info.new_src_ip.equal(send_info.new_dst_ip)||recv_info.src_port!=send_info.dst_port) |         if (!recv_info.new_src_ip.equal(send_info.new_dst_ip) || recv_info.src_port != send_info.dst_port) { | ||||||
| 		{ |  | ||||||
|             mylog(log_debug, "unexpected adress %s %s %d %d\n", recv_info.new_src_ip.get_str1(), send_info.new_dst_ip.get_str2(), recv_info.src_port, send_info.dst_port); |             mylog(log_debug, "unexpected adress %s %s %d %d\n", recv_info.new_src_ip.get_str1(), send_info.new_dst_ip.get_str2(), recv_info.src_port, send_info.dst_port); | ||||||
|             return -1; |             return -1; | ||||||
|         } |         } | ||||||
| 		if(data_len<int( 3*sizeof(my_id_t))) |         if (data_len < int(3 * sizeof(my_id_t))) { | ||||||
| 		{ |  | ||||||
|             mylog(log_debug, "too short to be a handshake\n"); |             mylog(log_debug, "too short to be a handshake\n"); | ||||||
|             return -1; |             return -1; | ||||||
|         } |         } | ||||||
| @@ -465,22 +449,17 @@ int client_on_raw_recv(conn_info_t &conn_info) //called when raw fd received a p | |||||||
|         memcpy(&tmp_oppsite_const_id, &data[sizeof(my_id_t) * 2], sizeof(tmp_oppsite_const_id)); |         memcpy(&tmp_oppsite_const_id, &data[sizeof(my_id_t) * 2], sizeof(tmp_oppsite_const_id)); | ||||||
|         tmp_oppsite_const_id = ntohl(tmp_oppsite_const_id); |         tmp_oppsite_const_id = ntohl(tmp_oppsite_const_id); | ||||||
|  |  | ||||||
| 		if(tmp_my_id!=conn_info.my_id) |         if (tmp_my_id != conn_info.my_id) { | ||||||
| 		{ |  | ||||||
|             mylog(log_debug, "tmp_my_id doesnt match\n"); |             mylog(log_debug, "tmp_my_id doesnt match\n"); | ||||||
|             return -1; |             return -1; | ||||||
|         } |         } | ||||||
|  |  | ||||||
|  |         if (raw_mode == mode_faketcp) { | ||||||
| 		if(raw_mode==mode_faketcp) |             if (recv_info.ack_seq != send_info.seq) { | ||||||
| 		{ |  | ||||||
| 			if(recv_info.ack_seq!=send_info.seq) |  | ||||||
| 			{ |  | ||||||
|                 mylog(log_debug, "seq ack_seq mis match\n"); |                 mylog(log_debug, "seq ack_seq mis match\n"); | ||||||
|                 return -1; |                 return -1; | ||||||
|             } |             } | ||||||
| 			if(recv_info.seq!=send_info.ack_seq) |             if (recv_info.seq != send_info.ack_seq) { | ||||||
| 			{ |  | ||||||
|                 mylog(log_debug, "seq ack_seq mis match\n"); |                 mylog(log_debug, "seq ack_seq mis match\n"); | ||||||
|                 return -1; |                 return -1; | ||||||
|             } |             } | ||||||
| @@ -495,20 +474,17 @@ int client_on_raw_recv(conn_info_t &conn_info) //called when raw fd received a p | |||||||
|         client_on_timer(conn_info); |         client_on_timer(conn_info); | ||||||
|  |  | ||||||
|         return 0; |         return 0; | ||||||
| 	} |     } else if (conn_info.state.client_current_state == client_handshake2 || conn_info.state.client_current_state == client_ready)  // received heartbeat or data | ||||||
| 	else if(conn_info.state.client_current_state==client_handshake2||conn_info.state.client_current_state==client_ready)//received heartbeat or data |  | ||||||
|     { |     { | ||||||
|         vector<char> type_vec; |         vector<char> type_vec; | ||||||
|         vector<string> data_vec; |         vector<string> data_vec; | ||||||
|         recv_safer_multi(conn_info, type_vec, data_vec); |         recv_safer_multi(conn_info, type_vec, data_vec); | ||||||
| 		if(data_vec.empty()) |         if (data_vec.empty()) { | ||||||
| 		{ |  | ||||||
|             mylog(log_debug, "recv_safer failed!\n"); |             mylog(log_debug, "recv_safer failed!\n"); | ||||||
|             return -1; |             return -1; | ||||||
|         } |         } | ||||||
|  |  | ||||||
| 		for(int i=0;i<(int)type_vec.size();i++) |         for (int i = 0; i < (int)type_vec.size(); i++) { | ||||||
|         { |  | ||||||
|             char type = type_vec[i]; |             char type = type_vec[i]; | ||||||
|             char *data = (char *)data_vec[i].c_str();  // be careful, do not append data to it |             char *data = (char *)data_vec[i].c_str();  // be careful, do not append data to it | ||||||
|             int data_len = data_vec[i].length(); |             int data_len = data_vec[i].length(); | ||||||
| @@ -516,19 +492,16 @@ int client_on_raw_recv(conn_info_t &conn_info) //called when raw fd received a p | |||||||
|         } |         } | ||||||
|  |  | ||||||
|         return 0; |         return 0; | ||||||
| 	} |     } else { | ||||||
| 	else |  | ||||||
| 	{ |  | ||||||
|         mylog(log_fatal, "unknown state,this shouldnt happen.\n"); |         mylog(log_fatal, "unknown state,this shouldnt happen.\n"); | ||||||
|         myexit(-1); |         myexit(-1); | ||||||
|     } |     } | ||||||
|     return 0; |     return 0; | ||||||
| } | } | ||||||
| int client_on_udp_recv(conn_info_t &conn_info) | int client_on_udp_recv(conn_info_t &conn_info) { | ||||||
| { |  | ||||||
|     int recv_len; |     int recv_len; | ||||||
|     char buf[buf_len]; |     char buf[buf_len]; | ||||||
| 	address_t::storage_t udp_new_addr_in={0}; |     address_t::storage_t udp_new_addr_in = {{0}}; | ||||||
|     socklen_t udp_new_addr_len = sizeof(address_t::storage_t); |     socklen_t udp_new_addr_len = sizeof(address_t::storage_t); | ||||||
|     if ((recv_len = recvfrom(udp_fd, buf, max_data_len + 1, 0, |     if ((recv_len = recvfrom(udp_fd, buf, max_data_len + 1, 0, | ||||||
|                              (struct sockaddr *)&udp_new_addr_in, &udp_new_addr_len)) == -1) { |                              (struct sockaddr *)&udp_new_addr_in, &udp_new_addr_len)) == -1) { | ||||||
| @@ -537,14 +510,12 @@ int client_on_udp_recv(conn_info_t &conn_info) | |||||||
|         // myexit(1); |         // myexit(1); | ||||||
|     }; |     }; | ||||||
|  |  | ||||||
| 	if(recv_len==max_data_len+1) |     if (recv_len == max_data_len + 1) { | ||||||
| 	{ |  | ||||||
|         mylog(log_warn, "huge packet, data_len > %d,dropped\n", max_data_len); |         mylog(log_warn, "huge packet, data_len > %d,dropped\n", max_data_len); | ||||||
|         return -1; |         return -1; | ||||||
|     } |     } | ||||||
|  |  | ||||||
| 	if(recv_len>=mtu_warn) |     if (recv_len >= mtu_warn) { | ||||||
| 	{ |  | ||||||
|         mylog(log_warn, "huge packet,data len=%d (>=%d).strongly suggested to set a smaller mtu at upper level,to get rid of this warn\n ", recv_len, mtu_warn); |         mylog(log_warn, "huge packet,data len=%d (>=%d).strongly suggested to set a smaller mtu at upper level,to get rid of this warn\n ", recv_len, mtu_warn); | ||||||
|     } |     } | ||||||
|  |  | ||||||
| @@ -552,56 +523,105 @@ int client_on_udp_recv(conn_info_t &conn_info) | |||||||
|     tmp_addr.from_sockaddr((sockaddr *)&udp_new_addr_in, udp_new_addr_len); |     tmp_addr.from_sockaddr((sockaddr *)&udp_new_addr_in, udp_new_addr_len); | ||||||
|     u32_t conv; |     u32_t conv; | ||||||
|  |  | ||||||
| 	if(!conn_info.blob->conv_manager.c.is_data_used(tmp_addr)) |     if (!conn_info.blob->conv_manager.c.is_data_used(tmp_addr)) { | ||||||
| 	{ |         if (conn_info.blob->conv_manager.c.get_size() >= max_conv_num) { | ||||||
| 		if(conn_info.blob->conv_manager.c.get_size() >=max_conv_num) |  | ||||||
| 		{ |  | ||||||
|             mylog(log_warn, "ignored new udp connect bc max_conv_num exceed\n"); |             mylog(log_warn, "ignored new udp connect bc max_conv_num exceed\n"); | ||||||
|             return -1; |             return -1; | ||||||
|         } |         } | ||||||
|         conv = conn_info.blob->conv_manager.c.get_new_conv(); |         conv = conn_info.blob->conv_manager.c.get_new_conv(); | ||||||
|         conn_info.blob->conv_manager.c.insert_conv(conv, tmp_addr); |         conn_info.blob->conv_manager.c.insert_conv(conv, tmp_addr); | ||||||
|         mylog(log_info, "new packet from %s,conv_id=%x\n", tmp_addr.get_str(), conv); |         mylog(log_info, "new packet from %s,conv_id=%x\n", tmp_addr.get_str(), conv); | ||||||
| 	} |     } else { | ||||||
| 	else |  | ||||||
| 	{ |  | ||||||
|         conv = conn_info.blob->conv_manager.c.find_conv_by_data(tmp_addr); |         conv = conn_info.blob->conv_manager.c.find_conv_by_data(tmp_addr); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     conn_info.blob->conv_manager.c.update_active_time(conv); |     conn_info.blob->conv_manager.c.update_active_time(conv); | ||||||
|  |  | ||||||
| 	if(conn_info.state.client_current_state==client_ready) |     if (conn_info.state.client_current_state == client_ready) { | ||||||
| 	{ |  | ||||||
|         send_data_safer(conn_info, buf, recv_len, conv); |         send_data_safer(conn_info, buf, recv_len, conv); | ||||||
|     } |     } | ||||||
|     return 0; |     return 0; | ||||||
| } | } | ||||||
| void udp_accept_cb(struct ev_loop *loop, struct ev_io *watcher, int revents) | void udp_accept_cb(struct ev_loop *loop, struct ev_io *watcher, int revents) { | ||||||
| { |  | ||||||
|     conn_info_t &conn_info = *((conn_info_t *)watcher->data); |     conn_info_t &conn_info = *((conn_info_t *)watcher->data); | ||||||
|     client_on_udp_recv(conn_info); |     client_on_udp_recv(conn_info); | ||||||
| } | } | ||||||
| void raw_recv_cb(struct ev_loop *loop, struct ev_io *watcher, int revents) | void raw_recv_cb(struct ev_loop *loop, struct ev_io *watcher, int revents) { | ||||||
| { |     if (is_udp2raw_mp) assert(0 == 1); | ||||||
| 	//assert(0==1); |  | ||||||
|     conn_info_t &conn_info = *((conn_info_t *)watcher->data); |     conn_info_t &conn_info = *((conn_info_t *)watcher->data); | ||||||
|     client_on_raw_recv(conn_info); |     client_on_raw_recv(conn_info); | ||||||
| } | } | ||||||
| void clear_timer_cb(struct ev_loop *loop, struct ev_timer *watcher, int revents) | #ifdef UDP2RAW_MP | ||||||
| { | void async_cb(struct ev_loop *loop, struct ev_async *watcher, int revents) { | ||||||
|  |     conn_info_t &conn_info = *((conn_info_t *)watcher->data); | ||||||
|  |  | ||||||
|  |     if (send_with_pcap && !pcap_header_captured) { | ||||||
|  |         int empty = 0; | ||||||
|  |         char *p; | ||||||
|  |         int len; | ||||||
|  |         pthread_mutex_lock(&queue_mutex); | ||||||
|  |         empty = my_queue.empty(); | ||||||
|  |         if (!empty) { | ||||||
|  |             my_queue.peek_front(p, len); | ||||||
|  |             my_queue.pop_front(); | ||||||
|  |         } | ||||||
|  |         pthread_mutex_unlock(&queue_mutex); | ||||||
|  |         if (empty) return; | ||||||
|  |  | ||||||
|  |         pcap_header_captured = 1; | ||||||
|  |         assert(pcap_link_header_len != -1); | ||||||
|  |         memcpy(pcap_header_buf, p, max_data_len); | ||||||
|  |  | ||||||
|  |         log_bare(log_info, "link level header captured:\n"); | ||||||
|  |         unsigned char *tmp = (unsigned char *)pcap_header_buf; | ||||||
|  |         pcap_captured_full_len = len; | ||||||
|  |         for (int i = 0; i < pcap_link_header_len; i++) | ||||||
|  |             log_bare(log_info, "<%x>", (u32_t)tmp[i]); | ||||||
|  |  | ||||||
|  |         log_bare(log_info, "\n"); | ||||||
|  |         return; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     // mylog(log_info,"async_cb called\n"); | ||||||
|  |     while (1) { | ||||||
|  |         int empty = 0; | ||||||
|  |         char *p; | ||||||
|  |         int len; | ||||||
|  |         pthread_mutex_lock(&queue_mutex); | ||||||
|  |         empty = my_queue.empty(); | ||||||
|  |         if (!empty) { | ||||||
|  |             my_queue.peek_front(p, len); | ||||||
|  |             my_queue.pop_front(); | ||||||
|  |         } | ||||||
|  |         pthread_mutex_unlock(&queue_mutex); | ||||||
|  |  | ||||||
|  |         if (empty) break; | ||||||
|  |         if (g_fix_gro == 0 && len > max_data_len) { | ||||||
|  |             mylog(log_warn, "huge packet %d > %d, dropped. maybe you need to turn down mtu at upper level, or maybe you need the --fix-gro option\n", len, max_data_len); | ||||||
|  |             break; | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         int new_len = len - pcap_link_header_len; | ||||||
|  |         memcpy(g_packet_buf, p + pcap_link_header_len, new_len); | ||||||
|  |         g_packet_buf_len = new_len; | ||||||
|  |         assert(g_packet_buf_cnt == 0); | ||||||
|  |         g_packet_buf_cnt++; | ||||||
|  |         client_on_raw_recv(conn_info); | ||||||
|  |     } | ||||||
|  | } | ||||||
|  | #endif | ||||||
|  | void clear_timer_cb(struct ev_loop *loop, struct ev_timer *watcher, int revents) { | ||||||
|     conn_info_t &conn_info = *((conn_info_t *)watcher->data); |     conn_info_t &conn_info = *((conn_info_t *)watcher->data); | ||||||
|     client_on_timer(conn_info); |     client_on_timer(conn_info); | ||||||
| } | } | ||||||
| void fifo_cb(struct ev_loop *loop, struct ev_io *watcher, int revents) | void fifo_cb(struct ev_loop *loop, struct ev_io *watcher, int revents) { | ||||||
| { |  | ||||||
|     conn_info_t &conn_info = *((conn_info_t *)watcher->data); |     conn_info_t &conn_info = *((conn_info_t *)watcher->data); | ||||||
|  |  | ||||||
|     char buf[buf_len]; |     char buf[buf_len]; | ||||||
|     int fifo_fd = watcher->fd; |     int fifo_fd = watcher->fd; | ||||||
|  |  | ||||||
|     int len = read(fifo_fd, buf, sizeof(buf)); |     int len = read(fifo_fd, buf, sizeof(buf)); | ||||||
| 	if(len<0) |     if (len < 0) { | ||||||
| 	{ |  | ||||||
|         mylog(log_warn, "fifo read failed len=%d,errno=%s\n", len, get_sock_error()); |         mylog(log_warn, "fifo read failed len=%d,errno=%s\n", len, get_sock_error()); | ||||||
|         return; |         return; | ||||||
|     } |     } | ||||||
| @@ -609,20 +629,15 @@ void fifo_cb(struct ev_loop *loop, struct ev_io *watcher, int revents) | |||||||
|     while (len >= 1 && buf[len - 1] == '\n') |     while (len >= 1 && buf[len - 1] == '\n') | ||||||
|         buf[len - 1] = 0; |         buf[len - 1] = 0; | ||||||
|     mylog(log_info, "got data from fifo,len=%d,s=[%s]\n", len, buf); |     mylog(log_info, "got data from fifo,len=%d,s=[%s]\n", len, buf); | ||||||
| 	if(strcmp(buf,"reconnect")==0) |     if (strcmp(buf, "reconnect") == 0) { | ||||||
| 	{ |  | ||||||
|         mylog(log_info, "received command: reconnect\n"); |         mylog(log_info, "received command: reconnect\n"); | ||||||
|         conn_info.state.client_current_state = client_idle; |         conn_info.state.client_current_state = client_idle; | ||||||
|         conn_info.my_id = get_true_random_number_nz(); |         conn_info.my_id = get_true_random_number_nz(); | ||||||
| 	} |     } else { | ||||||
| 	else |  | ||||||
| 	{ |  | ||||||
|         mylog(log_info, "unknown command\n"); |         mylog(log_info, "unknown command\n"); | ||||||
|     } |     } | ||||||
|  |  | ||||||
| } | } | ||||||
| int client_event_loop() | int client_event_loop() { | ||||||
| { |  | ||||||
|     char buf[buf_len]; |     char buf[buf_len]; | ||||||
|  |  | ||||||
|     conn_info_t conn_info; |     conn_info_t conn_info; | ||||||
| @@ -632,10 +647,9 @@ int client_event_loop() | |||||||
|     packet_info_t &send_info = conn_info.raw_info.send_info; |     packet_info_t &send_info = conn_info.raw_info.send_info; | ||||||
|     packet_info_t &recv_info = conn_info.raw_info.recv_info; |     packet_info_t &recv_info = conn_info.raw_info.recv_info; | ||||||
|  |  | ||||||
| 	if(lower_level) | #ifdef UDP2RAW_LINUX | ||||||
| 	{ |     if (lower_level) { | ||||||
| 		if(lower_level_manual) |         if (lower_level_manual) { | ||||||
| 		{ |  | ||||||
|             int index; |             int index; | ||||||
|             init_ifindex(if_name, raw_send_fd, index); |             init_ifindex(if_name, raw_send_fd, index); | ||||||
|             // init_ifindex(if_name); |             // init_ifindex(if_name); | ||||||
| @@ -646,37 +660,26 @@ int client_event_loop() | |||||||
|             send_info.addr_ll.sll_protocol = htons(ETH_P_IP); |             send_info.addr_ll.sll_protocol = htons(ETH_P_IP); | ||||||
|             memcpy(&send_info.addr_ll.sll_addr, dest_hw_addr, ETHER_ADDR_LEN); |             memcpy(&send_info.addr_ll.sll_addr, dest_hw_addr, ETHER_ADDR_LEN); | ||||||
|             mylog(log_info, "we are running at lower-level (manual) mode\n"); |             mylog(log_info, "we are running at lower-level (manual) mode\n"); | ||||||
| 		} |         } else { | ||||||
| 		else |  | ||||||
| 		{ |  | ||||||
|             u32_t dest_ip; |             u32_t dest_ip; | ||||||
|             string if_name_string; |             string if_name_string; | ||||||
|             string hw_string; |             string hw_string; | ||||||
|             assert(remote_addr.get_type() == AF_INET); |             assert(remote_addr.get_type() == AF_INET); | ||||||
|  |  | ||||||
| 			if(retry_on_error==0) |             if (retry_on_error == 0) { | ||||||
| 			{ |                 if (find_lower_level_info(remote_addr.inner.ipv4.sin_addr.s_addr, dest_ip, if_name_string, hw_string) != 0) { | ||||||
| 				if(find_lower_level_info(remote_addr.inner.ipv4.sin_addr.s_addr,dest_ip,if_name_string,hw_string)!=0) |  | ||||||
| 				{ |  | ||||||
|                     mylog(log_fatal, "auto detect lower-level info failed for %s,specific it manually\n", remote_addr.get_ip()); |                     mylog(log_fatal, "auto detect lower-level info failed for %s,specific it manually\n", remote_addr.get_ip()); | ||||||
|                     myexit(-1); |                     myexit(-1); | ||||||
|                 } |                 } | ||||||
| 			} |             } else { | ||||||
| 			else |  | ||||||
| 			{ |  | ||||||
|                 int ok = 0; |                 int ok = 0; | ||||||
| 				while(!ok) |                 while (!ok) { | ||||||
| 				{ |                     if (find_lower_level_info(remote_addr.inner.ipv4.sin_addr.s_addr, dest_ip, if_name_string, hw_string) != 0) { | ||||||
| 					if(find_lower_level_info(remote_addr.inner.ipv4.sin_addr.s_addr,dest_ip,if_name_string,hw_string)!=0) |  | ||||||
| 					{ |  | ||||||
|                         mylog(log_warn, "auto detect lower-level info failed for %s,retry in %d seconds\n", remote_addr.get_ip(), retry_on_error_interval); |                         mylog(log_warn, "auto detect lower-level info failed for %s,retry in %d seconds\n", remote_addr.get_ip(), retry_on_error_interval); | ||||||
|                         sleep(retry_on_error_interval); |                         sleep(retry_on_error_interval); | ||||||
| 					} |                     } else { | ||||||
| 					else |  | ||||||
| 					{ |  | ||||||
|                         ok = 1; |                         ok = 1; | ||||||
|                     } |                     } | ||||||
|  |  | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|             mylog(log_info, "we are running at lower-level (auto) mode,%s %s %s\n", my_ntoa(dest_ip), if_name_string.c_str(), hw_string.c_str()); |             mylog(log_info, "we are running at lower-level (auto) mode,%s %s %s\n", my_ntoa(dest_ip), if_name_string.c_str(), hw_string.c_str()); | ||||||
| @@ -705,23 +708,106 @@ int client_event_loop() | |||||||
|             memcpy(&send_info.addr_ll.sll_addr, dest_hw_addr, ETHER_ADDR_LEN); |             memcpy(&send_info.addr_ll.sll_addr, dest_hw_addr, ETHER_ADDR_LEN); | ||||||
|             // mylog(log_info,"we are running at lower-level (manual) mode\n"); |             // mylog(log_info,"we are running at lower-level (manual) mode\n"); | ||||||
|         } |         } | ||||||
|  |  | ||||||
|     } |     } | ||||||
|  | #endif | ||||||
|  |  | ||||||
|  | #ifdef UDP2RAW_MP | ||||||
|  |  | ||||||
|  |     address_t tmp_addr; | ||||||
|  |     if (get_src_adress2(tmp_addr, remote_addr) != 0) { | ||||||
|  |         mylog(log_error, "get_src_adress() failed\n"); | ||||||
|  |         myexit(-1); | ||||||
|  |     } | ||||||
|  |     if (strcmp(dev, "") == 0) { | ||||||
|  |         mylog(log_info, "--dev have not been set, trying to detect automatically, available devices:\n"); | ||||||
|  |  | ||||||
|  |         mylog(log_info, "available device(device name: ip address ; description):\n"); | ||||||
|  |  | ||||||
|  |         char errbuf[PCAP_ERRBUF_SIZE]; | ||||||
|  |  | ||||||
|  |         int found = 0; | ||||||
|  |  | ||||||
|  |         pcap_if_t *interfaces, *d; | ||||||
|  |         if (pcap_findalldevs(&interfaces, errbuf) == -1) { | ||||||
|  |             mylog(log_fatal, "error in pcap_findalldevs(),%s\n", errbuf); | ||||||
|  |             myexit(-1); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         for (pcap_if_t *d = interfaces; d != NULL; d = d->next) { | ||||||
|  |             log_bare(log_warn, "%s:", d->name); | ||||||
|  |             int cnt = 0; | ||||||
|  |             for (pcap_addr_t *a = d->addresses; a != NULL; a = a->next) { | ||||||
|  |                 if (a->addr == NULL) { | ||||||
|  |                     log_bare(log_debug, " [a->addr==NULL]"); | ||||||
|  |                     continue; | ||||||
|  |                 } | ||||||
|  |                 if (a->addr->sa_family == AF_INET || a->addr->sa_family == AF_INET6) { | ||||||
|  |                     cnt++; | ||||||
|  |  | ||||||
|  |                     if (a->addr->sa_family == AF_INET) { | ||||||
|  |                         char s[max_addr_len]; | ||||||
|  |                         inet_ntop(AF_INET, &((struct sockaddr_in *)a->addr)->sin_addr, s, max_addr_len); | ||||||
|  |                         log_bare(log_warn, " [%s]", s); | ||||||
|  |  | ||||||
|  |                         if (a->addr->sa_family == raw_ip_version) { | ||||||
|  |                             if (((struct sockaddr_in *)a->addr)->sin_addr.s_addr == tmp_addr.inner.ipv4.sin_addr.s_addr) { | ||||||
|  |                                 found++; | ||||||
|  |                                 strcpy(dev, d->name); | ||||||
|  |                             } | ||||||
|  |                         } | ||||||
|  |                     } else { | ||||||
|  |                         assert(a->addr->sa_family == AF_INET6); | ||||||
|  |  | ||||||
|  |                         char s[max_addr_len]; | ||||||
|  |                         inet_ntop(AF_INET6, &((struct sockaddr_in6 *)a->addr)->sin6_addr, s, max_addr_len); | ||||||
|  |                         log_bare(log_warn, " [%s]", s); | ||||||
|  |  | ||||||
|  |                         if (a->addr->sa_family == raw_ip_version) { | ||||||
|  |                             if (memcmp(&((struct sockaddr_in6 *)a->addr)->sin6_addr, &tmp_addr.inner.ipv6.sin6_addr, sizeof(struct in6_addr)) == 0) { | ||||||
|  |                                 found++; | ||||||
|  |                                 strcpy(dev, d->name); | ||||||
|  |                             } | ||||||
|  |                         } | ||||||
|  |                     } | ||||||
|  |                 } else { | ||||||
|  |                     log_bare(log_debug, " [unknow:%d]", int(a->addr->sa_family)); | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  |             if (cnt == 0) log_bare(log_warn, " [no ip found]"); | ||||||
|  |             if (d->description == 0) { | ||||||
|  |                 log_bare(log_warn, "; (no description available)"); | ||||||
|  |             } else { | ||||||
|  |                 log_bare(log_warn, "; %s", d->description); | ||||||
|  |             } | ||||||
|  |             log_bare(log_warn, "\n"); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         if (found == 0) { | ||||||
|  |             mylog(log_fatal, "no matched device found for ip: [%s]\n", tmp_addr.get_ip()); | ||||||
|  |             myexit(-1); | ||||||
|  |         } else if (found == 1) { | ||||||
|  |             mylog(log_info, "using device:[%s], ip: [%s]\n", dev, tmp_addr.get_ip()); | ||||||
|  |         } else { | ||||||
|  |             mylog(log_fatal, "more than one devices found for ip: [%s] , you need to use --dev manually\n", tmp_addr.get_ip()); | ||||||
|  |             myexit(-1); | ||||||
|  |         } | ||||||
|  |     } else { | ||||||
|  |         mylog(log_info, "--dev has been manually set, using device:[%s]\n", dev); | ||||||
|  |     } | ||||||
|  | #endif | ||||||
|  |  | ||||||
|     send_info.src_port = 0; |     send_info.src_port = 0; | ||||||
|     memset(&send_info.new_src_ip, 0, sizeof(send_info.new_src_ip)); |     memset(&send_info.new_src_ip, 0, sizeof(send_info.new_src_ip)); | ||||||
|  |  | ||||||
| 	int i, j, k;int ret; |     int i, j, k; | ||||||
|  |     int ret; | ||||||
|  |  | ||||||
|     send_info.new_dst_ip.from_address_t(remote_addr); |     send_info.new_dst_ip.from_address_t(remote_addr); | ||||||
|     send_info.dst_port = remote_addr.get_port(); |     send_info.dst_port = remote_addr.get_port(); | ||||||
|  |  | ||||||
|  |  | ||||||
|     udp_fd = socket(local_addr.get_type(), SOCK_DGRAM, IPPROTO_UDP); |     udp_fd = socket(local_addr.get_type(), SOCK_DGRAM, IPPROTO_UDP); | ||||||
|     set_buf_size(udp_fd, socket_buf_size); |     set_buf_size(udp_fd, socket_buf_size); | ||||||
|  |  | ||||||
|  |  | ||||||
|     if (::bind(udp_fd, (struct sockaddr *)&local_addr.inner, local_addr.get_len()) == -1) { |     if (::bind(udp_fd, (struct sockaddr *)&local_addr.inner, local_addr.get_len()) == -1) { | ||||||
|         mylog(log_fatal, "socket bind error\n"); |         mylog(log_fatal, "socket bind error\n"); | ||||||
|         // perror("socket bind error"); |         // perror("socket bind error"); | ||||||
| @@ -749,14 +835,12 @@ int client_event_loop() | |||||||
|     //	myexit(-1); |     //	myexit(-1); | ||||||
|     // } |     // } | ||||||
|  |  | ||||||
|  |  | ||||||
|     struct ev_io udp_accept_watcher; |     struct ev_io udp_accept_watcher; | ||||||
|  |  | ||||||
|     udp_accept_watcher.data = &conn_info; |     udp_accept_watcher.data = &conn_info; | ||||||
|     ev_io_init(&udp_accept_watcher, udp_accept_cb, udp_fd, EV_READ); |     ev_io_init(&udp_accept_watcher, udp_accept_cb, udp_fd, EV_READ); | ||||||
|     ev_io_start(loop, &udp_accept_watcher); |     ev_io_start(loop, &udp_accept_watcher); | ||||||
|  |  | ||||||
|  |  | ||||||
|     // ev.events = EPOLLIN; |     // ev.events = EPOLLIN; | ||||||
|     // ev.data.u64 = raw_recv_fd; |     // ev.data.u64 = raw_recv_fd; | ||||||
|  |  | ||||||
| @@ -766,11 +850,22 @@ int client_event_loop() | |||||||
|     //	myexit(-1); |     //	myexit(-1); | ||||||
|     // } |     // } | ||||||
|  |  | ||||||
|  | #ifdef UDP2RAW_LINUX | ||||||
|     struct ev_io raw_recv_watcher; |     struct ev_io raw_recv_watcher; | ||||||
|  |  | ||||||
|     raw_recv_watcher.data = &conn_info; |     raw_recv_watcher.data = &conn_info; | ||||||
|     ev_io_init(&raw_recv_watcher, raw_recv_cb, raw_recv_fd, EV_READ); |     ev_io_init(&raw_recv_watcher, raw_recv_cb, raw_recv_fd, EV_READ); | ||||||
|     ev_io_start(loop, &raw_recv_watcher); |     ev_io_start(loop, &raw_recv_watcher); | ||||||
|  | #endif | ||||||
|  |  | ||||||
|  | #ifdef UDP2RAW_MP | ||||||
|  |     g_default_loop = loop; | ||||||
|  |     async_watcher.data = &conn_info; | ||||||
|  |     ev_async_init(&async_watcher, async_cb); | ||||||
|  |     ev_async_start(loop, &async_watcher); | ||||||
|  |  | ||||||
|  |     init_raw_socket();  // must be put after dev detection | ||||||
|  | #endif | ||||||
|  |  | ||||||
|     // set_timer(epollfd,timer_fd); |     // set_timer(epollfd,timer_fd); | ||||||
|     struct ev_timer clear_timer; |     struct ev_timer clear_timer; | ||||||
| @@ -786,8 +881,7 @@ int client_event_loop() | |||||||
|     struct ev_io fifo_watcher; |     struct ev_io fifo_watcher; | ||||||
|     fifo_watcher.data = &conn_info; |     fifo_watcher.data = &conn_info; | ||||||
|  |  | ||||||
| 	if(fifo_file[0]!=0) |     if (fifo_file[0] != 0) { | ||||||
| 	{ |  | ||||||
|         fifo_fd = create_fifo(fifo_file); |         fifo_fd = create_fifo(fifo_file); | ||||||
|  |  | ||||||
|         ev_io_init(&fifo_watcher, fifo_cb, fifo_fd, EV_READ); |         ev_io_init(&fifo_watcher, fifo_cb, fifo_fd, EV_READ); | ||||||
|   | |||||||
							
								
								
									
										586
									
								
								common.cpp
									
									
									
									
									
								
							
							
						
						
									
										586
									
								
								common.cpp
									
									
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										194
									
								
								common.h
									
									
									
									
									
								
							
							
						
						
									
										194
									
								
								common.h
									
									
									
									
									
								
							| @@ -27,8 +27,12 @@ | |||||||
| #include <assert.h> | #include <assert.h> | ||||||
| #include <pthread.h> | #include <pthread.h> | ||||||
|  |  | ||||||
| #if defined(UDP2RAW_MP) | #ifndef USE_LIBNET | ||||||
|  | #define NO_LIBNET | ||||||
|  | #endif | ||||||
|  |  | ||||||
|  | #if defined(UDP2RAW_MP) | ||||||
|  | const int is_udp2raw_mp = 1; | ||||||
| #if !defined(__CYGWIN__) && !defined(__MINGW32__) | #if !defined(__CYGWIN__) && !defined(__MINGW32__) | ||||||
| #include <pcap.h> | #include <pcap.h> | ||||||
| #else | #else | ||||||
| @@ -41,7 +45,8 @@ | |||||||
| #endif | #endif | ||||||
|  |  | ||||||
| #else | #else | ||||||
|  | #define UDP2RAW_LINUX | ||||||
|  | const int is_udp2raw_mp = 0; | ||||||
| //#include <linux/if_ether.h> | //#include <linux/if_ether.h> | ||||||
| #include <linux/filter.h> | #include <linux/filter.h> | ||||||
| #include <linux/if_packet.h> | #include <linux/if_packet.h> | ||||||
| @@ -53,7 +58,11 @@ | |||||||
|  |  | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  | #if !defined(NO_LIBEV_EMBED) | ||||||
| #include <my_ev.h> | #include <my_ev.h> | ||||||
|  | #else | ||||||
|  | #include "ev.h" | ||||||
|  | #endif | ||||||
|  |  | ||||||
| #if defined(__MINGW32__) | #if defined(__MINGW32__) | ||||||
| #include <winsock2.h> | #include <winsock2.h> | ||||||
| @@ -70,7 +79,6 @@ typedef int socklen_t; | |||||||
| #include <netinet/in.h> | #include <netinet/in.h> | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  |  | ||||||
| #include <unordered_map> | #include <unordered_map> | ||||||
| #include <fstream> | #include <fstream> | ||||||
| #include <string> | #include <string> | ||||||
| @@ -90,7 +98,6 @@ using  namespace std; | |||||||
| #define UDP2RAW_BIG_ENDIAN 1 | #define UDP2RAW_BIG_ENDIAN 1 | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  |  | ||||||
| #if defined(__BYTE_ORDER) && __BYTE_ORDER == __LITTLE_ENDIAN ||             \ | #if defined(__BYTE_ORDER) && __BYTE_ORDER == __LITTLE_ENDIAN ||             \ | ||||||
|     defined(__BYTE_ORDER__) && __BYTE_ORDER__ == __ORDER_LITTLE_ENDIAN__ || \ |     defined(__BYTE_ORDER__) && __BYTE_ORDER__ == __ORDER_LITTLE_ENDIAN__ || \ | ||||||
|     defined(__LITTLE_ENDIAN__) ||                                           \ |     defined(__LITTLE_ENDIAN__) ||                                           \ | ||||||
| @@ -105,12 +112,10 @@ using  namespace std; | |||||||
| #error "endian detection conflicts" | #error "endian detection conflicts" | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  |  | ||||||
| #if !defined(UDP2RAW_BIG_ENDIAN) && !defined(UDP2RAW_LITTLE_ENDIAN) | #if !defined(UDP2RAW_BIG_ENDIAN) && !defined(UDP2RAW_LITTLE_ENDIAN) | ||||||
| #error "endian detection failed" | #error "endian detection failed" | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  |  | ||||||
| #if defined(__MINGW32__) | #if defined(__MINGW32__) | ||||||
| int inet_pton(int af, const char *src, void *dst); | int inet_pton(int af, const char *src, void *dst); | ||||||
| const char *inet_ntop(int af, const void *src, char *dst, socklen_t size); | const char *inet_ntop(int af, const void *src, char *dst, socklen_t size); | ||||||
| @@ -122,20 +127,17 @@ int get_sock_errno(); | |||||||
|  |  | ||||||
| #if defined(__MINGW32__) | #if defined(__MINGW32__) | ||||||
| typedef SOCKET my_fd_t; | typedef SOCKET my_fd_t; | ||||||
| inline int sock_close(my_fd_t fd) | inline int sock_close(my_fd_t fd) { | ||||||
| { |  | ||||||
|     return closesocket(fd); |     return closesocket(fd); | ||||||
| } | } | ||||||
| #else | #else | ||||||
| typedef int my_fd_t; | typedef int my_fd_t; | ||||||
| inline int sock_close(my_fd_t fd) | inline int sock_close(my_fd_t fd) { | ||||||
| { |  | ||||||
|     return close(fd); |     return close(fd); | ||||||
| } | } | ||||||
|  |  | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  |  | ||||||
| typedef unsigned long long u64_t;  // this works on most platform,avoid using the PRId64 | typedef unsigned long long u64_t;  // this works on most platform,avoid using the PRId64 | ||||||
| typedef long long i64_t; | typedef long long i64_t; | ||||||
|  |  | ||||||
| @@ -161,6 +163,8 @@ extern int force_socket_buf; | |||||||
|  |  | ||||||
| extern int g_fix_gro; | extern int g_fix_gro; | ||||||
|  |  | ||||||
|  | extern int g_tcp_spa; | ||||||
|  |  | ||||||
| /* | /* | ||||||
| struct ip_port_t | struct ip_port_t | ||||||
| { | { | ||||||
| @@ -178,10 +182,8 @@ u32_t sdbm(unsigned char *str,int len); | |||||||
|  |  | ||||||
| struct address_t  // TODO scope id | struct address_t  // TODO scope id | ||||||
| { | { | ||||||
| 	struct hash_function |     struct hash_function { | ||||||
| 	{ |         u32_t operator()(const address_t &key) const { | ||||||
| 	    u32_t operator()(const address_t &key) const |  | ||||||
| 		{ |  | ||||||
|             return sdbm((unsigned char *)&key.inner, sizeof(key.inner)); |             return sdbm((unsigned char *)&key.inner, sizeof(key.inner)); | ||||||
|         } |         } | ||||||
|     }; |     }; | ||||||
| @@ -193,16 +195,13 @@ struct address_t  //TODO scope id | |||||||
|     }; |     }; | ||||||
|     storage_t inner; |     storage_t inner; | ||||||
|  |  | ||||||
| 	address_t() |     address_t() { | ||||||
| 	{ |  | ||||||
|         clear(); |         clear(); | ||||||
|     } |     } | ||||||
| 	void clear() |     void clear() { | ||||||
| 	{ |  | ||||||
|         memset(&inner, 0, sizeof(inner)); |         memset(&inner, 0, sizeof(inner)); | ||||||
|     } |     } | ||||||
| 	int from_ip_port(u32_t  ip, int port) |     int from_ip_port(u32_t ip, int port) { | ||||||
| 	{ |  | ||||||
|         clear(); |         clear(); | ||||||
|         inner.ipv4.sin_family = AF_INET; |         inner.ipv4.sin_family = AF_INET; | ||||||
|         inner.ipv4.sin_port = htons(port); |         inner.ipv4.sin_port = htons(port); | ||||||
| @@ -210,17 +209,13 @@ struct address_t  //TODO scope id | |||||||
|         return 0; |         return 0; | ||||||
|     } |     } | ||||||
|  |  | ||||||
| 	int from_ip_port_new(int type, void *  ip, int port) |     int from_ip_port_new(int type, void *ip, int port) { | ||||||
| 	{ |  | ||||||
|         clear(); |         clear(); | ||||||
| 		if(type==AF_INET) |         if (type == AF_INET) { | ||||||
| 		{ |  | ||||||
|             inner.ipv4.sin_family = AF_INET; |             inner.ipv4.sin_family = AF_INET; | ||||||
|             inner.ipv4.sin_port = htons(port); |             inner.ipv4.sin_port = htons(port); | ||||||
|             inner.ipv4.sin_addr.s_addr = *((u32_t *)ip); |             inner.ipv4.sin_addr.s_addr = *((u32_t *)ip); | ||||||
| 		} |         } else if (type == AF_INET6) { | ||||||
| 		else if(type==AF_INET6) |  | ||||||
| 		{ |  | ||||||
|             inner.ipv6.sin6_family = AF_INET6; |             inner.ipv6.sin6_family = AF_INET6; | ||||||
|             inner.ipv6.sin6_port = htons(port); |             inner.ipv6.sin6_port = htons(port); | ||||||
|             inner.ipv6.sin6_addr = *((in6_addr *)ip); |             inner.ipv6.sin6_addr = *((in6_addr *)ip); | ||||||
| @@ -237,18 +232,15 @@ struct address_t  //TODO scope id | |||||||
|     char *get_str(); |     char *get_str(); | ||||||
|     void to_str(char *); |     void to_str(char *); | ||||||
|  |  | ||||||
| 	inline u32_t get_type() |     inline u32_t get_type() { | ||||||
| 	{ |  | ||||||
|         u32_t ret = ((sockaddr *)&inner)->sa_family; |         u32_t ret = ((sockaddr *)&inner)->sa_family; | ||||||
|         assert(ret == AF_INET || ret == AF_INET6); |         assert(ret == AF_INET || ret == AF_INET6); | ||||||
|         return ret; |         return ret; | ||||||
|     } |     } | ||||||
|  |  | ||||||
| 	inline u32_t get_len() |     inline u32_t get_len() { | ||||||
| 	{ |  | ||||||
|         u32_t type = get_type(); |         u32_t type = get_type(); | ||||||
| 		switch(type) |         switch (type) { | ||||||
| 		{ |  | ||||||
|             case AF_INET: |             case AF_INET: | ||||||
|                 return sizeof(sockaddr_in); |                 return sizeof(sockaddr_in); | ||||||
|             case AF_INET6: |             case AF_INET6: | ||||||
| @@ -259,11 +251,9 @@ struct address_t  //TODO scope id | |||||||
|         return -1; |         return -1; | ||||||
|     } |     } | ||||||
|  |  | ||||||
| 	inline u32_t get_port() |     inline u32_t get_port() { | ||||||
| 	{ |  | ||||||
|         u32_t type = get_type(); |         u32_t type = get_type(); | ||||||
| 		switch(type) |         switch (type) { | ||||||
| 		{ |  | ||||||
|             case AF_INET: |             case AF_INET: | ||||||
|                 return ntohs(inner.ipv4.sin_port); |                 return ntohs(inner.ipv4.sin_port); | ||||||
|             case AF_INET6: |             case AF_INET6: | ||||||
| @@ -274,11 +264,9 @@ struct address_t  //TODO scope id | |||||||
|         return -1; |         return -1; | ||||||
|     } |     } | ||||||
|  |  | ||||||
| 	inline void set_port(int port) |     inline void set_port(int port) { | ||||||
| 	{ |  | ||||||
|         u32_t type = get_type(); |         u32_t type = get_type(); | ||||||
| 		switch(type) |         switch (type) { | ||||||
| 		{ |  | ||||||
|             case AF_INET: |             case AF_INET: | ||||||
|                 inner.ipv4.sin_port = htons(port); |                 inner.ipv4.sin_port = htons(port); | ||||||
|                 break; |                 break; | ||||||
| @@ -291,8 +279,7 @@ struct address_t  //TODO scope id | |||||||
|         return; |         return; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     bool operator == (const address_t &b) const |     bool operator==(const address_t &b) const { | ||||||
|     { |  | ||||||
|         // return this->data==b.data; |         // return this->data==b.data; | ||||||
|         return memcmp(&this->inner, &b.inner, sizeof(this->inner)) == 0; |         return memcmp(&this->inner, &b.inner, sizeof(this->inner)) == 0; | ||||||
|     } |     } | ||||||
| @@ -304,16 +291,13 @@ struct address_t  //TODO scope id | |||||||
|  |  | ||||||
| namespace std { | namespace std { | ||||||
| template <> | template <> | ||||||
|  struct hash<address_t> | struct hash<address_t> { | ||||||
|  { |     std::size_t operator()(const address_t &key) const { | ||||||
|    std::size_t operator()(const address_t& key) const |  | ||||||
|    { |  | ||||||
|  |  | ||||||
|         // return address_t::hash_function(k); |         // return address_t::hash_function(k); | ||||||
|         return sdbm((unsigned char *)&key.inner, sizeof(key.inner)); |         return sdbm((unsigned char *)&key.inner, sizeof(key.inner)); | ||||||
|     } |     } | ||||||
| }; | }; | ||||||
| } | }  // namespace std | ||||||
|  |  | ||||||
| union my_ip_t  // just a simple version of address_t,stores ip only | union my_ip_t  // just a simple version of address_t,stores ip only | ||||||
| { | { | ||||||
| @@ -327,21 +311,15 @@ union my_ip_t //just a simple version of address_t,stores ip only | |||||||
|     char *get_str2() const; |     char *get_str2() const; | ||||||
|  |  | ||||||
|     int from_address_t(address_t a); |     int from_address_t(address_t a); | ||||||
|  |  | ||||||
| }; | }; | ||||||
|  |  | ||||||
| struct not_copy_able_t | struct not_copy_able_t { | ||||||
| { |     not_copy_able_t() { | ||||||
| 	not_copy_able_t() |  | ||||||
| 	{ |  | ||||||
|  |  | ||||||
|     } |     } | ||||||
| 	not_copy_able_t(const not_copy_able_t &other) |     not_copy_able_t(const not_copy_able_t &other) { | ||||||
| 	{ |  | ||||||
|         assert(0 == 1); |         assert(0 == 1); | ||||||
|     } |     } | ||||||
| 	const not_copy_able_t & operator=(const not_copy_able_t &other) |     const not_copy_able_t &operator=(const not_copy_able_t &other) { | ||||||
| 	{ |  | ||||||
|         assert(0 == 1); |         assert(0 == 1); | ||||||
|         return other; |         return other; | ||||||
|     } |     } | ||||||
| @@ -355,6 +333,51 @@ const int buf_len=max_data_len+400; | |||||||
|  |  | ||||||
| // const int max_address_len=512; | // const int max_address_len=512; | ||||||
|  |  | ||||||
|  | #ifdef UDP2RAW_MP | ||||||
|  | const int queue_len = 200; | ||||||
|  |  | ||||||
|  | struct queue_t { | ||||||
|  |     char data[queue_len][huge_buf_len]; | ||||||
|  |     int data_len[queue_len]; | ||||||
|  |  | ||||||
|  |     int head = 0; | ||||||
|  |     int tail = 0; | ||||||
|  |     void clear() { | ||||||
|  |         head = tail = 0; | ||||||
|  |     } | ||||||
|  |     int empty() { | ||||||
|  |         if (head == tail) | ||||||
|  |             return 1; | ||||||
|  |         else | ||||||
|  |             return 0; | ||||||
|  |     } | ||||||
|  |     int full() { | ||||||
|  |         if ((tail + 1) % queue_len == head) | ||||||
|  |             return 1; | ||||||
|  |         else | ||||||
|  |             return 0; | ||||||
|  |     } | ||||||
|  |     void peek_front(char *&p, int &len) { | ||||||
|  |         assert(!empty()); | ||||||
|  |         p = data[head]; | ||||||
|  |         len = data_len[head]; | ||||||
|  |     } | ||||||
|  |     void pop_front() { | ||||||
|  |         assert(!empty()); | ||||||
|  |         head++; | ||||||
|  |         head %= queue_len; | ||||||
|  |     } | ||||||
|  |     void push_back(char *p, int len) { | ||||||
|  |         assert(!full()); | ||||||
|  |         memcpy(data[tail], p, len); | ||||||
|  |         data_len[tail] = len; | ||||||
|  |         tail++; | ||||||
|  |         tail %= queue_len; | ||||||
|  |     } | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | int init_ws(); | ||||||
|  | #endif | ||||||
| u64_t get_current_time(); | u64_t get_current_time(); | ||||||
| u64_t pack_u64(u32_t a, u32_t b); | u64_t pack_u64(u32_t a, u32_t b); | ||||||
|  |  | ||||||
| @@ -418,12 +441,10 @@ int create_fifo(char * file); | |||||||
| void print_binary_chars(const char *a, int len); | void print_binary_chars(const char *a, int len); | ||||||
|  |  | ||||||
| template <class key_t> | template <class key_t> | ||||||
| struct lru_collector_t:not_copy_able_t | struct lru_collector_t : not_copy_able_t { | ||||||
| { |  | ||||||
|     // typedef void* key_t; |     // typedef void* key_t; | ||||||
|     //#define key_t void* |     //#define key_t void* | ||||||
| 	struct lru_pair_t |     struct lru_pair_t { | ||||||
| 	{ |  | ||||||
|         key_t key; |         key_t key; | ||||||
|         my_time_t ts; |         my_time_t ts; | ||||||
|     }; |     }; | ||||||
| @@ -431,65 +452,61 @@ struct lru_collector_t:not_copy_able_t | |||||||
|     unordered_map<key_t, typename list<lru_pair_t>::iterator> mp; |     unordered_map<key_t, typename list<lru_pair_t>::iterator> mp; | ||||||
|  |  | ||||||
|     list<lru_pair_t> q; |     list<lru_pair_t> q; | ||||||
| 	int update(key_t key) |     int update(key_t key) { | ||||||
| 	{ |  | ||||||
|         assert(mp.find(key) != mp.end()); |         assert(mp.find(key) != mp.end()); | ||||||
|         auto it = mp[key]; |         auto it = mp[key]; | ||||||
|         q.erase(it); |         q.erase(it); | ||||||
|  |  | ||||||
|         my_time_t value = get_current_time(); |         my_time_t value = get_current_time(); | ||||||
| 		if(!q.empty()) |         if (!q.empty()) { | ||||||
| 		{ |  | ||||||
|             assert(value >= q.front().ts); |             assert(value >= q.front().ts); | ||||||
|         } |         } | ||||||
| 		lru_pair_t tmp; tmp.key=key; tmp.ts=value; |         lru_pair_t tmp; | ||||||
|  |         tmp.key = key; | ||||||
|  |         tmp.ts = value; | ||||||
|         q.push_front(tmp); |         q.push_front(tmp); | ||||||
|         mp[key] = q.begin(); |         mp[key] = q.begin(); | ||||||
|  |  | ||||||
|         return 0; |         return 0; | ||||||
|     } |     } | ||||||
| 	int new_key(key_t key) |     int new_key(key_t key) { | ||||||
| 	{ |  | ||||||
|         assert(mp.find(key) == mp.end()); |         assert(mp.find(key) == mp.end()); | ||||||
|  |  | ||||||
|         my_time_t value = get_current_time(); |         my_time_t value = get_current_time(); | ||||||
| 		if(!q.empty()) |         if (!q.empty()) { | ||||||
| 		{ |  | ||||||
|             assert(value >= q.front().ts); |             assert(value >= q.front().ts); | ||||||
|         } |         } | ||||||
| 		lru_pair_t tmp; tmp.key=key; tmp.ts=value; |         lru_pair_t tmp; | ||||||
|  |         tmp.key = key; | ||||||
|  |         tmp.ts = value; | ||||||
|         q.push_front(tmp); |         q.push_front(tmp); | ||||||
|         mp[key] = q.begin(); |         mp[key] = q.begin(); | ||||||
|  |  | ||||||
|         return 0; |         return 0; | ||||||
|     } |     } | ||||||
| 	int size() |     int size() { | ||||||
| 	{ |  | ||||||
|         return q.size(); |         return q.size(); | ||||||
|     } |     } | ||||||
| 	int empty() |     int empty() { | ||||||
| 	{ |  | ||||||
|         return q.empty(); |         return q.empty(); | ||||||
|     } |     } | ||||||
| 	void clear() |     void clear() { | ||||||
| 	{ |         mp.clear(); | ||||||
| 		mp.clear(); q.clear(); |         q.clear(); | ||||||
|     } |     } | ||||||
| 	my_time_t ts_of(key_t key) |     my_time_t ts_of(key_t key) { | ||||||
| 	{ |  | ||||||
|         assert(mp.find(key) != mp.end()); |         assert(mp.find(key) != mp.end()); | ||||||
|         return mp[key]->ts; |         return mp[key]->ts; | ||||||
|     } |     } | ||||||
|  |  | ||||||
| 	my_time_t peek_back(key_t &key) |     my_time_t peek_back(key_t &key) { | ||||||
| 	{ |  | ||||||
|         assert(!q.empty()); |         assert(!q.empty()); | ||||||
| 		auto it=q.end(); it--; |         auto it = q.end(); | ||||||
|  |         it--; | ||||||
|         key = it->key; |         key = it->key; | ||||||
|         return it->ts; |         return it->ts; | ||||||
|     } |     } | ||||||
| 	void erase(key_t key) |     void erase(key_t key) { | ||||||
| 	{ |  | ||||||
|         assert(mp.find(key) != mp.end()); |         assert(mp.find(key) != mp.end()); | ||||||
|         q.erase(mp[key]); |         q.erase(mp[key]); | ||||||
|         mp.erase(key); |         mp.erase(key); | ||||||
| @@ -504,5 +521,4 @@ struct lru_collector_t:not_copy_able_t | |||||||
|     }*/ |     }*/ | ||||||
| }; | }; | ||||||
|  |  | ||||||
|  |  | ||||||
| #endif /* COMMON_H_ */ | #endif /* COMMON_H_ */ | ||||||
|   | |||||||
							
								
								
									
										289
									
								
								connection.cpp
									
									
									
									
									
								
							
							
						
						
									
										289
									
								
								connection.cpp
									
									
									
									
									
								
							| @@ -15,67 +15,53 @@ const int disable_conn_clear=0;//a raw connection is called conn. | |||||||
|  |  | ||||||
| conn_manager_t conn_manager; | conn_manager_t conn_manager; | ||||||
|  |  | ||||||
| 	anti_replay_seq_t anti_replay_t::get_new_seq_for_send() | anti_replay_seq_t anti_replay_t::get_new_seq_for_send() { | ||||||
| 	{ |  | ||||||
|     return anti_replay_seq++; |     return anti_replay_seq++; | ||||||
| } | } | ||||||
| 	anti_replay_t::anti_replay_t() | anti_replay_t::anti_replay_t() { | ||||||
| 	{ |  | ||||||
|     max_packet_received = 0; |     max_packet_received = 0; | ||||||
|     anti_replay_seq = get_true_random_number_64() / 10;  // random first seq |     anti_replay_seq = get_true_random_number_64() / 10;  // random first seq | ||||||
|     // memset(window,0,sizeof(window)); //not necessary |     // memset(window,0,sizeof(window)); //not necessary | ||||||
| } | } | ||||||
| 	void anti_replay_t::re_init() | void anti_replay_t::re_init() { | ||||||
| 	{ |  | ||||||
|     max_packet_received = 0; |     max_packet_received = 0; | ||||||
|     // memset(window,0,sizeof(window)); |     // memset(window,0,sizeof(window)); | ||||||
| } | } | ||||||
|  |  | ||||||
| 	int anti_replay_t::is_vaild(u64_t seq) | int anti_replay_t::is_vaild(u64_t seq) { | ||||||
| 	{ |  | ||||||
|     if (disable_anti_replay) return 1; |     if (disable_anti_replay) return 1; | ||||||
|     // if(disabled) return 0; |     // if(disabled) return 0; | ||||||
|  |  | ||||||
| 		if(seq==max_packet_received) return 0; |     if (seq == max_packet_received) | ||||||
| 		else if(seq>max_packet_received) |         return 0; | ||||||
| 		{ |     else if (seq > max_packet_received) { | ||||||
| 			if(seq-max_packet_received>=anti_replay_window_size) |         if (seq - max_packet_received >= anti_replay_window_size) { | ||||||
| 			{ |  | ||||||
|             memset(window, 0, sizeof(window)); |             memset(window, 0, sizeof(window)); | ||||||
|             window[seq % anti_replay_window_size] = 1; |             window[seq % anti_replay_window_size] = 1; | ||||||
| 			} |         } else { | ||||||
| 			else |  | ||||||
| 			{ |  | ||||||
|             for (u64_t i = max_packet_received + 1; i < seq; i++) |             for (u64_t i = max_packet_received + 1; i < seq; i++) | ||||||
|                 window[i % anti_replay_window_size] = 0; |                 window[i % anti_replay_window_size] = 0; | ||||||
|             window[seq % anti_replay_window_size] = 1; |             window[seq % anti_replay_window_size] = 1; | ||||||
|         } |         } | ||||||
|         max_packet_received = seq; |         max_packet_received = seq; | ||||||
|         return 1; |         return 1; | ||||||
| 		} |     } else if (seq < max_packet_received) { | ||||||
| 		else if(seq<max_packet_received) |         if (max_packet_received - seq >= anti_replay_window_size) | ||||||
| 		{ |             return 0; | ||||||
| 			if(max_packet_received-seq>=anti_replay_window_size) return 0; |         else { | ||||||
| 			else |             if (window[seq % anti_replay_window_size] == 1) | ||||||
| 			{ |                 return 0; | ||||||
| 				if (window[seq%anti_replay_window_size]==1) return 0; |             else { | ||||||
| 				else |  | ||||||
| 				{ |  | ||||||
|                 window[seq % anti_replay_window_size] = 1; |                 window[seq % anti_replay_window_size] = 1; | ||||||
|                 return 1; |                 return 1; | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |  | ||||||
|     return 0;  // for complier check |     return 0;  // for complier check | ||||||
| } | } | ||||||
|  |  | ||||||
|  | void conn_info_t::recover(const conn_info_t &conn_info) { | ||||||
|  |  | ||||||
|  |  | ||||||
| 	 void conn_info_t::recover(const conn_info_t &conn_info) |  | ||||||
| 	 { |  | ||||||
|     raw_info = conn_info.raw_info; |     raw_info = conn_info.raw_info; | ||||||
|  |  | ||||||
|     raw_info.rst_received = 0; |     raw_info.rst_received = 0; | ||||||
| @@ -91,11 +77,9 @@ conn_manager_t conn_manager; | |||||||
|     my_roller = 0;       // no need to set,but for easier debug,set it to zero |     my_roller = 0;       // no need to set,but for easier debug,set it to zero | ||||||
|     oppsite_roller = 0;  // same as above |     oppsite_roller = 0;  // same as above | ||||||
|     last_oppsite_roller_time = 0; |     last_oppsite_roller_time = 0; | ||||||
|  |  | ||||||
| } | } | ||||||
|  |  | ||||||
| 	void conn_info_t::re_init() | void conn_info_t::re_init() { | ||||||
| 	{ |  | ||||||
|     // send_packet_info.protocol=g_packet_info_send.protocol; |     // send_packet_info.protocol=g_packet_info_send.protocol; | ||||||
|     if (program_mode == server_mode) |     if (program_mode == server_mode) | ||||||
|         state.server_current_state = server_idle; |         state.server_current_state = server_idle; | ||||||
| @@ -110,49 +94,37 @@ conn_manager_t conn_manager; | |||||||
|     oppsite_roller = 0; |     oppsite_roller = 0; | ||||||
|     last_oppsite_roller_time = 0; |     last_oppsite_roller_time = 0; | ||||||
| } | } | ||||||
| 	conn_info_t::conn_info_t() | conn_info_t::conn_info_t() { | ||||||
| 	{ |  | ||||||
|     blob = 0; |     blob = 0; | ||||||
|     re_init(); |     re_init(); | ||||||
| } | } | ||||||
| 	void conn_info_t::prepare() | void conn_info_t::prepare() { | ||||||
| 	{ |  | ||||||
|     assert(blob == 0); |     assert(blob == 0); | ||||||
|     blob = new blob_t; |     blob = new blob_t; | ||||||
| 		if(program_mode==server_mode) |     if (program_mode == server_mode) { | ||||||
| 		{ |  | ||||||
|         blob->conv_manager.s.additional_clear_function = server_clear_function; |         blob->conv_manager.s.additional_clear_function = server_clear_function; | ||||||
| 		} |     } else { | ||||||
| 		else |  | ||||||
| 		{ |  | ||||||
|         assert(program_mode == client_mode); |         assert(program_mode == client_mode); | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  |  | ||||||
| 	conn_info_t::conn_info_t(const conn_info_t&b) | conn_info_t::conn_info_t(const conn_info_t &b) { | ||||||
| 	{ |  | ||||||
|     assert(0 == 1); |     assert(0 == 1); | ||||||
|     // mylog(log_error,"called!!!!!!!!!!!!!\n"); |     // mylog(log_error,"called!!!!!!!!!!!!!\n"); | ||||||
| } | } | ||||||
|  |  | ||||||
| 	conn_info_t& conn_info_t::operator=(const conn_info_t& b) | conn_info_t &conn_info_t::operator=(const conn_info_t &b) { | ||||||
| 	  { |  | ||||||
|     mylog(log_fatal, "not allowed\n"); |     mylog(log_fatal, "not allowed\n"); | ||||||
|     myexit(-1); |     myexit(-1); | ||||||
|     return *this; |     return *this; | ||||||
| } | } | ||||||
| 	conn_info_t::~conn_info_t() | conn_info_t::~conn_info_t() { | ||||||
| 	{ |     if (program_mode == server_mode) { | ||||||
| 		if(program_mode==server_mode) |         if (state.server_current_state == server_ready) { | ||||||
| 		{ |  | ||||||
| 			if(state.server_current_state==server_ready) |  | ||||||
| 			{ |  | ||||||
|             assert(blob != 0); |             assert(blob != 0); | ||||||
|             assert(oppsite_const_id != 0); |             assert(oppsite_const_id != 0); | ||||||
|             // assert(conn_manager.const_id_mp.find(oppsite_const_id)!=conn_manager.const_id_mp.end()); // conn_manager 's deconstuction function  erases it |             // assert(conn_manager.const_id_mp.find(oppsite_const_id)!=conn_manager.const_id_mp.end()); // conn_manager 's deconstuction function  erases it | ||||||
| 			} |         } else { | ||||||
| 			else |  | ||||||
| 			{ |  | ||||||
|             assert(blob == 0); |             assert(blob == 0); | ||||||
|             assert(oppsite_const_id == 0); |             assert(oppsite_const_id == 0); | ||||||
|         } |         } | ||||||
| @@ -166,9 +138,7 @@ conn_manager_t conn_manager; | |||||||
|     // send_packet_info.protocol=g_packet_info_send.protocol; |     // send_packet_info.protocol=g_packet_info_send.protocol; | ||||||
| } | } | ||||||
|  |  | ||||||
|  | conn_manager_t::conn_manager_t() { | ||||||
| 	conn_manager_t::conn_manager_t() |  | ||||||
|  { |  | ||||||
|     ready_num = 0; |     ready_num = 0; | ||||||
|     mp.reserve(10007); |     mp.reserve(10007); | ||||||
|     // clear_it=mp.begin(); |     // clear_it=mp.begin(); | ||||||
| @@ -179,14 +149,12 @@ conn_manager_t conn_manager; | |||||||
|     // current_ready_ip=0; |     // current_ready_ip=0; | ||||||
|     // current_ready_port=0; |     // current_ready_port=0; | ||||||
| } | } | ||||||
|  int conn_manager_t::exist(address_t addr) | int conn_manager_t::exist(address_t addr) { | ||||||
|  { |  | ||||||
|     // u64_t u64=0; |     // u64_t u64=0; | ||||||
|     // u64=ip; |     // u64=ip; | ||||||
|     // u64<<=32u; |     // u64<<=32u; | ||||||
|     // u64|=port; |     // u64|=port; | ||||||
| 	 if(mp.find(addr)!=mp.end()) |     if (mp.find(addr) != mp.end()) { | ||||||
| 	 { |  | ||||||
|         return 1; |         return 1; | ||||||
|     } |     } | ||||||
|     return 0; |     return 0; | ||||||
| @@ -208,13 +176,10 @@ conn_manager_t conn_manager; | |||||||
|     // u64<<=32u; |     // u64<<=32u; | ||||||
|     // u64|=port; |     // u64|=port; | ||||||
|     unordered_map<address_t, conn_info_t *>::iterator it = mp.find(addr); |     unordered_map<address_t, conn_info_t *>::iterator it = mp.find(addr); | ||||||
| 	 if(it==mp.end()) |     if (it == mp.end()) { | ||||||
| 	 { |  | ||||||
|         mp[addr] = new conn_info_t; |         mp[addr] = new conn_info_t; | ||||||
|         // lru.new_key(addr); |         // lru.new_key(addr); | ||||||
| 	 } |     } else { | ||||||
| 	 else |  | ||||||
| 	 { |  | ||||||
|         // lru.update(addr); |         // lru.update(addr); | ||||||
|     } |     } | ||||||
|     return mp[addr]; |     return mp[addr]; | ||||||
| @@ -226,21 +191,16 @@ conn_manager_t conn_manager; | |||||||
|     // u64<<=32u; |     // u64<<=32u; | ||||||
|     // u64|=port; |     // u64|=port; | ||||||
|     unordered_map<address_t, conn_info_t *>::iterator it = mp.find(addr); |     unordered_map<address_t, conn_info_t *>::iterator it = mp.find(addr); | ||||||
| 	 if(it==mp.end()) |     if (it == mp.end()) { | ||||||
| 	 { |  | ||||||
|         mp[addr] = new conn_info_t; |         mp[addr] = new conn_info_t; | ||||||
|         // lru.new_key(addr); |         // lru.new_key(addr); | ||||||
| 	 } |     } else { | ||||||
| 	 else |  | ||||||
| 	 { |  | ||||||
|         // lru.update(addr); |         // lru.update(addr); | ||||||
|     } |     } | ||||||
|     return *mp[addr]; |     return *mp[addr]; | ||||||
| } | } | ||||||
|  int conn_manager_t::erase(unordered_map<address_t,conn_info_t*>::iterator erase_it) | int conn_manager_t::erase(unordered_map<address_t, conn_info_t *>::iterator erase_it) { | ||||||
|  { |     if (erase_it->second->state.server_current_state == server_ready) { | ||||||
| 		if(erase_it->second->state.server_current_state==server_ready) |  | ||||||
| 		{ |  | ||||||
|         ready_num--; |         ready_num--; | ||||||
|         assert(i32_t(ready_num) != -1); |         assert(i32_t(ready_num) != -1); | ||||||
|         assert(erase_it->second != 0); |         assert(erase_it->second != 0); | ||||||
| @@ -252,7 +212,6 @@ conn_manager_t conn_manager; | |||||||
|         assert(erase_it->second->oppsite_const_id != 0); |         assert(erase_it->second->oppsite_const_id != 0); | ||||||
|         assert(const_id_mp.find(erase_it->second->oppsite_const_id) != const_id_mp.end()); |         assert(const_id_mp.find(erase_it->second->oppsite_const_id) != const_id_mp.end()); | ||||||
|  |  | ||||||
|  |  | ||||||
|         // assert(timer_fd_mp.find(erase_it->second->timer_fd)!=timer_fd_mp.end()); |         // assert(timer_fd_mp.find(erase_it->second->timer_fd)!=timer_fd_mp.end()); | ||||||
|  |  | ||||||
|         const_id_mp.erase(erase_it->second->oppsite_const_id); |         const_id_mp.erase(erase_it->second->oppsite_const_id); | ||||||
| @@ -264,30 +223,24 @@ conn_manager_t conn_manager; | |||||||
|         // close(erase_it->second->timer_fd);// close will auto delte it from epoll |         // close(erase_it->second->timer_fd);// close will auto delte it from epoll | ||||||
|         delete (erase_it->second); |         delete (erase_it->second); | ||||||
|         mp.erase(erase_it->first); |         mp.erase(erase_it->first); | ||||||
| 		} |     } else { | ||||||
| 		else |  | ||||||
| 		{ |  | ||||||
|         assert(erase_it->second->blob == 0); |         assert(erase_it->second->blob == 0); | ||||||
|         assert(erase_it->second->timer_fd64 == 0); |         assert(erase_it->second->timer_fd64 == 0); | ||||||
|  |  | ||||||
|  |  | ||||||
|         assert(erase_it->second->oppsite_const_id == 0); |         assert(erase_it->second->oppsite_const_id == 0); | ||||||
|         delete (erase_it->second); |         delete (erase_it->second); | ||||||
|         mp.erase(erase_it->first); |         mp.erase(erase_it->first); | ||||||
|     } |     } | ||||||
|     return 0; |     return 0; | ||||||
| } | } | ||||||
| int conn_manager_t::clear_inactive() | int conn_manager_t::clear_inactive() { | ||||||
| { |     if (get_current_time() - last_clear_time > conn_clear_interval) { | ||||||
| 	if(get_current_time()-last_clear_time>conn_clear_interval) |  | ||||||
| 	{ |  | ||||||
|         last_clear_time = get_current_time(); |         last_clear_time = get_current_time(); | ||||||
|         return clear_inactive0(); |         return clear_inactive0(); | ||||||
|     } |     } | ||||||
|     return 0; |     return 0; | ||||||
| } | } | ||||||
| int conn_manager_t::clear_inactive0() | int conn_manager_t::clear_inactive0() { | ||||||
| { |  | ||||||
|     unordered_map<address_t, conn_info_t *>::iterator it; |     unordered_map<address_t, conn_info_t *>::iterator it; | ||||||
|     unordered_map<address_t, conn_info_t *>::iterator old_it; |     unordered_map<address_t, conn_info_t *>::iterator old_it; | ||||||
|  |  | ||||||
| @@ -304,31 +257,22 @@ int conn_manager_t::clear_inactive0() | |||||||
|     num_to_clean = min(num_to_clean, (int)mp.size()); |     num_to_clean = min(num_to_clean, (int)mp.size()); | ||||||
|     u64_t current_time = get_current_time(); |     u64_t current_time = get_current_time(); | ||||||
|  |  | ||||||
| 	for(;;) |     for (;;) { | ||||||
| 	{ |  | ||||||
|         if (cnt >= num_to_clean) break; |         if (cnt >= num_to_clean) break; | ||||||
|         if (mp.begin() == mp.end()) break; |         if (mp.begin() == mp.end()) break; | ||||||
|  |  | ||||||
| 		if(it==mp.end()) |         if (it == mp.end()) { | ||||||
| 		{ |  | ||||||
|             it = mp.begin(); |             it = mp.begin(); | ||||||
|         } |         } | ||||||
|  |  | ||||||
| 		if(it->second->state.server_current_state==server_ready &¤t_time - it->second->last_hb_recv_time  <=server_conn_timeout) |         if (it->second->state.server_current_state == server_ready && current_time - it->second->last_hb_recv_time <= server_conn_timeout) { | ||||||
| 		{ |  | ||||||
|             it++; |             it++; | ||||||
| 		} |         } else if (it->second->state.server_current_state != server_ready && current_time - it->second->last_state_time <= server_handshake_timeout) { | ||||||
| 		else if(it->second->state.server_current_state!=server_ready&& current_time - it->second->last_state_time  <=server_handshake_timeout ) |  | ||||||
| 		{ |  | ||||||
|             it++; |             it++; | ||||||
| 		} |         } else if (it->second->blob != 0 && it->second->blob->conv_manager.s.get_size() > 0) { | ||||||
| 		else if(it->second->blob!=0&&it->second->blob->conv_manager.s.get_size() >0) |  | ||||||
| 		{ |  | ||||||
|             assert(it->second->state.server_current_state == server_ready); |             assert(it->second->state.server_current_state == server_ready); | ||||||
|             it++; |             it++; | ||||||
| 		} |         } else { | ||||||
| 		else |  | ||||||
| 		{ |  | ||||||
|             mylog(log_info, "[%s:%d]inactive conn cleared \n", it->second->raw_info.recv_info.new_src_ip.get_str1(), it->second->raw_info.recv_info.src_port); |             mylog(log_info, "[%s:%d]inactive conn cleared \n", it->second->raw_info.recv_info.new_src_ip.get_str1(), it->second->raw_info.recv_info.src_port); | ||||||
|             old_it = it; |             old_it = it; | ||||||
|             it++; |             it++; | ||||||
| @@ -341,13 +285,10 @@ int conn_manager_t::clear_inactive0() | |||||||
|     return 0; |     return 0; | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| int send_bare(raw_info_t &raw_info, const char *data, int len)  // send function with encryption but no anti replay,this is used when client and server verifys each other | int send_bare(raw_info_t &raw_info, const char *data, int len)  // send function with encryption but no anti replay,this is used when client and server verifys each other | ||||||
| // you have to design the protocol carefully, so that you wont be affect by relay attack | // you have to design the protocol carefully, so that you wont be affect by relay attack | ||||||
| { | { | ||||||
| 	if(len<0) |     if (len < 0) { | ||||||
| 	{ |  | ||||||
|         mylog(log_debug, "input_len <0\n"); |         mylog(log_debug, "input_len <0\n"); | ||||||
|         return -1; |         return -1; | ||||||
|     } |     } | ||||||
| @@ -357,7 +298,6 @@ int send_bare(raw_info_t &raw_info,const char* data,int len)//send function with | |||||||
|     char send_data_buf[buf_len];  // buf for send data and send hb |     char send_data_buf[buf_len];  // buf for send data and send hb | ||||||
|     char send_data_buf2[buf_len]; |     char send_data_buf2[buf_len]; | ||||||
|  |  | ||||||
|  |  | ||||||
|     // static send_bare[buf_len]; |     // static send_bare[buf_len]; | ||||||
|     iv_t iv = get_true_random_number_64(); |     iv_t iv = get_true_random_number_64(); | ||||||
|     padding_t padding = get_true_random_number_64(); |     padding_t padding = get_true_random_number_64(); | ||||||
| @@ -369,8 +309,7 @@ int send_bare(raw_info_t &raw_info,const char* data,int len)//send function with | |||||||
|     memcpy(send_data_buf + sizeof(iv) + sizeof(padding) + 1, data, len); |     memcpy(send_data_buf + sizeof(iv) + sizeof(padding) + 1, data, len); | ||||||
|     int new_len = len + sizeof(iv) + sizeof(padding) + 1; |     int new_len = len + sizeof(iv) + sizeof(padding) + 1; | ||||||
|  |  | ||||||
| 	if(my_encrypt(send_data_buf,send_data_buf2,new_len)!=0) |     if (my_encrypt(send_data_buf, send_data_buf2, new_len) != 0) { | ||||||
| 	{ |  | ||||||
|         return -1; |         return -1; | ||||||
|     } |     } | ||||||
|     send_raw0(raw_info, send_data_buf2, new_len); |     send_raw0(raw_info, send_data_buf2, new_len); | ||||||
| @@ -380,26 +319,22 @@ int reserved_parse_bare(const char *input,int input_len,char* & data,int & len) | |||||||
| { | { | ||||||
|     static char recv_data_buf[buf_len]; |     static char recv_data_buf[buf_len]; | ||||||
|  |  | ||||||
| 	if(input_len<0) |     if (input_len < 0) { | ||||||
| 	{ |  | ||||||
|         mylog(log_debug, "input_len <0\n"); |         mylog(log_debug, "input_len <0\n"); | ||||||
|         return -1; |         return -1; | ||||||
|     } |     } | ||||||
| 	if(my_decrypt(input,recv_data_buf,input_len)!=0) |     if (my_decrypt(input, recv_data_buf, input_len) != 0) { | ||||||
| 	{ |  | ||||||
|         mylog(log_debug, "decrypt_fail in recv bare\n"); |         mylog(log_debug, "decrypt_fail in recv bare\n"); | ||||||
|         return -1; |         return -1; | ||||||
|     } |     } | ||||||
| 	if(recv_data_buf[sizeof(iv_t)+sizeof(padding_t)]!='b') |     if (recv_data_buf[sizeof(iv_t) + sizeof(padding_t)] != 'b') { | ||||||
| 	{ |  | ||||||
|         mylog(log_debug, "not a bare packet\n"); |         mylog(log_debug, "not a bare packet\n"); | ||||||
|         return -1; |         return -1; | ||||||
|     } |     } | ||||||
|     len = input_len; |     len = input_len; | ||||||
|     data = recv_data_buf + sizeof(iv_t) + sizeof(padding_t) + 1; |     data = recv_data_buf + sizeof(iv_t) + sizeof(padding_t) + 1; | ||||||
|     len -= sizeof(iv_t) + sizeof(padding_t) + 1; |     len -= sizeof(iv_t) + sizeof(padding_t) + 1; | ||||||
| 	if(len<0) |     if (len < 0) { | ||||||
| 	{ |  | ||||||
|         mylog(log_debug, "len <0\n"); |         mylog(log_debug, "len <0\n"); | ||||||
|         return -1; |         return -1; | ||||||
|     } |     } | ||||||
| @@ -411,14 +346,18 @@ int recv_bare(raw_info_t &raw_info,char* & data,int & len)//recv function with e | |||||||
|     packet_info_t &send_info = raw_info.send_info; |     packet_info_t &send_info = raw_info.send_info; | ||||||
|     packet_info_t &recv_info = raw_info.recv_info; |     packet_info_t &recv_info = raw_info.recv_info; | ||||||
|  |  | ||||||
| 	if(recv_raw0(raw_info,data,len)<0) |     if (recv_raw0(raw_info, data, len) < 0) { | ||||||
| 	{ |  | ||||||
|         // printf("recv_raw_fail in recv bare\n"); |         // printf("recv_raw_fail in recv bare\n"); | ||||||
|         return -1; |         return -1; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     if (len >= max_data_len + 1) { | ||||||
|  |         mylog(log_debug, "data_len=%d >= max_data_len+1,ignored", len); | ||||||
|  |         return -1; | ||||||
|  |     } | ||||||
|  |  | ||||||
|     mylog(log_trace, "data len=%d\n", len); |     mylog(log_trace, "data len=%d\n", len); | ||||||
| 	if ((raw_mode == mode_faketcp && (recv_info.syn == 1 || recv_info.ack != 1))) |     if ((raw_mode == mode_faketcp && (recv_info.syn == 1 || recv_info.ack != 1))) { | ||||||
| 	{ |  | ||||||
|         mylog(log_debug, "unexpect packet type recv_info.syn=%d recv_info.ack=%d \n", recv_info.syn, recv_info.ack); |         mylog(log_debug, "unexpect packet type recv_info.syn=%d recv_info.ack=%d \n", recv_info.syn, recv_info.ack); | ||||||
|         return -1; |         return -1; | ||||||
|     } |     } | ||||||
| @@ -430,10 +369,14 @@ int send_handshake(raw_info_t &raw_info,my_id_t id1,my_id_t id2,my_id_t id3)// a | |||||||
|     packet_info_t &send_info = raw_info.send_info; |     packet_info_t &send_info = raw_info.send_info; | ||||||
|     packet_info_t &recv_info = raw_info.recv_info; |     packet_info_t &recv_info = raw_info.recv_info; | ||||||
|  |  | ||||||
| 	char * data;int len; |     char *data; | ||||||
|  |     int len; | ||||||
|     // len=sizeof(id_t)*3; |     // len=sizeof(id_t)*3; | ||||||
|     if (numbers_to_char(id1, id2, id3, data, len) != 0) return -1; |     if (numbers_to_char(id1, id2, id3, data, len) != 0) return -1; | ||||||
| 	if(send_bare(raw_info,data,len)!=0) {mylog(log_warn,"send bare fail\n");return -1;} |     if (send_bare(raw_info, data, len) != 0) { | ||||||
|  |         mylog(log_warn, "send bare fail\n"); | ||||||
|  |         return -1; | ||||||
|  |     } | ||||||
|     return 0; |     return 0; | ||||||
| } | } | ||||||
| /* | /* | ||||||
| @@ -449,17 +392,14 @@ int recv_handshake(packet_info_t &info,id_t &id1,id_t &id2,id_t &id3) | |||||||
|  |  | ||||||
| int send_safer(conn_info_t &conn_info, char type, const char *data, int len)  // safer transfer function with anti-replay,when mutually verification is done. | int send_safer(conn_info_t &conn_info, char type, const char *data, int len)  // safer transfer function with anti-replay,when mutually verification is done. | ||||||
| { | { | ||||||
|  |  | ||||||
|     packet_info_t &send_info = conn_info.raw_info.send_info; |     packet_info_t &send_info = conn_info.raw_info.send_info; | ||||||
|     packet_info_t &recv_info = conn_info.raw_info.recv_info; |     packet_info_t &recv_info = conn_info.raw_info.recv_info; | ||||||
|  |  | ||||||
| 	if(type!='h'&&type!='d') |     if (type != 'h' && type != 'd') { | ||||||
| 	{ |  | ||||||
|         mylog(log_warn, "first byte is not h or d  ,%x\n", type); |         mylog(log_warn, "first byte is not h or d  ,%x\n", type); | ||||||
|         return -1; |         return -1; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |  | ||||||
|     char send_data_buf[buf_len];  // buf for send data and send hb |     char send_data_buf[buf_len];  // buf for send data and send hb | ||||||
|     char send_data_buf2[buf_len]; |     char send_data_buf2[buf_len]; | ||||||
|  |  | ||||||
| @@ -475,7 +415,6 @@ int send_safer(conn_info_t &conn_info,char type,const char* data,int len)  //saf | |||||||
|  |  | ||||||
|     memcpy(send_data_buf + sizeof(n_tmp_id) * 2, &n_seq, sizeof(n_seq)); |     memcpy(send_data_buf + sizeof(n_tmp_id) * 2, &n_seq, sizeof(n_seq)); | ||||||
|  |  | ||||||
|  |  | ||||||
|     send_data_buf[sizeof(n_tmp_id) * 2 + sizeof(n_seq)] = type; |     send_data_buf[sizeof(n_tmp_id) * 2 + sizeof(n_seq)] = type; | ||||||
|     send_data_buf[sizeof(n_tmp_id) * 2 + sizeof(n_seq) + 1] = conn_info.my_roller; |     send_data_buf[sizeof(n_tmp_id) * 2 + sizeof(n_seq) + 1] = conn_info.my_roller; | ||||||
|  |  | ||||||
| @@ -483,33 +422,24 @@ int send_safer(conn_info_t &conn_info,char type,const char* data,int len)  //saf | |||||||
|  |  | ||||||
|     int new_len = len + sizeof(n_seq) + sizeof(n_tmp_id) * 2 + 2; |     int new_len = len + sizeof(n_seq) + sizeof(n_tmp_id) * 2 + 2; | ||||||
|  |  | ||||||
| 	if(g_fix_gro==0) |     if (g_fix_gro == 0) { | ||||||
|     { |         if (my_encrypt(send_data_buf, send_data_buf2, new_len) != 0) { | ||||||
|         if (my_encrypt(send_data_buf, send_data_buf2, new_len) != 0) |  | ||||||
|         { |  | ||||||
|             return -1; |             return -1; | ||||||
|         } |         } | ||||||
|     } |     } else { | ||||||
| 	else |         if (my_encrypt(send_data_buf, send_data_buf2 + 2, new_len) != 0) { | ||||||
|     { |  | ||||||
|         if (my_encrypt(send_data_buf, send_data_buf2+2, new_len) != 0) |  | ||||||
|         { |  | ||||||
|             return -1; |             return -1; | ||||||
|         } |         } | ||||||
|         write_u16(send_data_buf2, new_len); |         write_u16(send_data_buf2, new_len); | ||||||
|         new_len += 2; |         new_len += 2; | ||||||
| 	if(cipher_mode==cipher_xor) |         if (cipher_mode == cipher_xor) { | ||||||
| 	{ |  | ||||||
|             send_data_buf2[0] ^= gro_xor[0]; |             send_data_buf2[0] ^= gro_xor[0]; | ||||||
|             send_data_buf2[1] ^= gro_xor[1]; |             send_data_buf2[1] ^= gro_xor[1]; | ||||||
| 	} |         } else if (cipher_mode == cipher_aes128cbc || cipher_mode == cipher_aes128cfb) { | ||||||
| 	else if(cipher_mode==cipher_aes128cbc||cipher_mode==cipher_aes128cbc) |  | ||||||
| 	{ |  | ||||||
|             aes_ecb_encrypt1(send_data_buf2); |             aes_ecb_encrypt1(send_data_buf2); | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |  | ||||||
|     if (send_raw0(conn_info.raw_info, send_data_buf2, new_len) != 0) return -1; |     if (send_raw0(conn_info.raw_info, send_data_buf2, new_len) != 0) return -1; | ||||||
|  |  | ||||||
|     if (after_send_raw0(conn_info.raw_info) != 0) return -1; |     if (after_send_raw0(conn_info.raw_info) != 0) return -1; | ||||||
| @@ -530,21 +460,17 @@ int send_data_safer(conn_info_t &conn_info,const char* data,int len,u32_t conv_n | |||||||
|     int new_len = len + sizeof(n_conv_num); |     int new_len = len + sizeof(n_conv_num); | ||||||
|     send_safer(conn_info, 'd', send_data_buf, new_len); |     send_safer(conn_info, 'd', send_data_buf, new_len); | ||||||
|     return 0; |     return 0; | ||||||
|  |  | ||||||
| } | } | ||||||
| int reserved_parse_safer(conn_info_t &conn_info, const char *input, int input_len, char &type, char *&data, int &len)  // subfunction for recv_safer,allow overlap | int reserved_parse_safer(conn_info_t &conn_info, const char *input, int input_len, char &type, char *&data, int &len)  // subfunction for recv_safer,allow overlap | ||||||
| { | { | ||||||
|     static char recv_data_buf[buf_len]; |     static char recv_data_buf[buf_len]; | ||||||
|  |  | ||||||
|     // char *recv_data_buf=recv_data_buf0; //fix strict alias warning |     // char *recv_data_buf=recv_data_buf0; //fix strict alias warning | ||||||
| 	if(my_decrypt(input,recv_data_buf,input_len)!=0) |     if (my_decrypt(input, recv_data_buf, input_len) != 0) { | ||||||
| 	{ |  | ||||||
|         // printf("decrypt fail\n"); |         // printf("decrypt fail\n"); | ||||||
|         return -1; |         return -1; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|     // char *a=recv_data_buf; |     // char *a=recv_data_buf; | ||||||
|     // id_t h_oppiste_id= ntohl (  *((id_t * )(recv_data_buf)) ); |     // id_t h_oppiste_id= ntohl (  *((id_t * )(recv_data_buf)) ); | ||||||
|     my_id_t h_oppsite_id; |     my_id_t h_oppsite_id; | ||||||
| @@ -561,8 +487,7 @@ int reserved_parse_safer(conn_info_t &conn_info,const char * input,int input_len | |||||||
|     memcpy(&h_seq, recv_data_buf + sizeof(my_id_t) * 2, sizeof(h_seq)); |     memcpy(&h_seq, recv_data_buf + sizeof(my_id_t) * 2, sizeof(h_seq)); | ||||||
|     h_seq = ntoh64(h_seq); |     h_seq = ntoh64(h_seq); | ||||||
|  |  | ||||||
| 	if(h_oppsite_id!=conn_info.oppsite_id||h_my_id!=conn_info.my_id) |     if (h_oppsite_id != conn_info.oppsite_id || h_my_id != conn_info.my_id) { | ||||||
| 	{ |  | ||||||
|         mylog(log_debug, "id and oppsite_id verification failed %x %x %x %x \n", h_oppsite_id, conn_info.oppsite_id, h_my_id, conn_info.my_id); |         mylog(log_debug, "id and oppsite_id verification failed %x %x %x %x \n", h_oppsite_id, conn_info.oppsite_id, h_my_id, conn_info.my_id); | ||||||
|         return -1; |         return -1; | ||||||
|     } |     } | ||||||
| @@ -576,46 +501,37 @@ int reserved_parse_safer(conn_info_t &conn_info,const char * input,int input_len | |||||||
|     data = recv_data_buf + sizeof(anti_replay_seq_t) + sizeof(my_id_t) * 2; |     data = recv_data_buf + sizeof(anti_replay_seq_t) + sizeof(my_id_t) * 2; | ||||||
|     len = input_len - (sizeof(anti_replay_seq_t) + sizeof(my_id_t) * 2); |     len = input_len - (sizeof(anti_replay_seq_t) + sizeof(my_id_t) * 2); | ||||||
|  |  | ||||||
|  |     if (data[0] != 'h' && data[0] != 'd') { | ||||||
| 	if(data[0]!='h'&&data[0]!='d') |  | ||||||
| 	{ |  | ||||||
|         mylog(log_debug, "first byte is not h or d  ,%x\n", data[0]); |         mylog(log_debug, "first byte is not h or d  ,%x\n", data[0]); | ||||||
|         return -1; |         return -1; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     uint8_t roller = data[1]; |     uint8_t roller = data[1]; | ||||||
|  |  | ||||||
|  |  | ||||||
|     type = data[0]; |     type = data[0]; | ||||||
|     data += 2; |     data += 2; | ||||||
|     len -= 2; |     len -= 2; | ||||||
|  |  | ||||||
| 	if(len<0) |     if (len < 0) { | ||||||
| 	{ |  | ||||||
|         mylog(log_debug, "len <0 ,%d\n", len); |         mylog(log_debug, "len <0 ,%d\n", len); | ||||||
|         return -1; |         return -1; | ||||||
|     } |     } | ||||||
|  |  | ||||||
| 	if(roller!=conn_info.oppsite_roller) |     if (roller != conn_info.oppsite_roller) { | ||||||
| 	{ |  | ||||||
|         conn_info.oppsite_roller = roller; |         conn_info.oppsite_roller = roller; | ||||||
|         conn_info.last_oppsite_roller_time = get_current_time(); |         conn_info.last_oppsite_roller_time = get_current_time(); | ||||||
|     } |     } | ||||||
|     if (hb_mode == 0) |     if (hb_mode == 0) | ||||||
|         conn_info.my_roller++;  // increase on a successful recv |         conn_info.my_roller++;  // increase on a successful recv | ||||||
| 	else if(hb_mode==1) |     else if (hb_mode == 1) { | ||||||
| 	{ |  | ||||||
|         if (type == 'h') |         if (type == 'h') | ||||||
|             conn_info.my_roller++; |             conn_info.my_roller++; | ||||||
| 	} |     } else { | ||||||
| 	else |  | ||||||
| 	{ |  | ||||||
|         mylog(log_fatal, "unknow hb_mode\n"); |         mylog(log_fatal, "unknow hb_mode\n"); | ||||||
|         myexit(-1); |         myexit(-1); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     if (after_recv_raw0(conn_info.raw_info) != 0) return -1;  // TODO might need to move this function to somewhere else after --fix-gro is introduced | ||||||
| 	if(after_recv_raw0(conn_info.raw_info)!=0) return -1; |  | ||||||
|  |  | ||||||
|     return 0; |     return 0; | ||||||
| } | } | ||||||
| @@ -624,7 +540,8 @@ int recv_safer_notused(conn_info_t &conn_info,char &type,char* &data,int &len)// | |||||||
|     packet_info_t &send_info = conn_info.raw_info.send_info; |     packet_info_t &send_info = conn_info.raw_info.send_info; | ||||||
|     packet_info_t &recv_info = conn_info.raw_info.recv_info; |     packet_info_t &recv_info = conn_info.raw_info.recv_info; | ||||||
|  |  | ||||||
| 	char * recv_data;int recv_len; |     char *recv_data; | ||||||
|  |     int recv_len; | ||||||
|     // static char recv_data_buf[buf_len]; |     // static char recv_data_buf[buf_len]; | ||||||
|  |  | ||||||
|     if (recv_raw0(conn_info.raw_info, recv_data, recv_len) != 0) return -1; |     if (recv_raw0(conn_info.raw_info, recv_data, recv_len) != 0) return -1; | ||||||
| @@ -637,7 +554,8 @@ int recv_safer_multi(conn_info_t &conn_info,vector<char> &type_arr,vector<string | |||||||
|     packet_info_t &send_info = conn_info.raw_info.send_info; |     packet_info_t &send_info = conn_info.raw_info.send_info; | ||||||
|     packet_info_t &recv_info = conn_info.raw_info.recv_info; |     packet_info_t &recv_info = conn_info.raw_info.recv_info; | ||||||
|  |  | ||||||
|     char * recv_data;int recv_len; |     char *recv_data; | ||||||
|  |     int recv_len; | ||||||
|     assert(type_arr.empty()); |     assert(type_arr.empty()); | ||||||
|     assert(data_arr.empty()); |     assert(data_arr.empty()); | ||||||
|  |  | ||||||
| @@ -647,55 +565,45 @@ int recv_safer_multi(conn_info_t &conn_info,vector<char> &type_arr,vector<string | |||||||
|     char *data; |     char *data; | ||||||
|     int len; |     int len; | ||||||
|  |  | ||||||
|     if(g_fix_gro==0) |     if (g_fix_gro == 0) { | ||||||
|     { |  | ||||||
|         int ret = reserved_parse_safer(conn_info, recv_data, recv_len, type, data, len); |         int ret = reserved_parse_safer(conn_info, recv_data, recv_len, type, data, len); | ||||||
|         if(ret==0) |         if (ret == 0) { | ||||||
|         { |  | ||||||
|             type_arr.push_back(type); |             type_arr.push_back(type); | ||||||
|             data_arr.emplace_back(data, data + len); |             data_arr.emplace_back(data, data + len); | ||||||
|             // std::copy(data,data+len,data_arr[0]); |             // std::copy(data,data+len,data_arr[0]); | ||||||
|         } |         } | ||||||
|         return 0; |         return 0; | ||||||
|     } else |     } else { | ||||||
|     { |  | ||||||
|         char *ori_recv_data = recv_data; |         char *ori_recv_data = recv_data; | ||||||
|         int ori_recv_len = recv_len; |         int ori_recv_len = recv_len; | ||||||
|         // mylog(log_debug,"recv_len:%d\n",recv_len); |         // mylog(log_debug,"recv_len:%d\n",recv_len); | ||||||
|         int cnt = 0; |         int cnt = 0; | ||||||
|         while(recv_len>=16) |         while (recv_len >= 16) { | ||||||
|         { |  | ||||||
|             cnt++; |             cnt++; | ||||||
|             int single_len_no_xor; |             int single_len_no_xor; | ||||||
|             single_len_no_xor = read_u16(recv_data); |             single_len_no_xor = read_u16(recv_data); | ||||||
|             int single_len; |             int single_len; | ||||||
| 	    if(cipher_mode==cipher_xor) |             if (cipher_mode == cipher_xor) { | ||||||
| 	    { |  | ||||||
|                 recv_data[0] ^= gro_xor[0]; |                 recv_data[0] ^= gro_xor[0]; | ||||||
|                 recv_data[1] ^= gro_xor[1]; |                 recv_data[1] ^= gro_xor[1]; | ||||||
| 	    } |             } else if (cipher_mode == cipher_aes128cbc || cipher_mode == cipher_aes128cfb) { | ||||||
| 	    else if(cipher_mode==cipher_aes128cbc||cipher_mode==cipher_aes128cbc) |  | ||||||
| 	    { |  | ||||||
|                 aes_ecb_decrypt1(recv_data); |                 aes_ecb_decrypt1(recv_data); | ||||||
|             } |             } | ||||||
|             single_len = read_u16(recv_data); |             single_len = read_u16(recv_data); | ||||||
|             recv_len -= 2; |             recv_len -= 2; | ||||||
|             recv_data += 2; |             recv_data += 2; | ||||||
|             if(single_len > recv_len) |             if (single_len > recv_len) { | ||||||
|             { |  | ||||||
|                 mylog(log_debug, "illegal single_len %d(%d), recv_len %d left,dropped\n", single_len, single_len_no_xor, recv_len); |                 mylog(log_debug, "illegal single_len %d(%d), recv_len %d left,dropped\n", single_len, single_len_no_xor, recv_len); | ||||||
|                 break; |                 break; | ||||||
|             } |             } | ||||||
|             if(single_len> max_data_len ) |             if (single_len > max_data_len) { | ||||||
|             { |  | ||||||
|                 mylog(log_warn, "single_len %d(%d) > %d, maybe you need to turn down mtu at upper level\n", single_len, single_len_no_xor, max_data_len); |                 mylog(log_warn, "single_len %d(%d) > %d, maybe you need to turn down mtu at upper level\n", single_len, single_len_no_xor, max_data_len); | ||||||
|                 break; |                 break; | ||||||
|             } |             } | ||||||
|  |  | ||||||
|             int ret = reserved_parse_safer(conn_info, recv_data, single_len, type, data, len); |             int ret = reserved_parse_safer(conn_info, recv_data, single_len, type, data, len); | ||||||
|  |  | ||||||
|             if(ret!=0) |             if (ret != 0) { | ||||||
|             { |  | ||||||
|                 mylog(log_debug, "parse failed, offset= %d,single_len=%d(%d)\n", (int)(recv_data - ori_recv_data), single_len, single_len_no_xor); |                 mylog(log_debug, "parse failed, offset= %d,single_len=%d(%d)\n", (int)(recv_data - ori_recv_data), single_len, single_len_no_xor); | ||||||
|             } else { |             } else { | ||||||
|                 type_arr.push_back(type); |                 type_arr.push_back(type); | ||||||
| @@ -705,15 +613,13 @@ int recv_safer_multi(conn_info_t &conn_info,vector<char> &type_arr,vector<string | |||||||
|             recv_data += single_len; |             recv_data += single_len; | ||||||
|             recv_len -= single_len; |             recv_len -= single_len; | ||||||
|         } |         } | ||||||
|         if(cnt>1) |         if (cnt > 1) { | ||||||
|         { |  | ||||||
|             mylog(log_debug, "got a suspected gro packet, %d packets recovered, recv_len=%d, loop_cnt=%d\n", (int)data_arr.size(), ori_recv_len, cnt); |             mylog(log_debug, "got a suspected gro packet, %d packets recovered, recv_len=%d, loop_cnt=%d\n", (int)data_arr.size(), ori_recv_len, cnt); | ||||||
|         } |         } | ||||||
|         return 0; |         return 0; | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| void server_clear_function(u64_t u64)  // used in conv_manager in server mode.for server we have to use one udp fd for one conv(udp connection), | void server_clear_function(u64_t u64)  // used in conv_manager in server mode.for server we have to use one udp fd for one conv(udp connection), | ||||||
| // so we have to close the fd when conv expires | // so we have to close the fd when conv expires | ||||||
| { | { | ||||||
| @@ -731,7 +637,8 @@ void server_clear_function(u64_t u64)//used in conv_manager in server mode.for s | |||||||
|     { |     { | ||||||
|             mylog(log_fatal,"fd:%d epoll delete failed!!!!\n",fd); |             mylog(log_fatal,"fd:%d epoll delete failed!!!!\n",fd); | ||||||
|             myexit(-1);   //this shouldnt happen |             myexit(-1);   //this shouldnt happen | ||||||
| 	}*/                //no need |     }*/ | ||||||
|  |     // no need | ||||||
|  |  | ||||||
|     /*ret= close(fd);  //closed fd should be auto removed from epoll |     /*ret= close(fd);  //closed fd should be auto removed from epoll | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										96
									
								
								connection.h
									
									
									
									
									
								
							
							
						
						
									
										96
									
								
								connection.h
									
									
									
									
									
								
							| @@ -50,36 +50,29 @@ struct conv_manager_t  // manage the udp connections | |||||||
|  |  | ||||||
|     long long last_clear_time; |     long long last_clear_time; | ||||||
|  |  | ||||||
| 	conv_manager_t() |     conv_manager_t() { | ||||||
| 		{ |  | ||||||
|         // clear_it=conv_last_active_time.begin(); |         // clear_it=conv_last_active_time.begin(); | ||||||
|         long long last_clear_time = 0; |         long long last_clear_time = 0; | ||||||
|         additional_clear_function = 0; |         additional_clear_function = 0; | ||||||
|     } |     } | ||||||
| 	~conv_manager_t() |     ~conv_manager_t() { | ||||||
| 		{ |  | ||||||
|         clear(); |         clear(); | ||||||
|     } |     } | ||||||
| 		int get_size() |     int get_size() { | ||||||
| 		{ |  | ||||||
|         return conv_to_data.size(); |         return conv_to_data.size(); | ||||||
|     } |     } | ||||||
| 		void reserve() |     void reserve() { | ||||||
| 		{ |  | ||||||
|         data_to_conv.reserve(10007); |         data_to_conv.reserve(10007); | ||||||
|         conv_to_data.reserve(10007); |         conv_to_data.reserve(10007); | ||||||
|         // conv_last_active_time.reserve(10007); |         // conv_last_active_time.reserve(10007); | ||||||
|  |  | ||||||
|         lru.mp.reserve(10007); |         lru.mp.reserve(10007); | ||||||
|     } |     } | ||||||
| 		void clear() |     void clear() { | ||||||
| 		{ |  | ||||||
|         if (disable_conv_clear) return; |         if (disable_conv_clear) return; | ||||||
|  |  | ||||||
| 			if(additional_clear_function!=0) |         if (additional_clear_function != 0) { | ||||||
| 			{ |             for (auto it = conv_to_data.begin(); it != conv_to_data.end(); it++) { | ||||||
| 				for(auto it=conv_to_data.begin();it!=conv_to_data.end();it++) |  | ||||||
| 				{ |  | ||||||
|                 // int fd=int((it->second<<32u)>>32u); |                 // int fd=int((it->second<<32u)>>32u); | ||||||
|                 additional_clear_function(it->second); |                 additional_clear_function(it->second); | ||||||
|             } |             } | ||||||
| @@ -91,53 +84,42 @@ struct conv_manager_t  // manage the udp connections | |||||||
|         // conv_last_active_time.clear(); |         // conv_last_active_time.clear(); | ||||||
|  |  | ||||||
|         // clear_it=conv_last_active_time.begin(); |         // clear_it=conv_last_active_time.begin(); | ||||||
|  |  | ||||||
|     } |     } | ||||||
| 		u32_t get_new_conv() |     u32_t get_new_conv() { | ||||||
| 		{ |  | ||||||
|         u32_t conv = get_true_random_number_nz(); |         u32_t conv = get_true_random_number_nz(); | ||||||
| 			while(conv_to_data.find(conv)!=conv_to_data.end()) |         while (conv_to_data.find(conv) != conv_to_data.end()) { | ||||||
| 			{ |  | ||||||
|             conv = get_true_random_number_nz(); |             conv = get_true_random_number_nz(); | ||||||
|         } |         } | ||||||
|         return conv; |         return conv; | ||||||
|     } |     } | ||||||
| 		int is_conv_used(u32_t conv) |     int is_conv_used(u32_t conv) { | ||||||
| 		{ |  | ||||||
|         return conv_to_data.find(conv) != conv_to_data.end(); |         return conv_to_data.find(conv) != conv_to_data.end(); | ||||||
|     } |     } | ||||||
| 		int is_data_used(T data) |     int is_data_used(T data) { | ||||||
| 		{ |  | ||||||
|         return data_to_conv.find(data) != data_to_conv.end(); |         return data_to_conv.find(data) != data_to_conv.end(); | ||||||
|     } |     } | ||||||
| 		u32_t find_conv_by_data(T data) |     u32_t find_conv_by_data(T data) { | ||||||
| 		{ |  | ||||||
|         return data_to_conv[data]; |         return data_to_conv[data]; | ||||||
|     } |     } | ||||||
| 		T find_data_by_conv(u32_t conv) |     T find_data_by_conv(u32_t conv) { | ||||||
| 		{ |  | ||||||
|         return conv_to_data[conv]; |         return conv_to_data[conv]; | ||||||
|     } |     } | ||||||
| 		int update_active_time(u32_t conv) |     int update_active_time(u32_t conv) { | ||||||
| 		{ |  | ||||||
|         // return conv_last_active_time[conv]=get_current_time(); |         // return conv_last_active_time[conv]=get_current_time(); | ||||||
|         lru.update(conv); |         lru.update(conv); | ||||||
|         return 0; |         return 0; | ||||||
|     } |     } | ||||||
| 		int insert_conv(u32_t conv,T data) |     int insert_conv(u32_t conv, T data) { | ||||||
| 		{ |  | ||||||
|         data_to_conv[data] = conv; |         data_to_conv[data] = conv; | ||||||
|         conv_to_data[conv] = data; |         conv_to_data[conv] = data; | ||||||
|         // conv_last_active_time[conv]=get_current_time(); |         // conv_last_active_time[conv]=get_current_time(); | ||||||
|         lru.new_key(conv); |         lru.new_key(conv); | ||||||
|         return 0; |         return 0; | ||||||
|     } |     } | ||||||
| 		int erase_conv(u32_t conv) |     int erase_conv(u32_t conv) { | ||||||
| 		{ |  | ||||||
|         if (disable_conv_clear) return 0; |         if (disable_conv_clear) return 0; | ||||||
|         T data = conv_to_data[conv]; |         T data = conv_to_data[conv]; | ||||||
| 			if(additional_clear_function!=0) |         if (additional_clear_function != 0) { | ||||||
| 			{ |  | ||||||
|             additional_clear_function(data); |             additional_clear_function(data); | ||||||
|         } |         } | ||||||
|         conv_to_data.erase(conv); |         conv_to_data.erase(conv); | ||||||
| @@ -146,20 +128,16 @@ struct conv_manager_t  // manage the udp connections | |||||||
|         lru.erase(conv); |         lru.erase(conv); | ||||||
|         return 0; |         return 0; | ||||||
|     } |     } | ||||||
| 		int clear_inactive(char * info=0) |     int clear_inactive(char *info = 0) { | ||||||
| 		{ |         if (get_current_time() - last_clear_time > conv_clear_interval) { | ||||||
| 			if(get_current_time()-last_clear_time>conv_clear_interval) |  | ||||||
| 			{ |  | ||||||
|             last_clear_time = get_current_time(); |             last_clear_time = get_current_time(); | ||||||
|             return clear_inactive0(info); |             return clear_inactive0(info); | ||||||
|         } |         } | ||||||
|         return 0; |         return 0; | ||||||
|     } |     } | ||||||
| 		int clear_inactive0(char * info) |     int clear_inactive0(char *info) { | ||||||
| 		{ |  | ||||||
|         if (disable_conv_clear) return 0; |         if (disable_conv_clear) return 0; | ||||||
|  |  | ||||||
|  |  | ||||||
|         unordered_map<u32_t, u64_t>::iterator it; |         unordered_map<u32_t, u64_t>::iterator it; | ||||||
|         unordered_map<u32_t, u64_t>::iterator old_it; |         unordered_map<u32_t, u64_t>::iterator old_it; | ||||||
|  |  | ||||||
| @@ -172,8 +150,7 @@ struct conv_manager_t  // manage the udp connections | |||||||
|         num_to_clean = min(num_to_clean, size); |         num_to_clean = min(num_to_clean, size); | ||||||
|  |  | ||||||
|         my_time_t current_time = get_current_time(); |         my_time_t current_time = get_current_time(); | ||||||
| 			for(;;) |         for (;;) { | ||||||
| 			{ |  | ||||||
|             if (cnt >= num_to_clean) break; |             if (cnt >= num_to_clean) break; | ||||||
|             if (lru.empty()) break; |             if (lru.empty()) break; | ||||||
|  |  | ||||||
| @@ -183,12 +160,9 @@ struct conv_manager_t  // manage the udp connections | |||||||
|             if (current_time - ts < conv_timeout) break; |             if (current_time - ts < conv_timeout) break; | ||||||
|  |  | ||||||
|             erase_conv(conv); |             erase_conv(conv); | ||||||
| 				if(info==0) |             if (info == 0) { | ||||||
| 				{ |  | ||||||
|                 mylog(log_info, "conv %x cleared\n", conv); |                 mylog(log_info, "conv %x cleared\n", conv); | ||||||
| 				} |             } else { | ||||||
| 				else |  | ||||||
| 				{ |  | ||||||
|                 mylog(log_info, "[%s]conv %x cleared\n", info, conv); |                 mylog(log_info, "[%s]conv %x cleared\n", info, conv); | ||||||
|             } |             } | ||||||
|             cnt++; |             cnt++; | ||||||
| @@ -196,7 +170,6 @@ struct conv_manager_t  // manage the udp connections | |||||||
|         return 0; |         return 0; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |  | ||||||
|     /* |     /* | ||||||
| conv_manager_t(); | conv_manager_t(); | ||||||
| ~conv_manager_t(); | ~conv_manager_t(); | ||||||
| @@ -222,26 +195,18 @@ struct blob_t:not_copy_able_t //used in conn_info_t. | |||||||
|         conv_manager_t<address_t> c; |         conv_manager_t<address_t> c; | ||||||
|         conv_manager_t<u64_t> s; |         conv_manager_t<u64_t> s; | ||||||
|         // avoid templates here and there, avoid pointer and type cast |         // avoid templates here and there, avoid pointer and type cast | ||||||
| 		tmp_union_t() |         tmp_union_t() { | ||||||
| 		{ |             if (program_mode == client_mode) { | ||||||
| 			if(program_mode==client_mode) |  | ||||||
| 			{ |  | ||||||
|                 new (&c) conv_manager_t<address_t>(); |                 new (&c) conv_manager_t<address_t>(); | ||||||
| 			} |             } else { | ||||||
| 			else |  | ||||||
| 			{ |  | ||||||
|                 assert(program_mode == server_mode); |                 assert(program_mode == server_mode); | ||||||
|                 new (&s) conv_manager_t<u64_t>(); |                 new (&s) conv_manager_t<u64_t>(); | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
| 		~tmp_union_t() |         ~tmp_union_t() { | ||||||
| 		{ |             if (program_mode == client_mode) { | ||||||
| 			if(program_mode==client_mode) |  | ||||||
| 			{ |  | ||||||
|                 c.~conv_manager_t<address_t>(); |                 c.~conv_manager_t<address_t>(); | ||||||
| 			} |             } else { | ||||||
| 			else |  | ||||||
| 			{ |  | ||||||
|                 assert(program_mode == server_mode); |                 assert(program_mode == server_mode); | ||||||
|                 s.~conv_manager_t<u64_t>(); |                 s.~conv_manager_t<u64_t>(); | ||||||
|             } |             } | ||||||
| @@ -264,7 +229,6 @@ struct conn_info_t     //stores info for a raw connection.for client ,there is o | |||||||
|     my_id_t my_id; |     my_id_t my_id; | ||||||
|     my_id_t oppsite_id; |     my_id_t oppsite_id; | ||||||
|  |  | ||||||
|  |  | ||||||
|     fd64_t timer_fd64; |     fd64_t timer_fd64; | ||||||
|     fd64_t udp_fd64; |     fd64_t udp_fd64; | ||||||
|  |  | ||||||
| @@ -294,7 +258,6 @@ struct conn_info_t     //stores info for a raw connection.for client ,there is o | |||||||
|  |  | ||||||
| struct conn_manager_t  // manager for connections. for client,we dont need conn_manager since there is only one connection.for server we use one conn_manager for all connections | struct conn_manager_t  // manager for connections. for client,we dont need conn_manager since there is only one connection.for server we use one conn_manager for all connections | ||||||
| { | { | ||||||
|  |  | ||||||
|     u32_t ready_num; |     u32_t ready_num; | ||||||
|  |  | ||||||
|     // unordered_map<int,conn_info_t *> udp_fd_mp;  //a bit dirty to used pointer,but can void unordered_map search |     // unordered_map<int,conn_info_t *> udp_fd_mp;  //a bit dirty to used pointer,but can void unordered_map search | ||||||
| @@ -328,7 +291,6 @@ struct conn_manager_t  //manager for connections. for client,we dont need conn_m | |||||||
|     int erase(unordered_map<address_t, conn_info_t *>::iterator erase_it); |     int erase(unordered_map<address_t, conn_info_t *>::iterator erase_it); | ||||||
|     int clear_inactive(); |     int clear_inactive(); | ||||||
|     int clear_inactive0(); |     int clear_inactive0(); | ||||||
|  |  | ||||||
| }; | }; | ||||||
|  |  | ||||||
| extern conn_manager_t conn_manager; | extern conn_manager_t conn_manager; | ||||||
|   | |||||||
| @@ -14,21 +14,19 @@ udp2raw tunnel,通过raw socket给UDP包加上TCP或ICMP header,进而绕过 | |||||||
|  |  | ||||||
| **提示:** | **提示:** | ||||||
|  |  | ||||||
| udp2raw不是加速器,只是一个帮助你绕过UDP限制的工具。如果你需要UDP加速器,请看UDPspeeder。 | udp2raw不是加速器,只是一个帮助你绕过UDP限制的工具。如果你需要UDP“加速器” (改善UDP丢包),请看UDPspeeder。 | ||||||
|  |  | ||||||
| UDPspeeder的repo: | UDPspeeder的repo: | ||||||
|  |  | ||||||
| https://github.com/wangyu-/UDPspeeder | https://github.com/wangyu-/UDPspeeder | ||||||
| # 支持的平台 | # 支持的平台 | ||||||
| Linux主机,有root权限。可以是PC、android手机/平板、openwrt路由器、树莓派。主机上最好安装了iptables命令(apt/yum很容易安装)。 | Linux主机,有root权限或cap_net_raw capability.。可以是PC、android手机/平板、openwrt路由器、树莓派。主机上最好安装了iptables命令(apt/yum很容易安装)。 | ||||||
|  |  | ||||||
| Release中提供了`amd64`、`x86`、`arm`、`mips_be`、`mips_le`的预编译binary. | Release中提供了`amd64`、`x86`、`arm`、`mips_be`、`mips_le`的预编译binary. | ||||||
|  |  | ||||||
| ##### 对于windows和mac用户: | ##### 对于windows和mac用户: | ||||||
|  |  | ||||||
| 可以用[这个repo](https://github.com/wangyu-/udp2raw-multiplatform)里的udp2raw,原生运行。 | 可以用[这个repo](https://github.com/wangyu-/udp2raw-multiplatform)里的udp2raw。 | ||||||
|  |  | ||||||
| <del>可以把udp2raw运行在虚拟机上(网络必须是桥接模式)。可以参考: https://github.com/wangyu-/udp2raw-tunnel/wiki/在windows-mac上运行udp2raw客户端,带图形界面 </del> |  | ||||||
|  |  | ||||||
| ##### 对于ios和游戏主机用户: | ##### 对于ios和游戏主机用户: | ||||||
|  |  | ||||||
| @@ -44,10 +42,10 @@ Release中提供了`amd64`、`x86`、`arm`、`mips_be`、`mips_le`的预编译bi | |||||||
| ### 心跳保活、自动重连,连接恢复 | ### 心跳保活、自动重连,连接恢复 | ||||||
| 心跳保活、自动重连,udp2raw重连可以恢复上次的连接,重连后上层连接继续有效,底层掉线上层不掉线。有效解决上层连接断开的问题。 (功能借鉴自[kcptun-raw](https://github.com/Chion82/kcptun-raw))(**就算你拔掉网线重插,或者重新拨号获得新ip,上层应用也不会断线**) | 心跳保活、自动重连,udp2raw重连可以恢复上次的连接,重连后上层连接继续有效,底层掉线上层不掉线。有效解决上层连接断开的问题。 (功能借鉴自[kcptun-raw](https://github.com/Chion82/kcptun-raw))(**就算你拔掉网线重插,或者重新拨号获得新ip,上层应用也不会断线**) | ||||||
|  |  | ||||||
| ### 加密 防重放攻击 | ### 加密、防重放攻击 | ||||||
| 用aes128cbc加密(或更弱的xor),hmac-sha1(或更弱的md5/crc32/simple)做数据完整校验。用类似ipsec/openvpn的replay window机制来防止重放攻击。 | 用aes128cbc加密(或更弱的xor),hmac-sha1(或更弱的md5/crc32/simple)做数据完整校验。用类似ipsec/openvpn的replay window机制来防止重放攻击。 | ||||||
|  |  | ||||||
| 设计目标是,即使攻击者可以监听到tunnel的所有包,可以选择性丢弃tunnel的任意包,可以重放任意包;攻击者也没办法获得tunnel承载的任何数据,也没办法向tunnel的数据流中通过包构造/包重放插入任何数据。 | [Notes on encryption](https://github.com/wangyu-/udp2raw-tunnel/wiki/Notes-on-encryption) | ||||||
|  |  | ||||||
| ### 其他特性 | ### 其他特性 | ||||||
| 信道复用,client的udp端支持多个连接。 | 信道复用,client的udp端支持多个连接。 | ||||||
| @@ -56,7 +54,7 @@ server支持多个client,也能正确处理多个连接的重连和连接恢 | |||||||
|  |  | ||||||
| NAT 穿透 ,tcp icmp udp模式都支持nat穿透。 | NAT 穿透 ,tcp icmp udp模式都支持nat穿透。 | ||||||
|  |  | ||||||
| 支持Openvz,配合finalspeed使用,可以在openvz上用tcp模式的finalspeed | 支持Openvz,配合finalspeed使用,可以在openvz上用tcp模式的finalspeed. | ||||||
|  |  | ||||||
| 支持Openwrt,没有编译依赖,容易编译到任何平台上。 | 支持Openwrt,没有编译依赖,容易编译到任何平台上。 | ||||||
|  |  | ||||||
| @@ -113,10 +111,10 @@ usage: | |||||||
|     run as server : ./this_program -s -l server_listen_ip:server_port -r remote_address:remote_port  [options] |     run as server : ./this_program -s -l server_listen_ip:server_port -r remote_address:remote_port  [options] | ||||||
|  |  | ||||||
| common options,these options must be same on both side: | common options,these options must be same on both side: | ||||||
|     --raw-mode            <string>        avaliable values:faketcp(default),udp,icmp |     --raw-mode            <string>        available values:faketcp(default),udp,icmp | ||||||
|     -k,--key              <string>        password to gen symetric key,default:"secret key" |     -k,--key              <string>        password to gen symetric key,default:"secret key" | ||||||
|     --cipher-mode         <string>        avaliable values:aes128cbc(default),xor,none |     --cipher-mode         <string>        available values:aes128cbc(default),xor,none | ||||||
|     --auth-mode           <string>        avaliable values:hmac_sha1,md5(default),crc32,simple,none |     --auth-mode           <string>        available values:hmac_sha1,md5(default),crc32,simple,none | ||||||
|     -a,--auto-rule                        auto add (and delete) iptables rule |     -a,--auto-rule                        auto add (and delete) iptables rule | ||||||
|     -g,--gen-rule                         generate iptables rule then exit,so that you can copy and |     -g,--gen-rule                         generate iptables rule then exit,so that you can copy and | ||||||
|                                           add it manually.overrides -a |                                           add it manually.overrides -a | ||||||
| @@ -163,7 +161,7 @@ other options: | |||||||
| 如果要最大的安全性建议用aes128cbc+hmac_sha1。如果要运行在路由器上,建议用xor+simple,可以节省CPU。但是注意xor+simple只能骗过防火墙的包检测,不能防止真正的攻击者。 | 如果要最大的安全性建议用aes128cbc+hmac_sha1。如果要运行在路由器上,建议用xor+simple,可以节省CPU。但是注意xor+simple只能骗过防火墙的包检测,不能防止真正的攻击者。 | ||||||
|  |  | ||||||
| ### `--seq-mode` | ### `--seq-mode` | ||||||
| facktcp模式并没有模拟tcp的全部。所以理论上有办法把faketcp和真正的tcp流量区分开来(虽然大部分ISP不太可能做这种程度的包检测)。seq-mode可以改变一些seq ack的行为。如果遇到了连接问题,可以尝试更改。在我这边的移动线路用3种模式都没问题。 | faketcp模式并没有模拟tcp的全部。所以理论上有办法把faketcp和真正的tcp流量区分开来(虽然大部分ISP不太可能做这种程度的包检测)。seq-mode可以改变一些seq ack的行为。如果遇到了连接问题,可以尝试更改。在我这边的移动线路用3种模式都没问题。 | ||||||
|  |  | ||||||
| ### `--keep-rule` | ### `--keep-rule` | ||||||
| 定期主动检查iptables,如果udp2raw添加的iptables规则丢了,就重新添加。在一些iptables可能会被其他程序清空的情况下(比如梅林固件和openwrt的路由器)格外有用。 | 定期主动检查iptables,如果udp2raw添加的iptables规则丢了,就重新添加。在一些iptables可能会被其他程序清空的情况下(比如梅林固件和openwrt的路由器)格外有用。 | ||||||
| @@ -264,25 +262,6 @@ raw_mode: faketcp  cipher_mode: aes128cbc  auth_mode: md5 | |||||||
| [udp2raw+kcptun step_by_step教程](kcptun_step_by_step.md) | [udp2raw+kcptun step_by_step教程](kcptun_step_by_step.md) | ||||||
| ### 中转 finalspeed | ### 中转 finalspeed | ||||||
| [udp2raw+finalspeed step_by_step教程](finalspeed_step_by_step.md) | [udp2raw+finalspeed step_by_step教程](finalspeed_step_by_step.md) | ||||||
| # 如何自己编译 |  | ||||||
| [编译教程](build_guide.zh-cn.md) |  | ||||||
| # 相关repo |  | ||||||
| ### kcptun-raw |  | ||||||
| udp2raw was inspired by kcptun-raw,which modified kcptun to support tcp mode. |  | ||||||
|  |  | ||||||
| https://github.com/Chion82/kcptun-raw |  | ||||||
| ### relayRawSocket |  | ||||||
| kcptun-raw was inspired by relayRawSocket. A simple  udp to raw tunnel,wrote in python |  | ||||||
|  |  | ||||||
| https://github.com/linhua55/some_kcptun_tools/tree/master/relayRawSocket |  | ||||||
| ### kcpraw |  | ||||||
| another project of kcptun with tcp mode |  | ||||||
|  |  | ||||||
| https://github.com/ccsexyz/kcpraw |  | ||||||
| ### icmptunnel |  | ||||||
| Transparently tunnel your IP traffic through ICMP echo and reply packets. |  | ||||||
|  |  | ||||||
| https://github.com/DhavalKapil/icmptunnel |  | ||||||
|  |  | ||||||
| # wiki | # wiki | ||||||
|  |  | ||||||
|   | |||||||
| @@ -8,7 +8,7 @@ the guide on how to build udp2raw | |||||||
| such as PC,raspberry pi | such as PC,raspberry pi | ||||||
|  |  | ||||||
| ##### install git | ##### install git | ||||||
| run on debian/ubuntu: | run on debian/ubuntun: | ||||||
| ``` | ``` | ||||||
| sudo apt-get install git | sudo apt-get install git | ||||||
| ``` | ``` | ||||||
| @@ -18,7 +18,7 @@ sudo yum install git | |||||||
| ``` | ``` | ||||||
| ##### clone git code | ##### clone git code | ||||||
|  |  | ||||||
| run in any dir: | run in any dir: | ||||||
|  |  | ||||||
| ``` | ``` | ||||||
| git clone https://github.com/wangyu-/udp2raw-tunnel.git | git clone https://github.com/wangyu-/udp2raw-tunnel.git | ||||||
| @@ -26,7 +26,7 @@ cd udp2raw-tunnel | |||||||
| ``` | ``` | ||||||
|  |  | ||||||
| ##### install compile tool | ##### install compile tool | ||||||
| run on debian/ubuntu: | run on debian/ubuntun: | ||||||
| ``` | ``` | ||||||
| sudo apt-get install build-essential | sudo apt-get install build-essential | ||||||
| ``` | ``` | ||||||
| @@ -42,7 +42,7 @@ run 'make',compilation done. the udp2raw file is the just compiled binary | |||||||
| such as openwrt router,run following instructions on your PC | such as openwrt router,run following instructions on your PC | ||||||
|  |  | ||||||
| ##### install git | ##### install git | ||||||
| run on debian/ubuntu: | run on debian/ubuntun: | ||||||
| ``` | ``` | ||||||
| sudo apt-get install git | sudo apt-get install git | ||||||
| ``` | ``` | ||||||
|   | |||||||
							
								
								
									
										364
									
								
								encrypt.cpp
									
									
									
									
									
										
										
										Executable file → Normal file
									
								
							
							
						
						
									
										364
									
								
								encrypt.cpp
									
									
									
									
									
										
										
										Executable file → Normal file
									
								
							| @@ -28,9 +28,20 @@ unsigned char cipher_key_decrypt[cipher_key_len + 100];  //key for aes etc. | |||||||
|  |  | ||||||
| char gro_xor[256 + 100];  // dirty fix for gro | char gro_xor[256 + 100];  // dirty fix for gro | ||||||
|  |  | ||||||
| unordered_map<int, const char *> auth_mode_tostring = {{auth_none, "none"}, {auth_md5, "md5"}, {auth_crc32, "crc32"},{auth_simple,"simple"},{auth_hmac_sha1,"hmac_sha1"},}; | unordered_map<int, const char *> auth_mode_tostring = { | ||||||
|  |     {auth_none, "none"}, | ||||||
|  |     {auth_md5, "md5"}, | ||||||
|  |     {auth_crc32, "crc32"}, | ||||||
|  |     {auth_simple, "simple"}, | ||||||
|  |     {auth_hmac_sha1, "hmac_sha1"}, | ||||||
|  | }; | ||||||
|  |  | ||||||
| unordered_map<int, const char *> cipher_mode_tostring={{cipher_none,"none"},{cipher_aes128cfb,"aes128cfb"},{cipher_aes128cbc,"aes128cbc"},{cipher_xor,"xor"},}; | unordered_map<int, const char *> cipher_mode_tostring = { | ||||||
|  |     {cipher_none, "none"}, | ||||||
|  |     {cipher_aes128cfb, "aes128cfb"}, | ||||||
|  |     {cipher_aes128cbc, "aes128cbc"}, | ||||||
|  |     {cipher_xor, "xor"}, | ||||||
|  | }; | ||||||
| // TODO aes-gcm | // TODO aes-gcm | ||||||
|  |  | ||||||
| auth_mode_t auth_mode = auth_md5; | auth_mode_t auth_mode = auth_md5; | ||||||
| @@ -41,8 +52,7 @@ int aes128cfb_old=0; | |||||||
|  |  | ||||||
| // TODO key negotiation and forward secrecy | // TODO key negotiation and forward secrecy | ||||||
|  |  | ||||||
| int my_init_keys(const char * user_passwd,int is_client) | int my_init_keys(const char *user_passwd, int is_client) { | ||||||
| { |  | ||||||
|     char tmp[1000] = ""; |     char tmp[1000] = ""; | ||||||
|     int len = strlen(user_passwd); |     int len = strlen(user_passwd); | ||||||
|  |  | ||||||
| @@ -52,11 +62,9 @@ int my_init_keys(const char * user_passwd,int is_client) | |||||||
|  |  | ||||||
|     md5((uint8_t *)tmp, strlen(tmp), (uint8_t *)normal_key); |     md5((uint8_t *)tmp, strlen(tmp), (uint8_t *)normal_key); | ||||||
|  |  | ||||||
|  |  | ||||||
|     if (auth_mode == auth_hmac_sha1) |     if (auth_mode == auth_hmac_sha1) | ||||||
|         is_hmac_used = 1; |         is_hmac_used = 1; | ||||||
| 	if(is_hmac_used||g_fix_gro||1) |     if (is_hmac_used || g_fix_gro || 1) { | ||||||
| 	{ |  | ||||||
|         unsigned char salt[400] = ""; |         unsigned char salt[400] = ""; | ||||||
|         char salt_text[400] = "udp2raw_salt1"; |         char salt_text[400] = "udp2raw_salt1"; | ||||||
|         md5((uint8_t *)(salt_text), strlen(salt_text), salt);  // TODO different salt per session |         md5((uint8_t *)(salt_text), strlen(salt_text), salt);  // TODO different salt per session | ||||||
| @@ -72,14 +80,15 @@ int my_init_keys(const char * user_passwd,int is_client) | |||||||
|         const char *info_cipher_encrypt = "cipher_key server-->client"; |         const char *info_cipher_encrypt = "cipher_key server-->client"; | ||||||
|         const char *info_cipher_decrypt = "cipher_key client-->server"; |         const char *info_cipher_decrypt = "cipher_key client-->server"; | ||||||
|  |  | ||||||
| 		if(is_client) |         if (is_client) { | ||||||
| 		{ |  | ||||||
|             const char *tmp; |             const char *tmp; | ||||||
| 			tmp=info_hmac_encrypt; info_hmac_encrypt=info_hmac_decrypt;info_hmac_decrypt=tmp; |             tmp = info_hmac_encrypt; | ||||||
| 			tmp=info_cipher_encrypt; info_cipher_encrypt=info_cipher_decrypt;info_cipher_decrypt=tmp; |             info_hmac_encrypt = info_hmac_decrypt; | ||||||
| 		} |             info_hmac_decrypt = tmp; | ||||||
| 		else |             tmp = info_cipher_encrypt; | ||||||
| 		{ |             info_cipher_encrypt = info_cipher_decrypt; | ||||||
|  |             info_cipher_decrypt = tmp; | ||||||
|  |         } else { | ||||||
|             // nop |             // nop | ||||||
|         } |         } | ||||||
|  |  | ||||||
| @@ -143,8 +152,7 @@ void simple_hash(unsigned char *str,int len,unsigned char res[8])   //djb2+ sdbm | |||||||
|     u32_t hash2 = 0; |     u32_t hash2 = 0; | ||||||
|     int c; |     int c; | ||||||
|     int i = 0; |     int i = 0; | ||||||
|     while(c = *str++,i++!=len) |     while (c = *str++, i++ != len) { | ||||||
|     { |  | ||||||
|         // hash = ((hash << 5) + hash) + c; /* hash * 33 + c */ |         // hash = ((hash << 5) + hash) + c; /* hash * 33 + c */ | ||||||
|         hash = ((hash << 5) + hash) ^ c; /* (hash * 33) ^ c */ |         hash = ((hash << 5) + hash) ^ c; /* (hash * 33) ^ c */ | ||||||
|         hash2 = c + (hash2 << 6) + (hash2 << 16) - hash2; |         hash2 = c + (hash2 << 6) + (hash2 << 16) - hash2; | ||||||
| @@ -156,16 +164,14 @@ void simple_hash(unsigned char *str,int len,unsigned char res[8])   //djb2+ sdbm | |||||||
|     memcpy(res + sizeof(hash), &hash2, sizeof(hash2)); |     memcpy(res + sizeof(hash), &hash2, sizeof(hash2)); | ||||||
| } | } | ||||||
|  |  | ||||||
| int auth_md5_cal(const char *data,char * output,int &len) | int auth_md5_cal(const char *data, char *output, int &len) { | ||||||
| { |  | ||||||
|     memcpy(output, data, len);  // TODO inefficient code |     memcpy(output, data, len);  // TODO inefficient code | ||||||
|     md5((unsigned char *)output, len, (unsigned char *)(output + len)); |     md5((unsigned char *)output, len, (unsigned char *)(output + len)); | ||||||
|     len += 16; |     len += 16; | ||||||
|     return 0; |     return 0; | ||||||
| } | } | ||||||
|  |  | ||||||
| int auth_hmac_sha1_cal(const char *data,char * output,int &len) | int auth_hmac_sha1_cal(const char *data, char *output, int &len) { | ||||||
| { |  | ||||||
|     mylog(log_trace, "auth_hmac_sha1_cal() is called\n"); |     mylog(log_trace, "auth_hmac_sha1_cal() is called\n"); | ||||||
|     memcpy(output, data, len);  // TODO inefficient code |     memcpy(output, data, len);  // TODO inefficient code | ||||||
|     sha1_hmac(hmac_key_encrypt, 20, (const unsigned char *)data, len, (unsigned char *)(output + len)); |     sha1_hmac(hmac_key_encrypt, 20, (const unsigned char *)data, len, (unsigned char *)(output + len)); | ||||||
| @@ -174,11 +180,9 @@ int auth_hmac_sha1_cal(const char *data,char * output,int &len) | |||||||
|     return 0; |     return 0; | ||||||
| } | } | ||||||
|  |  | ||||||
| int auth_hmac_sha1_verify(const char *data,int &len) | int auth_hmac_sha1_verify(const char *data, int &len) { | ||||||
| { |  | ||||||
|     mylog(log_trace, "auth_hmac_sha1_verify() is called\n"); |     mylog(log_trace, "auth_hmac_sha1_verify() is called\n"); | ||||||
| 	if(len<20) |     if (len < 20) { | ||||||
| 	{ |  | ||||||
|         mylog(log_trace, "auth_hmac_sha1_verify len<20\n"); |         mylog(log_trace, "auth_hmac_sha1_verify len<20\n"); | ||||||
|         return -1; |         return -1; | ||||||
|     } |     } | ||||||
| @@ -186,8 +190,7 @@ int auth_hmac_sha1_verify(const char *data,int &len) | |||||||
|  |  | ||||||
|     sha1_hmac(hmac_key_decrypt, 20, (const unsigned char *)data, len - 20, (unsigned char *)(res)); |     sha1_hmac(hmac_key_decrypt, 20, (const unsigned char *)data, len - 20, (unsigned char *)(res)); | ||||||
|  |  | ||||||
| 	if(memcmp(res,data+len-20,20)!=0) |     if (memcmp(res, data + len - 20, 20) != 0) { | ||||||
| 	{ |  | ||||||
|         mylog(log_trace, "auth_hmac_sha1 check failed\n"); |         mylog(log_trace, "auth_hmac_sha1 check failed\n"); | ||||||
|         return -2; |         return -2; | ||||||
|     } |     } | ||||||
| @@ -195,8 +198,7 @@ int auth_hmac_sha1_verify(const char *data,int &len) | |||||||
|     return 0; |     return 0; | ||||||
| } | } | ||||||
|  |  | ||||||
| int auth_crc32_cal(const char *data,char * output,int &len) | int auth_crc32_cal(const char *data, char *output, int &len) { | ||||||
| { |  | ||||||
|     memcpy(output, data, len);  // TODO inefficient code |     memcpy(output, data, len);  // TODO inefficient code | ||||||
|     unsigned int ret = crc32h((unsigned char *)output, len); |     unsigned int ret = crc32h((unsigned char *)output, len); | ||||||
|     unsigned int ret_n = htonl(ret); |     unsigned int ret_n = htonl(ret); | ||||||
| @@ -205,16 +207,14 @@ int auth_crc32_cal(const char *data,char * output,int &len) | |||||||
|     return 0; |     return 0; | ||||||
| } | } | ||||||
|  |  | ||||||
| int auth_simple_cal(const char *data,char * output,int &len) | int auth_simple_cal(const char *data, char *output, int &len) { | ||||||
| { |  | ||||||
|     // char res[4]; |     // char res[4]; | ||||||
|     memcpy(output, data, len);  // TODO inefficient code |     memcpy(output, data, len);  // TODO inefficient code | ||||||
|     simple_hash((unsigned char *)output, len, (unsigned char *)(output + len)); |     simple_hash((unsigned char *)output, len, (unsigned char *)(output + len)); | ||||||
|     len += 8; |     len += 8; | ||||||
|     return 0; |     return 0; | ||||||
| } | } | ||||||
| int auth_simple_verify(const char *data,int &len) | int auth_simple_verify(const char *data, int &len) { | ||||||
| { |  | ||||||
|     if (len < 8) return -1; |     if (len < 8) return -1; | ||||||
|     unsigned char res[8]; |     unsigned char res[8]; | ||||||
|     len -= 8; |     len -= 8; | ||||||
| @@ -224,16 +224,12 @@ int auth_simple_verify(const char *data,int &len) | |||||||
|     return 0; |     return 0; | ||||||
| } | } | ||||||
|  |  | ||||||
|  | int auth_none_cal(const char *data, char *output, int &len) { | ||||||
| int auth_none_cal(const char *data,char * output,int &len) |  | ||||||
| { |  | ||||||
|     memcpy(output, data, len); |     memcpy(output, data, len); | ||||||
|     return 0; |     return 0; | ||||||
| } | } | ||||||
| int auth_md5_verify(const char *data,int &len) | int auth_md5_verify(const char *data, int &len) { | ||||||
| { |     if (len < 16) { | ||||||
| 	if(len<16) |  | ||||||
| 	{ |  | ||||||
|         mylog(log_trace, "auth_md5_verify len<16\n"); |         mylog(log_trace, "auth_md5_verify len<16\n"); | ||||||
|         return -1; |         return -1; | ||||||
|     } |     } | ||||||
| @@ -241,16 +237,14 @@ int auth_md5_verify(const char *data,int &len) | |||||||
|  |  | ||||||
|     md5((unsigned char *)data, len - 16, (unsigned char *)md5_res); |     md5((unsigned char *)data, len - 16, (unsigned char *)md5_res); | ||||||
|  |  | ||||||
| 	if(memcmp(md5_res,data+len-16,16)!=0) |     if (memcmp(md5_res, data + len - 16, 16) != 0) { | ||||||
| 	{ |  | ||||||
|         mylog(log_trace, "auth_md5_verify md5 check failed\n"); |         mylog(log_trace, "auth_md5_verify md5 check failed\n"); | ||||||
|         return -2; |         return -2; | ||||||
|     } |     } | ||||||
|     len -= 16; |     len -= 16; | ||||||
|     return 0; |     return 0; | ||||||
| } | } | ||||||
| int auth_none_verify(const char *data,int &len) | int auth_none_verify(const char *data, int &len) { | ||||||
| { |  | ||||||
|     return 0; |     return 0; | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -276,12 +270,10 @@ int cipher_xor_decrypt(const char * data, char *output,int &len, char *key) { | |||||||
|     return 0; |     return 0; | ||||||
| } | } | ||||||
|  |  | ||||||
| int padding(char *data ,int &data_len,int padding_num) | int padding(char *data, int &data_len, int padding_num) { | ||||||
| { |  | ||||||
|     int old_len = data_len; |     int old_len = data_len; | ||||||
|     data_len += 1; |     data_len += 1; | ||||||
| 	if(data_len%padding_num!=0) |     if (data_len % padding_num != 0) { | ||||||
| 	{ |  | ||||||
|         data_len = (data_len / padding_num) * padding_num + padding_num; |         data_len = (data_len / padding_num) * padding_num + padding_num; | ||||||
|     } |     } | ||||||
|     unsigned char *p = (unsigned char *)&data[data_len - 1]; |     unsigned char *p = (unsigned char *)&data[data_len - 1]; | ||||||
| @@ -289,52 +281,48 @@ int padding(char *data ,int &data_len,int padding_num) | |||||||
|     return 0; |     return 0; | ||||||
| } | } | ||||||
|  |  | ||||||
| int de_padding(const char *data ,int &data_len,int padding_num) | int de_padding(const char *data, int &data_len, int padding_num) { | ||||||
| { |     if (data_len == 0) return -1; | ||||||
|     if ((uint8_t)data[data_len - 1] > padding_num) return -1; |     if ((uint8_t)data[data_len - 1] > padding_num) return -1; | ||||||
|     data_len -= (uint8_t)data[data_len - 1]; |     data_len -= (uint8_t)data[data_len - 1]; | ||||||
| 	if(data_len<0) |     if (data_len < 0) { | ||||||
| 	{ |  | ||||||
|         return -1; |         return -1; | ||||||
|     } |     } | ||||||
|     return 0; |     return 0; | ||||||
| } | } | ||||||
| void aes_ecb_encrypt(const char *data,char *output) | void aes_ecb_encrypt(const char *data, char *output) { | ||||||
| { |  | ||||||
|     static int first_time = 1; |     static int first_time = 1; | ||||||
|     char *key = (char *)cipher_key_encrypt; |     char *key = (char *)cipher_key_encrypt; | ||||||
| 	if(aes_key_optimize) |     if (aes_key_optimize) { | ||||||
| 	{ |         if (first_time == 0) | ||||||
| 		if(first_time==0) key=0; |             key = 0; | ||||||
| 		else first_time=0; |         else | ||||||
|  |             first_time = 0; | ||||||
|     } |     } | ||||||
|     AES_ECB_encrypt_buffer((uint8_t *)data, (uint8_t *)key, (uint8_t *)output); |     AES_ECB_encrypt_buffer((uint8_t *)data, (uint8_t *)key, (uint8_t *)output); | ||||||
| } | } | ||||||
| void aes_ecb_encrypt1(char *data) | void aes_ecb_encrypt1(char *data) { | ||||||
| { |  | ||||||
|     char buf[16]; |     char buf[16]; | ||||||
|     memcpy(buf, data, 16); |     memcpy(buf, data, 16); | ||||||
|     aes_ecb_encrypt(buf, data); |     aes_ecb_encrypt(buf, data); | ||||||
| } | } | ||||||
| void aes_ecb_decrypt(const char *data,char *output) | void aes_ecb_decrypt(const char *data, char *output) { | ||||||
| { |  | ||||||
|     static int first_time = 1; |     static int first_time = 1; | ||||||
|     char *key = (char *)cipher_key_decrypt; |     char *key = (char *)cipher_key_decrypt; | ||||||
| 	if(aes_key_optimize) |     if (aes_key_optimize) { | ||||||
| 	{ |         if (first_time == 0) | ||||||
| 		if(first_time==0) key=0; |             key = 0; | ||||||
| 		else first_time=0; |         else | ||||||
|  |             first_time = 0; | ||||||
|     } |     } | ||||||
|     AES_ECB_decrypt_buffer((uint8_t *)data, (uint8_t *)key, (uint8_t *)output); |     AES_ECB_decrypt_buffer((uint8_t *)data, (uint8_t *)key, (uint8_t *)output); | ||||||
| } | } | ||||||
| void aes_ecb_decrypt1(char *data) | void aes_ecb_decrypt1(char *data) { | ||||||
| { |  | ||||||
|     char buf[16]; |     char buf[16]; | ||||||
|     memcpy(buf, data, 16); |     memcpy(buf, data, 16); | ||||||
|     aes_ecb_decrypt(buf, data); |     aes_ecb_decrypt(buf, data); | ||||||
| } | } | ||||||
| int cipher_aes128cbc_encrypt(const char *data,char *output,int &len,char * key) | int cipher_aes128cbc_encrypt(const char *data, char *output, int &len, char *key) { | ||||||
| { |  | ||||||
|     static int first_time = 1; |     static int first_time = 1; | ||||||
|  |  | ||||||
|     char buf[buf_len]; |     char buf[buf_len]; | ||||||
| @@ -342,83 +330,81 @@ int cipher_aes128cbc_encrypt(const char *data,char *output,int &len,char * key) | |||||||
|  |  | ||||||
|     if (padding(buf, len, 16) < 0) return -1; |     if (padding(buf, len, 16) < 0) return -1; | ||||||
|  |  | ||||||
| 	if(aes_key_optimize) |     if (aes_key_optimize) { | ||||||
| 	{ |         if (first_time == 0) | ||||||
| 		if(first_time==0) key=0; |             key = 0; | ||||||
| 		else first_time=0; |         else | ||||||
|  |             first_time = 0; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     AES_CBC_encrypt_buffer((unsigned char *)output, (unsigned char *)buf, len, (unsigned char *)key, (unsigned char *)zero_iv); |     AES_CBC_encrypt_buffer((unsigned char *)output, (unsigned char *)buf, len, (unsigned char *)key, (unsigned char *)zero_iv); | ||||||
|     return 0; |     return 0; | ||||||
| } | } | ||||||
| int cipher_aes128cfb_encrypt(const char *data,char *output,int &len,char * key) | int cipher_aes128cfb_encrypt(const char *data, char *output, int &len, char *key) { | ||||||
| { |  | ||||||
|     static int first_time = 1; |     static int first_time = 1; | ||||||
|     assert(len >= 16); |     assert(len >= 16); | ||||||
|  |  | ||||||
|     char buf[buf_len]; |     char buf[buf_len]; | ||||||
|     memcpy(buf, data, len);  // TODO inefficient code |     memcpy(buf, data, len);  // TODO inefficient code | ||||||
| 	if(aes_key_optimize) |     if (aes_key_optimize) { | ||||||
| 	{ |         if (first_time == 0) | ||||||
| 		if(first_time==0) key=0; |             key = 0; | ||||||
| 		else first_time=0; |         else | ||||||
|  |             first_time = 0; | ||||||
|     } |     } | ||||||
| 	if(!aes128cfb_old) |     if (!aes128cfb_old) { | ||||||
| 	{ |  | ||||||
|         aes_ecb_encrypt(data, buf);  // encrypt the first block |         aes_ecb_encrypt(data, buf);  // encrypt the first block | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     AES_CFB_encrypt_buffer((unsigned char *)output, (unsigned char *)buf, len, (unsigned char *)key, (unsigned char *)zero_iv); |     AES_CFB_encrypt_buffer((unsigned char *)output, (unsigned char *)buf, len, (unsigned char *)key, (unsigned char *)zero_iv); | ||||||
|     return 0; |     return 0; | ||||||
| } | } | ||||||
| int auth_crc32_verify(const char *data,int &len) | int auth_crc32_verify(const char *data, int &len) { | ||||||
| { |     if (len < int(sizeof(unsigned int))) { | ||||||
| 	if(len<int(sizeof(unsigned int))) |  | ||||||
| 	{ |  | ||||||
|         mylog(log_debug, "auth_crc32_verify len<%d\n", int(sizeof(unsigned int))); |         mylog(log_debug, "auth_crc32_verify len<%d\n", int(sizeof(unsigned int))); | ||||||
|         return -1; |         return -1; | ||||||
|     } |     } | ||||||
|     unsigned int ret = crc32h((unsigned char *)data, len - sizeof(unsigned int)); |     unsigned int ret = crc32h((unsigned char *)data, len - sizeof(unsigned int)); | ||||||
|     unsigned int ret_n = htonl(ret); |     unsigned int ret_n = htonl(ret); | ||||||
|  |  | ||||||
| 	if(memcmp(data+len-sizeof(unsigned int),&ret_n,sizeof(unsigned int))!=0) |     if (memcmp(data + len - sizeof(unsigned int), &ret_n, sizeof(unsigned int)) != 0) { | ||||||
| 	{ |  | ||||||
|         mylog(log_debug, "auth_crc32_verify memcmp fail\n"); |         mylog(log_debug, "auth_crc32_verify memcmp fail\n"); | ||||||
|         return -1; |         return -1; | ||||||
|     } |     } | ||||||
|     len -= sizeof(unsigned int); |     len -= sizeof(unsigned int); | ||||||
|     return 0; |     return 0; | ||||||
| } | } | ||||||
| int cipher_none_encrypt(const char *data,char *output,int &len,char * key) | int cipher_none_encrypt(const char *data, char *output, int &len, char *key) { | ||||||
| { |  | ||||||
|     memcpy(output, data, len); |     memcpy(output, data, len); | ||||||
|     return 0; |     return 0; | ||||||
| } | } | ||||||
| int cipher_aes128cbc_decrypt(const char *data,char *output,int &len,char * key) | int cipher_aes128cbc_decrypt(const char *data, char *output, int &len, char *key) { | ||||||
| { |  | ||||||
|     static int first_time = 1; |     static int first_time = 1; | ||||||
| 	if(len%16 !=0) {mylog(log_debug,"len%%16!=0\n");return -1;} |     if (len % 16 != 0) { | ||||||
| 	if(aes_key_optimize) |         mylog(log_debug, "len%%16!=0\n"); | ||||||
| 	{ |         return -1; | ||||||
| 		if(first_time==0) key=0; |     } | ||||||
| 		else first_time=0; |     if (aes_key_optimize) { | ||||||
|  |         if (first_time == 0) | ||||||
|  |             key = 0; | ||||||
|  |         else | ||||||
|  |             first_time = 0; | ||||||
|     } |     } | ||||||
|     AES_CBC_decrypt_buffer((unsigned char *)output, (unsigned char *)data, len, (unsigned char *)key, (unsigned char *)zero_iv); |     AES_CBC_decrypt_buffer((unsigned char *)output, (unsigned char *)data, len, (unsigned char *)key, (unsigned char *)zero_iv); | ||||||
|     if (de_padding(output, len, 16) < 0) return -1; |     if (de_padding(output, len, 16) < 0) return -1; | ||||||
|     return 0; |     return 0; | ||||||
| } | } | ||||||
| int cipher_aes128cfb_decrypt(const char *data,char *output,int &len,char * key) | int cipher_aes128cfb_decrypt(const char *data, char *output, int &len, char *key) { | ||||||
| { |  | ||||||
|     static int first_time = 1; |     static int first_time = 1; | ||||||
|     if (len < 16) return -1; |     if (len < 16) return -1; | ||||||
|  |  | ||||||
| 	if(aes_key_optimize) |     if (aes_key_optimize) { | ||||||
| 	{ |         if (first_time == 0) | ||||||
| 		if(first_time==0) key=0; |             key = 0; | ||||||
| 		else first_time=0; |         else | ||||||
|  |             first_time = 0; | ||||||
|     } |     } | ||||||
|  |  | ||||||
| 	 |  | ||||||
|     AES_CFB_decrypt_buffer((unsigned char *)output, (unsigned char *)data, len, (unsigned char *)key, (unsigned char *)zero_iv); |     AES_CFB_decrypt_buffer((unsigned char *)output, (unsigned char *)data, len, (unsigned char *)key, (unsigned char *)zero_iv); | ||||||
|  |  | ||||||
|     if (!aes128cfb_old) |     if (!aes128cfb_old) | ||||||
| @@ -427,81 +413,97 @@ int cipher_aes128cfb_decrypt(const char *data,char *output,int &len,char * key) | |||||||
|     return 0; |     return 0; | ||||||
| } | } | ||||||
|  |  | ||||||
| int cipher_none_decrypt(const char *data,char *output,int &len,char * key) | int cipher_none_decrypt(const char *data, char *output, int &len, char *key) { | ||||||
| { |  | ||||||
|     memcpy(output, data, len); |     memcpy(output, data, len); | ||||||
|     return 0; |     return 0; | ||||||
| } | } | ||||||
|  |  | ||||||
| int auth_cal(const char *data,char * output,int &len) | int auth_cal(const char *data, char *output, int &len) { | ||||||
| { |  | ||||||
|     mylog(log_trace, "auth:%d\n", auth_mode); |     mylog(log_trace, "auth:%d\n", auth_mode); | ||||||
| 	switch(auth_mode) |     switch (auth_mode) { | ||||||
| 	{ |         case auth_crc32: | ||||||
| 	case auth_crc32:return auth_crc32_cal(data, output, len); |             return auth_crc32_cal(data, output, len); | ||||||
| 	case auth_md5:return auth_md5_cal(data, output, len); |         case auth_md5: | ||||||
| 	case auth_simple:return auth_simple_cal(data, output, len); |             return auth_md5_cal(data, output, len); | ||||||
| 	case auth_none:return auth_none_cal(data, output, len); |         case auth_simple: | ||||||
| 	case auth_hmac_sha1:return auth_hmac_sha1_cal(data,output,len); |             return auth_simple_cal(data, output, len); | ||||||
|  |         case auth_none: | ||||||
|  |             return auth_none_cal(data, output, len); | ||||||
|  |         case auth_hmac_sha1: | ||||||
|  |             return auth_hmac_sha1_cal(data, output, len); | ||||||
|         // default:	return auth_md5_cal(data,output,len);//default; |         // default:	return auth_md5_cal(data,output,len);//default; | ||||||
| 	default: assert(0==1); |         default: | ||||||
|  |             assert(0 == 1); | ||||||
|     } |     } | ||||||
|     return -1; |     return -1; | ||||||
|  |  | ||||||
| } | } | ||||||
| int auth_verify(const char *data,int &len) | int auth_verify(const char *data, int &len) { | ||||||
| { |  | ||||||
|     mylog(log_trace, "auth:%d\n", auth_mode); |     mylog(log_trace, "auth:%d\n", auth_mode); | ||||||
| 	switch(auth_mode) |     switch (auth_mode) { | ||||||
| 	{ |         case auth_crc32: | ||||||
| 	case auth_crc32:return auth_crc32_verify(data, len); |             return auth_crc32_verify(data, len); | ||||||
| 	case auth_md5:return auth_md5_verify(data, len); |         case auth_md5: | ||||||
| 	case auth_simple:return auth_simple_verify(data, len); |             return auth_md5_verify(data, len); | ||||||
| 	case auth_none:return auth_none_verify(data, len); |         case auth_simple: | ||||||
| 	case auth_hmac_sha1:return auth_hmac_sha1_verify(data,len); |             return auth_simple_verify(data, len); | ||||||
|  |         case auth_none: | ||||||
|  |             return auth_none_verify(data, len); | ||||||
|  |         case auth_hmac_sha1: | ||||||
|  |             return auth_hmac_sha1_verify(data, len); | ||||||
|         // default:	return auth_md5_verify(data,len);//default |         // default:	return auth_md5_verify(data,len);//default | ||||||
| 	default: assert(0==1); |         default: | ||||||
|  |             assert(0 == 1); | ||||||
|     } |     } | ||||||
|     return -1; |     return -1; | ||||||
|  |  | ||||||
| } | } | ||||||
| int cipher_encrypt(const char *data,char *output,int &len,char * key) | int cipher_encrypt(const char *data, char *output, int &len, char *key) { | ||||||
| { |  | ||||||
|     mylog(log_trace, "cipher:%d\n", cipher_mode); |     mylog(log_trace, "cipher:%d\n", cipher_mode); | ||||||
| 	switch(cipher_mode) |     switch (cipher_mode) { | ||||||
| 	{ |         case cipher_aes128cbc: | ||||||
| 	case cipher_aes128cbc:return cipher_aes128cbc_encrypt(data,output,len, key); |             return cipher_aes128cbc_encrypt(data, output, len, key); | ||||||
| 	case cipher_aes128cfb:return cipher_aes128cfb_encrypt(data,output,len, key); |         case cipher_aes128cfb: | ||||||
| 	case cipher_xor:return cipher_xor_encrypt(data,output,len, key); |             return cipher_aes128cfb_encrypt(data, output, len, key); | ||||||
| 	case cipher_none:return cipher_none_encrypt(data,output,len, key); |         case cipher_xor: | ||||||
|  |             return cipher_xor_encrypt(data, output, len, key); | ||||||
|  |         case cipher_none: | ||||||
|  |             return cipher_none_encrypt(data, output, len, key); | ||||||
|         // default:return cipher_aes128cbc_encrypt(data,output,len, key); |         // default:return cipher_aes128cbc_encrypt(data,output,len, key); | ||||||
| 	default: assert(0==1); |         default: | ||||||
|  |             assert(0 == 1); | ||||||
|     } |     } | ||||||
|     return -1; |     return -1; | ||||||
| } | } | ||||||
| int cipher_decrypt(const char *data,char *output,int &len,char * key) | int cipher_decrypt(const char *data, char *output, int &len, char *key) { | ||||||
| { |  | ||||||
|     mylog(log_trace, "cipher:%d\n", cipher_mode); |     mylog(log_trace, "cipher:%d\n", cipher_mode); | ||||||
| 	switch(cipher_mode) |     switch (cipher_mode) { | ||||||
| 	{ |         case cipher_aes128cbc: | ||||||
| 		case cipher_aes128cbc:return cipher_aes128cbc_decrypt(data,output,len, key); |             return cipher_aes128cbc_decrypt(data, output, len, key); | ||||||
| 		case cipher_aes128cfb:return cipher_aes128cfb_decrypt(data,output,len, key); |         case cipher_aes128cfb: | ||||||
| 		case cipher_xor:return cipher_xor_decrypt(data,output,len, key); |             return cipher_aes128cfb_decrypt(data, output, len, key); | ||||||
| 		case cipher_none:return cipher_none_decrypt(data,output,len, key); |         case cipher_xor: | ||||||
|  |             return cipher_xor_decrypt(data, output, len, key); | ||||||
|  |         case cipher_none: | ||||||
|  |             return cipher_none_decrypt(data, output, len, key); | ||||||
|         //	default:	return cipher_aes128cbc_decrypt(data,output,len,key); |         //	default:	return cipher_aes128cbc_decrypt(data,output,len,key); | ||||||
| 	default: assert(0==1); |         default: | ||||||
|  |             assert(0 == 1); | ||||||
|     } |     } | ||||||
|     return -1; |     return -1; | ||||||
| } | } | ||||||
|  |  | ||||||
| int encrypt_AE(const char *data,char *output,int &len /*,char * key*/) | int encrypt_AE(const char *data, char *output, int &len /*,char * key*/) { | ||||||
| { |  | ||||||
|     mylog(log_trace, "encrypt_AE is called\n"); |     mylog(log_trace, "encrypt_AE is called\n"); | ||||||
|     char buf[buf_len]; |     char buf[buf_len]; | ||||||
|     char buf2[buf_len]; |     char buf2[buf_len]; | ||||||
|     memcpy(buf, data, len); |     memcpy(buf, data, len); | ||||||
| 	if(cipher_encrypt(buf,buf2,len,(char *)cipher_key_encrypt) !=0) {mylog(log_debug,"cipher_encrypt failed ");return -1;} |     if (cipher_encrypt(buf, buf2, len, (char *)cipher_key_encrypt) != 0) { | ||||||
| 	if(auth_cal(buf2,output,len)!=0) {mylog(log_debug,"auth_cal failed ");return -1;} |         mylog(log_debug, "cipher_encrypt failed "); | ||||||
|  |         return -1; | ||||||
|  |     } | ||||||
|  |     if (auth_cal(buf2, output, len) != 0) { | ||||||
|  |         mylog(log_debug, "auth_cal failed "); | ||||||
|  |         return -1; | ||||||
|  |     } | ||||||
|  |  | ||||||
|     // printf("%d %x %x\n",len,(int)(output[0]),(int)(output[1])); |     // printf("%d %x %x\n",len,(int)(output[0]),(int)(output[1])); | ||||||
|     // print_binary_chars(output,len); |     // print_binary_chars(output,len); | ||||||
| @@ -510,59 +512,77 @@ int encrypt_AE(const char *data,char *output,int &len /*,char * key*/) | |||||||
|     return 0; |     return 0; | ||||||
| } | } | ||||||
|  |  | ||||||
| int decrypt_AE(const char *data,char *output,int &len /*,char * key*/) | int decrypt_AE(const char *data, char *output, int &len /*,char * key*/) { | ||||||
| { |  | ||||||
|     mylog(log_trace, "decrypt_AE is called\n"); |     mylog(log_trace, "decrypt_AE is called\n"); | ||||||
|     // printf("%d %x %x\n",len,(int)(data[0]),(int)(data[1])); |     // printf("%d %x %x\n",len,(int)(data[0]),(int)(data[1])); | ||||||
|     // print_binary_chars(data,len); |     // print_binary_chars(data,len); | ||||||
|  |  | ||||||
| 	if(auth_verify(data,len)!=0) {mylog(log_debug,"auth_verify failed\n");return -1;} |     if (auth_verify(data, len) != 0) { | ||||||
| 	if(cipher_decrypt(data,output,len,(char *)cipher_key_decrypt) !=0) {mylog(log_debug,"cipher_decrypt failed \n"); return -1;} |         mylog(log_debug, "auth_verify failed\n"); | ||||||
|  |         return -1; | ||||||
|  |     } | ||||||
|  |     if (cipher_decrypt(data, output, len, (char *)cipher_key_decrypt) != 0) { | ||||||
|  |         mylog(log_debug, "cipher_decrypt failed \n"); | ||||||
|  |         return -1; | ||||||
|  |     } | ||||||
|     return 0; |     return 0; | ||||||
| } | } | ||||||
|  |  | ||||||
| int my_encrypt(const char *data,char *output,int &len /*,char * key*/) | int my_encrypt(const char *data, char *output, int &len /*,char * key*/) { | ||||||
| { |     if (len < 0) { | ||||||
| 	if(len<0) {mylog(log_trace,"len<0");return -1;} |         mylog(log_trace, "len<0"); | ||||||
| 	if(len>max_data_len) {mylog(log_warn,"len>max_data_len");return -1;} |         return -1; | ||||||
|  |     } | ||||||
|  |     if (len > max_data_len) { | ||||||
|  |         mylog(log_warn, "len>max_data_len"); | ||||||
|  |         return -1; | ||||||
|  |     } | ||||||
|  |  | ||||||
|     if (is_hmac_used) |     if (is_hmac_used) | ||||||
|         return encrypt_AE(data, output, len); |         return encrypt_AE(data, output, len); | ||||||
|  |  | ||||||
|  |  | ||||||
|     char buf[buf_len]; |     char buf[buf_len]; | ||||||
|     char buf2[buf_len]; |     char buf2[buf_len]; | ||||||
|     memcpy(buf, data, len); |     memcpy(buf, data, len); | ||||||
| 	if(auth_cal(buf,buf2,len)!=0) {mylog(log_debug,"auth_cal failed ");return -1;} |     if (auth_cal(buf, buf2, len) != 0) { | ||||||
| 	if(cipher_encrypt(buf2,output,len,normal_key) !=0) {mylog(log_debug,"cipher_encrypt failed ");return -1;} |         mylog(log_debug, "auth_cal failed "); | ||||||
|  |         return -1; | ||||||
|  |     } | ||||||
|  |     if (cipher_encrypt(buf2, output, len, normal_key) != 0) { | ||||||
|  |         mylog(log_debug, "cipher_encrypt failed "); | ||||||
|  |         return -1; | ||||||
|  |     } | ||||||
|     return 0; |     return 0; | ||||||
|  |  | ||||||
| } | } | ||||||
|  |  | ||||||
| int my_decrypt(const char *data,char *output,int &len /*,char * key*/) | int my_decrypt(const char *data, char *output, int &len /*,char * key*/) { | ||||||
| { |  | ||||||
|     if (len < 0) return -1; |     if (len < 0) return -1; | ||||||
| 	if(len>max_data_len) {mylog(log_warn,"len>max_data_len");return -1;} |     if (len > max_data_len) { | ||||||
|  |         mylog(log_warn, "len>max_data_len"); | ||||||
|  |         return -1; | ||||||
|  |     } | ||||||
|  |  | ||||||
|     if (is_hmac_used) |     if (is_hmac_used) | ||||||
|         return decrypt_AE(data, output, len); |         return decrypt_AE(data, output, len); | ||||||
|  |  | ||||||
| 	if(cipher_decrypt(data,output,len,normal_key) !=0) {mylog(log_debug,"cipher_decrypt failed \n"); return -1;} |     if (cipher_decrypt(data, output, len, normal_key) != 0) { | ||||||
| 	if(auth_verify(output,len)!=0) {mylog(log_debug,"auth_verify failed\n");return -1;} |         mylog(log_debug, "cipher_decrypt failed \n"); | ||||||
|  |         return -1; | ||||||
|  |     } | ||||||
|  |     if (auth_verify(output, len) != 0) { | ||||||
|  |         mylog(log_debug, "auth_verify failed\n"); | ||||||
|  |         return -1; | ||||||
|  |     } | ||||||
|  |  | ||||||
|     return 0; |     return 0; | ||||||
| } | } | ||||||
|  |  | ||||||
|  | int encrypt_AEAD(uint8_t *data, uint8_t *output, int &len, uint8_t *key, uint8_t *header, int hlen) { | ||||||
| int encrypt_AEAD(uint8_t *data,uint8_t *output,int &len,uint8_t * key,uint8_t *header,int hlen) |  | ||||||
| { |  | ||||||
|     // TODO |     // TODO | ||||||
|     return -1; |     return -1; | ||||||
| } | } | ||||||
|  |  | ||||||
| int decrypt_AEAD(uint8_t *data,uint8_t *output,int &len,uint8_t * key,uint8_t *header,int hlen) | int decrypt_AEAD(uint8_t *data, uint8_t *output, int &len, uint8_t *key, uint8_t *header, int hlen) { | ||||||
| { |  | ||||||
|     // TODO |     // TODO | ||||||
|     return -1; |     return -1; | ||||||
| } | } | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										20
									
								
								encrypt.h
									
									
									
									
									
										
										
										Executable file → Normal file
									
								
							
							
						
						
									
										20
									
								
								encrypt.h
									
									
									
									
									
										
										
										Executable file → Normal file
									
								
							| @@ -1,13 +1,10 @@ | |||||||
| #ifndef UDP2RAW_ENCRYPTION_H_ | #ifndef UDP2RAW_ENCRYPTION_H_ | ||||||
| #define UDP2RAW_ENCRYPTION_H_ | #define UDP2RAW_ENCRYPTION_H_ | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| //#include "aes.h" | //#include "aes.h" | ||||||
| //#include "md5.h" | //#include "md5.h" | ||||||
| #include "common.h" | #include "common.h" | ||||||
|  |  | ||||||
|  |  | ||||||
| // using namespace std; | // using namespace std; | ||||||
| // extern char key[16]; | // extern char key[16]; | ||||||
|  |  | ||||||
| @@ -19,15 +16,20 @@ int my_init_keys(const char *,int); | |||||||
| int my_encrypt(const char *data, char *output, int &len); | int my_encrypt(const char *data, char *output, int &len); | ||||||
| int my_decrypt(const char *data, char *output, int &len); | int my_decrypt(const char *data, char *output, int &len); | ||||||
|  |  | ||||||
|  |  | ||||||
| unsigned short csum(const unsigned short *ptr, int nbytes); | unsigned short csum(const unsigned short *ptr, int nbytes); | ||||||
|  |  | ||||||
|  | enum auth_mode_t { auth_none = 0, | ||||||
|  |                    auth_md5, | ||||||
|  |                    auth_crc32, | ||||||
|  |                    auth_simple, | ||||||
|  |                    auth_hmac_sha1, | ||||||
|  |                    auth_end }; | ||||||
|  |  | ||||||
| enum auth_mode_t {auth_none=0,auth_md5,auth_crc32,auth_simple,auth_hmac_sha1,auth_end}; | enum cipher_mode_t { cipher_none = 0, | ||||||
|  |                      cipher_aes128cbc, | ||||||
|  |                      cipher_xor, | ||||||
| enum cipher_mode_t {cipher_none=0,cipher_aes128cbc,cipher_xor,cipher_aes128cfb,cipher_end}; |                      cipher_aes128cfb, | ||||||
|  |                      cipher_end }; | ||||||
|  |  | ||||||
| extern auth_mode_t auth_mode; | extern auth_mode_t auth_mode; | ||||||
| extern cipher_mode_t cipher_mode; | extern cipher_mode_t cipher_mode; | ||||||
|   | |||||||
| @@ -5,60 +5,49 @@ | |||||||
|  *      Author: root |  *      Author: root | ||||||
|  */ |  */ | ||||||
|  |  | ||||||
|  |  | ||||||
| #include "fd_manager.h" | #include "fd_manager.h" | ||||||
| int fd_manager_t::fd_exist(int fd) | int fd_manager_t::fd_exist(int fd) { | ||||||
| { |  | ||||||
|     return fd_to_fd64_mp.find(fd) != fd_to_fd64_mp.end(); |     return fd_to_fd64_mp.find(fd) != fd_to_fd64_mp.end(); | ||||||
| } | } | ||||||
| int fd_manager_t::exist(fd64_t fd64) | int fd_manager_t::exist(fd64_t fd64) { | ||||||
| { |  | ||||||
|     return fd64_to_fd_mp.find(fd64) != fd64_to_fd_mp.end(); |     return fd64_to_fd_mp.find(fd64) != fd64_to_fd_mp.end(); | ||||||
| } | } | ||||||
| int fd_manager_t::to_fd(fd64_t fd64) | int fd_manager_t::to_fd(fd64_t fd64) { | ||||||
| { |  | ||||||
|     assert(exist(fd64)); |     assert(exist(fd64)); | ||||||
|     return fd64_to_fd_mp[fd64]; |     return fd64_to_fd_mp[fd64]; | ||||||
| } | } | ||||||
| void fd_manager_t::fd64_close(fd64_t fd64) | void fd_manager_t::fd64_close(fd64_t fd64) { | ||||||
| { |  | ||||||
|     assert(exist(fd64)); |     assert(exist(fd64)); | ||||||
|     int fd = fd64_to_fd_mp[fd64]; |     int fd = fd64_to_fd_mp[fd64]; | ||||||
|     fd64_to_fd_mp.erase(fd64); |     fd64_to_fd_mp.erase(fd64); | ||||||
|     fd_to_fd64_mp.erase(fd); |     fd_to_fd64_mp.erase(fd); | ||||||
| 	if(exist_info(fd64)) |     if (exist_info(fd64)) { | ||||||
| 	{ |  | ||||||
|         fd_info_mp.erase(fd64); |         fd_info_mp.erase(fd64); | ||||||
|     } |     } | ||||||
|     // assert(close(fd)==0); |     // assert(close(fd)==0); | ||||||
|     sock_close(fd); |     sock_close(fd); | ||||||
| } | } | ||||||
| void fd_manager_t::reserve(int n) | void fd_manager_t::reserve(int n) { | ||||||
| { |  | ||||||
|     fd_to_fd64_mp.reserve(n); |     fd_to_fd64_mp.reserve(n); | ||||||
|     fd64_to_fd_mp.reserve(n); |     fd64_to_fd_mp.reserve(n); | ||||||
|     fd_info_mp.reserve(n); |     fd_info_mp.reserve(n); | ||||||
| } | } | ||||||
| u64_t fd_manager_t::create(int fd) | u64_t fd_manager_t::create(int fd) { | ||||||
| { |  | ||||||
|     assert(!fd_exist(fd)); |     assert(!fd_exist(fd)); | ||||||
|     fd64_t fd64 = counter++; |     fd64_t fd64 = counter++; | ||||||
|     fd_to_fd64_mp[fd] = fd64; |     fd_to_fd64_mp[fd] = fd64; | ||||||
|     fd64_to_fd_mp[fd64] = fd; |     fd64_to_fd_mp[fd64] = fd; | ||||||
|     return fd64; |     return fd64; | ||||||
| } | } | ||||||
| fd_manager_t::fd_manager_t() | fd_manager_t::fd_manager_t() { | ||||||
| { |  | ||||||
|     counter = u32_t(-1); |     counter = u32_t(-1); | ||||||
|     counter += 100; |     counter += 100; | ||||||
|     reserve(10007); |     reserve(10007); | ||||||
| } | } | ||||||
| fd_info_t & fd_manager_t::get_info(fd64_t fd64) | fd_info_t& fd_manager_t::get_info(fd64_t fd64) { | ||||||
| { |  | ||||||
|     assert(exist(fd64)); |     assert(exist(fd64)); | ||||||
|     return fd_info_mp[fd64]; |     return fd_info_mp[fd64]; | ||||||
| } | } | ||||||
| int fd_manager_t::exist_info(fd64_t fd64) | int fd_manager_t::exist_info(fd64_t fd64) { | ||||||
| { |  | ||||||
|     return fd_info_mp.find(fd64) != fd_info_mp.end(); |     return fd_info_mp.find(fd64) != fd_info_mp.end(); | ||||||
| } | } | ||||||
|   | |||||||
| @@ -12,8 +12,7 @@ | |||||||
| //#include "packet.h" | //#include "packet.h" | ||||||
| #include "connection.h" | #include "connection.h" | ||||||
|  |  | ||||||
| struct fd_info_t | struct fd_info_t { | ||||||
| { |  | ||||||
|     // ip_port_t ip_port; |     // ip_port_t ip_port; | ||||||
|     conn_info_t *p_conn_info; |     conn_info_t *p_conn_info; | ||||||
| }; | }; | ||||||
| @@ -29,6 +28,7 @@ struct fd_manager_t   //conver fd to a uniq 64bit number,avoid fd value conflict | |||||||
|     void reserve(int n); |     void reserve(int n); | ||||||
|     u64_t create(int fd); |     u64_t create(int fd); | ||||||
|     fd_manager_t(); |     fd_manager_t(); | ||||||
|  |  | ||||||
|    private: |    private: | ||||||
|     u64_t counter; |     u64_t counter; | ||||||
|     unordered_map<int, fd64_t> fd_to_fd64_mp; |     unordered_map<int, fd64_t> fd_to_fd64_mp; | ||||||
|   | |||||||
							
								
								
									
										1
									
								
								git_version.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								git_version.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1 @@ | |||||||
|  | const char *gitversion = "e42f0e573221c5e0146c02fd5d71f32aa93c7221"; | ||||||
							
								
								
									
										9
									
								
								log.cpp
									
									
									
									
									
										
										
										Executable file → Normal file
									
								
							
							
						
						
									
										9
									
								
								log.cpp
									
									
									
									
									
										
										
										Executable file → Normal file
									
								
							| @@ -7,11 +7,9 @@ int enable_log_position=0; | |||||||
| int enable_log_color = 1; | int enable_log_color = 1; | ||||||
|  |  | ||||||
| void log0(const char* file, const char* function, int line, int level, const char* str, ...) { | void log0(const char* file, const char* function, int line, int level, const char* str, ...) { | ||||||
|  |  | ||||||
|     if (level > log_level) return; |     if (level > log_level) return; | ||||||
|     if (level > log_trace || level < 0) return; |     if (level > log_trace || level < 0) return; | ||||||
|  |  | ||||||
|  |  | ||||||
|     time_t timer; |     time_t timer; | ||||||
|     char buffer[100]; |     char buffer[100]; | ||||||
|     struct tm* tm_info; |     struct tm* tm_info; | ||||||
| @@ -39,14 +37,12 @@ void log0(const char * file,const char * function,int line,int level,const char* | |||||||
|     // printf(log_color[level]); |     // printf(log_color[level]); | ||||||
|     fflush(stdout); |     fflush(stdout); | ||||||
|  |  | ||||||
| 	if(log_level==log_fatal) |     if (log_level == log_fatal) { | ||||||
| 	{ |  | ||||||
|         about_to_exit = 1; |         about_to_exit = 1; | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  |  | ||||||
| void log_bare(int level,const char* str, ...) | void log_bare(int level, const char* str, ...) { | ||||||
| { |  | ||||||
|     if (level > log_level) return; |     if (level > log_level) return; | ||||||
|     if (level > log_trace || level < 0) return; |     if (level > log_trace || level < 0) return; | ||||||
|     if (enable_log_color) |     if (enable_log_color) | ||||||
| @@ -58,5 +54,4 @@ void log_bare(int level,const char* str, ...) | |||||||
|     if (enable_log_color) |     if (enable_log_color) | ||||||
|         printf("%s", RESET); |         printf("%s", RESET); | ||||||
|     fflush(stdout); |     fflush(stdout); | ||||||
|  |  | ||||||
| } | } | ||||||
|   | |||||||
							
								
								
									
										7
									
								
								log.h
									
									
									
									
									
										
										
										Executable file → Normal file
									
								
							
							
						
						
									
										7
									
								
								log.h
									
									
									
									
									
										
										
										Executable file → Normal file
									
								
							| @@ -2,13 +2,10 @@ | |||||||
| #ifndef UDP2RAW_LOG_MYLOG_H_ | #ifndef UDP2RAW_LOG_MYLOG_H_ | ||||||
| #define UDP2RAW_LOG_MYLOG_H_ | #define UDP2RAW_LOG_MYLOG_H_ | ||||||
|  |  | ||||||
|  |  | ||||||
| #include "common.h" | #include "common.h" | ||||||
|  |  | ||||||
|  |  | ||||||
| using namespace std; | using namespace std; | ||||||
|  |  | ||||||
|  |  | ||||||
| #define RED "\x1B[31m" | #define RED "\x1B[31m" | ||||||
| #define GRN "\x1B[32m" | #define GRN "\x1B[32m" | ||||||
| #define YEL "\x1B[33m" | #define YEL "\x1B[33m" | ||||||
| @@ -18,7 +15,6 @@ using namespace std; | |||||||
| #define WHT "\x1B[37m" | #define WHT "\x1B[37m" | ||||||
| #define RESET "\x1B[0m" | #define RESET "\x1B[0m" | ||||||
|  |  | ||||||
|  |  | ||||||
| const int log_never = 0; | const int log_never = 0; | ||||||
| const int log_fatal = 1; | const int log_fatal = 1; | ||||||
| const int log_error = 2; | const int log_error = 2; | ||||||
| @@ -35,7 +31,6 @@ extern int log_level; | |||||||
| extern int enable_log_position; | extern int enable_log_position; | ||||||
| extern int enable_log_color; | extern int enable_log_color; | ||||||
|  |  | ||||||
|  |  | ||||||
| #ifdef MY_DEBUG | #ifdef MY_DEBUG | ||||||
| #define mylog(__first_argu__dummy_abcde__, ...) printf(__VA_ARGS__) | #define mylog(__first_argu__dummy_abcde__, ...) printf(__VA_ARGS__) | ||||||
|  |  | ||||||
| @@ -43,12 +38,10 @@ extern int enable_log_color; | |||||||
| #define mylog(...) log0(__FILE__, __FUNCTION__, __LINE__, __VA_ARGS__) | #define mylog(...) log0(__FILE__, __FUNCTION__, __LINE__, __VA_ARGS__) | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  |  | ||||||
| //#define mylog(__first_argu__dummy_abcde__,...) {;} | //#define mylog(__first_argu__dummy_abcde__,...) {;} | ||||||
|  |  | ||||||
| void log0(const char* file, const char* function, int line, int level, const char* str, ...); | void log0(const char* file, const char* function, int line, int level, const char* str, ...); | ||||||
|  |  | ||||||
| void log_bare(int level, const char* str, ...); | void log_bare(int level, const char* str, ...); | ||||||
|  |  | ||||||
|  |  | ||||||
| #endif | #endif | ||||||
|   | |||||||
							
								
								
									
										60
									
								
								main.cpp
									
									
									
									
									
										
										
										Executable file → Normal file
									
								
							
							
						
						
									
										60
									
								
								main.cpp
									
									
									
									
									
										
										
										Executable file → Normal file
									
								
							| @@ -7,19 +7,16 @@ | |||||||
| #include "encrypt.h" | #include "encrypt.h" | ||||||
| #include "fd_manager.h" | #include "fd_manager.h" | ||||||
|  |  | ||||||
| void sigpipe_cb(struct ev_loop *l, ev_signal *w, int revents) | void sigpipe_cb(struct ev_loop *l, ev_signal *w, int revents) { | ||||||
| { |  | ||||||
|     mylog(log_info, "got sigpipe, ignored"); |     mylog(log_info, "got sigpipe, ignored"); | ||||||
| } | } | ||||||
|  |  | ||||||
| void sigterm_cb(struct ev_loop *l, ev_signal *w, int revents) | void sigterm_cb(struct ev_loop *l, ev_signal *w, int revents) { | ||||||
| { |  | ||||||
|     mylog(log_info, "got sigterm, exit"); |     mylog(log_info, "got sigterm, exit"); | ||||||
|     myexit(0); |     myexit(0); | ||||||
| } | } | ||||||
|  |  | ||||||
| void sigint_cb(struct ev_loop *l, ev_signal *w, int revents) | void sigint_cb(struct ev_loop *l, ev_signal *w, int revents) { | ||||||
| { |  | ||||||
|     mylog(log_info, "got sigint, exit"); |     mylog(log_info, "got sigint, exit"); | ||||||
|     myexit(0); |     myexit(0); | ||||||
| } | } | ||||||
| @@ -27,12 +24,15 @@ void sigint_cb(struct ev_loop *l, ev_signal *w, int revents) | |||||||
| int client_event_loop(); | int client_event_loop(); | ||||||
| int server_event_loop(); | int server_event_loop(); | ||||||
|  |  | ||||||
| int main(int argc, char *argv[]) | int main(int argc, char *argv[]) { | ||||||
| { |  | ||||||
|     assert(sizeof(unsigned short) == 2); |     assert(sizeof(unsigned short) == 2); | ||||||
|     assert(sizeof(unsigned int) == 4); |     assert(sizeof(unsigned int) == 4); | ||||||
|     assert(sizeof(unsigned long long) == 8); |     assert(sizeof(unsigned long long) == 8); | ||||||
|  |  | ||||||
|  | #ifdef UDP2RAW_MP | ||||||
|  |     init_ws(); | ||||||
|  | #endif | ||||||
|  |  | ||||||
|     dup2(1, 2);  // redirect stderr to stdout |     dup2(1, 2);  // redirect stderr to stdout | ||||||
| #if defined(__MINGW32__) | #if defined(__MINGW32__) | ||||||
|     enable_log_color = 0; |     enable_log_color = 0; | ||||||
| @@ -40,38 +40,37 @@ int main(int argc, char *argv[]) | |||||||
|  |  | ||||||
|     pre_process_arg(argc, argv); |     pre_process_arg(argc, argv); | ||||||
|  |  | ||||||
| 	if(program_mode==client_mode) |     ev_signal signal_watcher_sigpipe; | ||||||
| 	{ |     ev_signal signal_watcher_sigterm; | ||||||
|  |     ev_signal signal_watcher_sigint; | ||||||
|  |  | ||||||
|  |     if (program_mode == client_mode) { | ||||||
|         struct ev_loop *loop = ev_default_loop(0); |         struct ev_loop *loop = ev_default_loop(0); | ||||||
| #if !defined(__MINGW32__) | #if !defined(__MINGW32__) | ||||||
| 		ev_signal signal_watcher_sigpipe; |  | ||||||
|         ev_signal_init(&signal_watcher_sigpipe, sigpipe_cb, SIGPIPE); |         ev_signal_init(&signal_watcher_sigpipe, sigpipe_cb, SIGPIPE); | ||||||
|         ev_signal_start(loop, &signal_watcher_sigpipe); |         ev_signal_start(loop, &signal_watcher_sigpipe); | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
| 		ev_signal signal_watcher_sigterm; |  | ||||||
|         ev_signal_init(&signal_watcher_sigterm, sigterm_cb, SIGTERM); |         ev_signal_init(&signal_watcher_sigterm, sigterm_cb, SIGTERM); | ||||||
|         ev_signal_start(loop, &signal_watcher_sigterm); |         ev_signal_start(loop, &signal_watcher_sigterm); | ||||||
|  |  | ||||||
| 		ev_signal signal_watcher_sigint; |  | ||||||
|         ev_signal_init(&signal_watcher_sigint, sigint_cb, SIGINT); |         ev_signal_init(&signal_watcher_sigint, sigint_cb, SIGINT); | ||||||
|         ev_signal_start(loop, &signal_watcher_sigint); |         ev_signal_start(loop, &signal_watcher_sigint); | ||||||
| 	} |     } else { | ||||||
| 	else | #ifdef UDP2RAW_LINUX | ||||||
| 	{ |  | ||||||
|         signal(SIGINT, signal_handler); |         signal(SIGINT, signal_handler); | ||||||
|         signal(SIGHUP, signal_handler); |         signal(SIGHUP, signal_handler); | ||||||
|         signal(SIGKILL, signal_handler); |         signal(SIGKILL, signal_handler); | ||||||
|         signal(SIGTERM, signal_handler); |         signal(SIGTERM, signal_handler); | ||||||
|         signal(SIGQUIT, signal_handler); |         signal(SIGQUIT, signal_handler); | ||||||
|  | #else | ||||||
|  |         mylog(log_fatal, "server mode not supported in multi-platform version\n"); | ||||||
|  |         myexit(-1); | ||||||
|  | #endif | ||||||
|     } |     } | ||||||
| #if !defined(__MINGW32__) | #if !defined(__MINGW32__) | ||||||
| 	if(geteuid() != 0) |     if (geteuid() != 0) { | ||||||
| 	{ |  | ||||||
|         mylog(log_warn, "root check failed, it seems like you are using a non-root account. we can try to continue, but it may fail. If you want to run udp2raw as non-root, you have to add iptables rule manually, and grant udp2raw CAP_NET_RAW capability, check README.md in repo for more info.\n"); |         mylog(log_warn, "root check failed, it seems like you are using a non-root account. we can try to continue, but it may fail. If you want to run udp2raw as non-root, you have to add iptables rule manually, and grant udp2raw CAP_NET_RAW capability, check README.md in repo for more info.\n"); | ||||||
| 	} |     } else { | ||||||
| 	else |  | ||||||
| 	{ |  | ||||||
|         mylog(log_warn, "you can run udp2raw with non-root account for better security. check README.md in repo for more info.\n"); |         mylog(log_warn, "you can run udp2raw with non-root account for better security. check README.md in repo for more info.\n"); | ||||||
|     } |     } | ||||||
| #endif | #endif | ||||||
| @@ -87,15 +86,20 @@ int main(int argc, char *argv[]) | |||||||
|     my_init_keys(key_string, program_mode == client_mode ? 1 : 0); |     my_init_keys(key_string, program_mode == client_mode ? 1 : 0); | ||||||
|  |  | ||||||
|     iptables_rule(); |     iptables_rule(); | ||||||
| 	init_raw_socket(); |  | ||||||
|  |  | ||||||
| 	if(program_mode==client_mode) | #ifdef UDP2RAW_LINUX | ||||||
| 	{ |     init_raw_socket(); | ||||||
|  | #endif | ||||||
|  |  | ||||||
|  |     if (program_mode == client_mode) { | ||||||
|         client_event_loop(); |         client_event_loop(); | ||||||
| 	} |     } else { | ||||||
| 	else | #ifdef UDP2RAW_LINUX | ||||||
| 	{ |  | ||||||
|         server_event_loop(); |         server_event_loop(); | ||||||
|  | #else | ||||||
|  |         mylog(log_fatal, "server mode not supported in multi-platform version\n"); | ||||||
|  |         myexit(-1); | ||||||
|  | #endif | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     return 0; |     return 0; | ||||||
|   | |||||||
							
								
								
									
										144
									
								
								makefile
									
									
									
									
									
								
							
							
						
						
									
										144
									
								
								makefile
									
									
									
									
									
								
							| @@ -1,96 +1,134 @@ | |||||||
| cc_cross=/home/wangyu/Desktop/arm-2014.05/bin/arm-none-linux-gnueabi-g++ | cc_cross=/home/wangyu/Desktop/arm-2014.05/bin/arm-none-linux-gnueabi-g++ | ||||||
| cc_local=g++ | cc_local=g++ | ||||||
| #cc_local=/opt/cross/x86_64-linux-musl/bin/x86_64-linux-musl-g++ |  | ||||||
| #cc_mips34kc=/toolchains/OpenWrt-SDK-ar71xx-for-linux-x86_64-gcc-4.8-linaro_uClibc-0.9.33.2/staging_dir/toolchain-mips_34kc_gcc-4.8-linaro_uClibc-0.9.33.2/bin/mips-openwrt-linux-g++ |  | ||||||
| cc_mips24kc_be=/toolchains/lede-sdk-17.01.2-ar71xx-generic_gcc-5.4.0_musl-1.1.16.Linux-x86_64/staging_dir/toolchain-mips_24kc_gcc-5.4.0_musl-1.1.16/bin/mips-openwrt-linux-musl-g++ | cc_mips24kc_be=/toolchains/lede-sdk-17.01.2-ar71xx-generic_gcc-5.4.0_musl-1.1.16.Linux-x86_64/staging_dir/toolchain-mips_24kc_gcc-5.4.0_musl-1.1.16/bin/mips-openwrt-linux-musl-g++ | ||||||
| cc_mips24kc_le=/toolchains/lede-sdk-17.01.2-ramips-mt7621_gcc-5.4.0_musl-1.1.16.Linux-x86_64/staging_dir/toolchain-mipsel_24kc_gcc-5.4.0_musl-1.1.16/bin/mipsel-openwrt-linux-musl-g++ | cc_mips24kc_le=/toolchains/lede-sdk-17.01.2-ramips-mt7621_gcc-5.4.0_musl-1.1.16.Linux-x86_64/staging_dir/toolchain-mipsel_24kc_gcc-5.4.0_musl-1.1.16/bin/mipsel-openwrt-linux-musl-g++ | ||||||
| #cc_arm= /toolchains/gcc-linaro-4.9.4-2017.01-x86_64_arm-linux-gnueabi/bin/arm-linux-gnueabi-g++ -march=armv6 -marm  | cc_arm= /toolchains/lede-sdk-17.01.2-bcm53xx_gcc-5.4.0_musl-1.1.16_eabi.Linux-x86_64/staging_dir/toolchain-arm_cortex-a9_gcc-5.4.0_musl-1.1.16_eabi/bin/arm-openwrt-linux-c++ | ||||||
| cc_arm= /toolchains/arm-2014.05/bin/arm-none-linux-gnueabi-g++ | cc_mingw_cross=i686-w64-mingw32-g++-posix | ||||||
| #cc_arm=/toolchains/lede-sdk-17.01.2-brcm2708-bcm2708_gcc-5.4.0_musl-1.1.16_eabi.Linux-x86_64/staging_dir/toolchain-arm_arm1176jzf-s+vfp_gcc-5.4.0_musl-1.1.16_eabi/bin/arm-openwrt-linux-muslgnueabi-g++ | cc_mac_cross=o64-clang++ -stdlib=libc++ | ||||||
|  | cc_x86=/toolchains/lede-sdk-17.01.2-x86-generic_gcc-5.4.0_musl-1.1.16.Linux-x86_64/staging_dir/toolchain-i386_pentium4_gcc-5.4.0_musl-1.1.16/bin/i486-openwrt-linux-c++ | ||||||
|  | cc_amd64=/toolchains/lede-sdk-17.01.2-x86-64_gcc-5.4.0_musl-1.1.16.Linux-x86_64/staging_dir/toolchain-x86_64_gcc-5.4.0_musl-1.1.16/bin/x86_64-openwrt-linux-c++ | ||||||
| #cc_bcm2708=/home/wangyu/raspberry/tools/arm-bcm2708/gcc-linaro-arm-linux-gnueabihf-raspbian/bin/arm-linux-gnueabihf-g++  | #cc_bcm2708=/home/wangyu/raspberry/tools/arm-bcm2708/gcc-linaro-arm-linux-gnueabihf-raspbian/bin/arm-linux-gnueabihf-g++  | ||||||
| cc_tmp= /home/wangyu/OpenWrt-SDK-15.05-x86-64_gcc-4.8-linaro_uClibc-0.9.33.2.Linux-x86_64/staging_dir/toolchain-x86_64_gcc-4.8-linaro_uClibc-0.9.33.2/bin/x86_64-openwrt-linux-uclibc-g++ |  | ||||||
|  |  | ||||||
| FLAGS= -std=c++11   -Wall -Wextra -Wno-unused-variable -Wno-unused-parameter -Wno-missing-field-initializers ${OPT} | FLAGS= -std=c++11   -Wall -Wextra -Wno-unused-variable -Wno-unused-parameter -Wno-missing-field-initializers ${OPT} | ||||||
|  |  | ||||||
| COMMON=main.cpp lib/md5.cpp lib/pbkdf2-sha1.cpp lib/pbkdf2-sha256.cpp encrypt.cpp log.cpp network.cpp common.cpp  connection.cpp misc.cpp fd_manager.cpp client.cpp server.cpp -lpthread my_ev.cpp -isystem libev | COMMON=main.cpp lib/md5.cpp lib/pbkdf2-sha1.cpp lib/pbkdf2-sha256.cpp encrypt.cpp log.cpp network.cpp common.cpp  connection.cpp misc.cpp fd_manager.cpp client.cpp server.cpp -lpthread | ||||||
| SOURCES= $(COMMON) lib/aes_faster_c/aes.cpp lib/aes_faster_c/wrapper.cpp |  | ||||||
| SOURCES_TINY_AES= $(COMMON) lib/aes.c | SOURCES0= $(COMMON) lib/aes_faster_c/aes.cpp lib/aes_faster_c/wrapper.cpp | ||||||
| SOURCES_AES_ACC=$(COMMON) $(wildcard lib/aes_acc/aes*.c) | SOURCES= ${SOURCES0} my_ev.cpp -isystem libev | ||||||
|  | SOURCES_AES_ACC= $(COMMON) $(wildcard lib/aes_acc/aes*.c) my_ev.cpp -isystem libev | ||||||
|  | PCAP="-lpcap" | ||||||
|  | MP="-DUDP2RAW_MP" | ||||||
|  |  | ||||||
|  |  | ||||||
| NAME=udp2raw | NAME=udp2raw | ||||||
| TARGETS=amd64 arm amd64_hw_aes arm_asm_aes mips24kc_be mips24kc_be_asm_aes x86 x86_asm_aes mips24kc_le mips24kc_le_asm_aes |  | ||||||
| TAR=${NAME}_binaries.tar.gz `echo ${TARGETS}|sed -r 's/([^ ]+)/udp2raw_\1/g'` version.txt |  | ||||||
|  |  | ||||||
|  | TARGETS=amd64 arm amd64_hw_aes arm_asm_aes mips24kc_be mips24kc_be_asm_aes x86 x86_asm_aes mips24kc_le mips24kc_le_asm_aes | ||||||
|  |  | ||||||
|  | TAR=${NAME}_binaries.tar.gz `echo ${TARGETS}|sed -r 's/([^ ]+)/${NAME}_\1/g'` version.txt | ||||||
|  |  | ||||||
|  | TARGETS_MP= mingw_cross mingw_cross_wepoll mac_cross | ||||||
|  |  | ||||||
|  | export STAGING_DIR=/tmp/    #just for supress warning of staging_dir not define | ||||||
|  |  | ||||||
|  | # targets for nativei (non-cross) compile  | ||||||
| all:git_version | all:git_version | ||||||
| 	rm -f ${NAME} | 	rm -f ${NAME} | ||||||
| 	${cc_local}   -o ${NAME}          -I. ${SOURCES} ${FLAGS} -lrt -ggdb -static -O3 | 	${cc_local}   -o ${NAME}          -I. ${SOURCES} ${FLAGS} -lrt -ggdb -static -O2 | ||||||
|  |  | ||||||
|  | #dynamic link | ||||||
|  | dynamic: git_version | ||||||
|  | 	${cc_local}   -o ${NAME}_$@          -I. ${SOURCES} ${FLAGS} -lrt -O2 | ||||||
|  |  | ||||||
|  | #targes for general cross compile | ||||||
|  |  | ||||||
|  | cross:git_version | ||||||
|  | 	${cc_cross}   -o ${NAME}_cross    -I. ${SOURCES} ${FLAGS} -lrt -O2 | ||||||
|  |  | ||||||
|  | cross2:git_version | ||||||
|  | 	${cc_cross}   -o ${NAME}_cross    -I. ${SOURCES} ${FLAGS} -lrt -static -lgcc_eh -O2 | ||||||
|  |  | ||||||
|  | cross3:git_version | ||||||
|  | 	${cc_cross}   -o ${NAME}_cross    -I. ${SOURCES} ${FLAGS} -lrt -static -O2 | ||||||
|  |  | ||||||
|  | #targets only for debug purpose | ||||||
| fast: git_version | fast: git_version | ||||||
| 	rm -f ${NAME} | 	rm -f ${NAME} | ||||||
| 	${cc_local}   -o ${NAME}          -I. ${SOURCES} ${FLAGS} -lrt -ggdb | 	${cc_local}   -o ${NAME}          -I. ${SOURCES} ${FLAGS} -lrt -ggdb | ||||||
| debug: git_version | debug: git_version | ||||||
| 	rm -f ${NAME} | 	rm -f ${NAME} | ||||||
| 	${cc_local}   -o ${NAME}          -I. ${SOURCES} ${FLAGS} -lrt -Wformat-nonliteral -D MY_DEBUG  | 	${cc_local}   -o ${NAME}          -I. ${SOURCES} ${FLAGS} -lrt -Wformat-nonliteral -D MY_DEBUG  -ggdb | ||||||
| debug2: git_version | debug2: git_version | ||||||
| 	rm -f ${NAME} | 	rm -f ${NAME} | ||||||
| 	${cc_local}   -o ${NAME}          -I. ${SOURCES} ${FLAGS} -lrt -Wformat-nonliteral -ggdb | 	${cc_local}   -o ${NAME}          -I. ${SOURCES} ${FLAGS} -lrt -Wformat-nonliteral -ggdb -fsanitize=address | ||||||
|  |  | ||||||
| dynamic: git_version | #targets only for 'make release' | ||||||
| 	${cc_local}   -o ${NAME}_$@          -I. ${SOURCES} ${FLAGS} -lrt -O3 |  | ||||||
|  |  | ||||||
| tmp:git_version |  | ||||||
| 	${cc_tmp}   -o ${NAME}_$@    -I. ${SOURCES} ${FLAGS} -lrt -lgcc_eh -static -O3 |  | ||||||
|  |  | ||||||
| mips24kc_be: git_version | mips24kc_be: git_version | ||||||
| 	${cc_mips24kc_be}  -o ${NAME}_$@   -I. ${SOURCES} ${FLAGS} -lrt -lgcc_eh -static -O3 | 	${cc_mips24kc_be}  -o ${NAME}_$@   -I. ${SOURCES} ${FLAGS} -lrt -lgcc_eh -static -O2 | ||||||
| mips24kc_be_asm_aes: git_version | mips24kc_be_asm_aes: git_version | ||||||
| 	${cc_mips24kc_be}  -o ${NAME}_$@   -I. ${SOURCES_AES_ACC} ${FLAGS} -lrt -lgcc_eh -static -O3 lib/aes_acc/asm/mips_be.S | 	${cc_mips24kc_be}  -o ${NAME}_$@   -I. ${SOURCES_AES_ACC} ${FLAGS} -lrt -lgcc_eh -static -O2 lib/aes_acc/asm/mips_be.S | ||||||
|  |  | ||||||
| mips24kc_le: git_version | mips24kc_le: git_version | ||||||
| 	${cc_mips24kc_le}  -o ${NAME}_$@   -I. ${SOURCES} ${FLAGS} -lrt -lgcc_eh -static -O3 | 	${cc_mips24kc_le}  -o ${NAME}_$@   -I. ${SOURCES} ${FLAGS} -lrt -lgcc_eh -static -O2 | ||||||
| mips24kc_le_asm_aes: git_version | mips24kc_le_asm_aes: git_version | ||||||
| 	${cc_mips24kc_le}  -o ${NAME}_$@   -I. ${SOURCES_AES_ACC} ${FLAGS} -lrt -lgcc_eh -static -O3 lib/aes_acc/asm/mips.S | 	${cc_mips24kc_le}  -o ${NAME}_$@   -I. ${SOURCES_AES_ACC} ${FLAGS} -lrt -lgcc_eh -static -O2 lib/aes_acc/asm/mips.S | ||||||
|  |  | ||||||
| #bcm2708: |  | ||||||
| #	${cc_bcm2708} -o ${NAME}_bcm2708  -I. ${SOURCES} ${FLAGS} -lrt -static -O3 |  | ||||||
| amd64:git_version | amd64:git_version | ||||||
| 	${cc_local}   -o ${NAME}_$@    -I. ${SOURCES} ${FLAGS} -lrt -static -O3 | 	${cc_amd64}   -o ${NAME}_$@    -I. ${SOURCES} ${FLAGS} -lrt -static -O2 -lgcc_eh -ggdb | ||||||
|  |  | ||||||
| amd64_perf:git_version |  | ||||||
| 	${cc_local}   -o ${NAME}_$@    -I. ${SOURCES} ${FLAGS} -lrt -static -O0 -fno-omit-frame-pointer -g |  | ||||||
|  |  | ||||||
| amd64_hw_aes:git_version | amd64_hw_aes:git_version | ||||||
| 	${cc_local}   -o ${NAME}_$@   -I. ${SOURCES_AES_ACC} ${FLAGS} -lrt -static -O3 lib/aes_acc/asm/x64.S | 	${cc_amd64}   -o ${NAME}_$@   -I. ${SOURCES_AES_ACC} ${FLAGS} -lrt -static -O2 lib/aes_acc/asm/x64.S -lgcc_eh -ggdb | ||||||
| x86:git_version | x86:git_version | ||||||
| 	${cc_local}   -o ${NAME}_$@      -I. ${SOURCES} ${FLAGS} -lrt -static -O3 -m32 | 	${cc_x86}   -o ${NAME}_$@      -I. ${SOURCES} ${FLAGS} -lrt -static -O2 -lgcc_eh -ggdb | ||||||
| x86_asm_aes:git_version | x86_asm_aes:git_version | ||||||
| 	${cc_local}   -o ${NAME}_$@    -I. ${SOURCES_AES_ACC} ${FLAGS} -lrt -static -O3 -m32 lib/aes_acc/asm/x86.S | 	${cc_x86}   -o ${NAME}_$@    -I. ${SOURCES_AES_ACC} ${FLAGS} -lrt -static -O2 lib/aes_acc/asm/x86.S -lgcc_eh -ggdb | ||||||
| arm:git_version | arm:git_version | ||||||
| 	${cc_arm}   -o ${NAME}_$@      -I. ${SOURCES} ${FLAGS} -lrt -static -O3 | 	${cc_arm}   -o ${NAME}_$@      -I. ${SOURCES} ${FLAGS} -lrt -static -O2 -lgcc_eh | ||||||
|  |  | ||||||
| arm_perf:git_version |  | ||||||
| 	${cc_arm}   -o ${NAME}_$@      -I. ${SOURCES} ${FLAGS} -lrt -static -mapcs-frame -fno-omit-frame-pointer -g -O0 -lgcc_eh |  | ||||||
|  |  | ||||||
| arm_asm_aes:git_version | arm_asm_aes:git_version | ||||||
| 	${cc_arm}   -o ${NAME}_$@    -I. ${SOURCES_AES_ACC} ${FLAGS} -lrt -static -O3 lib/aes_acc/asm/arm.S | 	${cc_arm}   -o ${NAME}_$@    -I. ${SOURCES_AES_ACC} ${FLAGS} -lrt -static -O2 lib/aes_acc/asm/arm.S -lgcc_eh | ||||||
|  |  | ||||||
| cross:git_version |  | ||||||
| 	${cc_cross}   -o ${NAME}_cross    -I. ${SOURCES} ${FLAGS} -lrt -O3 |  | ||||||
|  |  | ||||||
| cross2:git_version |  | ||||||
| 	${cc_cross}   -o ${NAME}_cross    -I. ${SOURCES} ${FLAGS} -lrt -static -lgcc_eh -O3    |  | ||||||
|  |  | ||||||
| cross3:git_version |  | ||||||
| 	${cc_cross}   -o ${NAME}_cross    -I. ${SOURCES} ${FLAGS} -lrt -static -O3 |  | ||||||
|  |  | ||||||
| release: ${TARGETS} | release: ${TARGETS} | ||||||
| 	cp git_version.h version.txt | 	cp git_version.h version.txt | ||||||
| 	tar -zcvf ${TAR} | 	tar -zcvf ${TAR} | ||||||
|  |  | ||||||
|  | #targets for multi-platform version (native compile) | ||||||
|  | cygwin:git_version | ||||||
|  | 	${cc_local}   -o ${NAME}_$@          -I. ${SOURCES} pcap_wrapper.cpp ${FLAGS} -lrt -ggdb -static -O2 -D_GNU_SOURCE ${MP} | ||||||
|  |  | ||||||
|  | mingw:git_version | ||||||
|  | 	${cc_local}   -o ${NAME}_$@         -I. ${SOURCES} pcap_wrapper.cpp ${FLAGS} -ggdb -static -O2 -lws2_32 ${MP} | ||||||
|  |  | ||||||
|  | mingw_wepoll:git_version | ||||||
|  | 	${cc_local}   -o ${NAME}_$@        -I. ${SOURCES0} pcap_wrapper.cpp ${FLAGS} -ggdb -static -O2 -DNO_LIBEV_EMBED -D_WIN32 -lev -lws2_32 ${MP} | ||||||
|  |  | ||||||
|  | linux:git_version | ||||||
|  | 	${cc_local}   -o ${NAME}_$@          -I. ${SOURCES} ${PCAP} ${FLAGS} -lrt -ggdb -static -O2 ${MP} | ||||||
|  |  | ||||||
|  | freebsd:git_version | ||||||
|  | 	${cc_local}   -o ${NAME}_$@        -I. ${SOURCES} ${PCAP} ${FLAGS} -lrt -ggdb -static -libverbs -O2 ${MP} | ||||||
|  |  | ||||||
|  | mac:git_version | ||||||
|  | 	${cc_local}   -o ${NAME}_$@        -I. ${SOURCES} ${PCAP} ${FLAGS} -ggdb -O2 ${MP} | ||||||
|  |  | ||||||
|  | #targets for multi-platform version (cross compile) | ||||||
|  |  | ||||||
|  | mingw_cross:git_version | ||||||
|  | 	${cc_mingw_cross}   -o ${NAME}_mp.exe          -I. ${SOURCES} pcap_wrapper.cpp ${FLAGS} -ggdb -static -O2 -lws2_32 ${MP} | ||||||
|  |  | ||||||
|  | mingw_cross_wepoll:git_version | ||||||
|  | 	${cc_mingw_cross}   -o ${NAME}_mp_wepoll.exe   -I. ${SOURCES0} pcap_wrapper.cpp ${FLAGS} -ggdb -static -O2 -DNO_LIBEV_EMBED -D_WIN32 -lev -lws2_32 ${MP} | ||||||
|  |  | ||||||
|  | mac_cross:git_version | ||||||
|  | 	${cc_mac_cross}   -o ${NAME}_mp_mac            -I. ${SOURCES} ${PCAP} ${FLAGS} -ggdb -O2 ${MP} | ||||||
|  |  | ||||||
|  | release_mp:${TARGETS_MP} | ||||||
|  | 	cp git_version.h version.txt | ||||||
|  | 	tar -zcvf ${NAME}_mp_binaries.tar.gz ${NAME}_mp.exe ${NAME}_mp_wepoll.exe ${NAME}_mp_mac version.txt | ||||||
|  |  | ||||||
|  |  | ||||||
| clean:	 | clean:	 | ||||||
| 	rm -f ${TAR} | 	rm -f ${TAR} | ||||||
| 	rm -f udp2raw udp2raw_cross udp2raw_cmake udp2raw_dynamic | 	rm -f ${NAME} ${NAME}_cross ${NAME}.exe ${NAME}_wepoll.exe ${NAME}_mac | ||||||
|  | 	rm -f ${NAME}_mp_binaries.tar.gz ${NAME}_mp.exe ${NAME}_mp_wepoll.exe ${NAME}_mp_mac | ||||||
| 	rm -f git_version.h | 	rm -f git_version.h | ||||||
|  |  | ||||||
| git_version: | git_version: | ||||||
| 	    echo "const char *gitversion = \"$(shell git rev-parse HEAD)\";" > git_version.h | 	    echo "const char *gitversion = \"$(shell git rev-parse HEAD)\";" > git_version.h | ||||||
| 	 |  | ||||||
|   | |||||||
							
								
								
									
										32
									
								
								misc.h
									
									
									
									
									
								
							
							
						
						
									
										32
									
								
								misc.h
									
									
									
									
									
								
							| @@ -8,7 +8,6 @@ | |||||||
| #ifndef MISC_H_ | #ifndef MISC_H_ | ||||||
| #define MISC_H_ | #define MISC_H_ | ||||||
|  |  | ||||||
|  |  | ||||||
| #include "common.h" | #include "common.h" | ||||||
| #include "log.h" | #include "log.h" | ||||||
| #include "network.h" | #include "network.h" | ||||||
| @@ -26,7 +25,6 @@ extern int enable_dns_resolve; | |||||||
|  |  | ||||||
| extern int ttl_value; | extern int ttl_value; | ||||||
|  |  | ||||||
|  |  | ||||||
| const u32_t max_handshake_conn_num = 10000; | const u32_t max_handshake_conn_num = 10000; | ||||||
| const u32_t max_ready_conn_num = 1000; | const u32_t max_ready_conn_num = 1000; | ||||||
| const u32_t anti_replay_window_size = 4000; | const u32_t anti_replay_window_size = 4000; | ||||||
| @@ -45,7 +43,6 @@ const int conn_clear_min=1; | |||||||
| const u32_t conv_clear_interval = 1000;  // ms | const u32_t conv_clear_interval = 1000;  // ms | ||||||
| const u32_t conn_clear_interval = 1000;  // ms | const u32_t conn_clear_interval = 1000;  // ms | ||||||
|  |  | ||||||
|  |  | ||||||
| const i32_t max_fail_time = 0;  // disable | const i32_t max_fail_time = 0;  // disable | ||||||
|  |  | ||||||
| const u32_t heartbeat_interval = 600;  // ms | const u32_t heartbeat_interval = 600;  // ms | ||||||
| @@ -63,14 +60,25 @@ const uint32_t server_conn_timeout=conv_timeout+60000;//ms. this should be 60s+ | |||||||
|  |  | ||||||
| const u32_t iptables_rule_keep_interval = 20;  // unit: second; | const u32_t iptables_rule_keep_interval = 20;  // unit: second; | ||||||
|  |  | ||||||
| enum server_current_state_t {server_idle=0,server_handshake1,server_ready};  //server state machine | enum server_current_state_t { server_idle = 0, | ||||||
| enum client_current_state_t {client_idle=0,client_tcp_handshake,client_handshake1,client_handshake2,client_ready,client_tcp_handshake_dummy};//client state machine |                               server_handshake1, | ||||||
|  |                               server_ready };  // server state machine | ||||||
|  | enum client_current_state_t { client_idle = 0, | ||||||
|  |                               client_tcp_handshake, | ||||||
|  |                               client_handshake1, | ||||||
|  |                               client_handshake2, | ||||||
|  |                               client_ready, | ||||||
|  |                               client_tcp_handshake_dummy };  // client state machine | ||||||
|  |  | ||||||
| enum raw_mode_t{mode_faketcp=0,mode_udp,mode_icmp,mode_end}; | enum raw_mode_t { mode_faketcp = 0, | ||||||
| enum program_mode_t {unset_mode=0,client_mode,server_mode}; |                   mode_udp, | ||||||
|  |                   mode_icmp, | ||||||
|  |                   mode_end }; | ||||||
|  | enum program_mode_t { unset_mode = 0, | ||||||
|  |                       client_mode, | ||||||
|  |                       server_mode }; | ||||||
|  |  | ||||||
| union current_state_t | union current_state_t { | ||||||
| { |  | ||||||
|     server_current_state_t server_current_state; |     server_current_state_t server_current_state; | ||||||
|     client_current_state_t client_current_state; |     client_current_state_t client_current_state; | ||||||
| }; | }; | ||||||
| @@ -99,7 +107,6 @@ extern int fail_time_counter;//determine if the max_fail_time is reached | |||||||
| extern int epoll_trigger_counter;  // for debug only | extern int epoll_trigger_counter;  // for debug only | ||||||
| extern int debug_flag;             // for debug only | extern int debug_flag;             // for debug only | ||||||
|  |  | ||||||
|  |  | ||||||
| extern int simple_rule;                 // deprecated. | extern int simple_rule;                 // deprecated. | ||||||
| extern int keep_rule;                   // whether to monitor the iptables rule periodly,re-add if losted | extern int keep_rule;                   // whether to monitor the iptables rule periodly,re-add if losted | ||||||
| extern int auto_add_iptables_rule;      // if -a is set | extern int auto_add_iptables_rule;      // if -a is set | ||||||
| @@ -113,7 +120,6 @@ extern int debug_resend; // debug only | |||||||
| extern char key_string[1000];  // -k option | extern char key_string[1000];  // -k option | ||||||
| extern char fifo_file[1000]; | extern char fifo_file[1000]; | ||||||
|  |  | ||||||
|  |  | ||||||
| extern raw_mode_t raw_mode; | extern raw_mode_t raw_mode; | ||||||
| extern u32_t raw_ip_version; | extern u32_t raw_ip_version; | ||||||
|  |  | ||||||
| @@ -124,11 +130,9 @@ extern int about_to_exit; | |||||||
|  |  | ||||||
| extern int socket_buf_size; | extern int socket_buf_size; | ||||||
|  |  | ||||||
|  |  | ||||||
| extern pthread_t keep_thread; | extern pthread_t keep_thread; | ||||||
| extern int keep_thread_running; | extern int keep_thread_running; | ||||||
|  |  | ||||||
|  |  | ||||||
| int process_lower_level_arg(); | int process_lower_level_arg(); | ||||||
| void print_help(); | void print_help(); | ||||||
| void iptables_rule(); | void iptables_rule(); | ||||||
| @@ -146,8 +150,6 @@ int iptables_gen_add(const char * s,u32_t const_id); | |||||||
| int iptables_rule_init(const char *s, u32_t const_id, int keep); | int iptables_rule_init(const char *s, u32_t const_id, int keep); | ||||||
| int keep_iptables_rule(); | int keep_iptables_rule(); | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| void signal_handler(int sig); | void signal_handler(int sig); | ||||||
|  |  | ||||||
| #endif /* MISC_H_ */ | #endif /* MISC_H_ */ | ||||||
|   | |||||||
							
								
								
									
										1
									
								
								my_ev.h
									
									
									
									
									
								
							
							
						
						
									
										1
									
								
								my_ev.h
									
									
									
									
									
								
							| @@ -2,4 +2,3 @@ | |||||||
|  |  | ||||||
| #include "my_ev_common.h" | #include "my_ev_common.h" | ||||||
| #include "ev.h" | #include "ev.h" | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1,6 +1,8 @@ | |||||||
|  |  | ||||||
| #define EV_STANDALONE 1 | #define EV_STANDALONE 1 | ||||||
| #define EV_COMMON  void *data; unsigned long long u64; | #define EV_COMMON \ | ||||||
|  |     void *data;   \ | ||||||
|  |     unsigned long long u64; | ||||||
| #define EV_COMPAT3 0 | #define EV_COMPAT3 0 | ||||||
|  |  | ||||||
| //#include <wepoll.h> | //#include <wepoll.h> | ||||||
| @@ -15,4 +17,3 @@ | |||||||
|  |  | ||||||
| #endif | #endif | ||||||
| //#define EV_VERIFY 2 | //#define EV_VERIFY 2 | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										1391
									
								
								network.cpp
									
									
									
									
									
								
							
							
						
						
									
										1391
									
								
								network.cpp
									
									
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										67
									
								
								network.h
									
									
									
									
									
								
							
							
						
						
									
										67
									
								
								network.h
									
									
									
									
									
								
							| @@ -30,9 +30,33 @@ extern int ifindex; | |||||||
| extern char g_packet_buf[huge_buf_len]; | extern char g_packet_buf[huge_buf_len]; | ||||||
| extern int g_packet_buf_len; | extern int g_packet_buf_len; | ||||||
| extern int g_packet_buf_cnt; | extern int g_packet_buf_cnt; | ||||||
|  | #ifdef UDP2RAW_MP | ||||||
|  | extern queue_t my_queue; | ||||||
|  |  | ||||||
| struct my_iphdr | extern ev_async async_watcher; | ||||||
|   { | extern struct ev_loop *g_default_loop; | ||||||
|  |  | ||||||
|  | extern pthread_mutex_t queue_mutex; | ||||||
|  | extern int use_pcap_mutex; | ||||||
|  |  | ||||||
|  | extern int pcap_cnt; | ||||||
|  |  | ||||||
|  | extern int pcap_link_header_len; | ||||||
|  |  | ||||||
|  | extern int send_with_pcap; | ||||||
|  | extern int pcap_header_captured; | ||||||
|  | extern int pcap_header_buf[buf_len]; | ||||||
|  |  | ||||||
|  | struct icmphdr { | ||||||
|  |     uint8_t type; | ||||||
|  |     uint8_t code; | ||||||
|  |     uint16_t check_sum; | ||||||
|  |     uint16_t id; | ||||||
|  |     uint16_t seq; | ||||||
|  | }; | ||||||
|  | #endif | ||||||
|  |  | ||||||
|  | struct my_iphdr { | ||||||
| #ifdef UDP2RAW_LITTLE_ENDIAN | #ifdef UDP2RAW_LITTLE_ENDIAN | ||||||
|     unsigned char ihl : 4; |     unsigned char ihl : 4; | ||||||
|     unsigned char version : 4; |     unsigned char version : 4; | ||||||
| @@ -52,11 +76,8 @@ struct my_iphdr | |||||||
|     /*The options start here. */ |     /*The options start here. */ | ||||||
| }; | }; | ||||||
|  |  | ||||||
|  | struct my_udphdr { | ||||||
| struct my_udphdr |     /*__extension__*/ union { | ||||||
| { |  | ||||||
|   /*__extension__*/ union |  | ||||||
|   { |  | ||||||
|         struct |         struct | ||||||
|         { |         { | ||||||
|             u_int16_t uh_sport; /* source port */ |             u_int16_t uh_sport; /* source port */ | ||||||
| @@ -74,11 +95,8 @@ struct my_udphdr | |||||||
|     }; |     }; | ||||||
| }; | }; | ||||||
|  |  | ||||||
|  | struct my_tcphdr { | ||||||
| struct my_tcphdr |     /*__extension__*/ union { | ||||||
|   { |  | ||||||
|     /*__extension__*/ union |  | ||||||
|     { |  | ||||||
|         struct |         struct | ||||||
|         { |         { | ||||||
|             u_int16_t th_sport; /* source port */ |             u_int16_t th_sport; /* source port */ | ||||||
| @@ -137,8 +155,7 @@ struct my_tcphdr | |||||||
|     }; |     }; | ||||||
| }; | }; | ||||||
|  |  | ||||||
| struct my_ip6hdr | struct my_ip6hdr { | ||||||
|   { |  | ||||||
| #ifdef UDP2RAW_LITTLE_ENDIAN | #ifdef UDP2RAW_LITTLE_ENDIAN | ||||||
|     uint8_t traffic_class_high : 4; |     uint8_t traffic_class_high : 4; | ||||||
|     uint8_t version : 4; |     uint8_t version : 4; | ||||||
| @@ -159,8 +176,7 @@ struct my_ip6hdr | |||||||
|     struct in6_addr dst; |     struct in6_addr dst; | ||||||
| }; | }; | ||||||
|  |  | ||||||
| struct my_icmphdr | struct my_icmphdr { | ||||||
| { |  | ||||||
|     uint8_t type; |     uint8_t type; | ||||||
|     uint8_t code; |     uint8_t code; | ||||||
|     uint16_t check_sum; |     uint16_t check_sum; | ||||||
| @@ -189,7 +205,6 @@ struct packet_info_t  //todo change this to union | |||||||
| { | { | ||||||
|     uint8_t protocol; |     uint8_t protocol; | ||||||
|  |  | ||||||
|  |  | ||||||
|     // u32_t src_ip; |     // u32_t src_ip; | ||||||
|     // u32_t dst_ip; |     // u32_t dst_ip; | ||||||
|     my_ip_t new_src_ip; |     my_ip_t new_src_ip; | ||||||
| @@ -207,20 +222,20 @@ struct packet_info_t  //todo change this to union | |||||||
|  |  | ||||||
|     u32_t ts, ts_ack; |     u32_t ts, ts_ack; | ||||||
|  |  | ||||||
|  |  | ||||||
|     uint16_t my_icmp_seq; |     uint16_t my_icmp_seq; | ||||||
|  |  | ||||||
|     bool has_ts; |     bool has_ts; | ||||||
|  |  | ||||||
| 	sockaddr_ll addr_ll; |  | ||||||
|  |  | ||||||
|     i32_t data_len; |     i32_t data_len; | ||||||
|  |  | ||||||
|  | #ifdef UDP2RAW_LINUX | ||||||
|  |     sockaddr_ll addr_ll; | ||||||
|  | #endif | ||||||
|  |  | ||||||
|     packet_info_t(); |     packet_info_t(); | ||||||
| }; | }; | ||||||
|  |  | ||||||
| struct raw_info_t | struct raw_info_t { | ||||||
| { |  | ||||||
|     packet_info_t send_info; |     packet_info_t send_info; | ||||||
|     packet_info_t recv_info; |     packet_info_t recv_info; | ||||||
|     // int last_send_len; |     // int last_send_len; | ||||||
| @@ -234,14 +249,19 @@ struct raw_info_t | |||||||
|  |  | ||||||
| };  // g_raw_info; | };  // g_raw_info; | ||||||
|  |  | ||||||
|  |  | ||||||
| int init_raw_socket(); | int init_raw_socket(); | ||||||
|  |  | ||||||
| void init_filter(int port); | void init_filter(int port); | ||||||
|  |  | ||||||
| void remove_filter(); | void remove_filter(); | ||||||
|  |  | ||||||
|  | #ifdef UDP2RAW_LINUX | ||||||
| int init_ifindex(const char *if_name, int fd, int &index); | int init_ifindex(const char *if_name, int fd, int &index); | ||||||
|  | #endif | ||||||
|  |  | ||||||
|  | #ifdef UDP2RAW_MP | ||||||
|  | int init_ifindex(const char *if_name, int &index); | ||||||
|  | #endif | ||||||
|  |  | ||||||
| int find_lower_level_info(u32_t ip, u32_t &dest_ip, string &if_name, string &hw); | int find_lower_level_info(u32_t ip, u32_t &dest_ip, string &if_name, string &hw); | ||||||
|  |  | ||||||
| @@ -287,5 +307,4 @@ int after_send_raw0(raw_info_t &raw_info); | |||||||
|  |  | ||||||
| int after_recv_raw0(raw_info_t &raw_info); | int after_recv_raw0(raw_info_t &raw_info); | ||||||
|  |  | ||||||
|  |  | ||||||
| #endif /* NETWORK_H_ */ | #endif /* NETWORK_H_ */ | ||||||
|   | |||||||
							
								
								
									
										119
									
								
								pcap_wrapper.cpp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										119
									
								
								pcap_wrapper.cpp
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,119 @@ | |||||||
|  | #include <windows.h> | ||||||
|  | #include <pcap_wrapper.h> | ||||||
|  | #include <assert.h> | ||||||
|  | #include <stdio.h> | ||||||
|  | int (*pcap_loop)(pcap_t *, int, pcap_handler, u_char *); | ||||||
|  | int (*pcap_breakloop)(pcap_t *); | ||||||
|  |  | ||||||
|  | pcap_t *(*pcap_create)(const char *, char *); | ||||||
|  |  | ||||||
|  | int (*pcap_set_snaplen)(pcap_t *, int) = 0; | ||||||
|  | int (*pcap_set_promisc)(pcap_t *, int) = 0; | ||||||
|  | int (*pcap_can_set_rfmon)(pcap_t *) = 0; | ||||||
|  | int (*pcap_set_rfmon)(pcap_t *, int) = 0; | ||||||
|  | int (*pcap_set_timeout)(pcap_t *, int) = 0; | ||||||
|  | int (*pcap_set_buffer_size)(pcap_t *, int) = 0; | ||||||
|  | int (*pcap_activate)(pcap_t *) = 0; | ||||||
|  |  | ||||||
|  | int (*pcap_setfilter)(pcap_t *, struct bpf_program *) = 0; | ||||||
|  | int (*pcap_setdirection)(pcap_t *, pcap_direction_t) = 0; | ||||||
|  |  | ||||||
|  | int (*pcap_datalink)(pcap_t *) = 0; | ||||||
|  |  | ||||||
|  | void (*pcap_freecode)(struct bpf_program *) = 0; | ||||||
|  |  | ||||||
|  | int (*pcap_compile)(pcap_t *, struct bpf_program *, const char *, int, | ||||||
|  |                     bpf_u_int32) = 0; | ||||||
|  |  | ||||||
|  | char *(*pcap_geterr)(pcap_t *) = 0; | ||||||
|  | int (*pcap_sendpacket)(pcap_t *, const u_char *, int) = 0; | ||||||
|  |  | ||||||
|  | char *(*pcap_lookupdev)(char *) = 0; | ||||||
|  |  | ||||||
|  | int (*pcap_findalldevs)(pcap_if_t **, char *) = 0; | ||||||
|  |  | ||||||
|  | struct init_pcap_t { | ||||||
|  |     init_pcap_t() { | ||||||
|  |         init_pcap(); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  | } do_it; | ||||||
|  |  | ||||||
|  | static void init_npcap_dll_path() { | ||||||
|  |     BOOL(WINAPI * SetDllDirectory) | ||||||
|  |     (LPCTSTR); | ||||||
|  |     char sysdir_name[512]; | ||||||
|  |     int len; | ||||||
|  |  | ||||||
|  |     SetDllDirectory = (BOOL(WINAPI *)(LPCTSTR))GetProcAddress(GetModuleHandle("kernel32.dll"), "SetDllDirectoryA"); | ||||||
|  |     if (SetDllDirectory == NULL) { | ||||||
|  |         printf("Error in SetDllDirectory\n"); | ||||||
|  |     } else { | ||||||
|  |         len = GetSystemDirectory(sysdir_name, 480);  //	be safe | ||||||
|  |         if (!len) | ||||||
|  |             printf("Error in GetSystemDirectory (%d)\n", (int)GetLastError()); | ||||||
|  |         strcat(sysdir_name, "\\Npcap"); | ||||||
|  |         if (SetDllDirectory(sysdir_name) == 0) | ||||||
|  |             printf("Error in SetDllDirectory(\"System32\\Npcap\")\n"); | ||||||
|  |     } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | #define EXPORT_FUN(XXX)                                     \ | ||||||
|  |     do {                                                    \ | ||||||
|  |         XXX = (__typeof__(XXX))GetProcAddress(wpcap, #XXX); \ | ||||||
|  |     } while (0) | ||||||
|  | int init_pcap() { | ||||||
|  |     HMODULE wpcap = LoadLibrary("wpcap.dll"); | ||||||
|  |     if (wpcap != 0) { | ||||||
|  |         printf("using system32/wpcap.dll\n"); | ||||||
|  |     } else { | ||||||
|  |         init_npcap_dll_path(); | ||||||
|  |         // SetDllDirectory("C:\\Windows\\System32\\Npcap\\"); | ||||||
|  |         wpcap = LoadLibrary("wpcap.dll"); | ||||||
|  |         if (wpcap != 0) | ||||||
|  |             printf("using system32/npcap/wpcap.dll\n"); | ||||||
|  |     } | ||||||
|  |     if (wpcap == 0) { | ||||||
|  |         printf("cant not open wpcap.dll, make sure winpcap/npcap is installed\n"); | ||||||
|  |         exit(-1); | ||||||
|  |     } | ||||||
|  |     assert(wpcap != 0); | ||||||
|  |  | ||||||
|  |     EXPORT_FUN(pcap_loop); | ||||||
|  |     EXPORT_FUN(pcap_breakloop); | ||||||
|  |     EXPORT_FUN(pcap_create); | ||||||
|  |     EXPORT_FUN(pcap_set_snaplen); | ||||||
|  |     EXPORT_FUN(pcap_set_promisc); | ||||||
|  |     EXPORT_FUN(pcap_set_timeout); | ||||||
|  |     EXPORT_FUN(pcap_activate); | ||||||
|  |     EXPORT_FUN(pcap_setfilter); | ||||||
|  |     EXPORT_FUN(pcap_setdirection); | ||||||
|  |     EXPORT_FUN(pcap_datalink); | ||||||
|  |     EXPORT_FUN(pcap_freecode); | ||||||
|  |     EXPORT_FUN(pcap_compile); | ||||||
|  |     EXPORT_FUN(pcap_geterr); | ||||||
|  |     EXPORT_FUN(pcap_sendpacket); | ||||||
|  |     EXPORT_FUN(pcap_lookupdev); | ||||||
|  |     EXPORT_FUN(pcap_findalldevs); | ||||||
|  |     /* | ||||||
|  |     pcap_loop = (__typeof__(pcap_loop))GetProcAddress(wpcap, "pcap_loop"); | ||||||
|  |     pcap_create = (__typeof__(pcap_create))GetProcAddress(wpcap, "pcap_create"); | ||||||
|  |     pcap_set_snaplen = (__typeof__(pcap_set_snaplen))GetProcAddress(wpcap, "pcap_set_snaplen"); | ||||||
|  |     pcap_set_promisc = (__typeof__(pcap_set_promisc))GetProcAddress(wpcap, "pcap_set_promisc"); | ||||||
|  |     pcap_set_timeout = (__typeof__(pcap_set_timeout))GetProcAddress(wpcap, "pcap_set_timeout"); | ||||||
|  |     pcap_activate = (__typeof__(pcap_activate))GetProcAddress(wpcap, "pcap_activate"); | ||||||
|  |     pcap_setfilter = (__typeof__(pcap_setfilter))GetProcAddress(wpcap, "pcap_setfilter"); | ||||||
|  |     pcap_setdirection = (__typeof__(pcap_setdirection))GetProcAddress(wpcap, "pcap_setdirection"); | ||||||
|  |     pcap_datalink = (__typeof__(pcap_datalink))GetProcAddress(wpcap, "pcap_datalink"); | ||||||
|  |     pcap_freecode = (__typeof__(pcap_freecode))GetProcAddress(wpcap, "pcap_freecode"); | ||||||
|  |     pcap_compile = (__typeof__(pcap_compile))GetProcAddress(wpcap, "pcap_compile"); | ||||||
|  |     pcap_geterr = (__typeof__(pcap_geterr))GetProcAddress(wpcap, "pcap_geterr"); | ||||||
|  |     pcap_sendpacket = (__typeof__(pcap_sendpacket))GetProcAddress(wpcap, "pcap_sendpacket"); | ||||||
|  |     pcap_lookupdev = (__typeof__(pcap_lookupdev))GetProcAddress(wpcap, "pcap_lookupdev"); | ||||||
|  |     pcap_findalldevs = (__typeof__(pcap_findalldevs))GetProcAddress(wpcap, "pcap_findalldevs"); | ||||||
|  |     //pcap_loop = (__typeof__(pcap_loop))GetProcAddress(wpcap, "pcap_loop"); | ||||||
|  |     //pcap_loop = (__typeof__(pcap_loop))GetProcAddress(wpcap, "pcap_loop"); | ||||||
|  |     //pcap_loop = (__typeof__(pcap_loop))GetProcAddress(wpcap, "pcap_loop"); | ||||||
|  |     */ | ||||||
|  |     return 0; | ||||||
|  | } | ||||||
							
								
								
									
										117
									
								
								pcap_wrapper.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										117
									
								
								pcap_wrapper.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,117 @@ | |||||||
|  | #pragma once | ||||||
|  |  | ||||||
|  | //#ifdef __cplusplus | ||||||
|  | // extern "C" { | ||||||
|  | //#endif | ||||||
|  |  | ||||||
|  | //#include <sys/time.h> | ||||||
|  | //#include <stdint.h> | ||||||
|  |  | ||||||
|  | struct bpf_program { | ||||||
|  |     char a[4096]; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | struct pcap_t { | ||||||
|  |     char a[4096]; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | typedef unsigned int bpf_u_int32; | ||||||
|  |  | ||||||
|  | typedef struct my_timeval { | ||||||
|  |     int tv_sec; | ||||||
|  |     int tv_usec; | ||||||
|  | } my_timeval; | ||||||
|  |  | ||||||
|  | struct pcap_pkthdr { | ||||||
|  |     struct my_timeval ts; /* time stamp */ | ||||||
|  |     bpf_u_int32 caplen;   /* length of portion present */ | ||||||
|  |     bpf_u_int32 len;      /* length this packet (off wire) */ | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | typedef enum { | ||||||
|  |     PCAP_D_INOUT = 0, | ||||||
|  |     PCAP_D_IN, | ||||||
|  |     PCAP_D_OUT | ||||||
|  | } pcap_direction_t; | ||||||
|  |  | ||||||
|  | struct pcap_addr { | ||||||
|  |     struct pcap_addr *next; | ||||||
|  |     struct sockaddr *addr;      /* address */ | ||||||
|  |     struct sockaddr *netmask;   /* netmask for that address */ | ||||||
|  |     struct sockaddr *broadaddr; /* broadcast address for that address */ | ||||||
|  |     struct sockaddr *dstaddr;   /* P2P destination address for that address */ | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | struct pcap_if { | ||||||
|  |     struct pcap_if *next; | ||||||
|  |     char *name;        /* name to hand to "pcap_open_live()" */ | ||||||
|  |     char *description; /* textual description of interface, or NULL */ | ||||||
|  |     struct pcap_addr *addresses; | ||||||
|  |     bpf_u_int32 flags; /* PCAP_IF_ interface flags */ | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | typedef struct pcap_if pcap_if_t; | ||||||
|  | typedef struct pcap_addr pcap_addr_t; | ||||||
|  |  | ||||||
|  | typedef unsigned char u_char; | ||||||
|  |  | ||||||
|  | #define PCAP_ERRBUF_SIZE 256 | ||||||
|  |  | ||||||
|  | #define DLT_NULL 0    /* BSD loopback encapsulation */ | ||||||
|  | #define DLT_EN10MB 1  /* Ethernet (10Mb) */ | ||||||
|  | #define DLT_EN3MB 2   /* Experimental Ethernet (3Mb) */ | ||||||
|  | #define DLT_AX25 3    /* Amateur Radio AX.25 */ | ||||||
|  | #define DLT_PRONET 4  /* Proteon ProNET Token Ring */ | ||||||
|  | #define DLT_CHAOS 5   /* Chaos */ | ||||||
|  | #define DLT_IEEE802 6 /* 802.5 Token Ring */ | ||||||
|  | #define DLT_ARCNET 7  /* ARCNET, with BSD-style header */ | ||||||
|  | #define DLT_SLIP 8    /* Serial Line IP */ | ||||||
|  | #define DLT_PPP 9     /* Point-to-point Protocol */ | ||||||
|  | #define DLT_FDDI 10   /* FDDI */ | ||||||
|  | #define DLT_LINUX_SLL 113 | ||||||
|  |  | ||||||
|  | #define PCAP_NETMASK_UNKNOWN 0xffffffff | ||||||
|  |  | ||||||
|  | typedef void (*pcap_handler)(u_char *, const struct pcap_pkthdr *, | ||||||
|  |                              const u_char *); | ||||||
|  |  | ||||||
|  | extern int (*pcap_loop)(pcap_t *, int, pcap_handler, u_char *); | ||||||
|  |  | ||||||
|  | extern int (*pcap_breakloop)(pcap_t *); | ||||||
|  |  | ||||||
|  | extern pcap_t *(*pcap_create)(const char *, char *); | ||||||
|  |  | ||||||
|  | extern int (*pcap_set_snaplen)(pcap_t *, int); | ||||||
|  | extern int (*pcap_set_promisc)(pcap_t *, int); | ||||||
|  | extern int (*pcap_can_set_rfmon)(pcap_t *); | ||||||
|  | extern int (*pcap_set_rfmon)(pcap_t *, int); | ||||||
|  | extern int (*pcap_set_timeout)(pcap_t *, int); | ||||||
|  | extern int (*pcap_set_buffer_size)(pcap_t *, int); | ||||||
|  | extern int (*pcap_activate)(pcap_t *); | ||||||
|  |  | ||||||
|  | extern int (*pcap_setfilter)(pcap_t *, struct bpf_program *); | ||||||
|  | extern int (*pcap_setdirection)(pcap_t *, pcap_direction_t); | ||||||
|  |  | ||||||
|  | extern int (*pcap_datalink)(pcap_t *); | ||||||
|  |  | ||||||
|  | extern void (*pcap_freecode)(struct bpf_program *); | ||||||
|  |  | ||||||
|  | extern int (*pcap_compile)(pcap_t *, struct bpf_program *, const char *, int, | ||||||
|  |                            bpf_u_int32); | ||||||
|  |  | ||||||
|  | extern char *(*pcap_geterr)(pcap_t *); | ||||||
|  | extern int (*pcap_sendpacket)(pcap_t *, const u_char *, int); | ||||||
|  |  | ||||||
|  | extern char *(*pcap_lookupdev)(char *); | ||||||
|  |  | ||||||
|  | extern int (*pcap_findalldevs)(pcap_if_t **, char *); | ||||||
|  |  | ||||||
|  | inline int pcap_set_immediate_mode(pcap_t *, int) { | ||||||
|  |     return 0; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | //#ifdef __cplusplus | ||||||
|  | //} | ||||||
|  | //#endif | ||||||
|  |  | ||||||
|  | int init_pcap(); | ||||||
							
								
								
									
										297
									
								
								server.cpp
									
									
									
									
									
								
							
							
						
						
									
										297
									
								
								server.cpp
									
									
									
									
									
								
							| @@ -5,6 +5,7 @@ | |||||||
|  *      Author: root |  *      Author: root | ||||||
|  */ |  */ | ||||||
|  |  | ||||||
|  | #ifndef UDP2RAW_MP | ||||||
|  |  | ||||||
| #include "common.h" | #include "common.h" | ||||||
| #include "network.h" | #include "network.h" | ||||||
| @@ -18,7 +19,7 @@ | |||||||
| int server_on_timer_multi(conn_info_t &conn_info)  // for server. called when a timer is ready in epoll.for server,there will be one timer for every connection | int server_on_timer_multi(conn_info_t &conn_info)  // for server. called when a timer is ready in epoll.for server,there will be one timer for every connection | ||||||
| // there is also a global timer for server,but its not handled here | // there is also a global timer for server,but its not handled here | ||||||
| { | { | ||||||
| 	char ip_port[40]; |     char ip_port[max_addr_len]; | ||||||
|     // u32_t ip=conn_info.raw_info.send_info.dst_ip; |     // u32_t ip=conn_info.raw_info.send_info.dst_ip; | ||||||
|     // u32_t port=conn_info.raw_info.send_info.dst_port; |     // u32_t port=conn_info.raw_info.send_info.dst_port; | ||||||
|  |  | ||||||
| @@ -33,9 +34,7 @@ int server_on_timer_multi(conn_info_t &conn_info)  //for server. called when a t | |||||||
|  |  | ||||||
|     assert(conn_info.state.server_current_state == server_ready); |     assert(conn_info.state.server_current_state == server_ready); | ||||||
|  |  | ||||||
|  |     if (conn_info.state.server_current_state == server_ready) { | ||||||
| 	if(conn_info.state.server_current_state==server_ready) |  | ||||||
| 	{ |  | ||||||
|         conn_info.blob->conv_manager.s.clear_inactive(ip_port); |         conn_info.blob->conv_manager.s.clear_inactive(ip_port); | ||||||
|         /* |         /* | ||||||
|         if( get_current_time()-conn_info.last_hb_recv_time>heartbeat_timeout ) |         if( get_current_time()-conn_info.last_hb_recv_time>heartbeat_timeout ) | ||||||
| @@ -48,10 +47,10 @@ int server_on_timer_multi(conn_info_t &conn_info)  //for server. called when a t | |||||||
|  |  | ||||||
|                 mylog(log_info,"changed state to server_nothing\n"); |                 mylog(log_info,"changed state to server_nothing\n"); | ||||||
|                 return 0; |                 return 0; | ||||||
| 		}*/  //dont need to do this at server,conn_manger will clear expired connections |         }*/ | ||||||
|  |         // dont need to do this at server,conn_manger will clear expired connections | ||||||
|  |  | ||||||
| 		if(get_current_time()-conn_info.last_hb_sent_time<heartbeat_interval) |         if (get_current_time() - conn_info.last_hb_sent_time < heartbeat_interval) { | ||||||
| 		{ |  | ||||||
|             return 0; |             return 0; | ||||||
|         } |         } | ||||||
|  |  | ||||||
| @@ -62,19 +61,15 @@ int server_on_timer_multi(conn_info_t &conn_info)  //for server. called when a t | |||||||
|         conn_info.last_hb_sent_time = get_current_time(); |         conn_info.last_hb_sent_time = get_current_time(); | ||||||
|  |  | ||||||
|         mylog(log_debug, "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 { | ||||||
| 	else |  | ||||||
| 	{ |  | ||||||
|         mylog(log_fatal, "this shouldnt happen!\n"); |         mylog(log_fatal, "this shouldnt happen!\n"); | ||||||
|         myexit(-1); |         myexit(-1); | ||||||
|     } |     } | ||||||
|     return 0; |     return 0; | ||||||
|  |  | ||||||
| } | } | ||||||
| int server_on_raw_recv_ready(conn_info_t &conn_info, char *ip_port, char type, char *data, int data_len)  // called while the state for a connection is server_ready | int server_on_raw_recv_ready(conn_info_t &conn_info, char *ip_port, char type, char *data, int data_len)  // called while the state for a connection is server_ready | ||||||
| // receives data and heart beat by recv_safer. | // receives data and heart beat by recv_safer. | ||||||
| { | { | ||||||
|  |  | ||||||
|     raw_info_t &raw_info = conn_info.raw_info; |     raw_info_t &raw_info = conn_info.raw_info; | ||||||
|     packet_info_t &send_info = conn_info.raw_info.send_info; |     packet_info_t &send_info = conn_info.raw_info.send_info; | ||||||
|     packet_info_t &recv_info = conn_info.raw_info.recv_info; |     packet_info_t &recv_info = conn_info.raw_info.recv_info; | ||||||
| @@ -82,7 +77,6 @@ int server_on_raw_recv_ready(conn_info_t &conn_info,char * ip_port,char type,cha | |||||||
|  |  | ||||||
|     // sprintf(ip_port,"%s:%d",my_ntoa(recv_info.src_ip),recv_info.src_port); |     // sprintf(ip_port,"%s:%d",my_ntoa(recv_info.src_ip),recv_info.src_port); | ||||||
|  |  | ||||||
|  |  | ||||||
|     /* |     /* | ||||||
|             if (recv_info.src_ip != send_info.dst_ip |             if (recv_info.src_ip != send_info.dst_ip | ||||||
|                             || recv_info.src_port != send_info.dst_port) { |                             || recv_info.src_port != send_info.dst_port) { | ||||||
| @@ -95,15 +89,12 @@ int server_on_raw_recv_ready(conn_info_t &conn_info,char * ip_port,char type,cha | |||||||
|         mylog(log_debug, "[%s][hb]received hb \n", ip_port); |         mylog(log_debug, "[%s][hb]received hb \n", ip_port); | ||||||
|         conn_info.last_hb_recv_time = get_current_time(); |         conn_info.last_hb_recv_time = get_current_time(); | ||||||
|         return 0; |         return 0; | ||||||
| 	} else if (type== 'd' && data_len >=int( sizeof(u32_t) )) |     } else if (type == 'd' && data_len >= int(sizeof(u32_t))) { | ||||||
| 	{ |  | ||||||
|  |  | ||||||
|         // u32_t tmp_conv_id = ntohl(*((u32_t *) &data[0])); |         // u32_t tmp_conv_id = ntohl(*((u32_t *) &data[0])); | ||||||
|         my_id_t tmp_conv_id; |         my_id_t tmp_conv_id; | ||||||
|         memcpy(&tmp_conv_id, &data[0], sizeof(tmp_conv_id)); |         memcpy(&tmp_conv_id, &data[0], sizeof(tmp_conv_id)); | ||||||
|         tmp_conv_id = ntohl(tmp_conv_id); |         tmp_conv_id = ntohl(tmp_conv_id); | ||||||
|  |  | ||||||
|  |  | ||||||
|         if (hb_mode == 0) |         if (hb_mode == 0) | ||||||
|             conn_info.last_hb_recv_time = get_current_time(); |             conn_info.last_hb_recv_time = get_current_time(); | ||||||
|  |  | ||||||
| @@ -172,8 +163,6 @@ int server_on_raw_recv_ready(conn_info_t &conn_info,char * ip_port,char type,cha | |||||||
|  |  | ||||||
|             conn_info.blob->conv_manager.s.insert_conv(tmp_conv_id, new_udp_fd64); |             conn_info.blob->conv_manager.s.insert_conv(tmp_conv_id, new_udp_fd64); | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|             // assert(conn_manager.udp_fd_mp.find(new_udp_fd)==conn_manager.udp_fd_mp.end()); |             // assert(conn_manager.udp_fd_mp.find(new_udp_fd)==conn_manager.udp_fd_mp.end()); | ||||||
|  |  | ||||||
|             // conn_manager.udp_fd_mp[new_udp_fd] = &conn_info; |             // conn_manager.udp_fd_mp[new_udp_fd] = &conn_info; | ||||||
| @@ -182,9 +171,6 @@ int server_on_raw_recv_ready(conn_info_t &conn_info,char * ip_port,char type,cha | |||||||
|  |  | ||||||
|             mylog(log_info, "[%s]new conv conv_id=%x, assigned fd=%d\n", ip_port, |             mylog(log_info, "[%s]new conv conv_id=%x, assigned fd=%d\n", ip_port, | ||||||
|                   tmp_conv_id, new_udp_fd); |                   tmp_conv_id, new_udp_fd); | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         fd64_t fd64 = conn_info.blob->conv_manager.s.find_data_by_conv(tmp_conv_id); |         fd64_t fd64 = conn_info.blob->conv_manager.s.find_data_by_conv(tmp_conv_id); | ||||||
| @@ -219,12 +205,10 @@ int server_on_raw_recv_pre_ready(conn_info_t &conn_info,char * ip_port,u32_t tmp | |||||||
|     mylog(log_info, "[%s]received handshake oppsite_id:%x  my_id:%x\n", ip_port, conn_info.oppsite_id, conn_info.my_id); |     mylog(log_info, "[%s]received handshake oppsite_id:%x  my_id:%x\n", ip_port, conn_info.oppsite_id, conn_info.my_id); | ||||||
|  |  | ||||||
|     mylog(log_info, "[%s]oppsite const_id:%x \n", ip_port, tmp_oppsite_const_id); |     mylog(log_info, "[%s]oppsite const_id:%x \n", ip_port, tmp_oppsite_const_id); | ||||||
| 	if(conn_manager.const_id_mp.find(tmp_oppsite_const_id)==conn_manager.const_id_mp.end()) |     if (conn_manager.const_id_mp.find(tmp_oppsite_const_id) == conn_manager.const_id_mp.end()) { | ||||||
| 	{ |  | ||||||
|         // conn_manager.const_id_mp= |         // conn_manager.const_id_mp= | ||||||
|  |  | ||||||
| 		if(conn_manager.ready_num>=max_ready_conn_num) |         if (conn_manager.ready_num >= max_ready_conn_num) { | ||||||
| 		{ |  | ||||||
|             mylog(log_info, "[%s]max_ready_conn_num,cant turn to ready\n", ip_port); |             mylog(log_info, "[%s]max_ready_conn_num,cant turn to ready\n", ip_port); | ||||||
|             conn_info.state.server_current_state = server_idle; |             conn_info.state.server_current_state = server_idle; | ||||||
|             return 0; |             return 0; | ||||||
| @@ -236,7 +220,6 @@ int server_on_raw_recv_pre_ready(conn_info_t &conn_info,char * ip_port,u32_t tmp | |||||||
|         conn_manager.ready_num++; |         conn_manager.ready_num++; | ||||||
|         conn_manager.const_id_mp[tmp_oppsite_const_id] = &conn_info; |         conn_manager.const_id_mp[tmp_oppsite_const_id] = &conn_info; | ||||||
|  |  | ||||||
|  |  | ||||||
|         // conn_info.last_state_time=get_current_time(); //dont change this!!!!!!!!!!!!!!!!!!!!!!!!! |         // conn_info.last_state_time=get_current_time(); //dont change this!!!!!!!!!!!!!!!!!!!!!!!!! | ||||||
|  |  | ||||||
|         // conn_manager.current_ready_ip=ip; |         // conn_manager.current_ready_ip=ip; | ||||||
| @@ -264,7 +247,6 @@ int server_on_raw_recv_pre_ready(conn_info_t &conn_info,char * ip_port,u32_t tmp | |||||||
|         // assert(conn_manager.timer_fd_mp.find(new_timer_fd)==conn_manager.timer_fd_mp.end()); |         // assert(conn_manager.timer_fd_mp.find(new_timer_fd)==conn_manager.timer_fd_mp.end()); | ||||||
|         // conn_manager.timer_fd_mp[new_timer_fd] = &conn_info;//pack_u64(ip,port); |         // conn_manager.timer_fd_mp[new_timer_fd] = &conn_info;//pack_u64(ip,port); | ||||||
|  |  | ||||||
|  |  | ||||||
|         // timer_fd_mp[new_timer_fd] |         // timer_fd_mp[new_timer_fd] | ||||||
|         /* |         /* | ||||||
|          if(oppsite_const_id!=0&&tmp_oppsite_const_id!=oppsite_const_id)  //TODO MOVE TO READY |          if(oppsite_const_id!=0&&tmp_oppsite_const_id!=oppsite_const_id)  //TODO MOVE TO READY | ||||||
| @@ -273,28 +255,25 @@ int server_on_raw_recv_pre_ready(conn_info_t &conn_info,char * ip_port,u32_t tmp | |||||||
|          conv_manager.clear(); |          conv_manager.clear(); | ||||||
|          }*/ |          }*/ | ||||||
|         // oppsite_const_id=tmp_oppsite_const_id; |         // oppsite_const_id=tmp_oppsite_const_id; | ||||||
| 	} |     } else { | ||||||
| 	else |  | ||||||
| 	{ |  | ||||||
|  |  | ||||||
|         conn_info_t &ori_conn_info = *conn_manager.const_id_mp[tmp_oppsite_const_id]; |         conn_info_t &ori_conn_info = *conn_manager.const_id_mp[tmp_oppsite_const_id]; | ||||||
|  |  | ||||||
| 		if(ori_conn_info.state.server_current_state==server_ready) |         if (ori_conn_info.state.server_current_state == server_ready) { | ||||||
| 		{ |             if (conn_info.last_state_time < ori_conn_info.last_state_time) { | ||||||
| 			if(conn_info.last_state_time<ori_conn_info.last_state_time) |  | ||||||
| 			{ |  | ||||||
|                 mylog(log_info, "[%s]conn_info.last_state_time<ori_conn_info.last_state_time. ignored new handshake\n", ip_port); |                 mylog(log_info, "[%s]conn_info.last_state_time<ori_conn_info.last_state_time. ignored new handshake\n", ip_port); | ||||||
|                 conn_info.state.server_current_state = server_idle; |                 conn_info.state.server_current_state = server_idle; | ||||||
|                 conn_info.oppsite_const_id = 0; |                 conn_info.oppsite_const_id = 0; | ||||||
|                 return 0; |                 return 0; | ||||||
|             } |             } | ||||||
| 			address_t addr1;addr1.from_ip_port_new(raw_ip_version,&ori_conn_info.raw_info.recv_info.new_src_ip,ori_conn_info.raw_info.recv_info.src_port); |             address_t addr1; | ||||||
|  |             addr1.from_ip_port_new(raw_ip_version, &ori_conn_info.raw_info.recv_info.new_src_ip, ori_conn_info.raw_info.recv_info.src_port); | ||||||
|             if (!conn_manager.exist(addr1))  // TODO remove this |             if (!conn_manager.exist(addr1))  // TODO remove this | ||||||
|             { |             { | ||||||
|                 mylog(log_fatal, "[%s]this shouldnt happen\n", ip_port); |                 mylog(log_fatal, "[%s]this shouldnt happen\n", ip_port); | ||||||
|                 myexit(-1); |                 myexit(-1); | ||||||
|             } |             } | ||||||
| 			address_t addr2;addr2.from_ip_port_new(raw_ip_version,&conn_info.raw_info.recv_info.new_src_ip,conn_info.raw_info.recv_info.src_port); |             address_t addr2; | ||||||
|  |             addr2.from_ip_port_new(raw_ip_version, &conn_info.raw_info.recv_info.new_src_ip, conn_info.raw_info.recv_info.src_port); | ||||||
|             if (!conn_manager.exist(addr2))  // TODO remove this |             if (!conn_manager.exist(addr2))  // TODO remove this | ||||||
|             { |             { | ||||||
|                 mylog(log_fatal, "[%s]this shouldnt happen2\n", ip_port); |                 mylog(log_fatal, "[%s]this shouldnt happen2\n", ip_port); | ||||||
| @@ -306,10 +285,8 @@ int server_on_raw_recv_pre_ready(conn_info_t &conn_info,char * ip_port,u32_t tmp | |||||||
|             p = p_ori; |             p = p_ori; | ||||||
|             p_ori = tmp; |             p_ori = tmp; | ||||||
|  |  | ||||||
|  |  | ||||||
|             mylog(log_info, "[%s]grabbed a connection\n", ip_port); |             mylog(log_info, "[%s]grabbed a connection\n", ip_port); | ||||||
|  |  | ||||||
|  |  | ||||||
|             // ori_conn_info.state.server_current_state=server_ready; |             // ori_conn_info.state.server_current_state=server_ready; | ||||||
|             ori_conn_info.recover(conn_info); |             ori_conn_info.recover(conn_info); | ||||||
|  |  | ||||||
| @@ -322,14 +299,10 @@ int server_on_raw_recv_pre_ready(conn_info_t &conn_info,char * ip_port,u32_t tmp | |||||||
|  |  | ||||||
|             ori_conn_info.last_hb_recv_time = get_current_time(); |             ori_conn_info.last_hb_recv_time = get_current_time(); | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|             conn_info.state.server_current_state = server_idle; |             conn_info.state.server_current_state = server_idle; | ||||||
|             conn_info.oppsite_const_id = 0; |             conn_info.oppsite_const_id = 0; | ||||||
|  |  | ||||||
| 		} |         } else { | ||||||
| 		else |  | ||||||
| 		{ |  | ||||||
|             mylog(log_fatal, "[%s]this should never happen\n", ip_port); |             mylog(log_fatal, "[%s]this should never happen\n", ip_port); | ||||||
|             myexit(-1); |             myexit(-1); | ||||||
|         } |         } | ||||||
| @@ -349,8 +322,7 @@ int server_on_raw_recv_handshake1(conn_info_t &conn_info,char * ip_port,char * d | |||||||
|     // char ip_port[40]; |     // char ip_port[40]; | ||||||
|     // sprintf(ip_port,"%s:%d",my_ntoa(ip),port); |     // sprintf(ip_port,"%s:%d",my_ntoa(ip),port); | ||||||
|  |  | ||||||
| 	if(data_len<int( 3*sizeof(my_id_t))) |     if (data_len < int(3 * sizeof(my_id_t))) { | ||||||
| 	{ |  | ||||||
|         mylog(log_debug, "[%s] data_len=%d too short to be a handshake\n", ip_port, data_len); |         mylog(log_debug, "[%s] data_len=%d too short to be a handshake\n", ip_port, data_len); | ||||||
|         return -1; |         return -1; | ||||||
|     } |     } | ||||||
| @@ -366,22 +338,18 @@ int server_on_raw_recv_handshake1(conn_info_t &conn_info,char * ip_port,char * d | |||||||
|  |  | ||||||
|     if (tmp_my_id == 0)  // received  init handshake again |     if (tmp_my_id == 0)  // received  init handshake again | ||||||
|     { |     { | ||||||
| 		if(raw_mode==mode_faketcp) |         if (raw_mode == mode_faketcp) { | ||||||
| 		{ |  | ||||||
|             send_info.seq = recv_info.ack_seq; |             send_info.seq = recv_info.ack_seq; | ||||||
|             send_info.ack_seq = recv_info.seq + raw_info.recv_info.data_len; |             send_info.ack_seq = recv_info.seq + raw_info.recv_info.data_len; | ||||||
|             send_info.ts_ack = recv_info.ts; |             send_info.ts_ack = recv_info.ts; | ||||||
|         } |         } | ||||||
| 		if(raw_mode==mode_icmp) |         if (raw_mode == mode_icmp) { | ||||||
| 		{ |  | ||||||
|             send_info.my_icmp_seq = recv_info.my_icmp_seq; |             send_info.my_icmp_seq = recv_info.my_icmp_seq; | ||||||
|         } |         } | ||||||
|         send_handshake(raw_info, conn_info.my_id, tmp_oppsite_id, const_id);  //////////////send |         send_handshake(raw_info, conn_info.my_id, tmp_oppsite_id, const_id);  //////////////send | ||||||
|  |  | ||||||
|         mylog(log_info, "[%s]changed state to server_handshake1,my_id is %x\n", ip_port, conn_info.my_id); |         mylog(log_info, "[%s]changed state to server_handshake1,my_id is %x\n", ip_port, conn_info.my_id); | ||||||
| 	} |     } else if (tmp_my_id == conn_info.my_id) { | ||||||
| 	else if(tmp_my_id==conn_info.my_id) |  | ||||||
| 	{ |  | ||||||
|         conn_info.oppsite_id = tmp_oppsite_id; |         conn_info.oppsite_id = tmp_oppsite_id; | ||||||
|         // id_t tmp_oppsite_const_id=ntohl(* ((u32_t *)&data[sizeof(id_t)*2])); |         // id_t tmp_oppsite_const_id=ntohl(* ((u32_t *)&data[sizeof(id_t)*2])); | ||||||
|  |  | ||||||
| @@ -389,30 +357,24 @@ int server_on_raw_recv_handshake1(conn_info_t &conn_info,char * ip_port,char * d | |||||||
|         memcpy(&tmp_oppsite_const_id, &data[sizeof(my_id_t) * 2], sizeof(tmp_oppsite_const_id)); |         memcpy(&tmp_oppsite_const_id, &data[sizeof(my_id_t) * 2], sizeof(tmp_oppsite_const_id)); | ||||||
|         tmp_oppsite_const_id = ntohl(tmp_oppsite_const_id); |         tmp_oppsite_const_id = ntohl(tmp_oppsite_const_id); | ||||||
|  |  | ||||||
|  |         if (raw_mode == mode_faketcp) { | ||||||
| 		if(raw_mode==mode_faketcp) |  | ||||||
| 		{ |  | ||||||
|             send_info.seq = recv_info.ack_seq; |             send_info.seq = recv_info.ack_seq; | ||||||
|             send_info.ack_seq = recv_info.seq + raw_info.recv_info.data_len; |             send_info.ack_seq = recv_info.seq + raw_info.recv_info.data_len; | ||||||
|             send_info.ts_ack = recv_info.ts; |             send_info.ts_ack = recv_info.ts; | ||||||
|         } |         } | ||||||
|  |  | ||||||
| 		if(raw_mode==mode_icmp) |         if (raw_mode == mode_icmp) { | ||||||
| 		{ |  | ||||||
|             send_info.my_icmp_seq = recv_info.my_icmp_seq; |             send_info.my_icmp_seq = recv_info.my_icmp_seq; | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         server_on_raw_recv_pre_ready(conn_info, ip_port, tmp_oppsite_const_id); |         server_on_raw_recv_pre_ready(conn_info, ip_port, tmp_oppsite_const_id); | ||||||
|  |  | ||||||
| 	} |     } else { | ||||||
| 	else |  | ||||||
| 	{ |  | ||||||
|         mylog(log_debug, "[%s]invalid my_id %x,my_id is %x\n", ip_port, tmp_my_id, conn_info.my_id); |         mylog(log_debug, "[%s]invalid my_id %x,my_id is %x\n", ip_port, tmp_my_id, conn_info.my_id); | ||||||
|     } |     } | ||||||
|     return 0; |     return 0; | ||||||
| } | } | ||||||
| int server_on_recv_safer_multi(conn_info_t &conn_info,char type,char *data,int data_len) | int server_on_recv_safer_multi(conn_info_t &conn_info, char type, char *data, int data_len) { | ||||||
| { |  | ||||||
|     return 0; |     return 0; | ||||||
| } | } | ||||||
| int server_on_raw_recv_multi()  // called when server received an raw packet | int server_on_raw_recv_multi()  // called when server received an raw packet | ||||||
| @@ -423,8 +385,7 @@ int server_on_raw_recv_multi() //called when server received an raw packet | |||||||
|     packet_info_t &peek_info = peek_raw_info.recv_info; |     packet_info_t &peek_info = peek_raw_info.recv_info; | ||||||
|     mylog(log_trace, "got a packet\n"); |     mylog(log_trace, "got a packet\n"); | ||||||
|     if (pre_recv_raw_packet() < 0) return -1; |     if (pre_recv_raw_packet() < 0) return -1; | ||||||
| 	if(peek_raw(peek_raw_info)<0) |     if (peek_raw(peek_raw_info) < 0) { | ||||||
| 	{ |  | ||||||
|         discard_raw_packet(); |         discard_raw_packet(); | ||||||
|         // recv(raw_recv_fd, 0,0, 0  );// |         // recv(raw_recv_fd, 0,0, 0  );// | ||||||
|         // struct sockaddr saddr; |         // struct sockaddr saddr; | ||||||
| @@ -432,33 +393,33 @@ int server_on_raw_recv_multi() //called when server received an raw packet | |||||||
|         /// recvfrom(raw_recv_fd, 0,0, 0 ,&saddr , &saddr_size);// |         /// recvfrom(raw_recv_fd, 0,0, 0 ,&saddr , &saddr_size);// | ||||||
|         mylog(log_trace, "peek_raw failed\n"); |         mylog(log_trace, "peek_raw failed\n"); | ||||||
|         return -1; |         return -1; | ||||||
| 	}else |     } else { | ||||||
| 	{ |  | ||||||
|         mylog(log_trace, "peek_raw success\n"); |         mylog(log_trace, "peek_raw success\n"); | ||||||
|     } |     } | ||||||
|     // u32_t ip=peek_info.src_ip;uint16_t port=peek_info.src_port; |     // u32_t ip=peek_info.src_ip;uint16_t port=peek_info.src_port; | ||||||
|  |  | ||||||
|  |     int data_len; | ||||||
| 	int data_len; char *data; |     char *data; | ||||||
|  |  | ||||||
|     address_t addr; |     address_t addr; | ||||||
|     addr.from_ip_port_new(raw_ip_version, &peek_info.new_src_ip, peek_info.src_port); |     addr.from_ip_port_new(raw_ip_version, &peek_info.new_src_ip, peek_info.src_port); | ||||||
|  |  | ||||||
| 	char ip_port[40]; |     char ip_port[max_addr_len]; | ||||||
|     addr.to_str(ip_port); |     addr.to_str(ip_port); | ||||||
|     // sprintf(ip_port,"%s:%d",my_ntoa(ip),port); |     // sprintf(ip_port,"%s:%d",my_ntoa(ip),port); | ||||||
|     mylog(log_trace, "[%s]peek_raw\n", ip_port); |     mylog(log_trace, "[%s]peek_raw\n", ip_port); | ||||||
|  |  | ||||||
| 	if(raw_mode==mode_faketcp&&peek_info.syn==1) |     if (raw_mode == mode_faketcp && peek_info.syn == 1) { | ||||||
| 	{ |         if (!conn_manager.exist(addr) || conn_manager.find_insert(addr).state.server_current_state != server_ready) {  // reply any syn ,before state become ready | ||||||
| 		if(!conn_manager.exist(addr)||conn_manager.find_insert(addr).state.server_current_state!=server_ready) |  | ||||||
| 		{//reply any syn ,before state become ready |  | ||||||
|  |  | ||||||
|             raw_info_t tmp_raw_info; |             raw_info_t tmp_raw_info; | ||||||
| 			if(recv_raw0(tmp_raw_info,data,data_len)<0) |             if (recv_raw0(tmp_raw_info, data, data_len) < 0) { | ||||||
| 			{ |  | ||||||
|                 return 0; |                 return 0; | ||||||
|             } |             } | ||||||
|  |             if (data_len >= max_data_len + 1) { | ||||||
|  |                 mylog(log_debug, "data_len=%d >= max_data_len+1,ignored", data_len); | ||||||
|  |                 return -1; | ||||||
|  |             } | ||||||
|             if (use_tcp_dummy_socket != 0) |             if (use_tcp_dummy_socket != 0) | ||||||
|                 return 0; |                 return 0; | ||||||
|             raw_info_t &raw_info = tmp_raw_info; |             raw_info_t &raw_info = tmp_raw_info; | ||||||
| @@ -471,13 +432,11 @@ int server_on_raw_recv_multi() //called when server received an raw packet | |||||||
|             send_info.dst_port = recv_info.src_port; |             send_info.dst_port = recv_info.src_port; | ||||||
|             send_info.new_dst_ip = recv_info.new_src_ip; |             send_info.new_dst_ip = recv_info.new_src_ip; | ||||||
|  |  | ||||||
| 			if(lower_level) |             if (lower_level) { | ||||||
| 			{ |  | ||||||
|                 handle_lower_level(raw_info); |                 handle_lower_level(raw_info); | ||||||
|             } |             } | ||||||
|  |  | ||||||
| 			if(data_len==0&&raw_info.recv_info.syn==1&&raw_info.recv_info.ack==0) |             if (data_len == 0 && raw_info.recv_info.syn == 1 && raw_info.recv_info.ack == 0) { | ||||||
| 			{ |  | ||||||
|                 send_info.ack_seq = recv_info.seq + 1; |                 send_info.ack_seq = recv_info.seq + 1; | ||||||
|  |  | ||||||
|                 send_info.psh = 0; |                 send_info.psh = 0; | ||||||
| @@ -489,18 +448,14 @@ int server_on_raw_recv_multi() //called when server received an raw packet | |||||||
|                 send_raw0(raw_info, 0, 0); |                 send_raw0(raw_info, 0, 0); | ||||||
|                 return 0; |                 return 0; | ||||||
|             } |             } | ||||||
| 		} |         } else { | ||||||
| 		else |  | ||||||
| 		{ |  | ||||||
|             discard_raw_packet(); |             discard_raw_packet(); | ||||||
|             // recv(raw_recv_fd, 0,0,0); |             // recv(raw_recv_fd, 0,0,0); | ||||||
|         } |         } | ||||||
|         return 0; |         return 0; | ||||||
|     } |     } | ||||||
| 	if(!conn_manager.exist(addr)) |     if (!conn_manager.exist(addr)) { | ||||||
| 	{ |         if (conn_manager.mp.size() >= max_handshake_conn_num) { | ||||||
| 		if(conn_manager.mp.size()>=max_handshake_conn_num) |  | ||||||
| 		{ |  | ||||||
|             mylog(log_info, "[%s]reached max_handshake_conn_num,ignored new handshake\n", ip_port); |             mylog(log_info, "[%s]reached max_handshake_conn_num,ignored new handshake\n", ip_port); | ||||||
|             discard_raw_packet(); |             discard_raw_packet(); | ||||||
|             // recv(raw_recv_fd, 0,0, 0  );// |             // recv(raw_recv_fd, 0,0, 0  );// | ||||||
| @@ -509,17 +464,13 @@ int server_on_raw_recv_multi() //called when server received an raw packet | |||||||
|  |  | ||||||
|         raw_info_t tmp_raw_info; |         raw_info_t tmp_raw_info; | ||||||
|  |  | ||||||
|  |         if (raw_mode == mode_icmp) { | ||||||
| 		if(raw_mode==mode_icmp) |  | ||||||
| 		{ |  | ||||||
|             tmp_raw_info.send_info.dst_port = tmp_raw_info.send_info.src_port = addr.get_port(); |             tmp_raw_info.send_info.dst_port = tmp_raw_info.send_info.src_port = addr.get_port(); | ||||||
|         } |         } | ||||||
| 		if(recv_bare(tmp_raw_info,data,data_len)<0) |         if (recv_bare(tmp_raw_info, data, data_len) < 0) { | ||||||
| 		{ |  | ||||||
|             return 0; |             return 0; | ||||||
|         } |         } | ||||||
| 		if(data_len<int( 3*sizeof(my_id_t))) |         if (data_len < int(3 * sizeof(my_id_t))) { | ||||||
| 		{ |  | ||||||
|             mylog(log_debug, "[%s]too short to be a handshake\n", ip_port); |             mylog(log_debug, "[%s]too short to be a handshake\n", ip_port); | ||||||
|             return -1; |             return -1; | ||||||
|         } |         } | ||||||
| @@ -529,8 +480,7 @@ int server_on_raw_recv_multi() //called when server received an raw packet | |||||||
|         memcpy(&zero, &data[sizeof(my_id_t)], sizeof(zero)); |         memcpy(&zero, &data[sizeof(my_id_t)], sizeof(zero)); | ||||||
|         zero = ntohl(zero); |         zero = ntohl(zero); | ||||||
|  |  | ||||||
| 		if(zero!=0) |         if (zero != 0) { | ||||||
| 		{ |  | ||||||
|             mylog(log_debug, "[%s]not a invalid initial handshake\n", ip_port); |             mylog(log_debug, "[%s]not a invalid initial handshake\n", ip_port); | ||||||
|             return -1; |             return -1; | ||||||
|         } |         } | ||||||
| @@ -547,16 +497,13 @@ int server_on_raw_recv_multi() //called when server received an raw packet | |||||||
|         // conn_info.ip_port.ip=ip; |         // conn_info.ip_port.ip=ip; | ||||||
|         // conn_info.ip_port.port=port; |         // conn_info.ip_port.port=port; | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|         send_info.new_src_ip = recv_info.new_dst_ip; |         send_info.new_src_ip = recv_info.new_dst_ip; | ||||||
|         send_info.src_port = recv_info.dst_port; |         send_info.src_port = recv_info.dst_port; | ||||||
|  |  | ||||||
|         send_info.dst_port = recv_info.src_port; |         send_info.dst_port = recv_info.src_port; | ||||||
|         send_info.new_dst_ip = recv_info.new_src_ip; |         send_info.new_dst_ip = recv_info.new_src_ip; | ||||||
|  |  | ||||||
| 		if(lower_level) |         if (lower_level) { | ||||||
| 		{ |  | ||||||
|             handle_lower_level(raw_info); |             handle_lower_level(raw_info); | ||||||
|         } |         } | ||||||
|  |  | ||||||
| @@ -565,7 +512,6 @@ int server_on_raw_recv_multi() //called when server received an raw packet | |||||||
|  |  | ||||||
|         conn_info.my_id = get_true_random_number_nz(); |         conn_info.my_id = get_true_random_number_nz(); | ||||||
|  |  | ||||||
|  |  | ||||||
|         mylog(log_info, "[%s]created new conn,state: server_handshake1,my_id is %x\n", ip_port, conn_info.my_id); |         mylog(log_info, "[%s]created new conn,state: server_handshake1,my_id is %x\n", ip_port, conn_info.my_id); | ||||||
|  |  | ||||||
|         conn_info.state.server_current_state = server_handshake1; |         conn_info.state.server_current_state = server_handshake1; | ||||||
| @@ -575,46 +521,36 @@ int server_on_raw_recv_multi() //called when server received an raw packet | |||||||
|         return 0; |         return 0; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|     conn_info_t &conn_info = conn_manager.find_insert(addr);  // insert if not exist |     conn_info_t &conn_info = conn_manager.find_insert(addr);  // insert if not exist | ||||||
|     packet_info_t &send_info = conn_info.raw_info.send_info; |     packet_info_t &send_info = conn_info.raw_info.send_info; | ||||||
|     packet_info_t &recv_info = conn_info.raw_info.recv_info; |     packet_info_t &recv_info = conn_info.raw_info.recv_info; | ||||||
|     raw_info_t &raw_info = conn_info.raw_info; |     raw_info_t &raw_info = conn_info.raw_info; | ||||||
|  |  | ||||||
| 	if(conn_info.state.server_current_state==server_handshake1) |     if (conn_info.state.server_current_state == server_handshake1) { | ||||||
| 	{ |         if (recv_bare(raw_info, data, data_len) != 0) { | ||||||
| 		if(recv_bare(raw_info,data,data_len)!=0) |  | ||||||
| 		{ |  | ||||||
|             return -1; |             return -1; | ||||||
|         } |         } | ||||||
|         return server_on_raw_recv_handshake1(conn_info, ip_port, data, data_len); |         return server_on_raw_recv_handshake1(conn_info, ip_port, data, data_len); | ||||||
|     } |     } | ||||||
| 	if(conn_info.state.server_current_state==server_ready) |     if (conn_info.state.server_current_state == server_ready) { | ||||||
| 	{ |  | ||||||
|         vector<char> type_vec; |         vector<char> type_vec; | ||||||
|         vector<string> data_vec; |         vector<string> data_vec; | ||||||
|         recv_safer_multi(conn_info, type_vec, data_vec); |         recv_safer_multi(conn_info, type_vec, data_vec); | ||||||
|         if(data_vec.empty()) |         if (data_vec.empty()) { | ||||||
|         { |  | ||||||
|             mylog(log_debug, "recv_safer failed!\n"); |             mylog(log_debug, "recv_safer failed!\n"); | ||||||
|             return -1; |             return -1; | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         for(int i=0;i<(int)type_vec.size();i++) |         for (int i = 0; i < (int)type_vec.size(); i++) { | ||||||
|         { |  | ||||||
|             char type = type_vec[i]; |             char type = type_vec[i]; | ||||||
|             char *data = (char *)data_vec[i].c_str();  // be careful, do not append data to it |             char *data = (char *)data_vec[i].c_str();  // be careful, do not append data to it | ||||||
|             int data_len = data_vec[i].length(); |             int data_len = data_vec[i].length(); | ||||||
|             server_on_raw_recv_ready(conn_info, ip_port, type, data, data_len); |             server_on_raw_recv_ready(conn_info, ip_port, type, data, data_len); | ||||||
|         } |         } | ||||||
|         return 0; |         return 0; | ||||||
|  |  | ||||||
|     } |     } | ||||||
|  |  | ||||||
| 	if(conn_info.state.server_current_state==server_idle) |     if (conn_info.state.server_current_state == server_idle) { | ||||||
| 	{ |  | ||||||
|         discard_raw_packet(); |         discard_raw_packet(); | ||||||
|         // recv(raw_recv_fd, 0,0, 0  );// |         // recv(raw_recv_fd, 0,0, 0  );// | ||||||
|         return 0; |         return 0; | ||||||
| @@ -624,8 +560,7 @@ int server_on_raw_recv_multi() //called when server received an raw packet | |||||||
|     return -1; |     return -1; | ||||||
| } | } | ||||||
|  |  | ||||||
| int server_on_udp_recv(conn_info_t &conn_info,fd64_t fd64) | int server_on_udp_recv(conn_info_t &conn_info, fd64_t fd64) { | ||||||
| { |  | ||||||
|     char buf[buf_len]; |     char buf[buf_len]; | ||||||
|  |  | ||||||
|     if (conn_info.state.server_current_state != server_ready)  // TODO remove this for peformance |     if (conn_info.state.server_current_state != server_ready)  // TODO remove this for peformance | ||||||
| @@ -646,82 +581,64 @@ int server_on_udp_recv(conn_info_t &conn_info,fd64_t fd64) | |||||||
|  |  | ||||||
|     mylog(log_trace, "received a packet from udp_fd,len:%d\n", recv_len); |     mylog(log_trace, "received a packet from udp_fd,len:%d\n", recv_len); | ||||||
|  |  | ||||||
| 	if(recv_len==max_data_len+1) |     if (recv_len == max_data_len + 1) { | ||||||
| 	{ |  | ||||||
|         mylog(log_warn, "huge packet, data_len > %d,dropped\n", max_data_len); |         mylog(log_warn, "huge packet, data_len > %d,dropped\n", max_data_len); | ||||||
|         return -1; |         return -1; | ||||||
|     } |     } | ||||||
|  |  | ||||||
| 	if(recv_len<0) |     if (recv_len < 0) { | ||||||
| 	{ |  | ||||||
|         mylog(log_debug, "udp fd,recv_len<0 continue,%s\n", strerror(errno)); |         mylog(log_debug, "udp fd,recv_len<0 continue,%s\n", strerror(errno)); | ||||||
|         return -1; |         return -1; | ||||||
|     } |     } | ||||||
|  |  | ||||||
| 	if(recv_len>=mtu_warn) |     if (recv_len >= mtu_warn) { | ||||||
| 	{ |  | ||||||
|         mylog(log_warn, "huge packet,data len=%d (>=%d).strongly suggested to set a smaller mtu at upper level,to get rid of this warn\n ", recv_len, mtu_warn); |         mylog(log_warn, "huge packet,data len=%d (>=%d).strongly suggested to set a smaller mtu at upper level,to get rid of this warn\n ", recv_len, mtu_warn); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     // conn_info.conv_manager->update_active_time(conv_id);  server dosnt update from upd side,only update from raw side.  (client updates at both side) |     // conn_info.conv_manager->update_active_time(conv_id);  server dosnt update from upd side,only update from raw side.  (client updates at both side) | ||||||
|  |  | ||||||
| 	if(conn_info.state.server_current_state==server_ready) |     if (conn_info.state.server_current_state == server_ready) { | ||||||
| 	{ |  | ||||||
|         send_data_safer(conn_info, buf, recv_len, conv_id); |         send_data_safer(conn_info, buf, recv_len, conv_id); | ||||||
|         // send_data(g_packet_info_send,buf,recv_len,my_id,oppsite_id,conv_id); |         // send_data(g_packet_info_send,buf,recv_len,my_id,oppsite_id,conv_id); | ||||||
|         mylog(log_trace, "send_data_safer ,sent !!\n"); |         mylog(log_trace, "send_data_safer ,sent !!\n"); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |  | ||||||
|     return 0; |     return 0; | ||||||
| } | } | ||||||
|  |  | ||||||
|  | int server_event_loop() { | ||||||
| int server_event_loop() |  | ||||||
| { |  | ||||||
|     char buf[buf_len]; |     char buf[buf_len]; | ||||||
|  |  | ||||||
| 	int i, j, k;int ret; |     int i, j, k; | ||||||
|  |     int ret; | ||||||
|  |  | ||||||
| 	if(raw_ip_version==AF_INET) |     if (raw_ip_version == AF_INET) { | ||||||
| 	{ |         if (local_addr.inner.ipv4.sin_addr.s_addr != 0) { | ||||||
| 		if(local_addr.inner.ipv4.sin_addr.s_addr!=0) |  | ||||||
| 		{ |  | ||||||
|             bind_addr_used = 1; |             bind_addr_used = 1; | ||||||
|             bind_addr.v4 = local_addr.inner.ipv4.sin_addr.s_addr; |             bind_addr.v4 = local_addr.inner.ipv4.sin_addr.s_addr; | ||||||
|         } |         } | ||||||
| 	} |     } else { | ||||||
| 	else |  | ||||||
| 	{ |  | ||||||
|         assert(raw_ip_version == AF_INET6); |         assert(raw_ip_version == AF_INET6); | ||||||
|         char zero_arr[16] = {0}; |         char zero_arr[16] = {0}; | ||||||
| 		if(memcmp(&local_addr.inner.ipv6.sin6_addr,zero_arr,16)!=0) |         if (memcmp(&local_addr.inner.ipv6.sin6_addr, zero_arr, 16) != 0) { | ||||||
| 		{ |  | ||||||
|             bind_addr_used = 1; |             bind_addr_used = 1; | ||||||
|             bind_addr.v6 = local_addr.inner.ipv6.sin6_addr; |             bind_addr.v6 = local_addr.inner.ipv6.sin6_addr; | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|     // bind_address_uint32=local_ip_uint32;//only server has bind adress,client sets it to zero |     // bind_address_uint32=local_ip_uint32;//only server has bind adress,client sets it to zero | ||||||
|  |  | ||||||
| 	if(lower_level) |     if (lower_level) { | ||||||
| 	{ |         if (lower_level_manual) { | ||||||
| 		if(lower_level_manual) |  | ||||||
| 		{ |  | ||||||
|             init_ifindex(if_name, raw_send_fd, ifindex); |             init_ifindex(if_name, raw_send_fd, ifindex); | ||||||
|             mylog(log_info, "we are running at lower-level (manual) mode\n"); |             mylog(log_info, "we are running at lower-level (manual) mode\n"); | ||||||
| 		} |         } else { | ||||||
| 		else |  | ||||||
| 		{ |  | ||||||
|             mylog(log_info, "we are running at lower-level (auto) mode\n"); |             mylog(log_info, "we are running at lower-level (auto) mode\n"); | ||||||
|         } |         } | ||||||
|  |  | ||||||
|     } |     } | ||||||
|  |  | ||||||
| 	 if(raw_mode==mode_faketcp) |     if (raw_mode == mode_faketcp) { | ||||||
| 	 { |  | ||||||
|         bind_fd = socket(local_addr.get_type(), SOCK_STREAM, 0); |         bind_fd = socket(local_addr.get_type(), SOCK_STREAM, 0); | ||||||
| 	 } |     } else if (raw_mode == mode_udp || raw_mode == mode_icmp)  // bind an adress to avoid collision,for icmp,there is no port,just bind a udp port | ||||||
| 	 else  if(raw_mode==mode_udp||raw_mode==mode_icmp)//bind an adress to avoid collision,for icmp,there is no port,just bind a udp port |  | ||||||
|     { |     { | ||||||
|         bind_fd = socket(local_addr.get_type(), SOCK_DGRAM, 0); |         bind_fd = socket(local_addr.get_type(), SOCK_DGRAM, 0); | ||||||
|     } |     } | ||||||
| @@ -733,24 +650,18 @@ int server_event_loop() | |||||||
|     // temp_bind_addr.sin_port = local_addr.get_port(); |     // temp_bind_addr.sin_port = local_addr.get_port(); | ||||||
|     // temp_bind_addr.sin_addr.s_addr = local_addr.inner.ipv4.sin_addr.s_addr; |     // temp_bind_addr.sin_addr.s_addr = local_addr.inner.ipv4.sin_addr.s_addr; | ||||||
|  |  | ||||||
|      if (bind(bind_fd, (struct sockaddr*)&local_addr.inner, local_addr.get_len()) !=0) |     if (bind(bind_fd, (struct sockaddr *)&local_addr.inner, local_addr.get_len()) != 0) { | ||||||
|      { |  | ||||||
|         mylog(log_fatal, "bind fail\n"); |         mylog(log_fatal, "bind fail\n"); | ||||||
|         myexit(-1); |         myexit(-1); | ||||||
|     } |     } | ||||||
|  |  | ||||||
| 	 if(raw_mode==mode_faketcp) |     if (raw_mode == mode_faketcp) { | ||||||
| 	 { |         if (listen(bind_fd, SOMAXCONN) != 0) { | ||||||
|  |  | ||||||
| 		 if(listen(bind_fd, SOMAXCONN) != 0 ) |  | ||||||
| 		 { |  | ||||||
|             mylog(log_fatal, "listen fail\n"); |             mylog(log_fatal, "listen fail\n"); | ||||||
|             myexit(-1); |             myexit(-1); | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|     // init_raw_socket(); |     // init_raw_socket(); | ||||||
|     init_filter(local_addr.get_port());  // bpf filter |     init_filter(local_addr.get_port());  // bpf filter | ||||||
|  |  | ||||||
| @@ -782,8 +693,7 @@ int server_event_loop() | |||||||
|  |  | ||||||
|     int fifo_fd = -1; |     int fifo_fd = -1; | ||||||
|  |  | ||||||
| 	if(fifo_file[0]!=0) |     if (fifo_file[0] != 0) { | ||||||
| 	{ |  | ||||||
|         fifo_fd = create_fifo(fifo_file); |         fifo_fd = create_fifo(fifo_file); | ||||||
|         ev.events = EPOLLIN; |         ev.events = EPOLLIN; | ||||||
|         ev.data.u64 = fifo_fd; |         ev.data.u64 = fifo_fd; | ||||||
| @@ -796,40 +706,32 @@ int server_event_loop() | |||||||
|         mylog(log_info, "fifo_file=%s\n", fifo_file); |         mylog(log_info, "fifo_file=%s\n", fifo_file); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |  | ||||||
|     while (1)  //////////////////////// |     while (1)  //////////////////////// | ||||||
|     { |     { | ||||||
|  |  | ||||||
|         if (about_to_exit) myexit(0); |         if (about_to_exit) myexit(0); | ||||||
|  |  | ||||||
|         int nfds = epoll_wait(epollfd, events, max_events, 180 * 1000); |         int nfds = epoll_wait(epollfd, events, max_events, 180 * 1000); | ||||||
|         if (nfds < 0) {  // allow zero |         if (nfds < 0) {  // allow zero | ||||||
| 			if(errno==EINTR  ) |             if (errno == EINTR) { | ||||||
| 			{ |  | ||||||
|                 mylog(log_info, "epoll interrupted by signal,continue\n"); |                 mylog(log_info, "epoll interrupted by signal,continue\n"); | ||||||
|                 // myexit(0); |                 // myexit(0); | ||||||
| 			} |             } else { | ||||||
| 			else |  | ||||||
| 			{ |  | ||||||
|                 mylog(log_fatal, "epoll_wait return %d,%s\n", nfds, strerror(errno)); |                 mylog(log_fatal, "epoll_wait return %d,%s\n", nfds, strerror(errno)); | ||||||
|                 myexit(-1); |                 myexit(-1); | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|         int idx; |         int idx; | ||||||
| 		for (idx = 0; idx < nfds; ++idx) |         for (idx = 0; idx < nfds; ++idx) { | ||||||
| 		{ |  | ||||||
|             // mylog(log_debug,"ndfs:  %d \n",nfds); |             // mylog(log_debug,"ndfs:  %d \n",nfds); | ||||||
|             epoll_trigger_counter++; |             epoll_trigger_counter++; | ||||||
|             // printf("%d %d %d %d\n",timer_fd,raw_recv_fd,raw_send_fd,n); |             // printf("%d %d %d %d\n",timer_fd,raw_recv_fd,raw_send_fd,n); | ||||||
| 			if ((events[idx].data.u64 ) == (u64_t)timer_fd) |             if ((events[idx].data.u64) == (u64_t)timer_fd) { | ||||||
| 			{ |  | ||||||
|                 if (debug_flag) begin_time = get_current_time(); |                 if (debug_flag) begin_time = get_current_time(); | ||||||
|                 conn_manager.clear_inactive(); |                 conn_manager.clear_inactive(); | ||||||
|                 u64_t dummy; |                 u64_t dummy; | ||||||
|                 int unused = read(timer_fd, &dummy, 8); |                 int unused = read(timer_fd, &dummy, 8); | ||||||
|                 // current_time_rough=get_current_time(); |                 // current_time_rough=get_current_time(); | ||||||
| 				if(debug_flag) |                 if (debug_flag) { | ||||||
| 				{ |  | ||||||
|                     end_time = get_current_time(); |                     end_time = get_current_time(); | ||||||
|                     mylog(log_debug, "timer_fd,%llu,%llu,%llu\n", begin_time, end_time, end_time - begin_time); |                     mylog(log_debug, "timer_fd,%llu,%llu,%llu\n", begin_time, end_time, end_time - begin_time); | ||||||
|                 } |                 } | ||||||
| @@ -837,22 +739,16 @@ int server_event_loop() | |||||||
|                 mylog(log_trace, "epoll_trigger_counter:  %d \n", epoll_trigger_counter); |                 mylog(log_trace, "epoll_trigger_counter:  %d \n", epoll_trigger_counter); | ||||||
|                 epoll_trigger_counter = 0; |                 epoll_trigger_counter = 0; | ||||||
|  |  | ||||||
| 			} |             } else if (events[idx].data.u64 == (u64_t)raw_recv_fd) { | ||||||
| 			else if (events[idx].data.u64 == (u64_t)raw_recv_fd) |  | ||||||
| 			{ |  | ||||||
|                 if (debug_flag) begin_time = get_current_time(); |                 if (debug_flag) begin_time = get_current_time(); | ||||||
|                 server_on_raw_recv_multi(); |                 server_on_raw_recv_multi(); | ||||||
| 				if(debug_flag) |                 if (debug_flag) { | ||||||
| 				{ |  | ||||||
|                     end_time = get_current_time(); |                     end_time = get_current_time(); | ||||||
|                     mylog(log_debug, "raw_recv_fd,%llu,%llu,%llu  \n", begin_time, end_time, end_time - begin_time); |                     mylog(log_debug, "raw_recv_fd,%llu,%llu,%llu  \n", begin_time, end_time, end_time - begin_time); | ||||||
|                 } |                 } | ||||||
| 			} |             } else if (events[idx].data.u64 == (u64_t)fifo_fd) { | ||||||
| 			else if (events[idx].data.u64 == (u64_t)fifo_fd) |  | ||||||
| 			{ |  | ||||||
|                 int len = read(fifo_fd, buf, sizeof(buf)); |                 int len = read(fifo_fd, buf, sizeof(buf)); | ||||||
| 				if(len<0) |                 if (len < 0) { | ||||||
| 				{ |  | ||||||
|                     mylog(log_warn, "fifo read failed len=%d,errno=%s\n", len, strerror(errno)); |                     mylog(log_warn, "fifo read failed len=%d,errno=%s\n", len, strerror(errno)); | ||||||
|                     continue; |                     continue; | ||||||
|                 } |                 } | ||||||
| @@ -862,13 +758,9 @@ int server_event_loop() | |||||||
|                     buf[len - 1] = 0; |                     buf[len - 1] = 0; | ||||||
|                 mylog(log_info, "got data from fifo,len=%d,s=[%s]\n", len, buf); |                 mylog(log_info, "got data from fifo,len=%d,s=[%s]\n", len, buf); | ||||||
|                 mylog(log_info, "unknown command\n"); |                 mylog(log_info, "unknown command\n"); | ||||||
| 			} |             } else if (events[idx].data.u64 > u32_t(-1)) { | ||||||
| 			else if (events[idx].data.u64>u32_t(-1) ) |  | ||||||
| 			{ |  | ||||||
|  |  | ||||||
|                 fd64_t fd64 = events[idx].data.u64; |                 fd64_t fd64 = events[idx].data.u64; | ||||||
| 				if(!fd_manager.exist(fd64)) |                 if (!fd_manager.exist(fd64)) { | ||||||
| 				{ |  | ||||||
|                     mylog(log_trace, "fd64 no longer exist\n"); |                     mylog(log_trace, "fd64 no longer exist\n"); | ||||||
|                     return -1; |                     return -1; | ||||||
|                 } |                 } | ||||||
| @@ -877,37 +769,32 @@ int server_event_loop() | |||||||
|                 conn_info_t &conn_info = *p_conn_info; |                 conn_info_t &conn_info = *p_conn_info; | ||||||
|                 if (fd64 == conn_info.timer_fd64)  //////////timer_fd64 |                 if (fd64 == conn_info.timer_fd64)  //////////timer_fd64 | ||||||
|                 { |                 { | ||||||
|  |  | ||||||
|                     if (debug_flag) begin_time = get_current_time(); |                     if (debug_flag) begin_time = get_current_time(); | ||||||
|                     int fd = fd_manager.to_fd(fd64); |                     int fd = fd_manager.to_fd(fd64); | ||||||
|                     u64_t dummy; |                     u64_t dummy; | ||||||
|                     int unused = read(fd, &dummy, 8); |                     int unused = read(fd, &dummy, 8); | ||||||
|                     assert(conn_info.state.server_current_state == server_ready);  // TODO remove this for peformance |                     assert(conn_info.state.server_current_state == server_ready);  // TODO remove this for peformance | ||||||
|                     server_on_timer_multi(conn_info); |                     server_on_timer_multi(conn_info); | ||||||
| 					if(debug_flag) |                     if (debug_flag) { | ||||||
| 					{ |  | ||||||
|                         end_time = get_current_time(); |                         end_time = get_current_time(); | ||||||
|                         mylog(log_debug, "(events[idx].data.u64 >>32u) == 2u ,%llu,%llu,%llu  \n", begin_time, end_time, end_time - begin_time); |                         mylog(log_debug, "(events[idx].data.u64 >>32u) == 2u ,%llu,%llu,%llu  \n", begin_time, end_time, end_time - begin_time); | ||||||
|                     } |                     } | ||||||
| 				} |                 } else  // udp_fd64 | ||||||
| 				else//udp_fd64 |  | ||||||
|                 { |                 { | ||||||
|                     if (debug_flag) begin_time = get_current_time(); |                     if (debug_flag) begin_time = get_current_time(); | ||||||
|                     server_on_udp_recv(conn_info, fd64); |                     server_on_udp_recv(conn_info, fd64); | ||||||
| 					if(debug_flag) |                     if (debug_flag) { | ||||||
| 					{ |  | ||||||
|                         end_time = get_current_time(); |                         end_time = get_current_time(); | ||||||
|                         mylog(log_debug, "(events[idx].data.u64 >>32u) == 1u,%lld,%lld,%lld  \n", begin_time, end_time, end_time - begin_time); |                         mylog(log_debug, "(events[idx].data.u64 >>32u) == 1u,%lld,%lld,%lld  \n", begin_time, end_time, end_time - begin_time); | ||||||
|                     } |                     } | ||||||
|                 } |                 } | ||||||
| 			} |             } else { | ||||||
| 			else |  | ||||||
| 			{ |  | ||||||
|                 mylog(log_fatal, "unknown fd,this should never happen\n"); |                 mylog(log_fatal, "unknown fd,this should never happen\n"); | ||||||
|                 myexit(-1); |                 myexit(-1); | ||||||
|             } |             } | ||||||
|  |  | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|     return 0; |     return 0; | ||||||
| } | } | ||||||
|  |  | ||||||
|  | #endif | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user