esp_ping.c 5.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167
  1. /*
  2. * SPDX-FileCopyrightText: 2019-2021 Espressif Systems (Shanghai) CO LTD
  3. *
  4. * SPDX-License-Identifier: Apache-2.0
  5. */
  6. #include <string.h>
  7. #include "esp_ping.h"
  8. #include "lwip/ip_addr.h"
  9. typedef struct _ping_option {
  10. ip_addr_t ping_target;
  11. uint32_t ping_count;
  12. uint32_t ping_rcv_timeout;
  13. uint32_t ping_delay;
  14. uint32_t interface;
  15. size_t ping_data_len;
  16. uint16_t ping_id;
  17. u8_t ping_tos;
  18. u8_t ping_ttl;
  19. esp_ping_found_fn ping_res_fn;
  20. esp_ping_found ping_res;
  21. void *ping_reserve;
  22. } ping_option;
  23. static ping_option ping_option_info[1];
  24. esp_err_t esp_ping_set_target(ping_target_id_t opt_id, void *opt_val, uint32_t opt_len)
  25. {
  26. esp_err_t ret = ESP_OK;
  27. if (opt_val == NULL) {
  28. return ESP_ERR_PING_INVALID_PARAMS;
  29. }
  30. switch (opt_id) {
  31. case PING_TARGET_IP_ADDRESS:
  32. ipaddr_aton(opt_val, &(ping_option_info->ping_target));
  33. break;
  34. case PING_TARGET_IP_ADDRESS_COUNT:
  35. ESP_PING_CHECK_OPTLEN(opt_len, uint32_t);
  36. ping_option_info->ping_count = *(uint32_t *)opt_val;
  37. break;
  38. case PING_TARGET_IF_INDEX:
  39. ESP_PING_CHECK_OPTLEN(opt_len, uint32_t);
  40. ping_option_info->interface = *(uint32_t *)opt_val;
  41. break;
  42. case PING_TARGET_RCV_TIMEO:
  43. ESP_PING_CHECK_OPTLEN(opt_len, uint32_t);
  44. ping_option_info->ping_rcv_timeout = (*(uint32_t *)opt_val);
  45. break;
  46. case PING_TARGET_DELAY_TIME:
  47. ESP_PING_CHECK_OPTLEN(opt_len, uint32_t);
  48. ping_option_info->ping_delay = (*(uint32_t *)opt_val);
  49. break;
  50. case PING_TARGET_DATA_LEN:
  51. ESP_PING_CHECK_OPTLEN(opt_len, size_t);
  52. ping_option_info->ping_data_len = (*(size_t *)opt_val);
  53. break;
  54. case PING_TARGET_ID:
  55. ESP_PING_CHECK_OPTLEN(opt_len, uint16_t);
  56. ping_option_info->ping_id = *(uint16_t *)opt_val;
  57. break;
  58. case PING_TARGET_IP_TOS:
  59. ESP_PING_CHECK_OPTLEN(opt_len, u8_t);
  60. ping_option_info->ping_tos = *(u8_t *)opt_val;
  61. break;
  62. case PING_TARGET_RES_FN:
  63. ping_option_info->ping_res_fn = opt_val;
  64. break;
  65. case PING_TARGET_RES_RESET:
  66. memset(&ping_option_info->ping_res, 0, sizeof(ping_option_info->ping_res));
  67. break;
  68. default:
  69. ret = ESP_ERR_PING_INVALID_PARAMS;
  70. break;
  71. }
  72. return ret;
  73. }
  74. esp_err_t esp_ping_get_target(ping_target_id_t opt_id, void *opt_val, uint32_t opt_len)
  75. {
  76. esp_err_t ret = ESP_OK;
  77. if (opt_val == NULL) {
  78. return ESP_ERR_PING_INVALID_PARAMS;
  79. }
  80. switch (opt_id) {
  81. case PING_TARGET_IP_ADDRESS:
  82. ip_addr_copy(*(ip_addr_t*)opt_val, ping_option_info->ping_target);
  83. break;
  84. case PING_TARGET_IP_ADDRESS_COUNT:
  85. ESP_PING_CHECK_OPTLEN(opt_len, uint32_t);
  86. *(uint32_t *)opt_val = ping_option_info->ping_count;
  87. break;
  88. case PING_TARGET_IF_INDEX:
  89. ESP_PING_CHECK_OPTLEN(opt_len, uint32_t);
  90. *(uint32_t *)opt_val = ping_option_info->interface;
  91. break;
  92. case PING_TARGET_RCV_TIMEO:
  93. ESP_PING_CHECK_OPTLEN(opt_len, uint32_t);
  94. *(uint32_t *)opt_val = ping_option_info->ping_rcv_timeout;
  95. break;
  96. case PING_TARGET_DELAY_TIME:
  97. ESP_PING_CHECK_OPTLEN(opt_len, uint32_t);
  98. *(uint32_t *)opt_val = ping_option_info->ping_delay;
  99. break;
  100. case PING_TARGET_DATA_LEN:
  101. ESP_PING_CHECK_OPTLEN(opt_len, size_t);
  102. *(size_t *)opt_val = ping_option_info->ping_data_len;
  103. break;
  104. case PING_TARGET_ID:
  105. ESP_PING_CHECK_OPTLEN(opt_len, uint16_t);
  106. *(uint16_t *)opt_val = ping_option_info->ping_id;
  107. break;
  108. case PING_TARGET_IP_TOS:
  109. ESP_PING_CHECK_OPTLEN(opt_len, uint16_t);
  110. *(uint16_t *)opt_val = ping_option_info->ping_tos;
  111. break;
  112. default:
  113. ret = ESP_ERR_PING_INVALID_PARAMS;
  114. break;
  115. }
  116. return ret;
  117. }
  118. esp_err_t esp_ping_result(uint8_t res_val, uint16_t ping_len, uint32_t ping_time)
  119. {
  120. esp_err_t ret = ESP_OK;
  121. ping_option_info->ping_res.ping_err = res_val;
  122. if (res_val != PING_RES_FINISH) {
  123. ping_option_info->ping_res.bytes = ping_len;
  124. ping_option_info->ping_res.resp_time = ping_time;
  125. ping_option_info->ping_res.total_bytes += ping_len;
  126. ping_option_info->ping_res.send_count ++;
  127. if (res_val == PING_RES_TIMEOUT) {
  128. ping_option_info->ping_res.timeout_count ++;
  129. } else {
  130. if (!ping_option_info->ping_res.min_time || (ping_time < ping_option_info->ping_res.min_time)) {
  131. ping_option_info->ping_res.min_time = ping_time;
  132. }
  133. if (ping_time > ping_option_info->ping_res.max_time) {
  134. ping_option_info->ping_res.max_time = ping_time;
  135. }
  136. ping_option_info->ping_res.total_time += ping_time;
  137. ping_option_info->ping_res.recv_count ++;
  138. }
  139. }
  140. if (ping_option_info->ping_res_fn) {
  141. ping_option_info->ping_res_fn(PING_TARGET_RES_FN, &ping_option_info->ping_res);
  142. if (res_val == PING_RES_FINISH) {
  143. memset(&ping_option_info->ping_res, 0, sizeof(esp_ping_found));
  144. }
  145. }
  146. return ret;
  147. }