2019-07-09 05:33:40 -07:00
|
|
|
/*
|
|
|
|
* @file periodic_task.h
|
|
|
|
*
|
|
|
|
* @date Jul 8, 2019
|
2020-01-07 21:02:40 -08:00
|
|
|
* @author Andrey Belomutskiy, (c) 2012-2020
|
2019-07-09 05:33:40 -07:00
|
|
|
*/
|
|
|
|
|
|
|
|
#pragma once
|
|
|
|
|
|
|
|
#include "global.h"
|
|
|
|
|
|
|
|
class PeriodicTimerController;
|
|
|
|
|
|
|
|
void runAndScheduleNext(PeriodicTimerController *controller);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* this is an intermediate implementation - we should probably move from using virtual_timer_t which works on interrupts
|
|
|
|
* into sharing one thread with potentially lower priority instead
|
|
|
|
*/
|
|
|
|
|
|
|
|
class PeriodicTimerController {
|
|
|
|
|
|
|
|
public:
|
|
|
|
#if !EFI_UNIT_TEST
|
|
|
|
virtual_timer_t timer;
|
|
|
|
#endif /* EFI_UNIT_TEST */
|
|
|
|
|
|
|
|
virtual void PeriodicTask() = 0;
|
|
|
|
|
2019-07-13 07:16:47 -07:00
|
|
|
/**
|
|
|
|
* This method is invoked after corresponding PeriodicTask() invocation
|
|
|
|
*/
|
|
|
|
virtual int getPeriodMs() = 0;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* This invokes PeriodicTask() immediately and starts the cycle of invocations and sleeps
|
|
|
|
*/
|
2022-07-21 12:17:32 -07:00
|
|
|
virtual void start() {
|
2021-08-27 00:59:00 -07:00
|
|
|
#if !EFI_UNIT_TEST
|
|
|
|
chVTObjectInit(&timer);
|
|
|
|
#endif // EFI_UNIT_TEST
|
|
|
|
|
|
|
|
runAndScheduleNext(this);
|
|
|
|
}
|
2019-07-09 05:33:40 -07:00
|
|
|
};
|
|
|
|
|