2019-01-06 18:15:49 -08:00
|
|
|
/**
|
2019-03-29 06:11:13 -07:00
|
|
|
* @file thread_controller.h
|
2019-01-06 18:15:49 -08:00
|
|
|
*
|
|
|
|
* @date Jan 5, 2019
|
|
|
|
* @author Matthew Kennedy, (c) 2019
|
|
|
|
*/
|
|
|
|
|
|
|
|
#pragma once
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief A base class for a controller that requires its own thread.
|
|
|
|
*
|
|
|
|
* Inherit from ThreadController. Implement ThreadTask with the logic required for your thread.
|
|
|
|
* The template parameter specifies the size of the stack used for the thread. (because we have to
|
|
|
|
* allocate the stack at compile time, it has to be a template parameter instead of a normal parameter)
|
|
|
|
*/
|
|
|
|
template <int TStackSize>
|
2022-08-01 15:16:13 -07:00
|
|
|
class ThreadController : public chibios_rt::BaseStaticThread<TStackSize>
|
2019-01-06 18:15:49 -08:00
|
|
|
{
|
|
|
|
private:
|
2022-08-01 15:16:13 -07:00
|
|
|
const tprio_t m_prio;
|
2024-03-11 10:07:02 -07:00
|
|
|
/* TODO: use ref instead of m_started */
|
2023-10-12 16:08:53 -07:00
|
|
|
bool m_started = false;
|
2024-03-11 10:07:02 -07:00
|
|
|
chibios_rt::ThreadReference ref;
|
2019-01-06 18:15:49 -08:00
|
|
|
|
2022-08-01 15:16:13 -07:00
|
|
|
protected:
|
|
|
|
// Override this function to implement your controller's thread's behavior.
|
|
|
|
virtual void ThreadTask() = 0;
|
2019-01-06 18:15:49 -08:00
|
|
|
|
2022-08-01 15:16:13 -07:00
|
|
|
void main() override {
|
|
|
|
this->setName(m_name);
|
2019-01-06 18:15:49 -08:00
|
|
|
|
2022-08-01 15:16:13 -07:00
|
|
|
ThreadTask();
|
|
|
|
}
|
2019-01-06 18:15:49 -08:00
|
|
|
|
2021-06-24 17:18:23 -07:00
|
|
|
const char* const m_name;
|
|
|
|
|
2019-01-06 18:15:49 -08:00
|
|
|
public:
|
2022-08-01 15:16:13 -07:00
|
|
|
ThreadController(const char* name, tprio_t priority)
|
2021-06-24 17:18:23 -07:00
|
|
|
: m_prio(priority)
|
|
|
|
, m_name(name)
|
2022-08-01 15:16:13 -07:00
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Start the thread.
|
|
|
|
*/
|
|
|
|
void start()
|
|
|
|
{
|
2023-10-12 16:08:53 -07:00
|
|
|
if (!m_started)
|
|
|
|
{
|
|
|
|
m_started = true;
|
2024-03-11 10:07:02 -07:00
|
|
|
ref = chibios_rt::BaseStaticThread<TStackSize>::start(m_prio);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Request thread termination and waits for termination
|
|
|
|
*
|
|
|
|
* Thread should periadicaly execute something like:
|
|
|
|
* if (chThdShouldTerminateX())
|
|
|
|
* chThdExit((msg_t)0x0);
|
|
|
|
*/
|
|
|
|
void stop()
|
|
|
|
{
|
|
|
|
if (m_started) {
|
|
|
|
/* Asking for thread termination.*/
|
|
|
|
ref.requestTerminate();
|
|
|
|
|
|
|
|
/* Waiting for termination, releasing the reference.*/
|
|
|
|
ref.wait();
|
|
|
|
|
|
|
|
m_started = false;
|
2023-10-12 16:08:53 -07:00
|
|
|
}
|
2022-08-01 15:16:13 -07:00
|
|
|
}
|
2019-01-06 18:15:49 -08:00
|
|
|
};
|