/* * Main.c * * Created on: 2019年8月6日 * Author: 7564 */ #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include /*標準輸入輸出定義*/ #include /*標準函數庫定義*/ #include /*Unix 標準函數定義*/ #include /*檔控制定義*/ #include /*PPSIX 終端控制定義*/ #include /*錯誤號定義*/ #include #include #include #include #include #include #include #include "../../define.h" typedef unsigned char byte; #define PASS 1 #define FAIL -1 #define EQUAL 0 #define ARRAY_SIZE(A) (sizeof(A) / sizeof(A[0])) #define NO_DEFINE 255 #define DEFAULT_AC_INDEX 2 #define AUTORUN_STEP1_TIME_START 140 // Minutes #define AUTORUN_STEP1_TIME_END 150 #define AUTORUN_STEP2_TIME_START 210 #define AUTORUN_STEP2_TIME_END 410 #define AUTORUN_END_TIME 480 #define AUTORUN_CYCLE_COUNT 30 #define TTY_PATH "/dev/tty" #define STTY_US "stty raw -echo -F " #define STTY_DEF "stty -raw echo -F " byte _curAutoRunCount = 0; byte _usingAutoRun = 0; struct timeval _autoTime; struct SysConfigAndInfo *ShmSysConfigAndInfo; struct StatusCodeData *ShmStatusCodeData; struct PrimaryMcuData *ShmPrimaryMcuData; struct CHAdeMOData *ShmCHAdeMOData; struct CcsData *ShmCcsData; struct GBTData *ShmGBTData; struct FanModuleData *ShmFanModuleData; struct RelayModuleData *ShmRelayModuleData; struct LedModuleData *ShmLedModuleData; struct PsuData *ShmPsuData; struct ChargingInfoData *_chargingData[CHAdeMO_QUANTITY + CCS_QUANTITY + GB_QUANTITY]; struct ChargingInfoData *ac_chargingInfo[AC_QUANTITY]; char *msg = "\n" "state : get/set gun state (index)\n" " Example:\n" " state ac , get AC status, AC not support set command.\n" " state 0 , get DC connector 1 status\n" " state 1 , get DC connector 2 status\n" " state 0 0 , set DC connector 1 to state 0\n" " state 1 5 , set DC connector 2 to state 5\n" "\n" "card : swiping card simulation (card number), if parameter 1 is empty, means execute\n" " virtual swiping action \n" " Example:\n" " card , virtual swiping card (start or stop charging).\n" " card abcdef , write virtual card ID 'abcdef'.\n" "\n" "gun : get gun plugit state (index) \n" " Example:\n" " gun ac , get AC connector/socket plug status\n" " gun ac 1 , set AC connector/socket plug status to pluged\n" " gun ac 0 , set AC connector/socket plug status to unpluged\n" " gun 0 , get DC connector 1 plug status\n" " gun 0 1 , set DC connector 1 plug status to pluged\n" " gun 1 0 , set DC connector 2 plug status to unpluged\n" "\n" "lock : get gun locked state (index) \n" " Example:\n" " lock 0 , get DC connector 1 lock status\n" " lock 0 1 , set DC connector 1 lock status to locked\n" " lock 1 0 , set DC connector 2 lock status to unlocked\n" "\n" "self : self test state (x) \n" " Example:\n" " self , get present self status\n" "\n" "ver : ver of board (407 or index or rb or fan) \n" " Example:\n" " ver 0 , get firmware version of DC connector 1's EV board\n" " ver 1 , get firmware version of DC connector 2's EV board\n" " ver 407 , get firmware version of stm32f407 in DC main board\n" " ver rb , get firmware version of relay board\n" " ver fan , get firmware version of fan board\n" " ver dc , get firmware version of am3352 in DC main board\n" " ver led , get firmware version of LED board\n" " ver ac , get firmware version of AC charger\n" "\n" "ac : get ac contactor state (x) \n" " Example:\n" " ac , get AC contactor status (1 is close, 0 is open)\n" "\n" "cable : set cable check (IMD) result, 1: pass, 2: failed, 3: warning\n" " Example:\n" " cable 0 1 , set DC connector 1 IMD result to pass\n" " cable 1 2 , set DC connector 2 IMD result to failed\n" "\n" "pow : set target charging current, only for force charging use!!!\n" " Example:\n" " pow 20 , set target charging current to 20 A \n" " pow 10.5 , set target charging current to 10.5 A\n" "\n" "model : get model name, serial number and misc system information\n" " Example:\n" " model , get information\n" "\n" "select : get/set present selected connector\n" " Example:\n" " select , get present select connector number\n" " select 0 , set present select connector to connector 1\n" " select 1 , set present select connector to connector 2\n" "\n" "change : vitural gun select button press\n" " Example:\n" " change , simulate the gun select button pressed\n" "\n" "fan : set fan speed\n" " Example:\n" " fan 3000 , set fan speed to 3000 rpm\n" " fan 14000 , set fan speed to 14000 rpm\n" "\n" "speed : get fan speed\n" " Example:\n" " speed , get present fan speed\n" "\n" "debug : set debug mode\n" " Example:\n" " debug 1 , enable debug mode, print debug log to console\n" " debug 0 , disable debug mode, print debug log to log file\n" "\n" "gfd : set gfd(IMD) enable/disable in force charging\n" " Example:\n" " gfd 1 , enable IMD test in force charging mode\n" " gfd 0 , disable IMD test in force charging mode\n" "\n" "temp : get temperature from PSU\n" " Example:\n" " temp , display the present temperature of PSU\n" "\n" "acin : get 3 phase voltage of AC input\n" " Example:\n" " acin , display R(L1) S(L2) T(L3) voltage\n" "\n" "psu : get psu information and psu test command\n" " Example:\n" " psu count , display present PSU quantity\n" " psu ver , display primary and secondly firmware version of all PSU\n" " psu cap , display available current and power of all PSU group\n" " psu input , display 3 phase voltage of AC input which sensing by PSU\n" " psu output , display present DC output voltage and current of all PSU group\n" " psu test 1 , enable PSU test mode, for D to D and PFC firmware version 9.06 up\n" " after PSU test finish, please reboot charger to exit PSU test mode\n" " psu out 500 5 , need enable mode first, command PSU output 500V and 5A\n" " psu out 200.5 7.5 , need enable mode first, command PSU output 200.5V and 7.5A\n" "\n" "cap : get maximum output capacities\n" " Example:\n" " cap 0 , get initial and real maximum output power, voltage and current of connector 1\n" " cap 1 , get initial and real maximum output power, voltage and current of connector 2\n" "\n" "error : triggering error event\n" " Example:\n" " error 1 , virtual trigging L1 input OVP\n" " error 0 , cancel trigging L1 input OVP\n" "\n" "auth : setup authorize flag, it is for charging permission\n" " Example:\n" " auth 1 , setup authorize flag to vaild\n" "\n" "relay : get present output and pre-charge relay status\n" " Example:\n" " relay 0 , get present output relay status of connector 1\n" " relay 1 , get present output relay status of connector 2\n" "\n" "ccid : set EVCC ID\n" " Example:\n" " ccid 0 1a2b3c4d , setup EVCC ID '1a2b3c4d' to connector 1\n" " ccid 1 qwerasdf , setup EVCC ID 'qwerasdf' to connector 2\n" "\n" "strchg : command charger to start force charging procedure\n" " 1st parameter for select using connector\n" " 2nd parameter for command output voltage, range: 150V~1000V\n" " 3th parameter for command output current, range: 2A~100A\n" " Example:\n" " strchg 0 200 2 , command force charging output 200V and 2A from connector 1\n" " strchg 1 450.5 10.5 , command force charging output 450.5V and 10.5A from connector 2\n" ; bool FindChargingInfoData(byte target, struct ChargingInfoData **chargingData) { for (byte index = 0; index < CHAdeMO_QUANTITY; index++) { if (ShmSysConfigAndInfo->SysInfo.ChademoChargingData[index].Index == target) { chargingData[target] = &ShmSysConfigAndInfo->SysInfo.ChademoChargingData[index]; return true; } } for (byte index = 0; index < CCS_QUANTITY; index++) { if (ShmSysConfigAndInfo->SysInfo.CcsChargingData[index].Index == target) { chargingData[target] = &ShmSysConfigAndInfo->SysInfo.CcsChargingData[index]; return true; } } for (byte index = 0; index < GB_QUANTITY; index++) { if (ShmSysConfigAndInfo->SysInfo.GbChargingData[index].Index == target) { chargingData[target] = &ShmSysConfigAndInfo->SysInfo.GbChargingData[index]; return true; } } return false; } bool FindAcChargingInfoData(byte target, struct ChargingInfoData **acChargingData) { if (target < AC_QUANTITY) { acChargingData[target] = &ShmSysConfigAndInfo->SysInfo.AcChargingData[target]; return true; } return false; } int InitShareMemory() { int result = PASS; int MeterSMId; //initial ShmSysConfigAndInfo if ((MeterSMId = shmget(ShmSysConfigAndInfoKey, sizeof(struct SysConfigAndInfo), 0777)) < 0) { result = FAIL; } else if ((ShmSysConfigAndInfo = shmat(MeterSMId, NULL, 0)) == (void *) -1) { result = FAIL; } else {} //initial ShmStatusCodeData if ((MeterSMId = shmget(ShmStatusCodeKey, sizeof(struct StatusCodeData), 0777)) < 0) { result = FAIL; } else if ((ShmStatusCodeData = shmat(MeterSMId, NULL, 0)) == (void *) -1) { result = FAIL; } else {} if (CHAdeMO_QUANTITY > 0) { if ((MeterSMId = shmget(ShmCHAdeMOCommKey, sizeof(struct CHAdeMOData), IPC_CREAT | 0777)) < 0) { result = FAIL; } else if ((ShmCHAdeMOData = shmat(MeterSMId, NULL, 0)) == (void *) -1) { result = FAIL; } else { //NULL } } if (CCS_QUANTITY > 0) { if ((MeterSMId = shmget(ShmCcsCommKey, sizeof(struct CcsData), IPC_CREAT | 0777)) < 0) { result = FAIL; } else if ((ShmCcsData = shmat(MeterSMId, NULL, 0)) == (void *) -1) { result = FAIL; } else { //NULL } } if (GB_QUANTITY > 0) { if ((MeterSMId = shmget(ShmGBTCommKey, sizeof(struct GBTData), IPC_CREAT | 0777)) < 0) { return 0; } else if ((ShmGBTData = shmat(MeterSMId, NULL, 0)) == (void *) -1) { return 0; } memset(ShmGBTData, 0, sizeof(struct GBTData)); } if ((MeterSMId = shmget(ShmPrimaryMcuKey, sizeof(struct PrimaryMcuData), IPC_CREAT | 0777)) < 0) { result = FAIL; } else if ((ShmPrimaryMcuData = shmat(MeterSMId, NULL, 0)) == (void *) -1) { result = FAIL; } if ((MeterSMId = shmget(ShmFanBdKey, sizeof(struct FanModuleData), IPC_CREAT | 0777)) < 0) { result = FAIL; } else if ((ShmFanModuleData = shmat(MeterSMId, NULL, 0)) == (void *) -1) { result = FAIL; } if ((MeterSMId = shmget(ShmRelayBdKey, sizeof(struct RelayModuleData), IPC_CREAT | 0777)) < 0) { result = FAIL; } else if ((ShmRelayModuleData = shmat(MeterSMId, NULL, 0)) == (void *) -1) { result = FAIL; } if ((MeterSMId = shmget(ShmLedBdKey, sizeof(struct LedModuleData), 0777)) < 0) { result = FAIL; } else if ((ShmLedModuleData = shmat(MeterSMId, NULL, 0)) == (void *) -1) { result = FAIL; } if ((MeterSMId = shmget(ShmPsuKey, sizeof(struct PsuData), IPC_CREAT | 0777)) < 0) { result = FAIL; } else if ((ShmPsuData = shmat(MeterSMId, NULL, 0)) == (void *) -1) { result = FAIL; } return result; } unsigned long GetTimeoutValue(struct timeval _sour_time) { struct timeval _end_time; gettimeofday(&_end_time, NULL); return (_end_time.tv_sec - _sour_time.tv_sec); } void RunStatusProc(char *v1, char *v2) { printf("OrderCharging = %d \n", ShmSysConfigAndInfo->SysInfo.OrderCharging); printf("WaitForPlugit = %d \n", ShmSysConfigAndInfo->SysInfo.WaitForPlugit); if (strcmp(v1, "ac") == 0) { if (!FindAcChargingInfoData(0, &ac_chargingInfo[0])) { printf("FindChargingInfoData (AC) false \n"); } printf("AC Status = %d \n", ac_chargingInfo[0]->ConnectorPlugIn); return; } int _index = atoi(v1); if (_index <= 1) { if (!FindChargingInfoData(_index, &_chargingData[0])) { printf ("FindChargingInfoData error\n"); return; } if (strcmp(v2, "-1") == 0 || strcmp(v2, "") == 0) { // get printf ("index = %x, status = %x (%d)\n", _index, _chargingData[_index]->SystemStatus, _chargingData[_index]->IsAvailable); printf ("SystemTimeoutFlag = %d, PageIndex = %d\n", ShmSysConfigAndInfo->SysInfo.SystemTimeoutFlag, ShmSysConfigAndInfo->SysInfo.PageIndex); } else { // set _chargingData[_index]->SystemStatus = atoi(v2); } } else { if (!FindAcChargingInfoData(0, &ac_chargingInfo[0])) { printf("FindChargingInfoData (AC) false \n"); } if (strcmp(v2, "-1") == 0 || strcmp(v2, "") == 0) { // get printf ("AC Type, status = %x (%d)\n", ac_chargingInfo[0]->SystemStatus, ac_chargingInfo[0]->IsAvailable); } else { // set ac_chargingInfo[0]->SystemStatus = atoi(v2); } } } void RunCardProc(char *v1, char *v2) { if (strcmp(v1, "-1") == 0 || strcmp(v1, "") == 0) { if (ShmSysConfigAndInfo->SysInfo.WaitForPlugit) { ShmSysConfigAndInfo->SysInfo.WaitForPlugit = 0x00; printf ("SysInfo.WaitForPlugit = %x \n", ShmSysConfigAndInfo->SysInfo.WaitForPlugit); } else { ShmSysConfigAndInfo->SysInfo.WaitForPlugit = 0x01; printf ("SysInfo.WaitForPlugit = %x \n", ShmSysConfigAndInfo->SysInfo.WaitForPlugit); } } else { strcpy((char *)ShmSysConfigAndInfo->SysConfig.UserId, ""); memcpy((char *)ShmSysConfigAndInfo->SysConfig.UserId, v1, strlen(v1)); ShmSysConfigAndInfo->SysConfig.UserId[strlen(v1)] = '\0'; printf("StartUserId = %s \n", ShmSysConfigAndInfo->SysConfig.UserId); } } void RunGunPlugitProc(char *v1, char *v2) { if (strcmp(v1, "ac") == 0) { if (!FindAcChargingInfoData(0, &ac_chargingInfo[0])) { printf("FindChargingInfoData (AC) false \n"); } if (strcmp(v2, "-1") == 0 || strcmp(v2, "") == 0) { // get printf("ConnectorPlugIn = %d \n", ac_chargingInfo[0]->ConnectorPlugIn); } else { // set ac_chargingInfo[0]->ConnectorPlugIn = atoi(v2); } return; } int _index = atoi(v1); if (!FindChargingInfoData(_index, &_chargingData[0])) { printf("FindChargingInfoData error\n"); return; } if (strcmp(v2, "-1") == 0 || strcmp(v2, "") == 0) { // get printf("index = %x, plug it = %x\n", _index, _chargingData[_index]->ConnectorPlugIn); } else { // set _chargingData[_index]->ConnectorPlugIn = atoi(v2); } } void GetGunLockStatusProc(char *v1, char *v2) { int _index = atoi(v1); if (!FindChargingInfoData(_index, &_chargingData[0])) { printf("FindChargingInfoData error\n"); return; } if (strcmp(v2, "-1") != 0 && strcmp(v2, "") != 0) { _chargingData[_index]->GunLocked = atoi(v2); } printf("Gun Locked Status = %d \n", _chargingData[_index]->GunLocked); } void SetSystemIDProc() { char *systemId = "Alston_Test"; memcpy(&ShmSysConfigAndInfo->SysConfig.SystemId, systemId, strlen(systemId)); } void RunSelfProc() { printf("self test status = %x\n", ShmSysConfigAndInfo->SysInfo.SelfTestSeq); } void GetFwVerProc(char *v1) { if (strcmp(v1, "407") == 0) { printf("407 FW Version = %s \n", ShmPrimaryMcuData->version); } else if (strcmp(v1, "0") == 0 || strcmp(v1, "1") == 0) { int _index = atoi(v1); if (_index == 0) printf("Gun 0 FW Version = %s \n", ShmSysConfigAndInfo->SysInfo.Connector1FwRev); else if (_index == 1) printf("Gun 1 FW Version = %s \n", ShmSysConfigAndInfo->SysInfo.Connector2FwRev); } else if (strcmp(v1, "rb") == 0) { printf("RB Version = %s \n", ShmSysConfigAndInfo->SysInfo.RelayModuleFwRev); } else if (strcmp(v1, "fan") == 0) { printf("FAN Version = %s \n", ShmSysConfigAndInfo->SysInfo.FanModuleFwRev); } else if (strcmp(v1, "dc") == 0) { printf("DC Main Version = %s \n", ShmSysConfigAndInfo->SysInfo.CsuRootFsFwRev); } else if (strcmp(v1, "led") == 0) { printf("LED Version = %s \n", ShmSysConfigAndInfo->SysInfo.LedModuleFwRev); } else if (strcmp(v1, "ac") == 0) { if (!FindAcChargingInfoData(0, &ac_chargingInfo[0])) { printf("FindChargingInfoData (AC) false \n"); } printf("AC Version = %s \n", ac_chargingInfo[0]->version); } } void CreateOneError(char *v1) { int value = atoi(v1); ShmStatusCodeData->AlarmCode.AlarmEvents.bits.SystemL1InputOVP = value; ShmSysConfigAndInfo->SysConfig.BillingData.isBilling = value; } void GetAuthorizeFlag(char *v1) { if (strcmp(v1, "-1") == 0|| strcmp(v1, "") == 0) printf("AuthorizeFlag = %d \n", ShmSysConfigAndInfo->SysInfo.AuthorizeFlag); else ShmSysConfigAndInfo->SysInfo.AuthorizeFlag = atoi(v1); } void GetRelayStatus(char *v1) { int _index = atoi(v1); if (!FindChargingInfoData(_index, &_chargingData[0])) { printf("FindChargingInfoData error\n"); return; } printf("RelayK1K2Status = %d \n", _chargingData[_index]->RelayK1K2Status); printf("RelayKPK2Status = %d \n", _chargingData[_index]->RelayKPK2Status); } void FwUpdateFlagProc() { ShmSysConfigAndInfo->SysInfo.FirmwareUpdate = 0x01; } void CheckAcStatus(char *v1) { if (strcmp(v1, "-1") == 0|| strcmp(v1, "") == 0) { printf("AC Status = %d \n", ShmSysConfigAndInfo->SysInfo.AcContactorStatus); } } void SetCableChkStatus(char *v1, char *v2) { int _index = atoi(v1); if (!FindChargingInfoData(_index, &_chargingData[0])) { printf ("FindChargingInfoData error\n"); return; } _chargingData[_index]->GroundFaultStatus = atoi(v2); } void SetChargingInfoCCID(char *v1, char* v2) { int _index = atoi(v1); if (!FindChargingInfoData(_index, &_chargingData[0])) { printf ("FindChargingInfoData error\n"); return; } memcpy(_chargingData[_index]->EVCCID, v2, 8); _chargingData[_index]->EVCCID[8] = '\0'; } void SetPowerValue(char *v1, char *v2) { int _index = atoi(v1); float _Current = atof(v2); // 盲沖的時候才允許使用~ if (_chargingData[_index]->Type != 9) return; if (!FindChargingInfoData(_index, &_chargingData[0])) { printf ("FindChargingInfoData error\n"); return; } _chargingData[_index]->EvBatterytargetCurrent = _Current; } void GetSystemInfo() { printf ("ModelName = %s \n", ShmSysConfigAndInfo->SysConfig.ModelName); printf ("SerialNumber = %s \n", ShmSysConfigAndInfo->SysConfig.SerialNumber); printf ("InternetConn = %d \n", ShmSysConfigAndInfo->SysInfo.InternetConn); printf ("MaxChargingPower = %d, MaxChargingCurrent = %d \n", ShmSysConfigAndInfo->SysConfig.MaxChargingPower, ShmSysConfigAndInfo->SysConfig.MaxChargingCurrent); } void ChangeGunNum() { if (ShmSysConfigAndInfo->SysInfo.CurGunSelected + 1 < ShmSysConfigAndInfo->SysConfig.TotalConnectorCount) { ShmSysConfigAndInfo->SysInfo.CurGunSelected += 1; ShmSysConfigAndInfo->SysInfo.CurGunSelectedByAc = NO_DEFINE; } else if (ShmSysConfigAndInfo->SysConfig.AcConnectorCount > 0 && ShmSysConfigAndInfo->SysInfo.CurGunSelectedByAc == NO_DEFINE) ShmSysConfigAndInfo->SysInfo.CurGunSelectedByAc = DEFAULT_AC_INDEX; else { ShmSysConfigAndInfo->SysInfo.CurGunSelected = 0; ShmSysConfigAndInfo->SysInfo.CurGunSelectedByAc = NO_DEFINE; } } void GetGunSelectedNum(char *v1) { if (strcmp(v1, "-1") == 0 || strcmp(v1, "") == 0) { if (AC_QUANTITY > 0 && ShmSysConfigAndInfo->SysInfo.CurGunSelectedByAc != NO_DEFINE) { printf("connector select changed = AC \n"); } else printf("connector selected = %d \n", ShmSysConfigAndInfo->SysInfo.CurGunSelected); } else { int _index = atoi(v1); if (_index <= 1) { ShmSysConfigAndInfo->SysInfo.CurGunSelected = _index; ShmSysConfigAndInfo->SysInfo.CurGunSelectedByAc = NO_DEFINE; printf("connector select changed = %d \n", _index); } else if (AC_QUANTITY > 0) { ShmSysConfigAndInfo->SysInfo.CurGunSelectedByAc = DEFAULT_AC_INDEX; printf("connector select changed = AC \n"); } } } void SetFanSpeed(char *v1) { int speed = atoi(v1); ShmFanModuleData->TestFanSpeed = speed; } void GetFanSpeed() { printf("ShmFanModuleData->PresentFan1Speed = %d \n", ShmFanModuleData->PresentFan1Speed); printf("ShmFanModuleData->PresentFan2Speed = %d \n", ShmFanModuleData->PresentFan2Speed); printf("ShmFanModuleData->PresentFan3Speed = %d \n", ShmFanModuleData->PresentFan3Speed); printf("ShmFanModuleData->PresentFan4Speed = %d \n", ShmFanModuleData->PresentFan4Speed); } void SetDebugMode(char *v1) { int mode = atoi(v1); ShmSysConfigAndInfo->SysConfig.SwitchDebugFlag = mode; } void SetGFDMode(char *v1) { int mode = atoi(v1); ShmSysConfigAndInfo->SysConfig.AlwaysGfdFlag = mode; } void GetPsuTemp() { for (byte index = 0; index < ShmPsuData->GroupCount; index++) { for (byte count = 0; count < ShmPsuData->PsuGroup[index].GroupPresentPsuQuantity; count++) { printf("PSU Temp = %d \n", ShmPsuData->PsuGroup[index].PsuModule[count].ExletTemp); } } } void GetAcInputVol() { printf("L1N_L12 = %f, L2N_L23 = %f, L3N_L31 = %f \n", ShmSysConfigAndInfo->SysInfo.InputVoltageR, ShmSysConfigAndInfo->SysInfo.InputVoltageS, ShmSysConfigAndInfo->SysInfo.InputVoltageT); } void GetPsuInformation(char *v1, char *v2, char *v3) { printf("**********************AC Contact needed*************************\n"); if(strcmp(v1, "count") == 0) { for (int i = 0; i < 4; i++) { printf("Group Index = %d, Module Count = %d \n", i, ShmPsuData->PsuGroup[i].GroupPresentPsuQuantity); } } else if(strcmp(v1, "ver") == 0) { for (int i = 0; i < ShmPsuData->SystemPresentPsuQuantity; i++) { printf("Psu Index = %d, PriVersion = %s, SecVersion = %s \n", i, ShmPsuData->PsuVersion[i].FwPrimaryVersion, ShmPsuData->PsuVersion[i].FwSecondVersion); } for (int i = 0; i < ShmPsuData->GroupCount; i++) { for (int j = 0; j < ShmPsuData->PsuGroup[i].GroupPresentPsuQuantity; j++) { printf("Group Index = %d, Psu Index = %d, Version = %s \n", i, j, ShmPsuData->PsuGroup[i].PsuModule[j].FwVersion); } } } else if(strcmp(v1, "cap") == 0) { for (int i = 0; i < ShmPsuData->GroupCount; i++) { printf("Group Index = %d, MaxCur = %d, Power = %d \n", i, ShmPsuData->PsuGroup[i].GroupAvailableCurrent, ShmPsuData->PsuGroup[i].GroupAvailablePower); } } else if(strcmp(v1, "input") == 0) { for (int i = 0; i < ShmPsuData->GroupCount; i++) { for (byte count = 0; count < ShmPsuData->PsuGroup[i].GroupPresentPsuQuantity; count++) { printf("gp = %d, Index = %d, volR = %d, volS = %d, volT = %d \n", i, count, ShmPsuData->PsuGroup[i].PsuModule[count].InputVoltageL1, ShmPsuData->PsuGroup[i].PsuModule[count].InputVoltageL2, ShmPsuData->PsuGroup[i].PsuModule[count].InputVoltageL3); } } } else if (strcmp(v1, "output") == 0) { for (int i = 0; i < ShmPsuData->GroupCount; i++) { printf("Group Index = %d, OutputV = %d, OutputC = %d \n", i, ShmPsuData->PsuGroup[i].GroupPresentOutputVoltage, ShmPsuData->PsuGroup[i].GroupPresentOutputCurrent); } for (int i = 0; i < ShmSysConfigAndInfo->SysConfig.TotalConnectorCount; i++) { if (!FindChargingInfoData(i, &_chargingData[0])) { printf ("FindChargingInfoData error\n"); continue; } printf("Form RB : Group Index = %d, OutputV = %f \n", i, _chargingData[i]->FireChargingVoltage); } } else if (strcmp(v1, "test") == 0) { int mode = atoi(v2); if (mode >= _TEST_MODE && mode <= _TEST_MODE) { ShmPsuData->Work_Step = mode; } } else if (strcmp(v1, "out") == 0) { float vol = atof(v2); float cur = atof(v3); if (ShmPsuData->Work_Step >= _TEST_MODE && ShmPsuData->Work_Step <= _TEST_MODE) { if (!FindChargingInfoData(0, &_chargingData[0])) { printf ("FindChargingInfoData error\n"); return; } _chargingData[0]->EvBatterytargetVoltage = vol; _chargingData[0]->EvBatterytargetCurrent = cur; } } printf("*************************************************\n"); } void GetConnectorCapInfo(char *v1) { int _GunIndex = atoi(v1); if (!FindChargingInfoData(_GunIndex, &_chargingData[0])) { printf ("FindChargingInfoData error\n"); return; } printf ("Charger Max Current = %d, Max Power = %d \n", ShmSysConfigAndInfo->SysConfig.MaxChargingCurrent * 10, ShmSysConfigAndInfo->SysConfig.MaxChargingPower * 10); printf ("Index = %d, MaxPow = %f, MaxVol = %f, MaxCur = %f\n", _GunIndex, _chargingData[_GunIndex]->RealMaxPower, _chargingData[_GunIndex]->RealMaxVoltage, _chargingData[_GunIndex]->RealMaxCurrent); } static void get_char(char *word) { fd_set rfds; struct timeval tv; FD_ZERO(&rfds); FD_SET(0, &rfds); tv.tv_sec = 0; tv.tv_usec = 10; //wait input timout time //if input if (select(1, &rfds, NULL, NULL, &tv) > 0) { fgets(word, 128, stdin); } } void RunUnconditionalChargeIndex1(char *v1, char *v2, char *v3) { int _GunIndex; float _Voltage; float _Current; if (strcmp(v1, "auto") == EQUAL) { _usingAutoRun = 0x01; _GunIndex = 0; _Voltage = 500; _Current = (ShmSysConfigAndInfo->SysConfig.MaxChargingPower * 1000) / _Voltage; } else { _usingAutoRun = 0x00; _GunIndex = atoi(v1); _Voltage = atof(v2); _Current = atof(v3); } unsigned char PreviousSystemStatus = 0xff; if (!FindChargingInfoData(_GunIndex, &_chargingData[0])) { printf ("FindChargingInfoData error\n"); return; } printf ("Power = %d, ReqVoltage = %f, ReqCurrent = %f\n", ShmSysConfigAndInfo->SysConfig.MaxChargingPower, _Voltage, _Current); if(_Voltage > 1000 || _Voltage < 50) { printf ("Input Voltage over range\n"); return; } // if(_Current > 100 || _Current < 2){ // // printf ("Input Current over range\n"); // return; // } //測試期間先跳過自我測試 _STEST_COMPLETE = 0xfe //ShmSysConfigAndInfo->SysInfo.SelfTestSeq = 0xfe; //kill ev task system("killall Module_EvComm"); //_Voltage = (_Voltage * 10); //_Current = (_Current * 10); //system(STTY_US TTY_PATH); while(true) { //fix gun 1 ShmSysConfigAndInfo->SysInfo.CurGunSelected = _GunIndex; switch(_chargingData[ShmSysConfigAndInfo->SysInfo.CurGunSelected]->SystemStatus) { case S_IDLE: { if(PreviousSystemStatus != _chargingData[ShmSysConfigAndInfo->SysInfo.CurGunSelected]->SystemStatus) { PreviousSystemStatus = _chargingData[ShmSysConfigAndInfo->SysInfo.CurGunSelected]->SystemStatus; printf ("[UnconditionalCharge - S_IDLE]\n"); } ShmSysConfigAndInfo->SysInfo.StartToChargingFlag = 0x01; _chargingData[ShmSysConfigAndInfo->SysInfo.CurGunSelected]->SystemStatus = S_PREPARNING; } break; case S_PREPARNING: { if(PreviousSystemStatus != _chargingData[ShmSysConfigAndInfo->SysInfo.CurGunSelected]->SystemStatus) { PreviousSystemStatus = _chargingData[ShmSysConfigAndInfo->SysInfo.CurGunSelected]->SystemStatus; printf ("[UnconditionalCharge - S_PREPARNIN]\n"); //等待 AC Relay 搭上且找到模組 (main 在此 statue 其它 task 會去做完) printf ("wait find module\n"); } //main 會在此階段判斷以下資料跳到下一個 state //用來得知 AC 是否有搭上 (搭上模組的資訊才會出來) 因為每次 AC_Contactor //ShmPsuData->SystemPresentPsuQuantity; //ShmPsuData->PsuGroup[gun_index].GroupPresentPsuQuantity; //ShmPsuData->PsuGroup[gun_index].GroupAvailablePower; //_chargingData[gun_index]->AvailableChargingPower; //等待 AC Relay 搭上且找到模組 (main 在此 statue 其它 task 會去做完) //sleep(10); //清除 main timeout 機制 _chargingData[ShmSysConfigAndInfo->SysInfo.CurGunSelected]->TimeoutFlag = 0; //不論是什麼 type 的槍都固意設成 Chademo 不跑 Prechage step _chargingData[ShmSysConfigAndInfo->SysInfo.CurGunSelected]->Type = 9; } break; case S_PREPARING_FOR_EV: { if(PreviousSystemStatus != _chargingData[ShmSysConfigAndInfo->SysInfo.CurGunSelected]->SystemStatus) { PreviousSystemStatus = _chargingData[ShmSysConfigAndInfo->SysInfo.CurGunSelected]->SystemStatus; printf ("[UnconditionalCharge - S_PREPARING_FOR_EV]\n"); printf ("ReqVoltage = %f, ReqCurrent = %f \n", _Voltage * 10,_Current * 10); } //清除 main timeout 機制 _chargingData[ShmSysConfigAndInfo->SysInfo.CurGunSelected]->TimeoutFlag = 0; //不論是什麼 type 的槍都固意設成 Chademo 不跑 Prechage step _chargingData[ShmSysConfigAndInfo->SysInfo.CurGunSelected]->Type = 9; //充電電壓電流 _chargingData[ShmSysConfigAndInfo->SysInfo.CurGunSelected]->EvBatterySoc = 50; _chargingData[ShmSysConfigAndInfo->SysInfo.CurGunSelected]->EvBatterytargetVoltage = 500; _chargingData[ShmSysConfigAndInfo->SysInfo.CurGunSelected]->EvBatterytargetCurrent = 2; _chargingData[ShmSysConfigAndInfo->SysInfo.CurGunSelected]->AvailableChargingCurrent = 1000; //****** 注意~此行為是防止 K1K2 先開導到無法升壓 ( Relay Board 在此 state 還未搭上 K1K2 ) //確定模組己升壓完成 //if(_chargingData[ShmSysConfigAndInfo->SysInfo.CurGunSelected]->PresentChargingVoltage <= (3000+500) && // _chargingData[ShmSysConfigAndInfo->SysInfo.CurGunSelected]->PresentChargingVoltage >= (3000-500) ) { printf ("Precharge Done = %f \n", _chargingData[ShmSysConfigAndInfo->SysInfo.CurGunSelected]->PresentChargingVoltage); //EV done _chargingData[ShmSysConfigAndInfo->SysInfo.CurGunSelected]->SystemStatus = S_PREPARING_FOR_EVSE; } } break; case S_PREPARING_FOR_EVSE: { if(PreviousSystemStatus != _chargingData[ShmSysConfigAndInfo->SysInfo.CurGunSelected]->SystemStatus) { PreviousSystemStatus = _chargingData[ShmSysConfigAndInfo->SysInfo.CurGunSelected]->SystemStatus; printf ("[UnconditionalCharge - S_PREPARING_FOR_EVSE]\n"); } //printf ("tar vol = %d \n", _Voltage); //printf ("tar cur = %d \n", _Current); //清除 main timeout 機制 _chargingData[ShmSysConfigAndInfo->SysInfo.CurGunSelected]->TimeoutFlag = 0; //不論是什麼 type 的槍都固意設成 Chademo 不跑 Prechage step _chargingData[ShmSysConfigAndInfo->SysInfo.CurGunSelected]->Type = 9; //充電電壓電流 _chargingData[ShmSysConfigAndInfo->SysInfo.CurGunSelected]->EvBatterySoc = 50; _chargingData[ShmSysConfigAndInfo->SysInfo.CurGunSelected]->EvBatterytargetVoltage = 500; _chargingData[ShmSysConfigAndInfo->SysInfo.CurGunSelected]->EvBatterytargetCurrent = 2; _chargingData[ShmSysConfigAndInfo->SysInfo.CurGunSelected]->AvailableChargingCurrent = 1000; //printf ("tar vol_ = %d \n", _chargingData[ShmSysConfigAndInfo->SysInfo.CurGunSelected]->EvBatterytargetVoltage); // printf ("tar cur_ = %d \n", _chargingData[ShmSysConfigAndInfo->SysInfo.CurGunSelected]->EvBatterytargetCurrent); //****** 注意~此行為是防止 K1K2 先開導到無法升壓 ( Relay Board 在此 state 還未搭上 K1K2 ) //確定模組己升壓完成 if(_chargingData[ShmSysConfigAndInfo->SysInfo.CurGunSelected]->GroundFaultStatus == 0x01 || _chargingData[ShmSysConfigAndInfo->SysInfo.CurGunSelected]->GroundFaultStatus == 0x03) { printf ("First Ground Fault State (%d)\n",_chargingData[ShmSysConfigAndInfo->SysInfo.CurGunSelected]->GroundFaultStatus); printf ("Wait K1K2 = %f \n", _chargingData[ShmSysConfigAndInfo->SysInfo.CurGunSelected]->PresentChargingVoltage); sleep(5); //EV done _chargingData[ShmSysConfigAndInfo->SysInfo.CurGunSelected]->SystemStatus = S_CHARGING; } else if (_chargingData[ShmSysConfigAndInfo->SysInfo.CurGunSelected]->GroundFaultStatus > 0x02) { printf ("First Ground Fault check Fail (%d)\n",_chargingData[ShmSysConfigAndInfo->SysInfo.CurGunSelected]->GroundFaultStatus); _chargingData[ShmSysConfigAndInfo->SysInfo.CurGunSelected]->SystemStatus = S_TERMINATING; } } break; case S_CHARGING: { if(PreviousSystemStatus != _chargingData[ShmSysConfigAndInfo->SysInfo.CurGunSelected]->SystemStatus) { PreviousSystemStatus = _chargingData[ShmSysConfigAndInfo->SysInfo.CurGunSelected]->SystemStatus; if (_usingAutoRun == 0x00) { //充電電壓電流 _chargingData[ShmSysConfigAndInfo->SysInfo.CurGunSelected]->EvBatterytargetVoltage = _Voltage; _chargingData[ShmSysConfigAndInfo->SysInfo.CurGunSelected]->EvBatterytargetCurrent = _Current; } else { _curAutoRunCount = 0; gettimeofday(&_autoTime, NULL); } _chargingData[ShmSysConfigAndInfo->SysInfo.CurGunSelected]->EvBatterySoc = 50; _chargingData[ShmSysConfigAndInfo->SysInfo.CurGunSelected]->AvailableChargingCurrent = 1000; printf ("[UnconditionalCharge - S_CHARGING]\n"); } if (_usingAutoRun == 0x01) { if (((GetTimeoutValue(_autoTime)) >= AUTORUN_STEP1_TIME_START * 60 && (GetTimeoutValue(_autoTime)) <= AUTORUN_STEP1_TIME_END * 60) || ((GetTimeoutValue(_autoTime)) >= AUTORUN_STEP2_TIME_START * 60 && (GetTimeoutValue(_autoTime)) <= AUTORUN_STEP2_TIME_END * 60)) { _chargingData[ShmSysConfigAndInfo->SysInfo.CurGunSelected]->EvBatterytargetVoltage = _Voltage; _chargingData[ShmSysConfigAndInfo->SysInfo.CurGunSelected]->EvBatterytargetCurrent = _Current; } else if ((GetTimeoutValue(_autoTime)) >= AUTORUN_END_TIME * 60) { _curAutoRunCount++; if (_curAutoRunCount >= AUTORUN_CYCLE_COUNT) _chargingData[ShmSysConfigAndInfo->SysInfo.CurGunSelected]->SystemStatus = S_TERMINATING; else gettimeofday(&_autoTime, NULL); } else { _chargingData[ShmSysConfigAndInfo->SysInfo.CurGunSelected]->EvBatterytargetVoltage = 0; _chargingData[ShmSysConfigAndInfo->SysInfo.CurGunSelected]->EvBatterytargetCurrent = 0; } } // printf("out : vol = %f, cur = %f \n", // _chargingData[ShmSysConfigAndInfo->SysInfo.CurGunSelected]->EvBatterytargetVoltage, // _chargingData[ShmSysConfigAndInfo->SysInfo.CurGunSelected]->EvBatterytargetCurrent); //ev task do this _chargingData[ShmSysConfigAndInfo->SysInfo.CurGunSelected]->PresentChargingPower = ((float)((_chargingData[ShmSysConfigAndInfo->SysInfo.CurGunSelected]->PresentChargingVoltage) * (_chargingData[ShmSysConfigAndInfo->SysInfo.CurGunSelected]->PresentChargingCurrent)) / 1000); if (_chargingData[ShmSysConfigAndInfo->SysInfo.CurGunSelected]->GroundFaultStatus == 0x02) { printf ("Charging Ground Fault check Fail (%d)\n",_chargingData[ShmSysConfigAndInfo->SysInfo.CurGunSelected]->GroundFaultStatus); _chargingData[ShmSysConfigAndInfo->SysInfo.CurGunSelected]->SystemStatus = S_TERMINATING; } } break; case S_TERMINATING: { if(PreviousSystemStatus != _chargingData[ShmSysConfigAndInfo->SysInfo.CurGunSelected]->SystemStatus) { PreviousSystemStatus = _chargingData[ShmSysConfigAndInfo->SysInfo.CurGunSelected]->SystemStatus; system("/root/Module_EvComm &"); printf ("[UnconditionalCharge - S_TERMINATING]\n"); //無阻塞偵測 keybaord 結束 system(STTY_DEF TTY_PATH); } sleep(3); _chargingData[ShmSysConfigAndInfo->SysInfo.CurGunSelected]->SystemStatus = S_COMPLETE; return; } break; case S_COMPLETE: { if(PreviousSystemStatus != _chargingData[ShmSysConfigAndInfo->SysInfo.CurGunSelected]->SystemStatus) { PreviousSystemStatus = _chargingData[ShmSysConfigAndInfo->SysInfo.CurGunSelected]->SystemStatus; printf ("[UnconditionalCharge - S_COMPLETE]\n"); } _chargingData[ShmSysConfigAndInfo->SysInfo.CurGunSelected]->PresentChargingPower = 0; sleep(3); return; } break; } char word[128]; char newString[7][10]; int i,j,ctr; memset(word, 0x00, sizeof(word)); get_char(word); if (strlen(word) == 0) continue; j=0; ctr=0; strcpy(newString[1], "-1"); strcpy(newString[2], "-1"); for (i = 0; i <= (strlen(word)); i++) { if (word[i] == ' ' || word[i] == '\0' || word[i] == 10) { newString[ctr][j] = '\0'; ctr++; j = 0; } else { newString[ctr][j] = word[i]; j++; } } if(strcmp(newString[0], "chg") == 0) { if (strcmp(newString[1], "-1") == 0 || strcmp(newString[1], "") == 0) continue; if (strcmp(newString[2], "-1") == 0 || strcmp(newString[2], "") == 0) continue; float _vol = atof(newString[1]); float _cur = atof(newString[2]); if (_cur <= 0 || _cur <= 0) continue; printf("vol = %f, cur = %f \n", _vol, _cur); _chargingData[ShmSysConfigAndInfo->SysInfo.CurGunSelected]->EvBatterytargetVoltage = _vol; _chargingData[ShmSysConfigAndInfo->SysInfo.CurGunSelected]->EvBatterytargetCurrent = _cur; } else if (strcmp(newString[0], "c") == 0) { printf("stop \n\r"); ShmSysConfigAndInfo->SysInfo.StartToChargingFlag = 0x00; _chargingData[ShmSysConfigAndInfo->SysInfo.CurGunSelected]->SystemStatus = S_TERMINATING; } usleep(100000); } } int main(void) { if(InitShareMemory() == FAIL) { printf ("InitShareMemory = FAIL \n"); if(ShmStatusCodeData != NULL) { ShmStatusCodeData->AlarmCode.AlarmEvents.bits.FailToCreateShareMemory=1; } sleep(5); return 0; } printf ("%s\n", msg); for(;;) { char word[128]; char newString[7][10]; int i,j,ctr; fgets(word, sizeof(word), stdin); j=0; ctr=0; strcpy(newString[1], "-1"); strcpy(newString[2], "-1"); for (i = 0; i <= (strlen(word)); i++) { if (word[i] == ' ' || word[i] == '\0' || word[i] == 10) { newString[ctr][j] = '\0'; ctr++; j = 0; } else { newString[ctr][j] = word[i]; j++; } } if(strcmp(newString[0], "state") == 0) { if (strcmp(newString[1], "-1") == 0 || strcmp(newString[1], "") == 0) continue; // 槍狀態 RunStatusProc(newString[1], newString[2]); } else if(strcmp(newString[0], "card") == 0) { // 刷卡狀態 RunCardProc(newString[1], newString[2]); } else if(strcmp(newString[0], "gun") == 0) { if (strcmp(newString[1], "-1") == 0 || strcmp(newString[1], "") == 0) continue; // 插槍狀態 RunGunPlugitProc(newString[1], newString[2]); } else if(strcmp(newString[0], "lock") == 0) { if (strcmp(newString[1], "-1") == 0 || strcmp(newString[1], "") == 0) continue; // 插槍狀態 GetGunLockStatusProc(newString[1], newString[2]); } else if(strcmp(newString[0], "sysid") == 0) { // 測試 sys id SetSystemIDProc(); } else if(strcmp(newString[0], "self") == 0) { // CSU 自我檢測狀態 RunSelfProc(newString[1]); } else if(strcmp(newString[0], "ver") == 0) { if (strcmp(newString[1], "-1") == 0 || strcmp(newString[1], "") == 0) continue; // 取 FW 版號 GetFwVerProc(newString[1]); } else if (strcmp(newString[0], "update") == 0) { // 更新 FwUpdateFlagProc(newString[1]); } else if (strcmp(newString[0], "ac") == 0) { // AC contactor 狀態 CheckAcStatus(newString[1]); } else if (strcmp(newString[0], "cable") == 0) { if (strcmp(newString[1], "-1") == 0 || strcmp(newString[1], "") == 0) continue; // cable check pass SetCableChkStatus(newString[1], newString[2]); } else if (strcmp(newString[0], "pow") == 0) { if (strcmp(newString[1], "-1") == 0 || strcmp(newString[1], "") == 0) continue; // cable check pass SetPowerValue(newString[1], newString[2]); } else if (strcmp(newString[0], "model") == 0) { GetSystemInfo(); } else if(strcmp(newString[0], "select") == 0) { // 取得 / 設定 當前選的槍號 GetGunSelectedNum(newString[1]); } else if(strcmp(newString[0], "change") == 0) { // 模擬按鈕改變選槍 ChangeGunNum(); } else if(strcmp(newString[0], "fan") == 0) { // 設定風扇速度 SetFanSpeed(newString[1]); } else if(strcmp(newString[0], "speed") == 0) { // 取得風扇速度 GetFanSpeed(); } else if(strcmp(newString[0], "debug") == 0) { // 設定 debug mode SetDebugMode(newString[1]); } else if (strcmp(newString[0], "gfd") == 0) { // 設定盲沖使用 GFD 功能 SetGFDMode(newString[1]); } else if(strcmp(newString[0], "temp") == 0) { // 取得 PSU 溫度 GetPsuTemp(); } else if(strcmp(newString[0], "acin") == 0) { // 取得三向輸入電壓 GetAcInputVol(); } else if(strcmp(newString[0], "psu") == 0) { //如果連一個參數都沒有 (此命令不理會) 加上判斷第二參數 if (strcmp(newString[1], "-1") == 0 || strcmp(newString[1], "") == 0) { printf ("PSU : Param fail..Please retry again......\n"); continue; } // 取得 PSU 資訊 GetPsuInformation(newString[1], newString[2], newString[3]); } else if (strcmp(newString[0], "cap") == 0) { GetConnectorCapInfo(newString[1]); } else if(strcmp(newString[0], "error") == 0) { CreateOneError(newString[1]); } else if (strcmp(newString[0], "auth") == 0) { GetAuthorizeFlag(newString[1]); } else if (strcmp(newString[0], "relay") == 0) { GetRelayStatus(newString[1]); } else if (strcmp(newString[0], "ccid") == 0) { if (strcmp(newString[1], "-1") == 0 || strcmp(newString[1], "") == 0 || strcmp(newString[2], "-1") == 0 || strcmp(newString[2], "") == 0) { printf ("Input ccid fail.\n"); continue; } SetChargingInfoCCID(newString[1], newString[2]); } else if(strcmp(newString[0], "strchg") == 0) { //如果連一個參數都沒有 (此命令不理會) 加上判斷第二參數 if (strcmp(newString[1], "auto") == 0) { newString[2][0] = 0; newString[3][0] = 0; } else if (strcmp(newString[1], "-1") == 0 || strcmp(newString[1], "") == 0 || strcmp(newString[2], "-1") == 0 || strcmp(newString[2], "") == 0) { printf ("Input cmd fail ------ strchg [vol 150-1000] [cru 2-100]\n"); continue; } // 槍狀態 RunUnconditionalChargeIndex1(newString[1], newString[2], newString[3]); } else printf ("%s\n", msg); usleep(100000); } return 0; }