Rework structure and configuration

This commit is contained in:
Henrik Stickann 2022-04-09 21:15:27 +02:00
parent aa63b35e05
commit a4a4851704
13 changed files with 289 additions and 210 deletions

View File

@ -1,5 +1,5 @@
#ifndef STA_OS2_HPP #ifndef STA_OS2_DEFS_HPP
#define STA_OS2_HPP #define STA_OS2_DEFS_HPP
// See limits defined in cmsis_os2.c // See limits defined in cmsis_os2.c
@ -10,4 +10,4 @@
#define STA_OS2_EVENT_FLAGS_VALID_BITS ((1UL << STA_OS2_MAX_BITS_EVENT_GROUPS) - 1U) #define STA_OS2_EVENT_FLAGS_VALID_BITS ((1UL << STA_OS2_MAX_BITS_EVENT_GROUPS) - 1U)
#endif // STA_OS2_HPP #endif // STA_OS2_DEFS_HPP

View File

@ -0,0 +1,29 @@
/**
* @brief Implementation of startup system task.
*
* Define STA_OS2_STARTUP_ENABLE in <sta/config.hpp> to enable.
*
* Configuration:
* STA_OS2_STARTUP_ENTRY_FUNCTION: Name of task entry function (default: startupTask)
*/
#ifndef STA_OS2_STARTUP_HPP
#define STA_OS2_STARTUP_HPP
#include <sta/config.hpp>
#ifdef STA_OS2_STARTUP_ENABLE
namespace sta
{
/**
* @brief Extra initialization run at start of startup task.
*
* May be overridden by application if required.
*/
void startupExtras(void * argument);
} // namespace sta
#endif // STA_OS2_STARTUP_ENABLE
#endif // STA_OS2_STARTUP_HPP

View File

@ -0,0 +1,59 @@
/**
* @brief Implementation of system events.
*
* Define STA_OS2_SYSTEM_EVENT_ENABLE in <sta/config.hpp> to enable.
*
* Set STA_OS2_SYSTEM_EVENT_HANDLE to name of global handle variable.
* Defaults to `systemEventHandle`.
*/
#ifndef STA_OS2_SYSTEM_EVENT_HPP
#define STA_OS2_SYSTEM_EVENT_HPP
#include <sta/config.hpp>
#ifdef STA_OS2_SYSTEM_EVENT_ENABLE
#include <stdint.h>
// System event flags
//
#define STA_SYSTEM_EVENT_STARTUP 0x100000U
namespace sta
{
/**
* @brief Signal system events.
*
* @param flags System event flags
*/
void signalSystemEvents(uint32_t flags);
/**
* @brief Wait for system events.
*
* @param flags System event flags
* @param options osFlagsWaitAll or osFlagsWaitAny (osFlagsNoClear always set)
* @param timeout Wait timeout (0 = instant, osWaitForever = infinite)
*/
void waitForSystemEvents(uint32_t flags, uint32_t options, uint32_t timeout);
/**
* @brief Signal startup system event.
*/
void signalStartupEvent();
/**
* @brief Wait for startup system event.
*
* Blocking while waiting
*/
void waitForStartupEvent();
} // namespace sta
#endif // STA_OS2_SYSTEM_EVENT_ENABLE
#endif // STA_OS2_SYSTEM_EVENT_HPP

View File

@ -0,0 +1,44 @@
/**
* @brief Implementation of watchdog system task.
*
* Define STA_OS2_WATCHDOG_ENABLE in <sta/config.hpp> to enable.
*
* Configuration:
* STA_OS2_WATCHDOG_TIMER_PERIOD: Period of heartbeat timer (default: 1000)
* STA_OS2_WATCHDOG_TIMER_HANDLE: Name of global timer handle variable (default: heartbeatHandle)
* STA_OS2_WATCHDOG_TIMER_CALLBACK: Name of timer callback function (default: heartbeatCallback)
*
* STA_OS2_WATCHDOG_HANDLE: Name of global task handle variable (default: watchdogHandle)
* STA_OS2_WATCHDOG_ENTRY_FUNCTION: Name of task entry function (default: watchdogTask)
*/
#ifndef STA_OS2_WATCHDOG_HPP
#define STA_OS2_WATCHDOG_HPP
#include <sta/config.hpp>
#ifdef STA_OS2_WATCHDOG_ENABLE
#include <stdint.h>
// Watchdog task flags
//
#define STA_WATCHDOG_FLAG_HEARTBEAT 0x00001000U
namespace sta
{
/**
* @brief Start heartbeat timer for watchdog.
*/
void startWatchdogTimer();
/**
* @brief Send notification to watchdog task.
*/
void notifyWatchdog(uint32_t flags);
} // namespace sta
#endif // STA_OS2_WATCHDOG_ENABLE
#endif // STA_OS2_WATCHDOG_HPP

View File

