Config.h 3.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161
  1. /*
  2. * Config.h
  3. *
  4. * Created on: 2019年4月23日
  5. * Author: foluswen
  6. */
  7. #ifndef CONFIG_H_
  8. #define CONFIG_H_
  9. typedef unsigned char byte;
  10. #define TOTAL_QUANTITY_GUN 4 //Max Count
  11. #define MODE_BOOT 0
  12. #define MODE_IDLE 1
  13. #define MODE_AUTHORIZING 2
  14. #define MODE_REASSIGN_CHECK 3
  15. #define MODE_REASSIGN 4
  16. #define MODE_PRECHARGE 5
  17. #define MODE_PREPARE_FOR_EV 6
  18. #define MODE_PREPARE_FOR_EVSE 7
  19. #define MODE_CHARGING 8
  20. #define MODE_TERMINATING 9
  21. #define MODE_COMPLETE 10
  22. #define MODE_ALARM 11
  23. #define MODE_RESERVATION 12
  24. #define MODE_BOOKING 13
  25. #define MODE_MAINTAIN 14
  26. #define MODE_DEBUG 15
  27. #define MODE_CCS_PRECHARGE_STEP0 16 // ready for ccs precharge processing, For D+ relay to precharge relay
  28. #define MODE_CCS_PRECHARGE_STEP1 17 // waitting for ev board inform to enter to charging, For precharge relay to D+ relay
  29. #define MODE_SINGLE_RUN 18
  30. #define GFD_WAIT 0
  31. #define GFD_PASS 1
  32. #define GFD_FAIL 2
  33. #define PRECHARGE_WAIT 0
  34. #define PRECHARGE_READY 1
  35. #define PRECHARGE_PRERELAY_PASS 2
  36. #define PRECHARGE_CHARELAY_PASS 3
  37. #define BOOTTING 0
  38. #define BOOT_COMPLETE 1
  39. unsigned char mask_table[] = { 0x01, 0x02, 0x04, 0x08, 0x10, 0x20, 0x40, 0x80 };
  40. int whileLoopTime = 10000; // 10 ms
  41. enum _SYSTEM_STATUS
  42. {
  43. S_BOOTING = 0,
  44. S_IDLE,
  45. S_AUTHORIZING,
  46. S_REASSIGN_CHECK,
  47. S_REASSIGN,
  48. S_PREPARNING,
  49. S_PREPARING_FOR_EV,
  50. S_PREPARING_FOR_EVSE,
  51. S_CHARGING,
  52. S_TERMINATING,
  53. S_COMPLETE,
  54. S_ALARM,
  55. S_RESERVATION,
  56. S_BOOKING,
  57. S_MAINTAIN,
  58. S_DEBUG,
  59. S_CCS_PRECHARGE_ST0,
  60. S_CCS_PRECHARGE_ST1,
  61. S_SINGLE_RUN,
  62. };
  63. enum _GUN_TYPE
  64. {
  65. _Type_Chademo = 0,
  66. _Type_CCS,
  67. _Type_GB,
  68. };
  69. enum _LCM_INDEX
  70. {
  71. _LCM_INIT = 0x00,
  72. _LCM_IDLE = 0x01,
  73. _LCM_AUTHORIZING = 0x04,
  74. _LCM_AUTHORIZ_COMP = 0x05,
  75. _LCM_AUTHORIZ_FAIL = 0x06,
  76. _LCM_WAIT_FOR_PLUG = 0x07,
  77. _LCM_PRE_CHARGE = 0x08,
  78. _LCM_CHARGING = 0x09,
  79. _LCM_COMPLETE = 0x0A,
  80. _LCM_FIX = 0x0B,
  81. _LCM_NONE = 0xFF,
  82. };
  83. enum _SELF_TEST_SEQ
  84. {
  85. _STEST_VERSION = 0x00,
  86. _STEST_AC_CONTACTOR = 0x01,
  87. _STEST_PSU_DETECT = 0x02,
  88. _STEST_PSU_CAP = 0x03,
  89. _STEST_FAIL = 0x04,
  90. _STEST_COMPLETE = 0xFE,
  91. };
  92. enum _MODULE_PSU_WORK_STEP
  93. {
  94. ASSIGN_START = 0,
  95. ASSIGN_COMP = 1,
  96. ENABLE_POW = 2,
  97. _TEST_LINE_STEP = 3,
  98. _TEST_POWER_STEP = 4,
  99. _TEST_COMPLETE = 5,
  100. _WORK_CHARGING = 10,
  101. _NO_WORKING = 254,
  102. };
  103. #define DEBUG_INFO(format, args...) StoreLogMsg("[%s:%d][%s][Info] "format, __FILE__, __LINE__, __FUNCTION__, ##args)
  104. #define DEBUG_WARN(format, args...) StoreLogMsg("[%s:%d][%s][Warn] "format, __FILE__, __LINE__, __FUNCTION__, ##args)
  105. #define DEBUG_ERROR(format, args...) StoreLogMsg("[%s:%d][%s][Error] "format, __FILE__, __LINE__, __FUNCTION__, ##args)
  106. unsigned long GetTimeoutValue(struct timeval _sour_time);
  107. int StoreLogMsg(const char *fmt, ...)
  108. {
  109. char Buf[4096+256];
  110. char buffer[4096];
  111. time_t CurrentTime;
  112. struct tm *tm;
  113. va_list args;
  114. va_start(args, fmt);
  115. int rc = vsnprintf(buffer, sizeof(buffer), fmt, args);
  116. va_end(args);
  117. memset(Buf,0,sizeof(Buf));
  118. CurrentTime = time(NULL);
  119. tm=localtime(&CurrentTime);
  120. sprintf(Buf,"echo \"%04d-%02d-%02d %02d:%02d:%02d - %s\" >> /Storage/SystemLog/[%04d.%02d]SystemLog",
  121. tm->tm_year+1900,tm->tm_mon+1,tm->tm_mday,tm->tm_hour,tm->tm_min,tm->tm_sec,
  122. buffer,
  123. tm->tm_year+1900,tm->tm_mon+1);
  124. system(Buf);
  125. #ifdef Debug
  126. char value[21];
  127. getTimeStringByCSU(value);
  128. printf("%s - %s", value, buffer);
  129. #endif
  130. return rc;
  131. }
  132. unsigned long GetTimeoutValue(struct timeval _sour_time)
  133. {
  134. struct timeval _end_time;
  135. gettimeofday(&_end_time, NULL);
  136. return 1000000 * (_end_time.tv_sec - _sour_time.tv_sec) + _end_time.tv_usec - _sour_time.tv_usec;
  137. }
  138. #endif /* CONFIG_H_ */