// // Created by cfif on 20.01.2026. // #include "LinActuatorWork.h" #define LOG_SIGN "Lin" #define LOGGER &env->slog.logger void LinActuatorWork(tMma *env, tLinTaskActuator *linTaskActuator) { if (osMutexAcquire(linTaskActuator->access, 5000) == osOK) { // Если актуатор не занят if (linTaskActuator->busy == false) { for (uint8_t i = 0; i < linTaskActuator->LIN_ISSR_ALL; ++i) { linTaskActuator->linCommandActuator[i].POS = env->controllerData_local.POS[i]; linTaskActuator->linCommandActuator[i].BUS_ADR = env->controllerData_local.BUS_ADR[i]; linTaskActuator->linCommandActuator[i].MODE = env->controllerData_local.MODE[i]; // Если команда выполнена if (linTaskActuator->linCommandActuator[i].COM == LIN_ACT_CFR_SUCCESSFUL) { #if (LOG_LIN_ACTUATOR == 1) LoggerInfoStatic(LOGGER, LOG_SIGN, "SUCCESSFUL COMMAND") #endif // Установка входной команды в LIN_ACT_CFR_NONE env->controllerData_local.COM[i] = LIN_ACT_CFR_NONE; } linTaskActuator->linCommandActuator[i].COM = env->controllerData_local.COM[i]; linTaskActuator->linCommandActuator[i].Stall_SET = env->controllerData_local.Stall_SET[i]; linTaskActuator->linCommandActuator[i].Lnoise_SET = env->controllerData_local.Lnoise_SET[i]; linTaskActuator->linCommandActuator[i].Autos_SET = env->controllerData_local.Autos_SET[i]; linTaskActuator->linCommandActuator[i].Speed_SET = env->controllerData_local.Speed_SET[i]; linTaskActuator->linCommandActuator[i].Coils_Stop_SET = env->controllerData_local.Coils_Stop_SET[i]; env->controllerDataInput_local.in_CPOS_ALL_Ch0[i] = (int16_t) linTaskActuator->linStateActuator[i].CPOS_ALL; env->controllerDataInput_local.in_Act_Emrf_Slave_Ch0[i] = (int8_t) linTaskActuator->linStateActuator[i].Emrf_Slave; env->controllerDataInput_local.in_Mode_Slave_Ch0[i] = (int8_t) linTaskActuator->linStateActuator[i].Mode_Slave; env->controllerDataInput_local.in_Act_Err1_Supply_Ch0[i] = (int8_t) linTaskActuator->linStateActuator[i].Error1_Supply_Slave; env->controllerDataInput_local.in_Act_Err2_Communication_Ch0[i] = (int8_t) linTaskActuator->linStateActuator[i].Error2_Communication_Slave; env->controllerDataInput_local.in_Act_Err3_Temperature_Ch0[i] = (int8_t) linTaskActuator->linStateActuator[i].Error3_Temperature_Slave; env->controllerDataInput_local.in_Act_Err4_Permanent_Electrical_Ch0[i] = (int8_t) linTaskActuator->linStateActuator[i].Error4_Permanent_Electrical_Slave; env->controllerDataInput_local.in_Act_Stall_Slave_Ch0[i] = linTaskActuator->linStateActuator[i].Stall_Slave; env->controllerDataInput_local.in_Act_Reset_Ch0[i] = linTaskActuator->linStateActuator[i].Reset_Slave; } env->isActuatorWorkBusy = setBusy(linTaskActuator); env->in_Error_Connect_Ch0 = linTaskActuator->error_connect; env->in_Busy_Ch0 = linTaskActuator->busy; } osMutexRelease(linTaskActuator->access); } if (osMutexAcquire(env->ModelTask.access, 5000) == osOK) { // Если принята команда if (env->ModelTask.triggerCommand == true) { #if (LOG_LIN_ACTUATOR == 1) LoggerInfoStatic(LOGGER, LOG_SIGN, "DETECT COMMAND") #endif // env->in_Busy_Ch0 = 1; } // Если прията команда и актуатор не занят if ((env->ModelTask.triggerCommand == true) && (env->isActuatorWorkBusy == false)) { env->ModelTask.triggerCommand = false; env->isActuatorWorkBusy = true; // Сброс STALL в состоянии актуатор и локальном состоянии resetStall(linTaskActuator, (uint8_t *) env->controllerDataInput_local.in_Act_Stall_Slave_Ch0); // ВЫХОД МОДЕЛИ (АКТУАТОР) //memcpy(&env->rtY_local.Out1, &controllerData, sizeof(rtY.Out1)); memcpy(&env->controllerData_local, &controllerData, sizeof(ActuatorCmdBus)); // Копирование команд for (uint8_t i = 0; i < linTaskActuator->LIN_ISSR_ALL; ++i) { env->controllerData_local.COM[i] = env->ModelTask.numCommand[i]; } } // ВХОДЫ МОДЕЛИ memcpy(&rtDW.controllerDataInput, &env->controllerDataInput_local, sizeof(rtDW.controllerDataInput)); rtDW.Busy_Ch0 = env->in_Busy_Ch0; rtDW.Error_Connect_Ch0 = env->in_Error_Connect_Ch0; osMutexRelease(env->ModelTask.access); } }