Oursource task_fans and task_buzzer

- outsource task_fans and task_buzzer from main.cpp to their source files
- use task parameters to pass necessary configs and objects
- adjust task priorities (display was too low)
This commit is contained in:
jonny_jr9 2024-02-19 13:54:22 +01:00
parent 4951abbcbf
commit 26761f4a80
8 changed files with 73 additions and 48 deletions

View File

@ -153,7 +153,7 @@ joystick_config_t configJoystick = {
//---------------------------- //----------------------------
//--- configure fan contol --- //--- configure fan contol ---
//---------------------------- //----------------------------
fan_config_t configCooling = { fan_config_t configFans = {
.gpio_fan = GPIO_NUM_13, .gpio_fan = GPIO_NUM_13,
.dutyThreshold = 40, .dutyThreshold = 40,
.minOnMs = 1500, .minOnMs = 1500,

View File

@ -12,6 +12,28 @@ extern "C"
static const char * TAG = "fan-control"; static const char * TAG = "fan-control";
//=======================================
//============== fan task ===============
//=======================================
//task that controlls fans for cooling the drivers
//turns fan on/off depending on motor duty history
void task_fans( void * task_fans_parameters ){
//get configuration struct from task parameter
task_fans_parameters_t *objects = (task_fans_parameters_t *)task_fans_parameters;
//create fan instances with config defined in config.cpp
ESP_LOGI(TAG, "Initializing fans and starting fan handle loop");
controlledFan fan(objects->fan_config, objects->motorLeft, objects->motorRight);
//repeatedly run fan handle function in a slow loop
while(1){
fan.handle();
vTaskDelay(500 / portTICK_PERIOD_MS);
}
}
//----------------------------- //-----------------------------
//-------- constructor -------- //-------- constructor --------
//----------------------------- //-----------------------------

View File

@ -16,7 +16,22 @@ typedef struct fan_config_t {
uint32_t minOnMs; uint32_t minOnMs;
uint32_t minOffMs; uint32_t minOffMs;
uint32_t turnOffDelayMs; uint32_t turnOffDelayMs;
} fan_config; } fan_config_t;
// struct with variables passed to task from main
typedef struct task_fans_parameters_t {
fan_config_t fan_config;
controlledMotor * motorLeft;
controlledMotor * motorRight;
} task_fans_parameters_t;
//====================================
//========== motorctl task ===========
//====================================
//note: pointer to task_fans_parameters_t has to be passed as task-parameter (config, motor objects)
void task_fans( void * task_fans_parameters );

View File

@ -15,12 +15,13 @@ extern "C"
#include "wifi.h" #include "wifi.h"
} }
#include <new>
//custom C++ files //custom C++ files
//folder common //folder common
#include "uart_common.hpp" #include "uart_common.hpp"
#include "motordrivers.hpp" #include "motordrivers.hpp"
#include "http.hpp" #include "http.hpp"
#include "types.hpp"
#include "speedsensor.hpp" #include "speedsensor.hpp"
#include "motorctl.hpp" #include "motorctl.hpp"
@ -31,8 +32,6 @@ extern "C"
#include "display.hpp" #include "display.hpp"
#include "encoder.hpp" #include "encoder.hpp"
#include <new>
//only extends this file (no library): //only extends this file (no library):
//outsourced all configuration related structures //outsourced all configuration related structures
#include "config.cpp" #include "config.cpp"
@ -89,42 +88,11 @@ esp_err_t on_joystick_url(httpd_req_t *req)
return (httpJoystickMain->*pointerToReceiveFunc)(req); return (httpJoystickMain->*pointerToReceiveFunc)(req);
} }
//tag for logging //-- tag for logging --
static const char * TAG = "main"; static const char * TAG = "main";
//======================================
//============ buzzer task =============
//======================================
//TODO: move the task creation to buzzer class (buzzer.cpp)
//e.g. only have function buzzer.createTask() in app_main
void task_buzzer( void * pvParameters ){
ESP_LOGI("task_buzzer", "Start of buzzer task...");
//run function that waits for a beep events to arrive in the queue
//and processes them
buzzer->processQueue();
}
//=======================================
//============== fan task ===============
//=======================================
//TODO: move this definition to fan.cpp
//task that controlls fans for cooling the drivers
void task_fans( void * pvParameters ){
ESP_LOGI(TAG, "Initializing fans and starting fan handle loop");
//create fan instances with config defined in config.cpp
controlledFan fan(configCooling, motorLeft, motorRight);
//repeatedly run fan handle function in a slow loop
while(1){
fan.handle();
vTaskDelay(500 / portTICK_PERIOD_MS);
}
}
//================================= //=================================
//========== init spiffs ========== //========== init spiffs ==========
@ -150,7 +118,6 @@ void init_spiffs(){
//================================= //=================================
//========= createObjects ========= //========= createObjects =========
//================================= //=================================
@ -198,7 +165,6 @@ void createObjects()
legRest = new cControlledRest(GPIO_NUM_4, GPIO_NUM_16, "legRest"); legRest = new cControlledRest(GPIO_NUM_4, GPIO_NUM_16, "legRest");
backRest = new cControlledRest(GPIO_NUM_2, GPIO_NUM_15, "backRest"); backRest = new cControlledRest(GPIO_NUM_2, GPIO_NUM_15, "backRest");
} }
//sabertooth2x60a sabertoothDriver(sabertoothConfig);
@ -247,7 +213,6 @@ extern "C" void app_main(void) {
#ifndef ENCODER_TEST
//--- create tasks --- //--- create tasks ---
ESP_LOGW(TAG, "===== CREATING TASKS ====="); ESP_LOGW(TAG, "===== CREATING TASKS =====");
@ -261,7 +226,9 @@ extern "C" void app_main(void) {
//------------------------------ //------------------------------
//--- create task for buzzer --- //--- create task for buzzer ---
//------------------------------ //------------------------------
xTaskCreate(&task_buzzer, "task_buzzer", 2048, NULL, 2, NULL); //task that processes queued beeps
//note: pointer to shard object 'buzzer' is passed as task parameter:
xTaskCreate(&task_buzzer, "task_buzzer", 2048, buzzer, 2, NULL);
//------------------------------- //-------------------------------
//--- create task for control --- //--- create task for control ---
@ -275,23 +242,23 @@ extern "C" void app_main(void) {
//------------------------------ //------------------------------
//task that handles button/encoder events in any mode except 'MENU' (e.g. switch modes by pressing certain count) //task that handles button/encoder events in any mode except 'MENU' (e.g. switch modes by pressing certain count)
task_button_parameters_t button_param = {control, joystick, encoderQueue, motorLeft, motorRight, buzzer}; task_button_parameters_t button_param = {control, joystick, encoderQueue, motorLeft, motorRight, buzzer};
xTaskCreate(&task_button, "task_button", 4096, &button_param, 4, NULL); xTaskCreate(&task_button, "task_button", 4096, &button_param, 3, NULL);
//----------------------------------- //-----------------------------------
//--- create task for fan control --- //--- create task for fan control ---
//----------------------------------- //-----------------------------------
//task that controls cooling fans of the motor driver //task that controls cooling fans of the motor driver
xTaskCreate(&task_fans, "task_fans", 2048, NULL, 1, NULL); task_fans_parameters_t fans_param = {configFans, motorLeft, motorRight};
xTaskCreate(&task_fans, "task_fans", 2048, &fans_param, 1, NULL);
//----------------------------------- //-----------------------------------
//----- create task for display ----- //----- create task for display -----
//----------------------------------- //-----------------------------------
////task that handles the display (show stats, handle menu in 'MENU' mode) ////task that handles the display (show stats, handle menu in 'MENU' mode)
display_task_parameters_t display_param = {control, joystick, encoderQueue, motorLeft, motorRight, speedLeft, speedRight, buzzer}; display_task_parameters_t display_param = {control, joystick, encoderQueue, motorLeft, motorRight, speedLeft, speedRight, buzzer};
xTaskCreate(&display_task, "display_task", 3*2048, &display_param, 1, NULL); xTaskCreate(&display_task, "display_task", 3*2048, &display_param, 3, NULL);
#endif
//--- startup finished --- //--- startup finished ---
ESP_LOGW(TAG, "===== STARTUP FINISHED ====="); ESP_LOGW(TAG, "===== STARTUP FINISHED =====");
@ -315,7 +282,9 @@ extern "C" void app_main(void) {
//--- main loop --- //--- main loop ---
//does nothing except for testing things //does nothing except for testing things
while(1){ while(1){
vTaskDelay(5000 / portTICK_PERIOD_MS); vTaskDelay(portMAX_DELAY);
//vTaskDelay(5000 / portTICK_PERIOD_MS);
//--------------------------------- //---------------------------------
//-------- TESTING section -------- //-------- TESTING section --------
//--------------------------------- //---------------------------------

View File

@ -2,6 +2,19 @@
static const char *TAG_BUZZER = "buzzer"; static const char *TAG_BUZZER = "buzzer";
//======================================
//============ buzzer task =============
//======================================
// Task that repeatedly handles the buzzer object (process Queued beeps)
void task_buzzer(void * param_buzzerObject){
ESP_LOGI("task_buzzer", "Start of buzzer task...");
buzzer_t * buzzer = (buzzer_t *)param_buzzerObject;
//run function that waits for a beep events to arrive in the queue
//and processes them
buzzer->processQueue();
}
//============================ //============================
//========== init ============ //========== init ============
//============================ //============================

View File

@ -53,4 +53,9 @@ class buzzer_t {
}; };
//======================================
//============ buzzer task =============
//======================================
// Task that repeatedly handles the buzzer object (process Queued beeps)
// Note: pointer to globally initialized buzzer object has to be passed as task-parameter
void task_buzzer(void * param_buzzerObject);

View File

@ -19,7 +19,7 @@ void task_motorctl( void * task_motorctl_parameters ){
while(1){ while(1){
objects->motorRight->handle(); objects->motorRight->handle();
objects->motorLeft->handle(); objects->motorLeft->handle();
vTaskDelay(10 / portTICK_PERIOD_MS); vTaskDelay(15 / portTICK_PERIOD_MS);
} }
} }

View File

@ -12,6 +12,7 @@ extern "C"
//====== struct/type declarations ====== //====== struct/type declarations ======
//======================================= //=======================================
//global structs and types that need to be available for all boards //global structs and types that need to be available for all boards
//this file is necessary to prevent dependency loop between motordrivers.hpp and motorctl.hpp since
//=============================== //===============================