Blimp: remove fast loop and convert to tasks

This commit is contained in:
Andy Piper 2022-04-21 12:41:08 +01:00 committed by Randy Mackay
parent 2209576c90
commit d7d7574d2e
3 changed files with 23 additions and 37 deletions

View File

@ -22,10 +22,10 @@
const AP_HAL::HAL& hal = AP_HAL::get_HAL(); const AP_HAL::HAL& hal = AP_HAL::get_HAL();
#define SCHED_TASK(func, rate_hz, max_time_micros, priority) SCHED_TASK_CLASS(Blimp, &blimp, func, rate_hz, max_time_micros, priority) #define SCHED_TASK(func, rate_hz, max_time_micros, priority) SCHED_TASK_CLASS(Blimp, &blimp, func, rate_hz, max_time_micros, priority)
#define FAST_TASK(func) FAST_TASK_CLASS(Blimp, &blimp, func)
/* /*
scheduler table - all regular tasks apart from the fast_loop() scheduler table - all tasks should be listed here.
should be listed here.
All entries in this table must be ordered by priority. All entries in this table must be ordered by priority.
@ -49,6 +49,23 @@ SCHED_TASK_CLASS arguments:
*/ */
const AP_Scheduler::Task Blimp::scheduler_tasks[] = { const AP_Scheduler::Task Blimp::scheduler_tasks[] = {
// update INS immediately to get current gyro data populated
FAST_TASK_CLASS(AP_InertialSensor, &blimp.ins, update),
// send outputs to the motors library immediately
FAST_TASK(motors_output),
// run EKF state estimator (expensive)
FAST_TASK(read_AHRS),
// Inertial Nav
FAST_TASK(read_inertia),
// check if ekf has reset target heading or position
FAST_TASK(check_ekf_reset),
// run the attitude controllers
FAST_TASK(update_flight_mode),
// update home from EKF if necessary
FAST_TASK(update_home_from_EKF),
// log sensor health
FAST_TASK(Log_Sensor_Health),
SCHED_TASK(rc_loop, 100, 130, 3), SCHED_TASK(rc_loop, 100, 130, 3),
SCHED_TASK(throttle_loop, 50, 75, 6), SCHED_TASK(throttle_loop, 50, 75, 6),
SCHED_TASK_CLASS(AP_GPS, &blimp.gps, update, 50, 200, 9), SCHED_TASK_CLASS(AP_GPS, &blimp.gps, update, 50, 200, 9),
@ -93,40 +110,6 @@ void Blimp::get_scheduler_tasks(const AP_Scheduler::Task *&tasks,
constexpr int8_t Blimp::_failsafe_priorities[4]; constexpr int8_t Blimp::_failsafe_priorities[4];
// Main loop
void Blimp::fast_loop()
{
// update INS immediately to get current gyro data populated
ins.update();
// send outputs to the motors library immediately
motors_output();
// run EKF state estimator (expensive)
// --------------------
read_AHRS();
// Inertial Nav
// --------------------
read_inertia();
// check if ekf has reset target heading or position
check_ekf_reset();
// run the attitude controllers
update_flight_mode();
// update home from EKF if necessary
update_home_from_EKF();
// log sensor health
if (should_log(MASK_LOG_ANY)) {
Log_Sensor_Health();
}
AP_Vehicle::fast_loop(); //just does gyro fft
}
// rc_loops - reads user input from transmitter/receiver // rc_loops - reads user input from transmitter/receiver
// called at 100hz // called at 100hz
void Blimp::rc_loop() void Blimp::rc_loop()

View File

@ -297,7 +297,6 @@ private:
void get_scheduler_tasks(const AP_Scheduler::Task *&tasks, void get_scheduler_tasks(const AP_Scheduler::Task *&tasks,
uint8_t &task_count, uint8_t &task_count,
uint32_t &log_bit) override; uint32_t &log_bit) override;
void fast_loop() override;
void rc_loop(); void rc_loop();
void throttle_loop(); void throttle_loop();
void update_batt_compass(void); void update_batt_compass(void);

View File

@ -235,6 +235,10 @@ tuning_max : tune_max
// logs when baro or compass becomes unhealthy // logs when baro or compass becomes unhealthy
void Blimp::Log_Sensor_Health() void Blimp::Log_Sensor_Health()
{ {
if (!should_log(MASK_LOG_ANY)) {
return;
}
// check baro // check baro
if (sensor_health.baro != barometer.healthy()) { if (sensor_health.baro != barometer.healthy()) {
sensor_health.baro = barometer.healthy(); sensor_health.baro = barometer.healthy();