@ -1,52 +0,0 @@
#ifndef STA_SYSTEM_EVENT_HPP
#define STA_SYSTEM_EVENT_HPP
#include <sta/config.hpp>
#ifdef STA_SYSTEM_EVENT_ENABLE
#include <stdint.h>
// System event flags
//
#define STA_SYSTEM_EVENT_STARTUP 0x100000U
namespace sta
{
/**
* @brief Signal system events
*
* @param flags System event flags
*/
void signalSystemEvents(uint32_t flags);
/**
* @brief Wait for system event.
*
* @param flags System event flags
* @param options osFlagsWaitAll or osFlagsWaitAny (osFlagsNoClear always set)
* @param timeout Wait timeout (0 = instant, osWaitForever = infinite)
*/
void waitForSystemEvents(uint32_t flags, uint32_t options, uint32_t timeout);
/**
* @brief Signal startup system event
*/
void signalStartupEvent();
/**
* @brief Wait for startup system event.
*
* Blocking while waiting
*/
void waitForStartupEvent();
} // namespace sta
#endif // STA_SYSTEM_EVENT_ENABLE
#endif // STA_SYSTEM_EVENT_HPP

View File

@ -1,26 +0,0 @@
#ifndef STA_WATCHDOG_HPP
#define STA_WATCHDOG_HPP
#include <sta/config.hpp>
#ifdef STA_WATCHDOG_ENABLE
#include <stdint.h>
// Watchdog task flags
//
#define STA_WATCHDOG_FLAG_HEARTBEAT 0x00001000U
namespace sta
{
void startWatchdogTimer();
void notifyWatchdog(uint32_t flags);
} // namespace sta
#endif // STA_WATCHDOG_ENABLE
#endif // STA_WATCHDOG_HPP

50
src/os2/startup.cpp Normal file
View File

@ -0,0 +1,50 @@
#include <sta/os2/startup.hpp>
#ifdef STA_OS2_STARTUP_ENABLE
#include <sta/lang.hpp>
#include <sta/os2/system_event.hpp>
#include <sta/os2/watchdog.hpp>
#include <main.h>
#include <cmsis_os2.h>
#ifndef STA_OS2_STARTUP_ENTRY_FUNCTION
# define STA_OS2_STARTUP_ENTRY_FUNCTION startupTask
#endif // !STA_OS2_STARTUP_ENTRY_FUNCTION
namespace sta
{
// Provide weak implementation to allow overriding
STA_WEAK
void startupExtras(void *)
{}
} // namespace sta
// Declare with C linkage
extern "C"
{
void STA_OS2_STARTUP_ENTRY_FUNCTION(void * arg)
{
// Call further initialization code
sta::startupExtras(arg);
#ifdef STA_WATCHDOG_ENABLE
// Start timers
sta::startWatchdogTimer();
#endif
// Wake tasks
sta::signalStartupEvent();
// Terminate task
osThreadExit();
}
}
#endif // STA_OS2_STARTUP_ENABLE

41
src/os2/system_event.cpp Normal file
View File

@ -0,0 +1,41 @@
#include <sta/os2/system_event.hpp>
#ifdef STA_OS2_SYSTEM_EVENT_ENABLE
#include <cmsis_os2.h>
#ifndef STA_OS2_SYSTEM_EVENT_HANDLE
# define STA_OS2_SYSTEM_EVENT_HANDLE systemEventHandle
#endif // !STA_OS2_SYSTEM_EVENT_HANDLE
// Access handle from freertos.c
extern osEventFlagsId_t STA_OS2_SYSTEM_EVENT_HANDLE;
namespace sta
{
void signalSystemEvents(uint32_t flags)
{
osEventFlagsSet(STA_OS2_SYSTEM_EVENT_HANDLE, flags);
}
void waitForSystemEvents(uint32_t flags, uint32_t options, uint32_t timeout)
{
osEventFlagsWait(STA_OS2_SYSTEM_EVENT_HANDLE, flags, options | osFlagsNoClear, timeout);
}
void signalStartupEvent()
{
signalSystemEvents(STA_SYSTEM_EVENT_STARTUP);
}
void waitForStartupEvent()
{
waitForSystemEvents(STA_SYSTEM_EVENT_STARTUP, osFlagsWaitAll, osWaitForever);
}
} // namespace sta
#endif // STA_SYSTEM_EVENT_ENABLE

View File

@ -0,0 +1,46 @@
#include <sta/os2/watchdog.hpp>
#ifdef STA_OS2_WATCHDOG_ENABLE
#include <cmsis_os2.h>
#ifndef STA_OS2_WATCHDOG_TIMER_PERIOD
# define STA_OS2_WATCHDOG_TIMER_PERIOD 1000
#endif // !STA_OS2_WATCHDOG_TIMER_PERIOD
#ifndef STA_OS2_WATCHDOG_TIMER_HANDLE
# define STA_OS2_WATCHDOG_TIMER_HANDLE heartbeatHandle
#endif // !STA_OS2_WATCHDOG_TIMER_HANDLE
#ifndef STA_OS2_WATCHDOG_TIMER_CALLBACK
# define STA_OS2_WATCHDOG_TIMER_CALLBACK heartbeatCallback
#endif // !STA_OS2_WATCHDOG_TIMER_CALLBACK
// Access handles from freertos.c
extern osTimerId_t STA_OS2_WATCHDOG_TIMER_HANDLE;
namespace sta
{
void startWatchdogTimer()
{
osTimerStart(STA_OS2_WATCHDOG_TIMER_HANDLE, STA_OS2_WATCHDOG_TIMER_PERIOD);
}
} // namespace sta
// Declare with C linkage
extern "C"
{
void STA_OS2_WATCHDOG_TIMER_CALLBACK(void *)
{
// Notify watchdog task to send heartbeat message
// Required because blocking in a timer callback is not allowed
sta::notifyWatchdog(STA_WATCHDOG_FLAG_HEARTBEAT);
}
}
#endif // STA_OS2_WATCHDOG_ENABLE

