2020-02-03 05:01:04 -05:00
|
|
|
/* Wi-Fi iperf Example
|
2017-03-30 11:12:25 -04:00
|
|
|
|
|
|
|
This example code is in the Public Domain (or CC0 licensed, at your option.)
|
|
|
|
|
|
|
|
Unless required by applicable law or agreed to in writing, this
|
|
|
|
software is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR
|
|
|
|
CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <errno.h>
|
|
|
|
#include <string.h>
|
|
|
|
#include "esp_wifi.h"
|
|
|
|
#include "esp_log.h"
|
|
|
|
#include "esp_err.h"
|
2017-10-19 21:52:58 -04:00
|
|
|
#include "nvs_flash.h"
|
2017-03-30 11:12:25 -04:00
|
|
|
#include "esp_console.h"
|
2024-03-11 02:28:11 -04:00
|
|
|
#include "cmd_system.h"
|
|
|
|
|
|
|
|
/* component manager */
|
|
|
|
#include "iperf.h"
|
|
|
|
#include "wifi_cmd.h"
|
|
|
|
#include "iperf_cmd.h"
|
|
|
|
#include "ping_cmd.h"
|
|
|
|
|
|
|
|
|
|
|
|
#if CONFIG_ESP_WIFI_ENABLE_WIFI_TX_STATS || CONFIG_ESP_WIFI_ENABLE_WIFI_RX_STATS
|
|
|
|
#include "esp_wifi_he.h"
|
|
|
|
#endif
|
|
|
|
#if CONFIG_ESP_WIFI_ENABLE_WIFI_TX_STATS
|
|
|
|
extern int wifi_cmd_get_tx_statistics(int argc, char **argv);
|
|
|
|
extern int wifi_cmd_clr_tx_statistics(int argc, char **argv);
|
|
|
|
#endif
|
|
|
|
#if CONFIG_ESP_WIFI_ENABLE_WIFI_RX_STATS
|
|
|
|
extern int wifi_cmd_get_rx_statistics(int argc, char **argv);
|
|
|
|
extern int wifi_cmd_clr_rx_statistics(int argc, char **argv);
|
|
|
|
#endif
|
|
|
|
|
2024-06-19 09:31:50 -04:00
|
|
|
#ifdef CONFIG_ESP_EXT_CONN_ENABLE
|
|
|
|
#include "esp_extconn.h"
|
|
|
|
#endif
|
2024-03-11 02:28:11 -04:00
|
|
|
|
|
|
|
void iperf_hook_show_wifi_stats(iperf_traffic_type_t type, iperf_status_t status)
|
|
|
|
{
|
|
|
|
if (status == IPERF_STARTED) {
|
|
|
|
#if CONFIG_ESP_WIFI_ENABLE_WIFI_TX_STATS
|
|
|
|
if (type != IPERF_UDP_SERVER) {
|
|
|
|
wifi_cmd_clr_tx_statistics(0, NULL);
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
#if CONFIG_ESP_WIFI_ENABLE_WIFI_RX_STATS
|
|
|
|
if (type != IPERF_UDP_CLIENT) {
|
|
|
|
wifi_cmd_clr_rx_statistics(0, NULL);
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
}
|
|
|
|
|
|
|
|
if (status == IPERF_STOPPED) {
|
|
|
|
#if CONFIG_ESP_WIFI_ENABLE_WIFI_TX_STATS
|
|
|
|
if (type != IPERF_UDP_SERVER) {
|
|
|
|
wifi_cmd_get_tx_statistics(0, NULL);
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
#if CONFIG_ESP_WIFI_ENABLE_WIFI_RX_STATS
|
2024-05-16 07:20:59 -04:00
|
|
|
if (type != IPERF_UDP_CLIENT) {
|
2024-03-11 02:28:11 -04:00
|
|
|
wifi_cmd_get_rx_statistics(0, NULL);
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
2017-03-30 11:12:25 -04:00
|
|
|
|
|
|
|
void app_main(void)
|
|
|
|
{
|
2024-06-19 09:31:50 -04:00
|
|
|
#if CONFIG_ESP_EXT_CONN_ENABLE
|
|
|
|
esp_extconn_config_t ext_config = ESP_EXTCONN_CONFIG_DEFAULT();
|
|
|
|
esp_extconn_init(&ext_config);
|
|
|
|
#endif
|
|
|
|
|
2017-10-19 21:52:58 -04:00
|
|
|
esp_err_t ret = nvs_flash_init();
|
2018-07-25 11:11:09 -04:00
|
|
|
if (ret == ESP_ERR_NVS_NO_FREE_PAGES || ret == ESP_ERR_NVS_NEW_VERSION_FOUND) {
|
2017-10-19 21:52:58 -04:00
|
|
|
ESP_ERROR_CHECK(nvs_flash_erase());
|
|
|
|
ret = nvs_flash_init();
|
|
|
|
}
|
|
|
|
ESP_ERROR_CHECK( ret );
|
2018-09-20 07:26:14 -04:00
|
|
|
|
2024-03-11 02:28:11 -04:00
|
|
|
/* initialise wifi */
|
|
|
|
app_wifi_initialise_config_t config = APP_WIFI_CONFIG_DEFAULT();
|
|
|
|
config.storage = WIFI_STORAGE_RAM;
|
|
|
|
config.ps_type = WIFI_PS_NONE;
|
|
|
|
app_initialise_wifi(&config);
|
|
|
|
#if CONFIG_ESP_WIFI_ENABLE_WIFI_RX_STATS
|
|
|
|
#if CONFIG_ESP_WIFI_ENABLE_WIFI_RX_MU_STATS
|
|
|
|
esp_wifi_enable_rx_statistics(true, true);
|
|
|
|
#else
|
|
|
|
esp_wifi_enable_rx_statistics(true, false);
|
|
|
|
#endif
|
|
|
|
#endif
|
|
|
|
#if CONFIG_ESP_WIFI_ENABLE_WIFI_TX_STATS
|
|
|
|
esp_wifi_enable_tx_statistics(ESP_WIFI_ACI_BE, true);
|
|
|
|
#endif
|
|
|
|
|
2017-03-30 11:12:25 -04:00
|
|
|
|
2020-05-27 23:00:56 -04:00
|
|
|
esp_console_repl_t *repl = NULL;
|
2020-02-03 05:01:04 -05:00
|
|
|
esp_console_repl_config_t repl_config = ESP_CONSOLE_REPL_CONFIG_DEFAULT();
|
|
|
|
repl_config.prompt = "iperf>";
|
2020-10-14 06:10:11 -04:00
|
|
|
|
2020-05-27 23:00:56 -04:00
|
|
|
// init console REPL environment
|
2020-10-14 06:10:11 -04:00
|
|
|
#if CONFIG_ESP_CONSOLE_UART
|
|
|
|
esp_console_dev_uart_config_t uart_config = ESP_CONSOLE_DEV_UART_CONFIG_DEFAULT();
|
2020-05-27 23:00:56 -04:00
|
|
|
ESP_ERROR_CHECK(esp_console_new_repl_uart(&uart_config, &repl_config, &repl));
|
2020-10-14 06:10:11 -04:00
|
|
|
#elif CONFIG_ESP_CONSOLE_USB_CDC
|
|
|
|
esp_console_dev_usb_cdc_config_t cdc_config = ESP_CONSOLE_DEV_CDC_CONFIG_DEFAULT();
|
|
|
|
ESP_ERROR_CHECK(esp_console_new_repl_usb_cdc(&cdc_config, &repl_config, &repl));
|
2021-04-23 03:46:02 -04:00
|
|
|
#elif CONFIG_ESP_CONSOLE_USB_SERIAL_JTAG
|
|
|
|
esp_console_dev_usb_serial_jtag_config_t usbjtag_config = ESP_CONSOLE_DEV_USB_SERIAL_JTAG_CONFIG_DEFAULT();
|
|
|
|
ESP_ERROR_CHECK(esp_console_new_repl_usb_serial_jtag(&usbjtag_config, &repl_config, &repl));
|
2020-10-14 06:10:11 -04:00
|
|
|
#endif
|
|
|
|
|
2017-03-30 11:12:25 -04:00
|
|
|
/* Register commands */
|
2018-09-20 07:26:14 -04:00
|
|
|
register_system();
|
2024-03-11 02:28:11 -04:00
|
|
|
app_register_all_wifi_commands();
|
|
|
|
app_register_iperf_commands();
|
|
|
|
app_register_ping_commands();
|
|
|
|
app_register_iperf_hook_func(iperf_hook_show_wifi_stats);
|
|
|
|
|
2017-03-30 11:12:25 -04:00
|
|
|
|
|
|
|
printf("\n ==================================================\n");
|
|
|
|
printf(" | Steps to test WiFi throughput |\n");
|
|
|
|
printf(" | |\n");
|
|
|
|
printf(" | 1. Print 'help' to gain overview of commands |\n");
|
|
|
|
printf(" | 2. Configure device to station or soft-AP |\n");
|
|
|
|
printf(" | 3. Setup WiFi connection |\n");
|
|
|
|
printf(" | 4. Run iperf to test UDP/TCP RX/TX throughput |\n");
|
|
|
|
printf(" | |\n");
|
|
|
|
printf(" =================================================\n\n");
|
|
|
|
|
2020-02-03 05:01:04 -05:00
|
|
|
// start console REPL
|
2020-05-27 23:00:56 -04:00
|
|
|
ESP_ERROR_CHECK(esp_console_start_repl(repl));
|
2017-03-30 11:12:25 -04:00
|
|
|
}
|