AP_HAL_ESP32: update esp32empty
- Add INS_ACC offsets to param to skip calibration for esp32empty - Update esp32empty.h - Change tabs to whitespace. - Define HAL_INS_DEFAULT to HAL_INS_NONE - Update wifi details - Format comment in esp32empty - Update serial defaults and uarts - Use IO_MUX for UART_NUM_2 (TX 17, RX 16) - Update scheduler - Disable initialisation check in timer thread if HAL_INS_NONE - Print main loop rate every 10s - Remove serial(n)->begin() calls Signed-off-by: Rhys Mainwaring <rhys.mainwaring@me.com>
This commit is contained in:
parent
732b074bee
commit
b97e98242b
@ -28,6 +28,7 @@
|
|||||||
#include "esp_task_wdt.h"
|
#include "esp_task_wdt.h"
|
||||||
|
|
||||||
#include <AP_HAL/AP_HAL.h>
|
#include <AP_HAL/AP_HAL.h>
|
||||||
|
#include <AP_Scheduler/AP_Scheduler.h>
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
|
|
||||||
//#define SCHEDULERDEBUG 1
|
//#define SCHEDULERDEBUG 1
|
||||||
@ -50,6 +51,7 @@ void disableCore0WDT()
|
|||||||
//print("Failed to remove Core 0 IDLE task from WDT");
|
//print("Failed to remove Core 0 IDLE task from WDT");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void disableCore1WDT()
|
void disableCore1WDT()
|
||||||
{
|
{
|
||||||
TaskHandle_t idle_1 = xTaskGetIdleTaskHandleForCPU(1);
|
TaskHandle_t idle_1 = xTaskGetIdleTaskHandleForCPU(1);
|
||||||
@ -292,9 +294,14 @@ void Scheduler::_timer_thread(void *arg)
|
|||||||
printf("%s:%d start\n", __PRETTY_FUNCTION__, __LINE__);
|
printf("%s:%d start\n", __PRETTY_FUNCTION__, __LINE__);
|
||||||
#endif
|
#endif
|
||||||
Scheduler *sched = (Scheduler *)arg;
|
Scheduler *sched = (Scheduler *)arg;
|
||||||
|
|
||||||
|
#if HAL_INS_DEFAULT != HAL_INS_NONE
|
||||||
|
// wait to ensure INS system inits unless using HAL_INS_NONE
|
||||||
while (!_initialized) {
|
while (!_initialized) {
|
||||||
sched->delay_microseconds(1000);
|
sched->delay_microseconds(1000);
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
#ifdef SCHEDDEBUG
|
#ifdef SCHEDDEBUG
|
||||||
printf("%s:%d initialised\n", __PRETTY_FUNCTION__, __LINE__);
|
printf("%s:%d initialised\n", __PRETTY_FUNCTION__, __LINE__);
|
||||||
#endif
|
#endif
|
||||||
@ -507,17 +514,25 @@ void Scheduler::print_stats(void)
|
|||||||
// printf("loop_rate_hz: %d",get_loop_rate_hz());
|
// printf("loop_rate_hz: %d",get_loop_rate_hz());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Run every 10s
|
||||||
|
void Scheduler::print_main_loop_rate(void)
|
||||||
|
{
|
||||||
|
static int64_t last_run = 0;
|
||||||
|
if (AP_HAL::millis64() - last_run > 10000) {
|
||||||
|
last_run = AP_HAL::millis64();
|
||||||
|
const float actual_loop_rate = AP::scheduler().get_filtered_loop_rate_hz();
|
||||||
|
const uint16_t expected_loop_rate = AP::scheduler().get_loop_rate_hz();
|
||||||
|
hal.console->printf("loop_rate: actual: %uHz, expected: %uHz\n",
|
||||||
|
(uint16_t)actual_loop_rate, (uint16_t)expected_loop_rate);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
void IRAM_ATTR Scheduler::_main_thread(void *arg)
|
void IRAM_ATTR Scheduler::_main_thread(void *arg)
|
||||||
{
|
{
|
||||||
#ifdef SCHEDDEBUG
|
#ifdef SCHEDDEBUG
|
||||||
printf("%s:%d start\n", __PRETTY_FUNCTION__, __LINE__);
|
printf("%s:%d start\n", __PRETTY_FUNCTION__, __LINE__);
|
||||||
#endif
|
#endif
|
||||||
Scheduler *sched = (Scheduler *)arg;
|
Scheduler *sched = (Scheduler *)arg;
|
||||||
hal.serial(0)->begin(115200);
|
|
||||||
hal.serial(1)->begin(57600);
|
|
||||||
hal.serial(2)->begin(57600);
|
|
||||||
//hal.uartC->begin(921600);
|
|
||||||
hal.serial(3)->begin(115200);
|
|
||||||
|
|
||||||
#ifndef HAL_DISABLE_ADC_DRIVER
|
#ifndef HAL_DISABLE_ADC_DRIVER
|
||||||
hal.analogin->init();
|
hal.analogin->init();
|
||||||
@ -535,7 +550,9 @@ void IRAM_ATTR Scheduler::_main_thread(void *arg)
|
|||||||
sched->callbacks->loop();
|
sched->callbacks->loop();
|
||||||
sched->delay_microseconds(250);
|
sched->delay_microseconds(250);
|
||||||
|
|
||||||
sched->print_stats(); // only runs every 60 seconds.
|
// run stats periodically
|
||||||
|
sched->print_stats();
|
||||||
|
sched->print_main_loop_rate();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -49,6 +49,8 @@ public:
|
|||||||
bool is_system_initialized() override;
|
bool is_system_initialized() override;
|
||||||
|
|
||||||
void print_stats(void) ;
|
void print_stats(void) ;
|
||||||
|
void print_main_loop_rate(void);
|
||||||
|
|
||||||
uint16_t get_loop_rate_hz(void);
|
uint16_t get_loop_rate_hz(void);
|
||||||
AP_Int16 _active_loop_rate_hz;
|
AP_Int16 _active_loop_rate_hz;
|
||||||
AP_Int16 _loop_rate_hz;
|
AP_Int16 _loop_rate_hz;
|
||||||
|
@ -23,108 +23,128 @@
|
|||||||
|
|
||||||
#define HAL_ESP32_BOARD_NAME "esp32-empty"
|
#define HAL_ESP32_BOARD_NAME "esp32-empty"
|
||||||
|
|
||||||
#define TRUE 1
|
#define TRUE 1
|
||||||
#define FALSE 0
|
#define FALSE 0
|
||||||
|
|
||||||
//Protocols
|
//Protocols
|
||||||
//list of protocols/enum: ardupilot/libraries/AP_SerialManager/AP_SerialManager.h
|
// list of protocols/enum: ardupilot/libraries/AP_SerialManager/AP_SerialManager.h
|
||||||
//default protocols: ardupilot/libraries/AP_SerialManager/AP_SerialManager.cpp
|
// default protocols: ardupilot/libraries/AP_SerialManager/AP_SerialManager.cpp
|
||||||
//ESP32 serials: AP_HAL_ESP32/HAL_ESP32_Class.cpp
|
// ESP32 serials: AP_HAL_ESP32/HAL_ESP32_Class.cpp
|
||||||
|
|
||||||
//#define DEFAULT_SERIAL0_PROTOCOL SerialProtocol_MAVLink2 //A UART0: Always: Console, MAVLink2
|
//#define DEFAULT_SERIAL0_PROTOCOL SerialProtocol_MAVLink2 //A UART0: Always: Console, MAVLink2
|
||||||
//#define DEFAULT_SERIAL0_BAUD AP_SERIALMANAGER_CONSOLE_BAUD/1000 //115200
|
//#define DEFAULT_SERIAL0_BAUD AP_SERIALMANAGER_CONSOLE_BAUD/1000 //115200
|
||||||
|
|
||||||
//#define DEFAULT_SERIAL1_PROTOCOL SerialProtocol_MAVLink2 //C WiFi: TCP, UDP, or disable (depends on HAL_ESP32_WIFI)
|
//#define DEFAULT_SERIAL1_PROTOCOL SerialProtocol_MAVLink2 //C WiFi: TCP, UDP, or disable (depends on HAL_ESP32_WIFI)
|
||||||
//#define DEFAULT_SERIAL1_BAUD AP_SERIALMANAGER_MAVLINK_BAUD/1000 //57600
|
//#define DEFAULT_SERIAL1_BAUD AP_SERIALMANAGER_MAVLINK_BAUD/1000 //57600
|
||||||
|
|
||||||
#define DEFAULT_SERIAL2_PROTOCOL SerialProtocol_MAVLink2 //D UART2: Always: MAVLink2 on ESP32
|
#define DEFAULT_SERIAL2_PROTOCOL SerialProtocol_MAVLink2 //D UART2
|
||||||
//#define DEFAULT_SERIAL2_BAUD AP_SERIALMANAGER_MAVLINK_BAUD/1000 //57600
|
#define DEFAULT_SERIAL2_BAUD AP_SERIALMANAGER_MAVLINK_BAUD/1000 //57600
|
||||||
|
|
||||||
#define DEFAULT_SERIAL3_PROTOCOL SerialProtocol_GPS //B UART1: GPS1
|
#define DEFAULT_SERIAL3_PROTOCOL SerialProtocol_GPS //B UART1: GPS1
|
||||||
//#define DEFAULT_SERIAL4_BAUD AP_SERIALMANAGER_GPS_BAUD/1000 //38400, Can not define default baudrate here (by config only)
|
#define DEFAULT_SERIAL3_BAUD AP_SERIALMANAGER_GPS_BAUD/1000 //38400, Can not define default baudrate here (by config only)
|
||||||
|
//#define DEFAULT_SERIAL3_PROTOCOL SerialProtocol_None //B
|
||||||
|
//#define DEFAULT_SERIAL3_BAUD (115200/1000)
|
||||||
|
|
||||||
#define DEFAULT_SERIAL4_PROTOCOL SerialProtocol_None //E
|
#define DEFAULT_SERIAL4_PROTOCOL SerialProtocol_None //E
|
||||||
//#define DEFAULT_SERIAL4_BAUD AP_SERIALMANAGER_GPS_BAUD/1000 //38400, Can not define default baudrate here (by config only)
|
#define DEFAULT_SERIAL5_BAUD (115200/1000)
|
||||||
|
|
||||||
#define DEFAULT_SERIAL5_PROTOCOL SerialProtocol_None //F
|
#define DEFAULT_SERIAL5_PROTOCOL SerialProtocol_None //F
|
||||||
#define DEFAULT_SERIAL5_BAUD (115200/1000)
|
#define DEFAULT_SERIAL5_BAUD (115200/1000)
|
||||||
|
|
||||||
#define DEFAULT_SERIAL6_PROTOCOL SerialProtocol_None //G
|
#define DEFAULT_SERIAL6_PROTOCOL SerialProtocol_None //G
|
||||||
#define DEFAULT_SERIAL6_BAUD (115200/1000)
|
#define DEFAULT_SERIAL6_BAUD (115200/1000)
|
||||||
|
|
||||||
#define DEFAULT_SERIAL7_PROTOCOL SerialProtocol_None //H
|
#define DEFAULT_SERIAL7_PROTOCOL SerialProtocol_None //H
|
||||||
#define DEFAULT_SERIAL7_BAUD (115200/1000)
|
#define DEFAULT_SERIAL7_BAUD (115200/1000)
|
||||||
|
|
||||||
#define DEFAULT_SERIAL8_PROTOCOL SerialProtocol_None //I
|
#define DEFAULT_SERIAL8_PROTOCOL SerialProtocol_None //I
|
||||||
#define DEFAULT_SERIAL8_BAUD (115200/1000)
|
#define DEFAULT_SERIAL8_BAUD (115200/1000)
|
||||||
|
|
||||||
#define DEFAULT_SERIAL9_PROTOCOL SerialProtocol_None //J
|
#define DEFAULT_SERIAL9_PROTOCOL SerialProtocol_None //J
|
||||||
#define DEFAULT_SERIAL9_BAUD (115200/1000)
|
#define DEFAULT_SERIAL9_BAUD (115200/1000)
|
||||||
|
|
||||||
//Inertial sensors
|
//Inertial sensors
|
||||||
//#define HAL_INS_DEFAULT HAL_INS_MPU9250_I2C
|
#define HAL_INS_DEFAULT HAL_INS_NONE
|
||||||
//#define PROBE_IMU_I2C(driver, bus, addr, args ...) ADD_BACKEND(AP_InertialSensor_ ## driver::probe(*this,GET_I2C_DEVICE(bus, addr),##args))
|
//#define HAL_INS_DEFAULT HAL_INS_MPU9250_I2C
|
||||||
//#define HAL_INS_PROBE_LIST PROBE_IMU_I2C(Invensense, 0, 0x68, ROTATION_NONE)
|
//#define PROBE_IMU_I2C(driver, bus, addr, args ...) ADD_BACKEND(AP_InertialSensor_ ## driver::probe(*this,GET_I2C_DEVICE(bus, addr),##args))
|
||||||
|
//#define HAL_INS_PROBE_LIST PROBE_IMU_I2C(Invensense, 0, 0x68, ROTATION_NONE)
|
||||||
|
|
||||||
//I2C Buses
|
//I2C Buses
|
||||||
#define HAL_ESP32_I2C_BUSES {.port=I2C_NUM_0, .sda=GPIO_NUM_13, .scl=GPIO_NUM_14, .speed=400*KHZ, .internal=true, .soft=true}
|
#define HAL_ESP32_I2C_BUSES {.port=I2C_NUM_0, .sda=GPIO_NUM_13, .scl=GPIO_NUM_14, .speed=400*KHZ, .internal=true, .soft=true}
|
||||||
|
|
||||||
//SPI Buses
|
//SPI Buses
|
||||||
#define HAL_ESP32_SPI_BUSES {}
|
#define HAL_ESP32_SPI_BUSES {}
|
||||||
|
|
||||||
//SPI Devices
|
//SPI Devices
|
||||||
#define HAL_ESP32_SPI_DEVICES {}
|
#define HAL_ESP32_SPI_DEVICES {}
|
||||||
|
|
||||||
//RCIN
|
//RCIN
|
||||||
#define HAL_ESP32_RCIN GPIO_NUM_36
|
#define HAL_ESP32_RCIN GPIO_NUM_36
|
||||||
|
|
||||||
//RCOUT
|
//RCOUT
|
||||||
#define HAL_ESP32_RCOUT { GPIO_NUM_25, GPIO_NUM_27, GPIO_NUM_33, GPIO_NUM_32, GPIO_NUM_22, GPIO_NUM_21 }
|
#define HAL_ESP32_RCOUT {GPIO_NUM_25, GPIO_NUM_27, GPIO_NUM_33, GPIO_NUM_32, GPIO_NUM_22, GPIO_NUM_21}
|
||||||
|
|
||||||
|
//AIRSPEED
|
||||||
|
#define AP_AIRSPEED_ENABLED 0
|
||||||
|
#define AP_AIRSPEED_ANALOG_ENABLED 0
|
||||||
|
#define AP_AIRSPEED_BACKEND_DEFAULT_ENABLED 0
|
||||||
|
|
||||||
//BAROMETER
|
//BAROMETER
|
||||||
#define HAL_BARO_ALLOW_INIT_NO_BARO 1
|
#define HAL_BARO_ALLOW_INIT_NO_BARO 1
|
||||||
|
|
||||||
|
//IMU
|
||||||
|
// #define AP_INERTIALSENSOR_ENABLED 1
|
||||||
|
// #define AP_INERTIALSENSOR_KILL_IMU_ENABLED 0
|
||||||
|
|
||||||
//COMPASS
|
//COMPASS
|
||||||
|
#define AP_COMPASS_ENABLE_DEFAULT 0
|
||||||
#define ALLOW_ARM_NO_COMPASS
|
#define ALLOW_ARM_NO_COMPASS
|
||||||
|
|
||||||
|
//See boards.py
|
||||||
|
#ifndef ENABLE_HEAP
|
||||||
|
#define ENABLE_HEAP 1
|
||||||
|
#endif
|
||||||
|
|
||||||
//WIFI
|
//WIFI
|
||||||
#define HAL_ESP32_WIFI 1 //1-TCP, 2-UDP, comment this line = without wifi
|
#define HAL_ESP32_WIFI 1 //1-TCP, 2-UDP, comment this line = without wifi
|
||||||
#define WIFI_SSID "ardupilot-empty"
|
#define WIFI_SSID "ardupilot-esp32"
|
||||||
#define WIFI_PWD "ardupilot-empty"
|
#define WIFI_PWD "ardupilot-esp32"
|
||||||
|
|
||||||
//UARTs
|
//UARTs
|
||||||
|
// UART_NUM_0 and UART_NUM_2 are configured to use defaults
|
||||||
#define HAL_ESP32_UART_DEVICES \
|
#define HAL_ESP32_UART_DEVICES \
|
||||||
{.port=UART_NUM_0, .rx=GPIO_NUM_3 , .tx=GPIO_NUM_1 },\
|
{.port=UART_NUM_0, .rx=GPIO_NUM_3 , .tx=GPIO_NUM_1 },\
|
||||||
{.port=UART_NUM_1, .rx=GPIO_NUM_34, .tx=GPIO_NUM_18},\
|
{.port=UART_NUM_1, .rx=GPIO_NUM_34, .tx=GPIO_NUM_18},\
|
||||||
{.port=UART_NUM_2, .rx=GPIO_NUM_35, .tx=GPIO_NUM_19}
|
{.port=UART_NUM_2, .rx=GPIO_NUM_16, .tx=GPIO_NUM_17}
|
||||||
|
|
||||||
//ADC
|
//ADC
|
||||||
#define HAL_DISABLE_ADC_DRIVER 1
|
#define HAL_DISABLE_ADC_DRIVER 1
|
||||||
#define HAL_USE_ADC 0
|
#define HAL_USE_ADC 0
|
||||||
|
|
||||||
//LED
|
//LED
|
||||||
#define DEFAULT_NTF_LED_TYPES Notify_LED_None
|
#define DEFAULT_NTF_LED_TYPES Notify_LED_None
|
||||||
|
|
||||||
//RMT pin number
|
//RMT pin number
|
||||||
#define HAL_ESP32_RMT_RX_PIN_NUMBER 4
|
#define HAL_ESP32_RMT_RX_PIN_NUMBER 4
|
||||||
|
|
||||||
//SD CARD
|
//SD CARD
|
||||||
// Do u want to use mmc or spi mode for the sd card, this is board specific ,
|
// Do u want to use mmc or spi mode for the sd card, this is board specific,
|
||||||
// as mmc uses specific pins but is quicker,
|
// as mmc uses specific pins but is quicker,
|
||||||
// and spi is more flexible pinouts.... dont forget vspi/hspi should be selected to NOT conflict with HAL_ESP32_SPI_BUSES
|
// and spi is more flexible pinouts....
|
||||||
|
// dont forget vspi/hspi should be selected to NOT conflict with HAL_ESP32_SPI_BUSES
|
||||||
|
|
||||||
//#define HAL_ESP32_SDCARD //after enabled, uncomment one of below
|
//#define HAL_ESP32_SDCARD //after enabled, uncomment one of below
|
||||||
//#define HAL_ESP32_SDMMC
|
//#define HAL_ESP32_SDMMC
|
||||||
//#define HAL_ESP32_SDSPI {.host=VSPI_HOST, .dma_ch=2, .mosi=GPIO_NUM_2, .miso=GPIO_NUM_15, .sclk=GPIO_NUM_26, .cs=GPIO_NUM_21}
|
//#define HAL_ESP32_SDSPI {.host=VSPI_HOST, .dma_ch=2, .mosi=GPIO_NUM_2, .miso=GPIO_NUM_15, .sclk=GPIO_NUM_26, .cs=GPIO_NUM_21}
|
||||||
|
|
||||||
#define HAL_LOGGING_FILESYSTEM_ENABLED 0
|
#define HAL_LOGGING_FILESYSTEM_ENABLED 0
|
||||||
#define HAL_LOGGING_DATAFLASH_ENABLED 0
|
#define HAL_LOGGING_DATAFLASH_ENABLED 0
|
||||||
#define HAL_LOGGING_MAVLINK_ENABLED 0
|
#define HAL_LOGGING_MAVLINK_ENABLED 0
|
||||||
|
|
||||||
#define HAL_BOARD_LOG_DIRECTORY "/SDCARD/APM/LOGS"
|
#define HAL_BOARD_LOG_DIRECTORY "/SDCARD/APM/LOGS"
|
||||||
#define HAL_BOARD_STORAGE_DIRECTORY "/SDCARD/APM/STORAGE"
|
#define HAL_BOARD_STORAGE_DIRECTORY "/SDCARD/APM/STORAGE"
|
||||||
#define HAL_BOARD_LOG_DIRECTORY "/SDCARD/APM/LOGS"
|
#define HAL_BOARD_LOG_DIRECTORY "/SDCARD/APM/LOGS"
|
||||||
#define HAL_BOARD_TERRAIN_DIRECTORY "/SDCARD/APM/TERRAIN"
|
#define HAL_BOARD_TERRAIN_DIRECTORY "/SDCARD/APM/TERRAIN"
|
||||||
|
|
||||||
#define HAL_LOGGING_BACKENDS_DEFAULT 1
|
#define HAL_LOGGING_BACKENDS_DEFAULT 1
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user