Files
hping3/statistics.c

61 lines
1.4 KiB
C
Raw Normal View History

2022-04-13 18:01:39 +08:00
/*
* $smu-mark$
* $name: statistics.c$
* $author: Salvatore Sanfilippo <antirez@invece.org>$
* $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 <stdlib.h>
#include <stdio.h>
#include <stdlib.h>
2025-05-25 18:59:13 +08:00
#include <math.h>
2022-04-13 18:01:39 +08:00
#include "hping2.h"
#include "globals.h"
2025-05-25 18:59:13 +08:00
void print_statistics(int signal_id)
2022-04-13 18:01:39 +08:00
{
2025-05-25 18:59:13 +08:00
uint32_t lossrate=0;
2024-06-21 07:49:53 +08:00
uint32_t losspack=0;
2022-04-13 18:01:39 +08:00
#if (defined OSTYPE_LINUX) && (!defined FORCE_LIBPCAP)
close_sockpacket(sockpacket);
#else
close_pcap();
#endif /* OSTYPE_LINUX && !FORCE_LIBPCAP */
2024-06-21 07:49:53 +08:00
if (recv_pkt > 0){
2025-05-25 19:06:09 +08:00
losspack=sent_pkt-recv_pkt;
lossrate = ( (float)(sent_pkt - recv_pkt) / sent_pkt ) * 100.0;
2024-06-21 07:49:53 +08:00
}else{
2025-05-25 18:59:13 +08:00
losspack=sent_pkt<0?0:sent_pkt;
lossrate=sent_pkt<0?0:100;
2024-06-21 07:49:53 +08:00
}
2022-04-13 18:01:39 +08:00
2025-05-25 14:44:29 +08:00
printf("\n--- %s 统计 ---\n", targetname);
2025-05-25 19:06:09 +08:00
printf("发送: %d|收到: %d|%d%% 丢包率|已丢弃 %d\n", sent_pkt, recv_pkt, lossrate,losspack);
2025-05-25 18:59:13 +08:00
if (out_of_sequence_pkt>0)
2025-05-25 14:44:29 +08:00
printf("已收到 %d 个乱序数据包\n",
2022-04-13 18:01:39 +08:00
out_of_sequence_pkt);
2025-05-25 14:44:29 +08:00
if(dup_count>0){
2025-05-25 18:59:13 +08:00
printf("重复确认了 %d 个数据包\n",dup_count);
2025-05-25 14:44:29 +08:00
}
printf("==往返时间==\n最小:%.1f 毫秒\n平均: %.1f 毫秒\n最大:%.1f 毫秒\n",
2022-04-13 18:01:39 +08:00
rtt_min, rtt_avg, rtt_max);
/* manage exit code */
if (opt_tcpexitcode)
{
exit(tcp_exitcode);
}
else
{
if (recv_pkt)
exit(0);
else
exit(1);
}
};