Обновление

This commit is contained in:
cfif 2025-12-19 16:07:24 +03:00
parent fe9179dfe0
commit 2291e38e57
3 changed files with 77 additions and 1 deletions

View File

@ -4,6 +4,7 @@
#include "MainModesArbiter_Private.h" #include "MainModesArbiter_Private.h"
#include "stdio.h" #include "stdio.h"
#include "fc7xxx_driver_rgm.h" #include "fc7xxx_driver_rgm.h"
#include "Model_actuator.h"
#include "ADC_Temp_Table.h" #include "ADC_Temp_Table.h"
@ -31,6 +32,20 @@ void Mma_Init(
env->thread.id = 0; env->thread.id = 0;
} }
static bool isActuatorCommandSet_in_Model() {
for (uint8_t i = 0; i < LIN0_ISSR_ALL; ++i) {
if (rtY.Out1.COM[i] != 0)
return true;
}
return false;
}
static void clearActuatorCommand_in_Model() {
for (uint8_t i = 0; i < LIN0_ISSR_ALL; ++i) {
rtY.Out1.COM[i] = 0;
}
}
static _Noreturn void Mma_Thread(tMma *env) { static _Noreturn void Mma_Thread(tMma *env) {
// Запуск устройства // Запуск устройства
@ -46,12 +61,66 @@ static _Noreturn void Mma_Thread(tMma *env) {
LoggerInfoStatic(&env->slog.logger, LOG_TASK_ARB, "Wake up from standby") LoggerInfoStatic(&env->slog.logger, LOG_TASK_ARB, "Wake up from standby")
} }
SystemDelayMs(1000);
ModelTask_StartThread(&env->ModelTask);
bool isActuatorBusy = false;
for (;;) { for (;;) {
if (osMutexAcquire(env->linTaskActuator0.access, 5000) == osOK) {
if (env->linTaskActuator0.busy == 0) {
for (uint8_t i = 0; i < LIN0_ISSR_ALL; ++i) {
env->linTaskActuator0.linCommandActuator[i].POS = env->rtY_local.Out1.POS[i];
env->linTaskActuator0.linCommandActuator[i].BUS_ADR = env->rtY_local.Out1.BUS_ADR[i];
env->linTaskActuator0.linCommandActuator[i].MODE = env->rtY_local.Out1.MODE[i];
env->linTaskActuator0.linCommandActuator[i].COM = env->rtY_local.Out1.COM[i];
env->linTaskActuator0.linCommandActuator[i].Stall_SET = env->rtY_local.Out1.Stall_SET[i];
env->linTaskActuator0.linCommandActuator[i].Lnoise_SET = env->rtY_local.Out1.Lnoise_SET[i];
env->linTaskActuator0.linCommandActuator[i].Autos_SET = env->rtY_local.Out1.Autos_SET[i];
env->linTaskActuator0.linCommandActuator[i].Speed_SET = env->rtY_local.Out1.Speed_SET[i];
env->linTaskActuator0.linCommandActuator[i].Coils_Stop_SET = env->rtY_local.Out1.Coils_Stop_SET[i];
env->rtU_local.in_CPOS_ALL_Ch0[i] = env->linTaskActuator0.linStateActuator[i].CPOS_ALL;
env->rtU_local.in_Act_Emrf_Slave_Ch0[i] = env->linTaskActuator0.linStateActuator[i].Emrf_Slave;
env->rtU_local.in_Mode_Slave_Ch0[i] = env->linTaskActuator0.linStateActuator[i].Mode_Slave;
env->rtU_local.in_Act_Err1_Supply_Ch0[i] = env->linTaskActuator0.linStateActuator[i].Error1_Supply_Slave;
env->rtU_local.in_Act_Err2_Communication_Ch0[i] = env->linTaskActuator0.linStateActuator[i].Error2_Communication_Slave;
env->rtU_local.in_Act_Err3_Temperature_Ch0[i] = env->linTaskActuator0.linStateActuator[i].Error3_Temperature_Slave;
env->rtU_local.in_Act_Err4_Permanent_Electrical_Ch0[i] = env->linTaskActuator0.linStateActuator[i].Error4_Permanent_Electrical_Slave;
env->rtU_local.in_Act_Stall_Slave_Ch0[i] = env->linTaskActuator0.linStateActuator[i].Stall_Slave;
env->rtU_local.in_Act_Reset_Ch0[i] = env->linTaskActuator0.linStateActuator[i].Reset_Slave;
}
isActuatorBusy = setBusy(&env->linTaskActuator0);
resetStall(&env->linTaskActuator0);
env->rtU_local.in_Error_Connect_Ch0 = env->linTaskActuator0.error_connect;
env->rtU_local.in_Busy_Ch0 = env->linTaskActuator0.busy;
}
osMutexRelease(env->linTaskActuator0.access);
}
if (osMutexAcquire(env->ModelTask.access, 5000) == osOK) {
memcpy(&rtU, &env->rtU_local, sizeof(ExtU));
if ((isActuatorCommandSet_in_Model() == true) && (isActuatorBusy == false)) {
clearActuatorCommand_in_Model();
isActuatorBusy = true;
memcpy(&env->rtY_local.Out1, &rtY.Out1, sizeof(rtY.Out1));
}
osMutexRelease(env->ModelTask.access);
}
SystemDelayMs(100);
/* /*

View File

@ -25,7 +25,8 @@
#include "LinTasks.h" #include "LinTasks.h"
#include "AdcTasks.h" #include "AdcTasks.h"
#include "standby.h" #include "standby.h"
#include "Model_Task.h"
#include "Model_actuator.h"
typedef struct { typedef struct {
@ -60,6 +61,8 @@ typedef struct {
tStandBy standBy; tStandBy standBy;
tModelTask ModelTask;
struct { struct {
osThreadId_t id; osThreadId_t id;
uint32_t stack[1024 * 1]; uint32_t stack[1024 * 1];
@ -67,6 +70,8 @@ typedef struct {
osThreadAttr_t attr; osThreadAttr_t attr;
} thread; } thread;
ExtU rtU_local;
ExtY rtY_local;
} tMma; } tMma;
void Mma_Init( void Mma_Init(

View File

@ -89,6 +89,8 @@ static void Mma_InitSubSystems(tMma *env) {
StandBy_Init(&env->standBy); StandBy_Init(&env->standBy);
ModelTask_Init(&env->ModelTask);
LoggerInfoStatic(&env->slog.logger, LOG_TASK_MAIN, "End of subsystem initialization") LoggerInfoStatic(&env->slog.logger, LOG_TASK_MAIN, "End of subsystem initialization")
} }