|
@@ -41,7 +41,7 @@
|
|
#include "../Define/define.h"
|
|
#include "../Define/define.h"
|
|
#include "../ShareMemory/shmMem.h"
|
|
#include "../ShareMemory/shmMem.h"
|
|
#include "../SelectGun/SelectGun.h"
|
|
#include "../SelectGun/SelectGun.h"
|
|
-#include "CheckSystemTask.h"
|
|
|
|
|
|
+
|
|
|
|
|
|
//------------------------------------------------------------------------------
|
|
//------------------------------------------------------------------------------
|
|
static struct SysInfoData *pSysInfo = NULL;
|
|
static struct SysInfoData *pSysInfo = NULL;
|
|
@@ -82,7 +82,7 @@ uint8_t bd0_2_status = 0;
|
|
uint8_t bd1_1_status = 0;
|
|
uint8_t bd1_1_status = 0;
|
|
uint8_t bd1_2_status = 0;
|
|
uint8_t bd1_2_status = 0;
|
|
|
|
|
|
-char *fwVersion = "V1.15.00.0000.00"; // "V0.16.00.0000.00";
|
|
|
|
|
|
+char *fwVersion = "V1.17.00.0000.00"; // "V0.16.00.0000.00";
|
|
|
|
|
|
//sqlite3 *localDb;
|
|
//sqlite3 *localDb;
|
|
bool isDb_ready;
|
|
bool isDb_ready;
|
|
@@ -120,7 +120,7 @@ extern void SetIsCardScan(bool value);
|
|
extern void SelfTestRun(void);
|
|
extern void SelfTestRun(void);
|
|
|
|
|
|
//UpgradeFW.c
|
|
//UpgradeFW.c
|
|
-extern void CheckFwUpdateFunction(void);
|
|
|
|
|
|
+/*extern void CheckFwUpdateFunction(void);*/
|
|
|
|
|
|
//Ethernet.c
|
|
//Ethernet.c
|
|
extern void InitEthernet(void);
|
|
extern void InitEthernet(void);
|
|
@@ -1637,12 +1637,14 @@ void _DetectPlugInTimeout(void)
|
|
ClearDetectPluginFlag();
|
|
ClearDetectPluginFlag();
|
|
|
|
|
|
sleep(1); //等待DoComm回報插槍訊號給主櫃
|
|
sleep(1); //等待DoComm回報插槍訊號給主櫃
|
|
-#if defined DD360Audi || DD360 || DD360Combox
|
|
|
|
|
|
+#if defined DD360Audi
|
|
//pSysInfo->SystemPage = _LCM_COMPLETE;
|
|
//pSysInfo->SystemPage = _LCM_COMPLETE;
|
|
setChargerMode(pSysInfo->CurGunSelected, S_TERMINATING);
|
|
setChargerMode(pSysInfo->CurGunSelected, S_TERMINATING);
|
|
- return;
|
|
|
|
-#endif
|
|
|
|
|
|
+#elif DD360 || DD360Combox
|
|
|
|
+ setChargerMode(pSysInfo->CurGunSelected, S_COMPLETE);
|
|
systemPageRestoreInit();
|
|
systemPageRestoreInit();
|
|
|
|
+#endif
|
|
|
|
+
|
|
}
|
|
}
|
|
|
|
|
|
void _DetectEvChargingEnableTimeout(uint8_t gunIndex)
|
|
void _DetectEvChargingEnableTimeout(uint8_t gunIndex)
|
|
@@ -1671,11 +1673,11 @@ void _DetectEvseChargingEnableTimeout(uint8_t gunIndex)
|
|
log_info("*********** _DetectEvseChargingEnableTimeout (GFD timeout) ***********\n");
|
|
log_info("*********** _DetectEvseChargingEnableTimeout (GFD timeout) ***********\n");
|
|
//if (chargingInfo[gunIndex]->GroundFaultStatus != GFD_PASS)
|
|
//if (chargingInfo[gunIndex]->GroundFaultStatus != GFD_PASS)
|
|
{
|
|
{
|
|
-#if defined DD360Audi || DD360 || DD360Combox
|
|
|
|
- pSysInfo->SystemPage = _LCM_COMPLETE;
|
|
|
|
- setChargerMode(gunIndex, S_TERMINATING);
|
|
|
|
-#else
|
|
|
|
- setChargerMode(gunIndex, MODE_IDLE);
|
|
|
|
|
|
+#if defined DD360Audi
|
|
|
|
+ //pSysInfo->SystemPage = _LCM_COMPLETE;
|
|
|
|
+ setChargerMode(pSysInfo->CurGunSelected, S_TERMINATING);
|
|
|
|
+#elif DD360 || DD360Combox
|
|
|
|
+ setChargerMode(pSysInfo->CurGunSelected, S_COMPLETE);
|
|
#endif
|
|
#endif
|
|
_AutoReturnTimeout();
|
|
_AutoReturnTimeout();
|
|
}
|
|
}
|
|
@@ -1684,11 +1686,11 @@ void _DetectEvseChargingEnableTimeout(uint8_t gunIndex)
|
|
void _PrepareTimeout(uint8_t gunIndex)
|
|
void _PrepareTimeout(uint8_t gunIndex)
|
|
{
|
|
{
|
|
log_info("*********** _PrepareTimeout ***********\n");
|
|
log_info("*********** _PrepareTimeout ***********\n");
|
|
-#if defined DD360Audi || DD360 || DD360Combox
|
|
|
|
- pSysInfo->SystemPage = _LCM_COMPLETE;
|
|
|
|
- setChargerMode(gunIndex, S_TERMINATING);
|
|
|
|
-#else
|
|
|
|
- setChargerMode(gunIndex, MODE_IDLE);
|
|
|
|
|
|
+#if defined DD360Audi
|
|
|
|
+ //pSysInfo->SystemPage = _LCM_COMPLETE;
|
|
|
|
+ setChargerMode(pSysInfo->CurGunSelected, S_TERMINATING);
|
|
|
|
+#elif DD360 || DD360Combox
|
|
|
|
+ setChargerMode(pSysInfo->CurGunSelected, S_COMPLETE);
|
|
#endif
|
|
#endif
|
|
pAlarmCode->AlarmEvents.bits.PsuNoResource = YES;
|
|
pAlarmCode->AlarmEvents.bits.PsuNoResource = YES;
|
|
_AutoReturnTimeout();
|
|
_AutoReturnTimeout();
|
|
@@ -1697,76 +1699,15 @@ void _PrepareTimeout(uint8_t gunIndex)
|
|
void _CcsPrechargeTimeout(uint8_t gunIndex)
|
|
void _CcsPrechargeTimeout(uint8_t gunIndex)
|
|
{
|
|
{
|
|
log_info("*********** _CcsPrechargeTimeout ***********\n");
|
|
log_info("*********** _CcsPrechargeTimeout ***********\n");
|
|
-#if defined DD360Audi || DD360 || DD360Combox
|
|
|
|
- pSysInfo->SystemPage = _LCM_COMPLETE;
|
|
|
|
- setChargerMode(gunIndex, S_TERMINATING);
|
|
|
|
-#else
|
|
|
|
- setChargerMode(gunIndex, MODE_IDLE);
|
|
|
|
|
|
+#if defined DD360Audi
|
|
|
|
+ //pSysInfo->SystemPage = _LCM_COMPLETE;
|
|
|
|
+ setChargerMode(pSysInfo->CurGunSelected, S_TERMINATING);
|
|
|
|
+#elif DD360 || DD360Combox
|
|
|
|
+ setChargerMode(pSysInfo->CurGunSelected, S_COMPLETE);
|
|
#endif
|
|
#endif
|
|
}
|
|
}
|
|
|
|
|
|
-//===============================================
|
|
|
|
-// Check System Task alive
|
|
|
|
-// ==============================================
|
|
|
|
-void CheckSystemTaskAlive()
|
|
|
|
-{
|
|
|
|
- unsigned char lostId = CheckSystemTask(ShmSysConfigAndInfo->SysInfo.SystemPage);
|
|
|
|
- if (lostId != 0) {
|
|
|
|
- log_info("Check task(%d) lost\n",lostId);
|
|
|
|
- if (ShmStatusCodeData->AlarmCode.AlarmEvents.bits.SystemTaskLost == NO) {
|
|
|
|
- if (lostId == _SYSTEM_TASK_LOST_ITEM_MAIN)
|
|
|
|
- log_info("System task lost (CSU). \n");
|
|
|
|
- else if (lostId == _SYSTEM_TASK_LOST_ITEM_EVCOMM)
|
|
|
|
- log_info("System task lost (EVComm). \n");
|
|
|
|
-// else if (lostId == _SYSTEM_TASK_LOST_ITEM_PSUCOMM)
|
|
|
|
-// PRINTF_FUNC("System task lost (PSU Task). \n");
|
|
|
|
- else if (lostId == _SYSTEM_TASK_LOST_ITEM_EVENTLOG)
|
|
|
|
- log_info("System task lost (Event log). \n");
|
|
|
|
- else if (lostId == _SYSTEM_TASK_LOST_ITEM_PRIMARYCOMM)
|
|
|
|
- log_info("System task lost (Primary). \n");
|
|
|
|
- else if (lostId == _SYSTEM_TASK_LOST_ITEM_LCMCONTROL)
|
|
|
|
- log_info("System task lost (LCM Comm). \n");
|
|
|
|
- else if (lostId == _SYSTEM_TASK_LOST_ITEM_INTERCOMM)
|
|
|
|
- log_info("System task lost (Internal Comm). \n");
|
|
|
|
- else if (lostId == _SYSTEM_TASK_LOST_ITEM_DOCOMM)
|
|
|
|
- log_info("System task lost (Do Comm). \n");
|
|
|
|
- else if (lostId == _SYSTEM_TASK_LOST_ITEM_PRODUCTUTILS)
|
|
|
|
- log_info("System task lost (ProcductUtils Comm). \n");
|
|
|
|
- ShmStatusCodeData->AlarmCode.AlarmEvents.bits.SystemTaskLost = YES;
|
|
|
|
- }
|
|
|
|
- } else
|
|
|
|
- ShmStatusCodeData->AlarmCode.AlarmEvents.bits.SystemTaskLost = NO;
|
|
|
|
-}
|
|
|
|
-
|
|
|
|
-void CreateCheckSystemTaskFork()
|
|
|
|
-{
|
|
|
|
- pid_t taskPid;
|
|
|
|
- taskPid = fork();
|
|
|
|
- if (taskPid == 0)
|
|
|
|
- {
|
|
|
|
- while(true)
|
|
|
|
- {
|
|
|
|
- /*
|
|
|
|
- for (int _index = 0; _index < ShmSysConfigAndInfo->SysConfig.TotalConnectorCount; _index++)
|
|
|
|
- {
|
|
|
|
- if (chargingInfo[_index]->SystemStatus == SYS_MODE_UPDATE ||
|
|
|
|
- chargingInfo[_index]->Type == 0x09)
|
|
|
|
- {
|
|
|
|
- stopToDet = true;
|
|
|
|
- continue;
|
|
|
|
- }
|
|
|
|
- }
|
|
|
|
- */
|
|
|
|
- for (uint8_t gun = 0; gun < pSysConfig->TotalConnectorCount; gun++) {
|
|
|
|
- pDcChargingInfo = (struct ChargingInfoData *)GetDcChargingInfoData(gun);
|
|
|
|
- if (pDcChargingInfo->SystemStatus == SYS_MODE_UPDATE )
|
|
|
|
- continue;
|
|
|
|
- }
|
|
|
|
- CheckSystemTaskAlive();
|
|
|
|
- sleep(5);
|
|
|
|
- }
|
|
|
|
- }
|
|
|
|
-}
|
|
|
|
|
|
+
|
|
//===============================================
|
|
//===============================================
|
|
// 取得卡號與卡號驗證
|
|
// 取得卡號與卡號驗證
|
|
//===============================================
|
|
//===============================================
|
|
@@ -2663,6 +2604,11 @@ int SpawnTask(void)
|
|
system("/root/Module_LcmControl &");
|
|
system("/root/Module_LcmControl &");
|
|
system("/root/Module_InternalComm &");
|
|
system("/root/Module_InternalComm &");
|
|
system("/root/Module_ProduceUtils &");
|
|
system("/root/Module_ProduceUtils &");
|
|
|
|
+ system("/root/Module_UpdateFW &");
|
|
|
|
+
|
|
|
|
+ unsigned char count = GetProcessCount("Module_ChkSysTask");
|
|
|
|
+ if( count != 1)
|
|
|
|
+ system("/root/Module_ChkSysTask &");
|
|
|
|
|
|
#if defined DD360 ||defined DD360Audi || defined DD360ComBox
|
|
#if defined DD360 ||defined DD360Audi || defined DD360ComBox
|
|
system("/root/Module_DoComm &");
|
|
system("/root/Module_DoComm &");
|
|
@@ -2702,6 +2648,8 @@ void KillTask(void)
|
|
system("killall Module_EvComm");
|
|
system("killall Module_EvComm");
|
|
system("killall Module_LcmControl");
|
|
system("killall Module_LcmControl");
|
|
system("killall Module_InternalComm");
|
|
system("killall Module_InternalComm");
|
|
|
|
+ system("killall Module_UpdateFW");
|
|
|
|
+ system("killall Module_ChkSysTask");
|
|
//system("killall Module_DoComm");
|
|
//system("killall Module_DoComm");
|
|
#if defined DD360 || defined DD360Audi || defined DD360ComBox
|
|
#if defined DD360 || defined DD360Audi || defined DD360ComBox
|
|
return ;
|
|
return ;
|
|
@@ -2738,6 +2686,8 @@ void KillAllTask(void)
|
|
system("killall Module_EvComm");
|
|
system("killall Module_EvComm");
|
|
system("killall Module_LcmControl");
|
|
system("killall Module_LcmControl");
|
|
system("killall Module_InternalComm");
|
|
system("killall Module_InternalComm");
|
|
|
|
+ system("killall Module_UpdateFW");
|
|
|
|
+ system("killall Module_ChkSysTask");
|
|
|
|
|
|
#if defined DD360 || defined DD360Audi || defined DD360ComBox
|
|
#if defined DD360 || defined DD360Audi || defined DD360ComBox
|
|
system("killall Module_DoComm");
|
|
system("killall Module_DoComm");
|
|
@@ -2849,8 +2799,8 @@ void CreateTimeoutFork(void)
|
|
pAlarmCode->AlarmEvents.bits.DisconnectedFromDo = ABNORMAL;
|
|
pAlarmCode->AlarmEvents.bits.DisconnectedFromDo = ABNORMAL;
|
|
log_error("Author timeout restart DoComm\r\n");
|
|
log_error("Author timeout restart DoComm\r\n");
|
|
system("killall Module_DoComm");
|
|
system("killall Module_DoComm");
|
|
- sleep(1);
|
|
|
|
- system("/root/Module_DoComm &");
|
|
|
|
|
|
+ //sleep(1);
|
|
|
|
+ //system("/root/Module_DoComm &");
|
|
}
|
|
}
|
|
}
|
|
}
|
|
break;
|
|
break;
|
|
@@ -2865,8 +2815,8 @@ void CreateTimeoutFork(void)
|
|
pAlarmCode->AlarmEvents.bits.DisconnectedFromDo = ABNORMAL;
|
|
pAlarmCode->AlarmEvents.bits.DisconnectedFromDo = ABNORMAL;
|
|
log_error("Author timeout restart DoComm\r\n");
|
|
log_error("Author timeout restart DoComm\r\n");
|
|
system("killall Module_DoComm");
|
|
system("killall Module_DoComm");
|
|
- sleep(1);
|
|
|
|
- system("/root/Module_DoComm &");
|
|
|
|
|
|
+ //sleep(1);
|
|
|
|
+ //system("/root/Module_DoComm &");
|
|
}
|
|
}
|
|
}
|
|
}
|
|
break;
|
|
break;
|
|
@@ -3431,7 +3381,7 @@ void StopProcessingLoop()
|
|
{
|
|
{
|
|
for (;;) {
|
|
for (;;) {
|
|
CheckFactoryConfigFunction();
|
|
CheckFactoryConfigFunction();
|
|
- CheckFwUpdateFunction();
|
|
|
|
|
|
+ //CheckFwUpdateFunction();
|
|
if (pSysWarning->Level == WARN_LV_ER) {
|
|
if (pSysWarning->Level == WARN_LV_ER) {
|
|
ChkPrimaryStatus();
|
|
ChkPrimaryStatus();
|
|
if (pSysWarning->Level == WARN_LV_NL) {
|
|
if (pSysWarning->Level == WARN_LV_NL) {
|
|
@@ -3792,13 +3742,29 @@ static void autoStartChargingForComBox(uint8_t gunIndex)
|
|
return ;
|
|
return ;
|
|
#endif //!defined DD360ComBox
|
|
#endif //!defined DD360ComBox
|
|
|
|
|
|
|
|
+ if ( (pSysInfo->SystemPage >= _LCM_AUTHORIZING && pSysInfo->SystemPage <= _LCM_AUTHORIZ_FAIL) ||
|
|
|
|
+ pDcChargingInfo->isVerify ) {
|
|
|
|
+ return;
|
|
|
|
+ }
|
|
pDcChargingInfo = (struct ChargingInfoData *)GetDcChargingInfoData(gunIndex);
|
|
pDcChargingInfo = (struct ChargingInfoData *)GetDcChargingInfoData(gunIndex);
|
|
|
|
|
|
if ((pDcChargingInfo->ConnectorPlugIn == YES) &&
|
|
if ((pDcChargingInfo->ConnectorPlugIn == YES) &&
|
|
(pDcChargingInfo->SystemStatus == S_IDLE)
|
|
(pDcChargingInfo->SystemStatus == S_IDLE)
|
|
) {
|
|
) {
|
|
- pSysInfo->CurGunSelected = gunIndex;
|
|
|
|
|
|
+
|
|
|
|
+#if VERIFY_EVCCID
|
|
|
|
+ if (!pDcChargingInfo->isVerify ) {
|
|
|
|
+ strcpy((char *)pSysConfig->UserId, (char *)pDcChargingInfo->EVCCID);
|
|
|
|
+ if( strcmp( (char *)pSysConfig->UserId , "" ) != EQUAL ) {
|
|
|
|
+ pDcChargingInfo->isVerify = true;
|
|
|
|
+ log_info("Get User(%d) ID:%s\n",gunIndex,pSysConfig->UserId);
|
|
|
|
+ pSysInfo->CurGunSelected = gunIndex;
|
|
|
|
+ pSysInfo->SystemPage = _LCM_AUTHORIZING;
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+#else
|
|
strcpy((char *)&pSysConfig->UserId, "AutoStartCharging");
|
|
strcpy((char *)&pSysConfig->UserId, "AutoStartCharging");
|
|
|
|
+#endif
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
|
|
@@ -4018,7 +3984,58 @@ static uint8_t distributionPsuModule(uint8_t *isRessign, uint8_t gunIndex)
|
|
|
|
|
|
return NO;
|
|
return NO;
|
|
}
|
|
}
|
|
|
|
+bool Taskconutstring(char *src, char *taskname)
|
|
|
|
+{
|
|
|
|
+ bool result = false;
|
|
|
|
+
|
|
|
|
+ if (src == NULL || strlen(src) == 0)
|
|
|
|
+ return result;
|
|
|
|
+
|
|
|
|
+ if (strstr(src, taskname) != NULL &&
|
|
|
|
+ strstr(src, "grep") == NULL &&
|
|
|
|
+ strstr(src, "[") == NULL)
|
|
|
|
+ {
|
|
|
|
+ result = true;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ return result;
|
|
|
|
+}
|
|
|
|
+
|
|
|
|
+int GetProcessCount(char *procName)
|
|
|
|
+{
|
|
|
|
+ int result = 0;
|
|
|
|
+ FILE *fp;
|
|
|
|
+ char cmd[256];
|
|
|
|
+ char buf[256];
|
|
|
|
+
|
|
|
|
+ sprintf(cmd, "ps -ef |grep %s", procName);
|
|
|
|
+ fp = popen(cmd, "r");
|
|
|
|
+ if(fp != NULL)
|
|
|
|
+ {
|
|
|
|
+ while(fgets(buf, sizeof(buf), fp) != NULL)
|
|
|
|
+ {
|
|
|
|
+ if (Taskconutstring(buf, procName))
|
|
|
|
+ result++;
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ pclose(fp);
|
|
|
|
|
|
|
|
+ return result;
|
|
|
|
+}
|
|
|
|
+void CheckTaskAlive()
|
|
|
|
+{
|
|
|
|
+ //log_info("Checking Task Alive\n");
|
|
|
|
+ unsigned char count = GetProcessCount("Module_ChkSysTask");
|
|
|
|
+ if( count != 1 ) {
|
|
|
|
+ system("killall Module_ChkSysTask");
|
|
|
|
+ sleep(3);
|
|
|
|
+ system("/root/Module_ChkSysTask");
|
|
|
|
+ log_info("System task lost (Check System Task) \n");
|
|
|
|
+ //ShmStatusCodeData->AlarmCode.AlarmEvents.bits.SystemTaskLost = YES;
|
|
|
|
+ } //else
|
|
|
|
+ //ShmStatusCodeData->AlarmCode.AlarmEvents.bits.SystemTaskLost = NO;
|
|
|
|
+}
|
|
/**
|
|
/**
|
|
* [checkPileEndGfdResult 確認充電樁GFD狀態]
|
|
* [checkPileEndGfdResult 確認充電樁GFD狀態]
|
|
* @Author Jerry
|
|
* @Author Jerry
|
|
@@ -4363,11 +4380,14 @@ int main(void)
|
|
|
|
|
|
//signal(SIGCHLD,SIG_IGN);
|
|
//signal(SIGCHLD,SIG_IGN);
|
|
|
|
|
|
- CreateCheckSystemTaskFork();
|
|
|
|
|
|
+ //CreateCheckSystemTaskFork();
|
|
|
|
|
|
CreateWatchdog();
|
|
CreateWatchdog();
|
|
|
|
|
|
for (;;) {
|
|
for (;;) {
|
|
|
|
+
|
|
|
|
+ CheckTaskAlive();
|
|
|
|
+
|
|
CheckOcppStatus();
|
|
CheckOcppStatus();
|
|
|
|
|
|
ChkPrimaryStatus();
|
|
ChkPrimaryStatus();
|
|
@@ -4378,7 +4398,7 @@ int main(void)
|
|
) {
|
|
) {
|
|
CheckFactoryConfigFunction();
|
|
CheckFactoryConfigFunction();
|
|
|
|
|
|
- CheckFwUpdateFunction();
|
|
|
|
|
|
+ //CheckFwUpdateFunction();
|
|
}
|
|
}
|
|
|
|
|
|
// OCPP 邏輯
|
|
// OCPP 邏輯
|
|
@@ -5094,6 +5114,9 @@ int main(void)
|
|
GetTimeoutValue(pDcChargingInfo->TimeoutTimer) >= 10000000) {
|
|
GetTimeoutValue(pDcChargingInfo->TimeoutTimer) >= 10000000) {
|
|
setChargerMode(gunIndex, MODE_IDLE);
|
|
setChargerMode(gunIndex, MODE_IDLE);
|
|
destroySelGun(gunIndex); //Jerry add
|
|
destroySelGun(gunIndex); //Jerry add
|
|
|
|
+#ifdef DD360 || DD3660ComBox
|
|
|
|
+ pSysInfo->SystemPage = _LCM_IDLE;
|
|
|
|
+#endif
|
|
}
|
|
}
|
|
|
|
|
|
if (pSysInfo->CurGunSelected == gunIndex) {
|
|
if (pSysInfo->CurGunSelected == gunIndex) {
|