ref: 45e65b66b11b6b8533b225067ce4c2a4b5eac653
src/systemtask/SystemMonitor.h
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 |
#pragma once #include <FreeRTOS.h> #include <task.h> #include <nrf_log.h> namespace Pinetime { namespace System { struct DummyMonitor {}; struct FreeRtosMonitor {}; template<class T> class SystemMonitor { public: SystemMonitor() = delete; }; template<> class SystemMonitor<DummyMonitor> { public: void Process() const {} }; template<> class SystemMonitor<FreeRtosMonitor> { public: void Process() const { if(xTaskGetTickCount() - lastTick > 10000) { NRF_LOG_INFO("---------------------------------------\nFree heap : %d", xPortGetFreeHeapSize()); auto nb = uxTaskGetSystemState(tasksStatus, 10, nullptr); for (uint32_t i = 0; i < nb; i++) { NRF_LOG_INFO("Task [%s] - %d", tasksStatus[i].pcTaskName, tasksStatus[i].usStackHighWaterMark); if (tasksStatus[i].usStackHighWaterMark < 20) NRF_LOG_INFO("WARNING!!! Task %s task is nearly full, only %dB available", tasksStatus[i].pcTaskName, tasksStatus[i].usStackHighWaterMark * 4); } lastTick = xTaskGetTickCount(); } } private: mutable TickType_t lastTick = 0; mutable TaskStatus_t tasksStatus[10]; }; } } |