4
0
mirror of https://github.com/RT-Thread/rt-thread.git synced 2025-01-31 16:30:29 +08:00

[components][netdev] add statistics and more inupt parameters to ping command

This commit is contained in:
Evlers 2025-01-04 21:59:16 +08:00 committed by Rbb666
parent 9c164882e8
commit 45bb1ddac9

View File

@ -6,6 +6,7 @@
* Change Logs:
* Date Author Notes
* 2019-03-18 ChenYong First version
* 2025-01-04 Evlers add statistics and more inupt parameters to ping command
*/
#include <stdio.h>
@ -1286,7 +1287,7 @@ int netdev_cmd_ping(char* target_name, char *netdev_name, rt_uint32_t times, rt_
struct netdev *netdev = RT_NULL;
struct netdev_ping_resp ping_resp;
rt_uint32_t index;
rt_uint32_t index, received, loss, max_time, min_time, avg_time;
int ret = 0;
rt_bool_t isbind = RT_FALSE;
@ -1326,6 +1327,8 @@ int netdev_cmd_ping(char* target_name, char *netdev_name, rt_uint32_t times, rt_
}
}
max_time = avg_time = received = 0;
min_time = 0xFFFFFFFF;
for (index = 0; index < times; index++)
{
int delay_tick = 0;
@ -1337,7 +1340,7 @@ int netdev_cmd_ping(char* target_name, char *netdev_name, rt_uint32_t times, rt_
if (ret == -RT_ETIMEOUT)
{
rt_kprintf("ping: from %s icmp_seq=%d timeout\n",
(ip_addr_isany(&(ping_resp.ip_addr))) ? target_name : inet_ntoa(ping_resp.ip_addr), index);
(ip_addr_isany(&(ping_resp.ip_addr))) ? target_name : inet_ntoa(ping_resp.ip_addr), index + 1);
}
else if (ret == -RT_ERROR)
{
@ -1350,13 +1353,23 @@ int netdev_cmd_ping(char* target_name, char *netdev_name, rt_uint32_t times, rt_
if (ping_resp.ttl == 0)
{
rt_kprintf("%d bytes from %s icmp_seq=%d time=%d ms\n",
ping_resp.data_len, inet_ntoa(ping_resp.ip_addr), index, ping_resp.ticks);
ping_resp.data_len, inet_ntoa(ping_resp.ip_addr), index + 1, ping_resp.ticks);
}
else
{
rt_kprintf("%d bytes from %s icmp_seq=%d ttl=%d time=%d ms\n",
ping_resp.data_len, inet_ntoa(ping_resp.ip_addr), index, ping_resp.ttl, ping_resp.ticks);
ping_resp.data_len, inet_ntoa(ping_resp.ip_addr), index + 1, ping_resp.ttl, ping_resp.ticks);
}
received += 1;
if (ping_resp.ticks > max_time)
{
max_time = ping_resp.ticks;
}
else if (ping_resp.ticks < min_time)
{
min_time = ping_resp.ticks;
}
avg_time += ping_resp.ticks;
}
/* if the response time is more than NETDEV_PING_DELAY, no need to delay */
@ -1364,6 +1377,29 @@ int netdev_cmd_ping(char* target_name, char *netdev_name, rt_uint32_t times, rt_
rt_thread_delay(delay_tick);
}
/* print ping statistics */
loss = (uint32_t)((1 - ((float)received) / index) * 100);
avg_time = (uint32_t)(avg_time / received);
#if NETDEV_IPV4 && NETDEV_IPV6
if (IP_IS_V4_VAL(&ping_resp.ip_addr))
{
rt_kprintf("\n--- %s ping statistics ---\n", inet_ntoa(*ip_2_ip4(&ping_resp.ip_addr)));
}
else
{
rt_kprintf("\n--- %s ping statistics ---\n", inet6_ntoa(*ip_2_ip6(&ping_resp.ip_addr)));
}
#elif NETDEV_IPV4
rt_kprintf("\n--- %s ping statistics ---\n", inet_ntoa(ping_resp.ip_addr));
#elif NETDEV_IPV6
rt_kprintf("\n--- %s ping statistics ---\n", inet6_ntoa(ping_resp.ip_addr));
#endif
rt_kprintf("%d packets transmitted, %d received, %d%% packet loss\n", index, received, loss);
if (received > 0)
{
rt_kprintf("minimum = %dms, maximum = %dms, average = %dms\n", min_time, max_time, avg_time);
}
return RT_EOK;
}
@ -1371,7 +1407,7 @@ int netdev_ping(int argc, char **argv)
{
if (argc == 1)
{
rt_kprintf("Please input: ping <host address> [netdev name]\n");
rt_kprintf("Please input: ping <host address> [netdev name] [times] [data size]\n");
}
else if (argc == 2)
{
@ -1381,6 +1417,14 @@ int netdev_ping(int argc, char **argv)
{
netdev_cmd_ping(argv[1], argv[2], 4, 0);
}
else if (argc == 4)
{
netdev_cmd_ping(argv[1], argv[2], atoi(argv[3]), 0);
}
else if (argc == 5)
{
netdev_cmd_ping(argv[1], argv[2], atoi(argv[3]), atoi(argv[4]));
}
return 0;
}