View File

@ -1,18 +1,26 @@
#include <sta/watchdog.hpp> #include <sta/os2/watchdog.hpp>
#ifdef STA_WATCHDOG_ENABLE #ifdef STA_OS2_WATCHDOG_ENABLE
#include <sta/lang.hpp> #include <sta/os2/defs.hpp>
#include <sta/os2.hpp> #include <sta/os2/system_event.hpp>
#include <sta/system_event.hpp>
#include <main.h> #include <main.h>
#include <cmsis_os2.h> #include <cmsis_os2.h>
// Access handles from freertos.c #ifndef STA_OS2_WATCHDOG_HANDLE
extern osThreadId_t watchdogHandle; # define STA_OS2_WATCHDOG_HANDLE watchdogHandle
#endif // !STA_OS2_WATCHDOG_HANDLE
#ifndef STA_OS2_WATCHDOG_ENTRY_FUNCTION
# define STA_OS2_WATCHDOG_ENTRY_FUNCTION watchdogTask
#endif // !STA_OS2_WATCHDOG_ENTRY_FUNCTION
// Access handle from freertos.c
extern osThreadId_t STA_OS2_WATCHDOG_HANDLE;
namespace sta namespace sta
@ -31,7 +39,7 @@ namespace sta
// Declare with C linkage // Declare with C linkage
extern "C" extern "C"
{ {
STA_WEAK void watchdogTask(void * arg) void STA_OS2_WATCHDOG_ENTRY_FUNCTION(void * arg)
{ {
sta::waitForStartupEvent(); sta::waitForStartupEvent();
@ -47,4 +55,4 @@ extern "C"
} }
#endif // STA_WATCHDOG_ENABLE #endif // STA_OS2_WATCHDOG_ENABLE

View File

@ -1,44 +0,0 @@
#include <sta/config.hpp>
#ifdef STA_STARTUP_TASK_ENABLE
#include <sta/lang.hpp>
#include <sta/system_event.hpp>
#include <sta/watchdog.hpp>
#include <main.h>
#include <cmsis_os2.h>
namespace sta
{
// Weak noop to be overridden by application if required
STA_WEAK void startupTaskExtras(void *) {}
} // namespace sta
// Declare with C linkage
extern "C"
{
void startupTask(void * arg)
{
// Call further initialization code
sta::startupTaskExtras(arg);
#ifdef STA_WATCHDOG_ENABLE
// Start timers
sta::startWatchdogTimer();
#endif
// Wake tasks
sta::signalStartupEvent();
// Terminate task
osThreadExit();
}
}
#endif // STA_STARTUP_TASK_ENABLE

View File

@ -1,38 +0,0 @@
#include <sta/system_event.hpp>
#ifdef STA_SYSTEM_EVENT_ENABLE
#include <cmsis_os2.h>
// Access handles from freertos.c
extern osEventFlagsId_t systemEventHandle;
namespace sta
{
void signalSystemEvents(uint32_t flags)
{
osEventFlagsSet(systemEventHandle, flags);
}
void waitForSystemEvents(uint32_t flags, uint32_t options, uint32_t timeout)
{
osEventFlagsWait(systemEventHandle, flags, options | osFlagsNoClear, timeout);
}
void signalStartupEvent()
{
signalSystemEvents(STA_SYSTEM_EVENT_STARTUP);
}
void waitForStartupEvent()
{
waitForSystemEvents(STA_SYSTEM_EVENT_STARTUP, osFlagsWaitAll, osWaitForever);
}
} // namespace sta
#endif // STA_SYSTEM_EVENT_ENABLE

View File

@ -1,38 +0,0 @@
#include <sta/watchdog.hpp>
#ifdef STA_WATCHDOG_ENABLE
#include <cmsis_os2.h>
#ifndef STA_WATCHDOG_TIMER_PERIOD
# define STA_WATCHDOG_TIMER_PERIOD 1000
#endif // STA_WATCHDOG_TIMER_PERIOD
// Access handles from freertos.c
extern osTimerId_t heartbeatHandle;
namespace sta
{
void startWatchdogTimer()
{
osTimerStart(heartbeatHandle, STA_WATCHDOG_TIMER_PERIOD);
}
} // namespace sta
// Declare with C linkage
extern "C"
{
void heartbeatCallback(void *)
{
// Notify watchdog task to send heartbeat message
// Required because blocking in a timer callback is not allowed
sta::notifyWatchdog(STA_WATCHDOG_FLAG_HEARTBEAT);
}
}
#endif // STA_WATCHDOG_ENABLE