// // Created by cfif on 05.05.23. // #include "MainModesArbiter_Private.h" #include "stdio.h" #include "fc7xxx_driver_rgm.h" #include "HVAC_model.h" #include "LinActuatorWork.h" #include "StatusError.h" #include "ADC_Temp.h" const char LOG_TASK_ARB[] = "Arb"; #define LOGGER &env->slog.logger void Mma_Init( tMma *env, tGpios *gpios, tAdcs *adcs, tSerialPorts *serialPorts, tLinPorts *linPorts, tCanPorts *canPorts, tStorageOnFlash *flash, tPwms *pwms, tRtcs *rtcs ) { env->gpios = gpios; env->serialPorts = serialPorts; env->linPorts = linPorts; env->canPorts = canPorts; env->rtcs = rtcs; env->adcs = adcs; env->flash = flash; env->pwms = pwms; InitThreadAtrStatic(&env->thread.attr, "Mma", env->thread.controlBlock, env->thread.stack, osPriorityNormal); env->thread.id = 0; } //uint8_t dataR[1024 * 2]; void BTS5180_120(tMma *env, char *desc, uint16_t adc_value) { float kILIS = 550.0f; float ERROR_THRESHOLD_V = 4.9f; uint16_t ERROR_THRESHOLD_CODE = (uint16_t) (ERROR_THRESHOLD_V * 4095.0f / 5.0f); if (adc_value >= ERROR_THRESHOLD_CODE) { LoggerFormatInfo(LOGGER, LOG_TASK_ARB, "%s: Error !!!", desc) } else { // Преобразование в напряжение float U = (float) adc_value * 5.0f / 4095.0f; float I = U / 1200; // Ток диагностики R = 1200 float Iout = I * kILIS; // Ток устройства LoggerFormatInfo(LOGGER, LOG_TASK_ARB, "%s: U = %f I = %f Iout = %f", desc, U, I, Iout) } } void VN7008AJ(tMma *env, char *desc, uint16_t adc_value) { float RSENSE = 2490.0f; // Сопротивление датчика, Ом (На схеме) float K_TYPICAL = 5890.0f; // Типичный коэффициент из даташита на микросхему float ERROR_THRESHOLD_V = 4.9f; uint16_t ERROR_THRESHOLD_CODE = (uint16_t) (ERROR_THRESHOLD_V * 4095.0f / 5.0f); // 1. Проверка на ошибку if (adc_value >= ERROR_THRESHOLD_CODE) { LoggerFormatInfo(LOGGER, LOG_TASK_ARB, "%s: Error !!!", desc) } else { // 2. Преобразование в напряжение float vsense = (float) adc_value * 5.0f / 4095.0f; // 3. Вычисление тока float Isense = vsense / RSENSE; float Iout = Isense * K_TYPICAL; LoggerFormatInfo(LOGGER, LOG_TASK_ARB, "%s: U = %f I = %f Iout = %f", desc, vsense, Isense, Iout) } } void ANALOG_SENSOR(tMma *env, char *desc, uint16_t adc_value) { float ERROR_THRESHOLD_V = 4.9f; uint16_t ERROR_THRESHOLD_CODE = (uint16_t) (ERROR_THRESHOLD_V * 4095.0f / 5.0f); // 1. Проверка на ошибку if (adc_value >= ERROR_THRESHOLD_CODE) { LoggerFormatInfo(LOGGER, LOG_TASK_ARB, "%s: Error !!!", desc) } else { // Преобразование в напряжение float U = (float) adc_value * 5.0f / 4095.0f; LoggerFormatInfo(LOGGER, LOG_TASK_ARB, "%s: U = %f", desc, U) } } void LoadDataInFromModel(tMma *env) { // int16_t temp1 = 0; // float temp2 = 0; /* if (osMutexAcquire(env->adcTask0.access, 5000) == osOK) { if (env->adcTask0.ADC_isUpdate) { env->adcTask0.ADC_isUpdate = false; memcpy(&env->ADC_Data_Model_local, &env->adcTask0.ADC0_Data, sizeof(env->adcTask0.ADC0_Data)); // temp1 = get_temperature_fast(env->adcTask0.ADC0_Data.Sensor_Ambient_Temp); // temp2 = get_temperature_from_adc(env->adcTask0.ADC0_Data.Sensor_Ambient_Temp, ALG_STEINHART); //env->ADC_Data_Model_local.Sensor_Incar_Temp_FL = env->adcTask0.ADC0_Data.Sensor_Ambient_Temp; // LoggerFormatInfo(LOGGER, LOG_TASK_ARB, "Temp1 = %d; Temp2 = %d; ADC = %d", temp1, (int16_t) (temp2 * 10.0f), env->adcTask0.ADC0_Data.Sensor_Ambient_Temp) // R1 = 91000 R2 = 20000 ((5 * (91000 + 20000)) / 20000 = 27.75 В) // float U_IGN_CHECK = ((float) env->adcTask0.ADC0_Data.IGN_ANS * 27.75f) / 4095.0f; // LoggerFormatInfo(LOGGER, LOG_TASK_ARB, "U_IGN_CHECK = %f", U_IGN_CHECK) // BTS5180_120(env, "BTS5120_2EKA_ShutoffValvePowerTXV1", // env->adcTask0.ADC0_Data.BTS5120_2EKA_ShutoffValvePowerTXV1); // BTS5180_120(env, "BTS5120_2EKA_ShutoffValvePowerTXV2", // env->adcTask0.ADC0_Data.BTS5120_2EKA_ShutoffValvePowerTXV2); // BTS5180_120(env, "BTS5180_2EKA_ShutOFFValveFront", env->adcTask0.ADC0_Data.BTS5180_2EKA_ShutOFFValveFront); // BTS5180_120(env, "BTS5180_2EKA_ShutOFFValveRear", env->adcTask0.ADC0_Data.BTS5180_2EKA_ShutOFFValveRear); // BTS5180_120(env, "BTS5180_2EKA_TwoWayValve", env->adcTask0.ADC0_Data.BTS5180_2EKA_TwoWayValve); // BTS5180_120(env, "BTS5180_2EKA_ReservePowerSupply", // env->adcTask0.ADC0_Data.BTS5180_2EKA_ReservePowerSupply); // BTS5180_120(env, "BTS5180_2EKA_FrontIncarMotor", env->adcTask0.ADC0_Data.BTS5180_2EKA_FrontIncarMotor); // BTS5180_120(env, "BTS5180_2EKA_RearIncarMotor", env->adcTask0.ADC0_Data.BTS5180_2EKA_RearIncarMotor); // BTS5180_120(env, "BTS5180_2EKA_ChannelPTCPower1", env->adcTask0.ADC0_Data.BTS5180_2EKA_ChannelPTCPower1); // BTS5180_120(env, "BTS5180_2EKA_ChannelPTCPower2", env->adcTask0.ADC0_Data.BTS5180_2EKA_ChannelPTCPower2); // ANALOG_SENSOR(env, "Sensor_Ambient_Temp", env->adcTask0.ADC0_Data.Sensor_Ambient_Temp); // ANALOG_SENSOR(env, "Sensor_AC_Pressure", env->adcTask0.ADC0_Data.Sensor_AC_Pressure); // ANALOG_SENSOR(env, "Sensor_Incar_Temp_FL", env->adcTask0.ADC0_Data.Sensor_Incar_Temp_FL); // ANALOG_SENSOR(env, "Sensor_Incar_Temp_RL", env->adcTask0.ADC0_Data.Sensor_Incar_Temp_RL); // ANALOG_SENSOR(env, "Sensor_Rear_Evap_Temp", env->adcTask0.ADC0_Data.Sensor_Rear_Evap_Temp); // ANALOG_SENSOR(env, "Sensor_Evap_Temp", env->adcTask0.ADC0_Data.Sensor_Evap_Temp); // ANALOG_SENSOR(env, "Sensor_Rear_Duct1", env->adcTask0.ADC0_Data.Sensor_Rear_Duct1); // ANALOG_SENSOR(env, "Sensor_Rear_Duct2", env->adcTask0.ADC0_Data.Sensor_Rear_Duct2); // ANALOG_SENSOR(env, "Sensor_Front_Duct1", env->adcTask0.ADC0_Data.Sensor_Front_Duct1); // ANALOG_SENSOR(env, "Sensor_Front_Duct2", env->adcTask0.ADC0_Data.Sensor_Front_Duct2); // ANALOG_SENSOR(env, "Sensor_Front_Duct3", env->adcTask0.ADC0_Data.Sensor_Front_Duct3); // ANALOG_SENSOR(env, "Sensor_Front_Duct4", env->adcTask0.ADC0_Data.Sensor_Front_Duct4); // ANALOG_SENSOR(env, "Sensor_Rear_Duct3", env->adcTask0.ADC0_Data.Sensor_Rear_Duct3); // ANALOG_SENSOR(env, "Sensor_Rear_Duct4", env->adcTask0.ADC0_Data.Sensor_Rear_Duct4); // ANALOG_SENSOR(env, "Sensor_Incar_Temp_FR", env->adcTask0.ADC0_Data.Sensor_Incar_Temp_FR); // ANALOG_SENSOR(env, "Sensor_Incar_Temp_RR", env->adcTask0.ADC0_Data.Sensor_Incar_Temp_RR); // ANALOG_SENSOR(env, "Sensor_Rear_Duct5", env->adcTask0.ADC0_Data.Sensor_Rear_Duct5); // ANALOG_SENSOR(env, "Sensor_Rear_Duct6", env->adcTask0.ADC0_Data.Sensor_Rear_Duct6); // ANALOG_SENSOR(env, "Reserve_Sensor_Duct_Temp_1", env->adcTask0.ADC0_Data.Reserve_Sensor_Duct_Temp_1); // ANALOG_SENSOR(env, "Sensor_Front_Duct5", env->adcTask0.ADC0_Data.Sensor_Front_Duct5); // ANALOG_SENSOR(env, "Sensor_Front_Duct6", env->adcTask0.ADC0_Data.Sensor_Front_Duct6); // R1 = 10000 R2 = 47000 ((5 * (10000 + 47000)) / 47000 = 6.0638 В) // float Pressure_DIAG = ((float) env->adcTask0.ADC0_Data.Pressure_DIAG * 6.0638f) / 4095.0f; // LoggerFormatInfo(LOGGER, LOG_TASK_ARB, "Pressure_DIAG = %f", Pressure_DIAG) // ANALOG_SENSOR(env, "Reserve_Sensor_Duct_Temp_2", env->adcTask0.ADC0_Data.Reserve_Sensor_Duct_Temp_2); } osMutexRelease(env->adcTask0.access); } if (osMutexAcquire(env->adcTask1.access, 5000) == osOK) { if (env->adcTask1.ADC_isUpdate) { env->adcTask1.ADC_isUpdate = false; memcpy(&env->ADC_Data_Model_local.VN7008AJ_DIAG_FrontLINActuatorPowerDriverAB, &env->adcTask1.ADC1_Data, sizeof(env->adcTask1.ADC1_Data)); asm("nop"); // R1 = 91000 R2 = 16000 ((5 * (91000 + 16000)) / 16000 = 33.4375 В) // float U_PBATT_CHECK = ((float) env->adcTask1.ADC1_Data.PBATT_CHECK * 33.4375f) / 4095.0f; // LoggerFormatInfo(LOGGER, LOG_TASK_ARB, "U_PBATT_CHECK = %f", U_PBATT_CHECK) // R1 = 30000 R2 = 12000 ((5 * (30000 + 12000)) / 12000 = 17.5 В) // float U_VN7008AJ_DIAG_FrontLINActuatorPowerDriverAB = // ((float) env->adcTask1.ADC1_Data.VN7008AJ_DIAG_FrontLINActuatorPowerDriverAB * 17.5f) / 4095.0f; // LoggerFormatInfo(LOGGER, LOG_TASK_ARB, "U_VN7008AJ_DIAG_FrontLINActuatorPowerDriverAB = %f", // U_VN7008AJ_DIAG_FrontLINActuatorPowerDriverAB) // R1 = 30000 R2 = 12000 ((5 * (30000 + 12000)) / 12000 = 17.5 В) // float U_VN7008AJ_DIAG_RearLINActuatorPowerDriverC = // ((float) env->adcTask1.ADC1_Data.VN7008AJ_DIAG_RearLINActuatorPowerDriverC * 17.5f) / 4095.0f; // LoggerFormatInfo(LOGGER, LOG_TASK_ARB, "U_VN7008AJ_DIAG_RearLINActuatorPowerDriverC = %f", // U_VN7008AJ_DIAG_RearLINActuatorPowerDriverC) // VN7008AJ(env, "VN7008AJ_FrontLINActuatorPowerDriverAB", env->adcTask1.ADC1_Data.VN7008AJ_FrontLINActuatorPowerDriverAB); // VN7008AJ(env, "VN7008AJ_RearLINActuatorPowerDriverC", env->adcTask1.ADC1_Data.VN7008AJ_RearLINActuatorPowerDriverC); } //temp2 = get_temperature_fast(env->adcTask1.ADC_Data[0], fast_lookup_KST45, 512); //env->rtDW.controllerDataIncarInput.InIncarFR = env->adcTask1.ADC_Data[0]; osMutexRelease(env->adcTask1.access); //LoggerFormatInfo(LOGGER, LOG_TASK_ARB, "Temp2 = %d", temp2) } */ // if (osMutexAcquire(env->ModelTask.access, 5000) == osOK) { /* rtDW.ADC_Key_Data_Model.ST_ReservePower = GpioPinGet( &env->gpios->power.BTS4175SGAXUMA1_ReservePowerOutput.ST_ReservePower); rtDW.ADC_Key_Data_Model.ST_BATTChiller = GpioPinGet( &env->gpios->power.BTS4175SGAXUMA1_ShutOFFValveBatteryChiller.ST_BATTChiller); rtDW.ADC_Key_Data_Model.EmergencyAirCleanSwitch = GpioPinGet(&env->gpios->EmergencyAirCleanSwitch); rtDW.ADC_Key_Data_Model.FireExtinguishSwitch = GpioPinGet(&env->gpios->FireExtinguishSwitch); rtDW.ADC_Key_Data_Model.Ign_Wakeup = GpioPinGet(&env->gpios->Ign_Wakeup); */ /* PWM_Get.pwmPercentFront = env->pwms->pwmFrontCaptureIO.getPwm(env->pwms->pwmFrontCaptureIO.env); PWM_Get.pwmPercentRear = env->pwms->pwmRearCaptureIO.getPwm(env->pwms->pwmRearCaptureIO.env); PWM_Get.pwmPercentFrontReserved = env->pwms->pwmFrontCaptureIO.getPwm(env->pwms->pwmFrontReservedCaptureIO.env); PWM_Get.pwmPercentRearReserved = env->pwms->pwmRearCaptureIO.getPwm(env->pwms->pwmRearReservedCaptureIO.env); // LoggerFormatInfo(LOGGER, LOG_TASK_ARB, "PWM (Front) = %d", PWM_Get.pwmPercentFront ) // LoggerFormatInfo(LOGGER, LOG_TASK_ARB, "PWM (Rear) = %d", PWM_Get.pwmPercentRear) // LoggerFormatInfo(LOGGER, LOG_TASK_ARB, "PWM (Front Reserve) = %d", PWM_Get.pwmPercentFrontReserved) // LoggerFormatInfo(LOGGER, LOG_TASK_ARB, "PWM (Rear Reserve) = %d", PWM_Get.pwmPercentRearReserved) env->pwms->pwmFrontIo.setActivePercent(env->pwms->pwmFrontIo.env, rtDW.PWM_Set_Model.pwmPercentFront); env->pwms->pwmRearIo.setActivePercent(env->pwms->pwmRearIo.env, rtDW.PWM_Set_Model.pwmPercentRear); env->pwms->pwmFrontReservedIo.setActivePercent(env->pwms->pwmFrontReservedIo.env, rtDW.PWM_Set_Model.pwmPercentFrontReserved); env->pwms->pwmRearReservedIo.setActivePercent(env->pwms->pwmRearReservedIo.env, rtDW.PWM_Set_Model.pwmPercentRearReserved); PWM_Get.pwmPercentFront = env->pwms->pwmFrontCaptureIO.getPwm(env->pwms->pwmFrontCaptureIO.env); PWM_Get.pwmPercentRear = env->pwms->pwmRearCaptureIO.getPwm(env->pwms->pwmRearCaptureIO.env); PWM_Get.pwmPercentFrontReserved = env->pwms->pwmFrontCaptureIO.getPwm( env->pwms->pwmFrontReservedCaptureIO.env); PWM_Get.pwmPercentRearReserved = env->pwms->pwmRearCaptureIO.getPwm( env->pwms->pwmRearReservedCaptureIO.env); env->pwms->pwmFrontIo.setActivePercent(env->pwms->pwmFrontIo.env, PWM_Get.pwmPercentFront); env->pwms->pwmRearIo.setActivePercent(env->pwms->pwmRearIo.env, PWM_Get.pwmPercentRear); env->pwms->pwmFrontReservedIo.setActivePercent(env->pwms->pwmFrontReservedIo.env, PWM_Get.pwmPercentFrontReserved); env->pwms->pwmRearReservedIo.setActivePercent(env->pwms->pwmRearReservedIo.env, PWM_Get.pwmPercentRearReserved); */ // set_Dtc_state_error(&env->Diagnostic); // set_CCU_Errors(&env->canSpamTransmitter, (CCU_Errors_t *) &CCU_Errors_Model); // osMutexRelease(env->ModelTask.access); // } if (osMutexAcquire(env->ModelTask.access, 5000) == osOK) { env->pwms->pwmFrontIo.setActivePercent(env->pwms->pwmFrontIo.env, rtY.PWM_Get_f.pwmPercentFront); env->pwms->pwmRearIo.setActivePercent(env->pwms->pwmRearIo.env, rtY.PWM_Get_f.pwmPercentRear); env->pwms->pwmFrontReservedIo.setActivePercent(env->pwms->pwmFrontReservedIo.env, rtY.PWM_Get_f.pwmPercentFrontReserved); env->pwms->pwmRearReservedIo.setActivePercent(env->pwms->pwmRearReservedIo.env, rtY.PWM_Get_f.pwmPercentRearReserved); PWM_Get.pwmPercentFront = env->pwms->pwmFrontCaptureIO.getPwm(env->pwms->pwmFrontCaptureIO.env); PWM_Get.pwmPercentRear = env->pwms->pwmRearCaptureIO.getPwm(env->pwms->pwmRearCaptureIO.env); PWM_Get.pwmPercentFrontReserved = env->pwms->pwmFrontCaptureIO.getPwm( env->pwms->pwmFrontReservedCaptureIO.env); PWM_Get.pwmPercentRearReserved = env->pwms->pwmRearCaptureIO.getPwm( env->pwms->pwmRearReservedCaptureIO.env); set_Dtc_state_error(&env->Diagnostic); set_CanSpamTransmitter(&env->canSpamTransmitter); get_CanSpamReceiver(&env->canSpamReceiver); osMutexRelease(env->ModelTask.access); } } static _Noreturn void Mma_Thread(tMma *env) { uint8_t step = 0; bool busy = false; // Запуск устройства Mma_InitStage(env); // Инициализируем обе таблицы одновременно с разными значениями R1 // init_both_tables(20000.0f, // R1 для KST45 // 20000.0f, // R1 для INCAR // ALG_STEINHART); // can_rx_message_type frame_data; // uint32_t step = 0; if (RGM_SRS_WAKEUP_MASK == (RGM->SRS & RGM_SRS_WAKEUP_MASK)) { LoggerInfoStatic(LOGGER, LOG_TASK_ARB, "Wake up from standby") } env->pwms->pwmFrontIo.run(env->pwms->pwmFrontIo.env); ModelTask_StartThread(&env->ModelTask); while (!env->ModelTask.isRunning) { LoggerInfoStatic(LOGGER, LOG_TASK_ARB, "Waiting for the model to run...") SystemDelayMs(1); } LoggerInfoStatic(LOGGER, LOG_TASK_ARB, "Model running...") /* for (;;) { uint16_t len = SerialPortReceive(&env->serialPorts->SerialPortLog_IO, dataR, 1024, 1000); if (len != 0) { SerialPortTransmit(&env->serialPorts->SerialPortLog_IO, dataR, len, 1000); } } */ for (;;) { // if (osMutexAcquire(env->adcTask0.access, 1000) == osOK) { /* uint16_t adc_value = env->adcTask0.ADC0_Data.Sensor_Front_Duct1; int16_t temp_incar = get_temperature_log_fast_for_table(adc_value, TABLE_KST45); float resistance = get_resistance_log_fast_for_table(temp_incar, TABLE_KST45); float U = (float) adc_value * 5.0f / 4095.0f; LoggerFormatInfo(LOGGER, LOG_TASK_ARB, "Sensor_Front_Duct1: ADC = %u, Temp = %.2f °C, Resistance = %.2f Ohm U = %.2f", adc_value, temp_incar / 10.0f, resistance, U) */ /* uint16_t adc_value = env->adcTask0.ADC0_Data.Sensor_Front_Duct2; int16_t temp_incar = get_temperature_log_fast_for_table(adc_value, TABLE_KST45); float resistance = get_resistance_log_fast_for_table(temp_incar, TABLE_KST45); float U = (float) adc_value * 5.0f / 4095.0f; LoggerFormatInfo(LOGGER, LOG_TASK_ARB, "Sensor_Front_Duct1: ADC = %u, Temp = %.2f °C, Resistance = %.2f Ohm U = %.2f", adc_value, temp_incar / 10.0f, resistance, U) */ /* uint16_t adc_value = env->adcTask0.ADC0_Data.Sensor_Ambient_Temp; int16_t Sensor_Ambient_Temp = get_temperature_log_fast_for_table(adc_value, TABLE_KST45); float resistance = get_resistance_log_fast_for_table(Sensor_Ambient_Temp, TABLE_KST45); float U = (float) adc_value * 5.0f / 4095.0f; LoggerFormatInfo(LOGGER, LOG_TASK_ARB, "Sensor_Ambient_Temp: ADC = %u, Temp = %.2f °C, Resistance = %.2f Ohm U = %.2f", adc_value, Sensor_Ambient_Temp / 10.0f, resistance, U) */ //uint16_t adc_value = env->adcTask0.ADC0_Data.Sensor_Incar_Temp_FL; //int16_t temp_incar = get_temperature_log_fast_for_table(adc_value, TABLE_INCAR); //LoggerFormatInfo(LOGGER, LOG_TASK_ARB, "Sensor_Incar_Temp_FL: ADC = %u, Temp = %.2f °C", adc_value, // temp_incar / 10.0f) // osMutexRelease(env->adcTask0.access); // } /* if (osMutexAcquire(env->ModelTask.access, 5000) == osOK) { PWM_Get.pwmPercentFront = env->pwms->pwmFrontCaptureIO.getPwm(env->pwms->pwmFrontCaptureIO.env); PWM_Get.pwmPercentRear = env->pwms->pwmRearCaptureIO.getPwm(env->pwms->pwmRearCaptureIO.env); PWM_Get.pwmPercentFrontReserved = env->pwms->pwmFrontCaptureIO.getPwm( env->pwms->pwmFrontReservedCaptureIO.env); PWM_Get.pwmPercentRearReserved = env->pwms->pwmRearCaptureIO.getPwm( env->pwms->pwmRearReservedCaptureIO.env); env->pwms->pwmFrontIo.setActivePercent(env->pwms->pwmFrontIo.env, 95); env->pwms->pwmRearIo.setActivePercent(env->pwms->pwmRearIo.env, 95); env->pwms->pwmFrontReservedIo.setActivePercent(env->pwms->pwmFrontReservedIo.env, 10); env->pwms->pwmRearReservedIo.setActivePercent(env->pwms->pwmRearReservedIo.env, 20); set_Dtc_state_error(&env->Diagnostic); set_CCU_Errors(&env->canSpamTransmitter, (CCU_Errors_t *) &CCU_Errors_Model); osMutexRelease(env->ModelTask.access); } */ /* SystemDelayMs(10); uint8_t pwm1 = env->pwms->pwmFrontCaptureIO.getPwm(env->pwms->pwmFrontCaptureIO.env); LoggerFormatInfo(LOGGER, LOG_TASK_ARB, "PWM (Front) = %d", pwm1) SystemDelayMs(10); uint8_t pwm2 = env->pwms->pwmRearCaptureIO.getPwm(env->pwms->pwmRearCaptureIO.env); LoggerFormatInfo(LOGGER, LOG_TASK_ARB, "PWM (Rear) = %d", pwm2) SystemDelayMs(10); uint8_t pwm3 = env->pwms->pwmFrontReservedCaptureIO.getPwm(env->pwms->pwmFrontReservedCaptureIO.env); LoggerFormatInfo(LOGGER, LOG_TASK_ARB, "PWM (Front Reserve) = %d", pwm3) SystemDelayMs(10); uint8_t pwm4 = env->pwms->pwmRearReservedCaptureIO.getPwm(env->pwms->pwmRearReservedCaptureIO.env); LoggerFormatInfo(LOGGER, LOG_TASK_ARB, "PWM (Rear Reserve) = %d", pwm4) */ // LoadDataInFromModel(env); /* LinActuatorWork(env, &env->linTaskActuator1, 1, &env->actuator_Ch0_Command_Model_local_1, &env->ModelTask.triggerActuatorCmdBus_1, &env->actuator_Ch0_Input_Model_local_1, &Actuator_Ch0_Status_Model, &env->ModelTask.triggerCommand1, "Ln1 "); LinActuatorWork(env, &env->linTaskActuator2, 2, &env->actuator_Ch1_Command_Model_local_2, &env->ModelTask.triggerActuatorCmdBus_2, &env->actuator_Ch1_Input_Model_local_2, &Actuator_Ch1_Status_Model, &env->ModelTask.triggerCommand2, "Ln2 "); LinActuatorWork(env, &env->linTaskActuator3, 3, &env->actuator_Ch2_Command_Model_local_3, &env->ModelTask.triggerActuatorCmdBus_3, &env->actuator_Ch2_Input_Model_local_3, &Actuator_Ch2_Status_Model, &env->ModelTask.triggerCommand3, "Ln3 "); */ LoadDataInFromModel(env); SystemDelayMs(25); GpioPinToggle(&env->gpios->led.LED_G); SystemDelayMs(25); /* if (RGM_SRS_WAKEUP_MASK == (RGM->SRS & RGM_SRS_WAKEUP_MASK)) { } else { SMC_SetSystemMode(SMC_MODE_STANBY_3); } */ /* if (osMutexAcquire(env->adcTask0.access, 1000) == osOK) { temp1 = get_temperature_fast(env->adcTask0.ADC_Data[0], fast_lookup_Incar, 512); osMutexRelease(env->adcTask0.access); LoggerFormatInfo(LOGGER, LOG_TASK_ARB, "Temp1 = %d", temp1) } if (osMutexAcquire(env->adcTask1.access, 1000) == osOK) { temp2 = get_temperature_fast(env->adcTask1.ADC_Data[0], fast_lookup_KST45, 512); osMutexRelease(env->adcTask1.access); LoggerFormatInfo(LOGGER, LOG_TASK_ARB, "Temp2 = %d", temp2) } */ /* frame_data.id_type = FLEXCAN_ID_STD; frame_data.dlc = 1; env->canPorts->Can1_IO.transmit(env->canPorts->Can1_IO.env, frame_data.data, frame_data.dlc, 0x123, frame_data.id_type, 1000); */ /* uint16_t len = env->canPorts->Can1_IO.receive(env->canPorts->Can1_IO.env, 0, (uint8_t *)&frame_data, 1, 1000); if (len > 0) { env->canPorts->Can1_IO.transmit(env->canPorts->Can1_IO.env, frame_data.data, frame_data.dlc, frame_data.standard_id, frame_data.id_type, 1000); } */ /* uint16_t len = env->canPorts->Can0_IO.receive(env->canPorts->Can0_IO.env, 0, (uint8_t *)&frame_data, 1, 1000); if (len > 0) { env->canPorts->Can0_IO.transmit(env->canPorts->Can0_IO.env, frame_data.data, frame_data.dlc, 0x123, frame_data.id_type, 1000); } */ /* uint16_t len = env->canPorts->Can0_IO.receive(env->canPorts->Can0_IO.env, 0, (uint8_t *)&frame_data, 1, 1000); if (len > 0) { if (frame_data.id_type == FLEXCAN_ID_STD) { CanSerialPortFrameSetType(env->canPorts->Can0_IO.env, FLEXCAN_ID_STD); CanSerialPortFrameSetId(env->canPorts->Can0_IO.env, frame_data.standard_id); } else { CanSerialPortFrameSetType(env->canPorts->Can0_IO.env, FLEXCAN_ID_EXT); CanSerialPortFrameSetId(env->canPorts->Can0_IO.env, frame_data.extended_id); } env->canPorts->Can0_IO.transmit(env->canPorts->Can0_IO.env, frame_data.data, frame_data.dlc, 1000); } */ } } void Mma_StartThread(tMma *env) { if (!env->thread.id) { env->thread.id = osThreadNew((osThreadFunc_t) (Mma_Thread), (void *) (env), &env->thread.attr); } else { osThreadResume(env->thread.id); } }