/* * $smu-mark$ * $name: statistics.c$ * $author: Salvatore Sanfilippo $ * $copyright: Copyright (C) 1999 by Salvatore Sanfilippo$ * $license: This software is under GPL version 2 of license$ * $date: Fri Nov 5 11:55:50 MET 1999$ * $rev: 8$ */ #include #include #include #include "hping2.h" #include "globals.h" void print_statistics(int signal_id) { unsigned int lossrate; uint32_t losspack=0; #if (defined OSTYPE_LINUX) && (!defined FORCE_LIBPCAP) close_sockpacket(sockpacket); #else close_pcap(); #endif /* OSTYPE_LINUX && !FORCE_LIBPCAP */ if (recv_pkt > 0){ losspack=(recv_pkt!=sent_pkt)?(recv_pkt/sent_pkt):0; lossrate = 100 - ((recv_pkt*100)/sent_pkt); }else{ losspack=!sent_pkt?0:sent_pkt; lossrate=!sent_pkt?0:100; } fprintf(stderr, "\n--- %s 统计 ---\n", targetname); fprintf(stderr, "发送: %d|收到: %d|%d%% 丢包率|已丢弃 %d\n", sent_pkt, recv_pkt, lossrate,losspack); if (out_of_sequence_pkt) fprintf(stderr, "已收到 %d 个乱序数据包\n", out_of_sequence_pkt); fprintf(stderr, "往返时间:\n最小:%.1f 毫秒\n平均: %.1f 毫秒\n最大:%.1f 毫秒\n", rtt_min, rtt_avg, rtt_max); /* manage exit code */ if (opt_tcpexitcode) { exit(tcp_exitcode); } else { if (recv_pkt) exit(0); else exit(1); } };