/*
* This file is free software: you can redistribute it and/or modify it
* under the terms of the GNU General Public License as published by the
* Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* This file is distributed in the hope that it will be useful, but
* WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
* See the GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License along
* with this program. If not, see .
*/
#pragma once
#include
#include
#include "HAL_ESP32_Namespace.h"
#include "freertos/FreeRTOS.h"
#include "freertos/task.h"
#define ESP32_SCHEDULER_MAX_TIMER_PROCS 10
#define ESP32_SCHEDULER_MAX_IO_PROCS 10
#define TWDT_TIMEOUT_MS 3000
/* Scheduler implementation: */
class ESP32::Scheduler : public AP_HAL::Scheduler
{
public:
Scheduler();
~Scheduler();
/* AP_HAL::Scheduler methods */
void init() override;
void set_callbacks(AP_HAL::HAL::Callbacks *cb)
{
callbacks = cb;
};
void delay(uint16_t ms) override;
void delay_microseconds(uint16_t us) override;
void register_timer_process(AP_HAL::MemberProc) override;
void register_io_process(AP_HAL::MemberProc) override;
void register_timer_failsafe(AP_HAL::Proc, uint32_t period_us) override;
void reboot(bool hold_in_bootloader) override;
bool in_main_thread() const override;
// check and set the startup state
void set_system_initialized() override;
bool is_system_initialized() override;
void print_stats(void) ;
void print_main_loop_rate(void);
uint16_t get_loop_rate_hz(void);
AP_Int16 _active_loop_rate_hz;
AP_Int16 _loop_rate_hz;
static void thread_create_trampoline(void *ctx);
bool thread_create(AP_HAL::MemberProc, const char *name, uint32_t stack_size, priority_base base, int8_t priority) override;
/*static const int SPI_PRIORITY = 40; // if your primary imu is spi, this should be above the i2c value, spi is better.
static const int MAIN_PRIO = 15;
static const int I2C_PRIORITY = 8; // if your primary imu is i2c, this should be above the spi value, i2c is not preferred.
static const int TIMER_PRIO = 15;
static const int RCIN_PRIO = 15;
static const int RCOUT_PRIO = 15;
static const int WIFI_PRIO = 10;
static const int UART_PRIO = 8;
static const int IO_PRIO = 6;
static const int STORAGE_PRIO = 6; */
// configMAX_PRIORITIES=25
static const int SPI_PRIORITY = 24; // if your primary imu is spi, this should be above the i2c value, spi is better.
static const int MAIN_PRIO = 24; // cpu0: we want scheduler running at full tilt.
static const int I2C_PRIORITY = 5; // if your primary imu is i2c, this should be above the spi value, i2c is not preferred.
static const int TIMER_PRIO = 23; //dont make 24. a low priority mere might cause wifi thruput to suffer
static const int RCIN_PRIO = 5;
static const int RCOUT_PRIO = 10;
static const int WIFI_PRIO1 = 20; //cpu1:
static const int WIFI_PRIO2 = 12; //cpu1:
static const int UART_PRIO = 23; //dont make 24, scheduler suffers a bit. cpu1: a low priority mere might cause wifi thruput to suffer, as wifi gets passed its data frim the uart subsustem in _writebuf/_readbuf
static const int IO_PRIO = 5;
static const int STORAGE_PRIO = 4;
static const int TIMER_SS = 4096;
static const int MAIN_SS = 8192;
static const int RCIN_SS = 4096;
static const int RCOUT_SS = 4096;
static const int WIFI_SS1 = 6192;
static const int WIFI_SS2 = 6192;
static const int UART_SS = 2048;
static const int DEVICE_SS = 4096;
static const int IO_SS = 4096;
static const int STORAGE_SS = 8192;
private:
AP_HAL::HAL::Callbacks *callbacks;
AP_HAL::Proc _failsafe;
AP_HAL::MemberProc _timer_proc[ESP32_SCHEDULER_MAX_TIMER_PROCS];
uint8_t _num_timer_procs;
AP_HAL::MemberProc _io_proc[ESP32_SCHEDULER_MAX_IO_PROCS];
uint8_t _num_io_procs;
static bool _initialized;
tskTaskControlBlock* _main_task_handle;
tskTaskControlBlock* _timer_task_handle;
tskTaskControlBlock* _rcin_task_handle;
tskTaskControlBlock* _rcout_task_handle;
tskTaskControlBlock* _uart_task_handle;
tskTaskControlBlock* _io_task_handle;
tskTaskControlBlock* test_task_handle;
tskTaskControlBlock* _storage_task_handle;
static void _main_thread(void *arg);
static void _timer_thread(void *arg);
static void _rcout_thread(void *arg);
static void _rcin_thread(void *arg);
static void _uart_thread(void *arg);
static void _io_thread(void *arg);
static void _storage_thread(void *arg);
static void set_position(void* arg);
static void _print_profile(void* arg);
static void test_esc(void* arg);
static void wdt_init(uint32_t timeout, uint32_t core_mask);
bool _in_timer_proc;
void _run_timers();
Semaphore _timer_sem;
bool _in_io_proc;
void _run_io();
Semaphore _io_sem;
};