2016-12-07 17:34:26 +08:00
|
|
|
// Copyright 2015-2016 Espressif Systems (Shanghai) PTE LTD
|
|
|
|
//
|
|
|
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
// you may not use this file except in compliance with the License.
|
|
|
|
// You may obtain a copy of the License at
|
|
|
|
|
|
|
|
// http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
//
|
|
|
|
// Unless required by applicable law or agreed to in writing, software
|
|
|
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
// See the License for the specific language governing permissions and
|
|
|
|
// limitations under the License.
|
|
|
|
|
|
|
|
#include <string.h>
|
2018-09-10 12:21:59 +08:00
|
|
|
#include "esp_ping.h"
|
2016-12-07 17:34:26 +08:00
|
|
|
|
|
|
|
#include "lwip/ip_addr.h"
|
|
|
|
typedef struct _ping_option {
|
2020-07-06 19:20:48 +08:00
|
|
|
ip_addr_t ping_target;
|
2016-12-07 17:34:26 +08:00
|
|
|
uint32_t ping_count;
|
|
|
|
uint32_t ping_rcv_timeout;
|
|
|
|
uint32_t ping_delay;
|
2020-07-06 19:20:48 +08:00
|
|
|
uint32_t interface;
|
2018-09-05 21:02:38 +08:00
|
|
|
size_t ping_data_len;
|
2016-12-07 17:34:26 +08:00
|
|
|
uint16_t ping_id;
|
2018-09-05 21:02:38 +08:00
|
|
|
u8_t ping_tos;
|
2022-07-11 19:40:27 +08:00
|
|
|
u8_t ping_ttl;
|
2016-12-07 17:34:26 +08:00
|
|
|
esp_ping_found_fn ping_res_fn;
|
|
|
|
esp_ping_found ping_res;
|
|
|
|
void *ping_reserve;
|
|
|
|
} ping_option;
|
|
|
|
|
|
|
|
static ping_option ping_option_info[1];
|
|
|
|
|
|
|
|
esp_err_t esp_ping_set_target(ping_target_id_t opt_id, void *opt_val, uint32_t opt_len)
|
|
|
|
{
|
|
|
|
esp_err_t ret = ESP_OK;
|
|
|
|
|
|
|
|
if (opt_val == NULL) {
|
|
|
|
return ESP_ERR_PING_INVALID_PARAMS;
|
|
|
|
}
|
|
|
|
|
|
|
|
switch (opt_id) {
|
|
|
|
case PING_TARGET_IP_ADDRESS:
|
2020-07-06 19:20:48 +08:00
|
|
|
ipaddr_aton(opt_val, &(ping_option_info->ping_target));
|
2016-12-07 17:34:26 +08:00
|
|
|
break;
|
|
|
|
case PING_TARGET_IP_ADDRESS_COUNT:
|
|
|
|
ESP_PING_CHECK_OPTLEN(opt_len, uint32_t);
|
|
|
|
ping_option_info->ping_count = *(uint32_t *)opt_val;
|
|
|
|
break;
|
2020-07-06 19:20:48 +08:00
|
|
|
case PING_TARGET_IF_INDEX:
|
|
|
|
ESP_PING_CHECK_OPTLEN(opt_len, uint32_t);
|
|
|
|
ping_option_info->interface = *(uint32_t *)opt_val;
|
|
|
|
break;
|
2016-12-07 17:34:26 +08:00
|
|
|
case PING_TARGET_RCV_TIMEO:
|
|
|
|
ESP_PING_CHECK_OPTLEN(opt_len, uint32_t);
|
2018-02-18 18:47:46 -05:00
|
|
|
ping_option_info->ping_rcv_timeout = (*(uint32_t *)opt_val);
|
2016-12-07 17:34:26 +08:00
|
|
|
break;
|
|
|
|
case PING_TARGET_DELAY_TIME:
|
|
|
|
ESP_PING_CHECK_OPTLEN(opt_len, uint32_t);
|
2018-02-18 18:47:46 -05:00
|
|
|
ping_option_info->ping_delay = (*(uint32_t *)opt_val);
|
2016-12-07 17:34:26 +08:00
|
|
|
break;
|
2018-09-05 21:02:38 +08:00
|
|
|
case PING_TARGET_DATA_LEN:
|
|
|
|
ESP_PING_CHECK_OPTLEN(opt_len, size_t);
|
|
|
|
ping_option_info->ping_data_len = (*(size_t *)opt_val);
|
|
|
|
break;
|
2016-12-07 17:34:26 +08:00
|
|
|
case PING_TARGET_ID:
|
|
|
|
ESP_PING_CHECK_OPTLEN(opt_len, uint16_t);
|
|
|
|
ping_option_info->ping_id = *(uint16_t *)opt_val;
|
|
|
|
break;
|
2018-09-05 21:02:38 +08:00
|
|
|
case PING_TARGET_IP_TOS:
|
|
|
|
ESP_PING_CHECK_OPTLEN(opt_len, u8_t);
|
|
|
|
ping_option_info->ping_tos = *(u8_t *)opt_val;
|
|
|
|
break;
|
2016-12-07 17:34:26 +08:00
|
|
|
case PING_TARGET_RES_FN:
|
|
|
|
ping_option_info->ping_res_fn = opt_val;
|
|
|
|
break;
|
2017-06-15 11:37:23 +08:00
|
|
|
case PING_TARGET_RES_RESET:
|
|
|
|
memset(&ping_option_info->ping_res, 0, sizeof(ping_option_info->ping_res));
|
|
|
|
break;
|
2016-12-07 17:34:26 +08:00
|
|
|
default:
|
|
|
|
ret = ESP_ERR_PING_INVALID_PARAMS;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
return ret;
|
|
|
|
}
|
|
|
|
|
|
|
|
esp_err_t esp_ping_get_target(ping_target_id_t opt_id, void *opt_val, uint32_t opt_len)
|
|
|
|
{
|
|
|
|
esp_err_t ret = ESP_OK;
|
|
|
|
|
|
|
|
if (opt_val == NULL) {
|
|
|
|
return ESP_ERR_PING_INVALID_PARAMS;
|
|
|
|
}
|
|
|
|
|
|
|
|
switch (opt_id) {
|
|
|
|
case PING_TARGET_IP_ADDRESS:
|
2020-07-06 19:20:48 +08:00
|
|
|
ip_addr_copy(*(ip_addr_t*)opt_val, ping_option_info->ping_target);
|
2016-12-07 17:34:26 +08:00
|
|
|
break;
|
|
|
|
case PING_TARGET_IP_ADDRESS_COUNT:
|
|
|
|
ESP_PING_CHECK_OPTLEN(opt_len, uint32_t);
|
|
|
|
*(uint32_t *)opt_val = ping_option_info->ping_count;
|
|
|
|
break;
|
2020-07-06 19:20:48 +08:00
|
|
|
case PING_TARGET_IF_INDEX:
|
|
|
|
ESP_PING_CHECK_OPTLEN(opt_len, uint32_t);
|
|
|
|
*(uint32_t *)opt_val = ping_option_info->interface;
|
|
|
|
break;
|
2016-12-07 17:34:26 +08:00
|
|
|
case PING_TARGET_RCV_TIMEO:
|
|
|
|
ESP_PING_CHECK_OPTLEN(opt_len, uint32_t);
|
|
|
|
*(uint32_t *)opt_val = ping_option_info->ping_rcv_timeout;
|
|
|
|
break;
|
|
|
|
case PING_TARGET_DELAY_TIME:
|
|
|
|
ESP_PING_CHECK_OPTLEN(opt_len, uint32_t);
|
|
|
|
*(uint32_t *)opt_val = ping_option_info->ping_delay;
|
|
|
|
break;
|
2018-09-05 21:02:38 +08:00
|
|
|
case PING_TARGET_DATA_LEN:
|
|
|
|
ESP_PING_CHECK_OPTLEN(opt_len, size_t);
|
|
|
|
*(size_t *)opt_val = ping_option_info->ping_data_len;
|
|
|
|
break;
|
2016-12-07 17:34:26 +08:00
|
|
|
case PING_TARGET_ID:
|
|
|
|
ESP_PING_CHECK_OPTLEN(opt_len, uint16_t);
|
|
|
|
*(uint16_t *)opt_val = ping_option_info->ping_id;
|
|
|
|
break;
|
2018-09-05 21:02:38 +08:00
|
|
|
case PING_TARGET_IP_TOS:
|
|
|
|
ESP_PING_CHECK_OPTLEN(opt_len, uint16_t);
|
|
|
|
*(uint16_t *)opt_val = ping_option_info->ping_tos;
|
|
|
|
break;
|
2016-12-07 17:34:26 +08:00
|
|
|
default:
|
|
|
|
ret = ESP_ERR_PING_INVALID_PARAMS;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
return ret;
|
|
|
|
}
|
|
|
|
|
|
|
|
esp_err_t esp_ping_result(uint8_t res_val, uint16_t ping_len, uint32_t ping_time)
|
|
|
|
{
|
|
|
|
esp_err_t ret = ESP_OK;
|
|
|
|
|
|
|
|
ping_option_info->ping_res.ping_err = res_val;
|
|
|
|
|
2017-06-15 11:37:23 +08:00
|
|
|
if (res_val != PING_RES_FINISH) {
|
|
|
|
ping_option_info->ping_res.bytes = ping_len;
|
|
|
|
ping_option_info->ping_res.resp_time = ping_time;
|
|
|
|
ping_option_info->ping_res.total_bytes += ping_len;
|
|
|
|
ping_option_info->ping_res.send_count ++;
|
|
|
|
|
|
|
|
if (res_val == PING_RES_TIMEOUT) {
|
|
|
|
ping_option_info->ping_res.timeout_count ++;
|
|
|
|
} else {
|
|
|
|
if (!ping_option_info->ping_res.min_time || (ping_time < ping_option_info->ping_res.min_time)) {
|
|
|
|
ping_option_info->ping_res.min_time = ping_time;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (ping_time > ping_option_info->ping_res.max_time) {
|
|
|
|
ping_option_info->ping_res.max_time = ping_time;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
ping_option_info->ping_res.total_time += ping_time;
|
|
|
|
ping_option_info->ping_res.recv_count ++;
|
|
|
|
}
|
2016-12-07 17:34:26 +08:00
|
|
|
}
|
|
|
|
|
2017-06-15 11:37:23 +08:00
|
|
|
if (ping_option_info->ping_res_fn) {
|
2016-12-07 17:34:26 +08:00
|
|
|
ping_option_info->ping_res_fn(PING_TARGET_RES_FN, &ping_option_info->ping_res);
|
2017-06-15 11:37:23 +08:00
|
|
|
if (res_val == PING_RES_FINISH) {
|
|
|
|
memset(&ping_option_info->ping_res, 0, sizeof(esp_ping_found));
|
|
|
|
}
|
2016-12-07 17:34:26 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
return ret;
|
|
|
|
}
|