Infypwr_PsuCommObj.c 19 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769
  1. /*
  2. * Infypwr_PsuCommObj.c
  3. *
  4. * Created on: 2019年11月26日
  5. * Author: 7564
  6. */
  7. #include "Infypwr_PsuCommObj.h"
  8. #define DEBUG_LIB 1
  9. void PRINTF_LIB_FUNC(char *string, ...);
  10. float IEEE_754_to_float(const byte raw[4]);
  11. void IEEE_754_to_bytes(float target, byte *bytes2);
  12. //================================================
  13. // Private function
  14. //================================================
  15. void PRINTF_LIB_FUNC(char *string, ...)
  16. {
  17. if (DEBUG_LIB)
  18. {
  19. va_list args;
  20. char buffer[4096];
  21. va_start(args, string);
  22. vsnprintf(buffer, sizeof(buffer), string, args);
  23. va_end(args);
  24. printf("%s \n", buffer);
  25. }
  26. }
  27. float IEEE_754_to_float(const byte raw[4])
  28. {
  29. int sign = (raw[0] >> 7) ? -1 : 1;
  30. byte exponent = (raw[0] << 1) + (raw[1] >> 7) - 126;
  31. unsigned int fraction_bits = ((raw[1] & 0x7F) << 16) + (raw[2] << 8) + raw[3];
  32. float fraction = 0.5f;
  33. for (byte ii = 0; ii < 24; ++ii)
  34. fraction += ldexpf((fraction_bits >> (23 - ii)) & 1, -(ii + 1));
  35. float significand = sign * fraction;
  36. return ldexpf(significand, exponent);
  37. }
  38. void IEEE_754_to_bytes(float target, byte *bytes2)
  39. {
  40. int value2 = 0;
  41. number.f = target;
  42. int index = 31;
  43. value2 |= number.raw.sign << index;
  44. int k;
  45. for (k = 8 - 1; k >= 0; k--)
  46. {
  47. index--;
  48. if ((number.raw.exponent >> k) & 1)
  49. value2 |= 1 << index;
  50. }
  51. for (k = 23 - 1; k >= 0; k--)
  52. {
  53. index--;
  54. if ((number.raw.mantissa >> k) & 1)
  55. value2 |= 1 << index;
  56. }
  57. *(bytes2) = (value2 >> 24) & 0xFF;
  58. *(bytes2 + 1) = (value2 >> 16) & 0xFF;
  59. *(bytes2 + 2) = (value2 >> 8) & 0xFF;
  60. *(bytes2 + 3) = value2 & 0xFF;
  61. }
  62. //================================================
  63. // Callback function
  64. //================================================
  65. void RefreshStatus(void *func)
  66. {
  67. return_status = func;
  68. }
  69. void RefreshModuleCount(void *func)
  70. {
  71. return_module_count = func;
  72. }
  73. void RefreshAvailableCap(void *func)
  74. {
  75. return_available_cap = func;
  76. }
  77. void RefreshFwVersion(void *func)
  78. {
  79. return_fw_version = func;
  80. }
  81. void RefreshInputVol(void *func)
  82. {
  83. return_input_vol = func;
  84. }
  85. void RefreshGetOutput(void *func)
  86. {
  87. return_get_output = func;
  88. }
  89. void RefreshGetOutputF(void *func)
  90. {
  91. return_get_output_float = func;
  92. }
  93. void RefreshFanInfo(void *func)
  94. {
  95. return_fanspeed_info = func;
  96. }
  97. void RefreshIavailable(void *func)
  98. {
  99. return_iavail_info = func;
  100. }
  101. void AutoMode_RefreshOutputAndTemp(void *func)
  102. {
  103. return_output_temp = func;
  104. }
  105. void AutoMode_RefreshModuleStatus(void *func)
  106. {
  107. return_module_status = func;
  108. }
  109. void AutoMode_RefreshModuleInput(void *func)
  110. {
  111. return_module_input = func;
  112. }
  113. //================================================
  114. // CANBUS initialization
  115. //================================================
  116. int InitCanBus()
  117. {
  118. int s0,nbytes;
  119. struct timeval tv;
  120. struct ifreq ifr0;
  121. struct sockaddr_can addr0;
  122. system("/sbin/ip link set can1 down");
  123. system("/sbin/ip link set can1 type can bitrate 500000 restart-ms 100");
  124. system("/sbin/ip link set can1 up");
  125. s0 = socket(PF_CAN, SOCK_RAW, CAN_RAW);
  126. tv.tv_sec = 0;
  127. tv.tv_usec = 10000;
  128. if (setsockopt(s0, SOL_SOCKET, SO_RCVTIMEO, (char *)&tv, sizeof(struct timeval)) < 0)
  129. {
  130. #ifdef SystemLogMessage
  131. PRINTF_LIB_FUNC("Set SO_RCVTIMEO NG");
  132. #endif
  133. }
  134. nbytes=40960;
  135. if (setsockopt(s0, SOL_SOCKET, SO_RCVBUF, &nbytes, sizeof(int)) < 0)
  136. {
  137. #ifdef SystemLogMessage
  138. PRINTF_LIB_FUNC("Set SO_RCVBUF NG");
  139. #endif
  140. }
  141. nbytes=40960;
  142. if (setsockopt(s0, SOL_SOCKET, SO_SNDBUF, &nbytes, sizeof(int)) < 0)
  143. {
  144. #ifdef SystemLogMessage
  145. PRINTF_LIB_FUNC("Set SO_SNDBUF NG");
  146. #endif
  147. }
  148. strcpy(ifr0.ifr_name, "can1" );
  149. ioctl(s0, SIOCGIFINDEX, &ifr0); /* ifr.ifr_ifindex gets filled with that device's index */
  150. addr0.can_family = AF_CAN;
  151. addr0.can_ifindex = ifr0.ifr_ifindex;
  152. bind(s0, (struct sockaddr *)&addr0, sizeof(addr0));
  153. return s0;
  154. }
  155. //================================================
  156. // Receive Cmd from canbus
  157. //================================================
  158. void ReceiveDataFromCanBus()
  159. {
  160. int nbytes;
  161. struct can_frame frame;
  162. int intCmd = 0;
  163. byte group, address;
  164. while(1)
  165. {
  166. memset(&frame, 0, sizeof(struct can_frame));
  167. nbytes = read(CanFd, &frame, sizeof(struct can_frame));
  168. if (nbytes > 0)
  169. {
  170. frame.can_id = frame.can_id & CAN_EFF_MASK;
  171. intCmd = frame.can_id & 0x00FF0000;
  172. intCmd |= INFYPWR_GROUP_SHIFT | intCmd;
  173. switch (intCmd)
  174. {
  175. case WALK_IN_MODE:
  176. case INFYPWR_GROUP_SHIFT | WALK_IN_MODE:
  177. {
  178. //address = frame.can_id & 0x000000FF;
  179. // printf("walk in response address = %d, [0] = %d, [1] = %d, [2] = %d, [3] = %d, [4] = %d, [5] = %d, [6] = %d, [7] = %d \n"
  180. // , address,
  181. // frame.data[0], frame.data[1],
  182. // frame.data[2], frame.data[3],
  183. // frame.data[4], frame.data[5],
  184. // frame.data[6], frame.data[7]);
  185. }
  186. break;
  187. case INFYPWR_GROUP_SHIFT | STATUS:
  188. {
  189. group = frame.data[2];
  190. address = frame.can_id & 0x000000FF;
  191. short temp = frame.data[4];
  192. int status = (frame.data[5] << 16) + (frame.data[6] << 8) + frame.data[7];
  193. return_status(group, address, temp, status);
  194. //PRINTF_LIB_FUNC("group = %d, address = %d, temp = %d \n", group, address, temp);
  195. }
  196. break;
  197. case INFYPWR_GROUP_SHIFT | MODULE_COUNT:
  198. {
  199. // 回傳模組數量
  200. group = frame.can_id & 0x000000FF;
  201. byte count = frame.data[2];
  202. return_module_count(group, count);
  203. //PRINTF_LIB_FUNC("group = %d, count = %d \n", group, count);
  204. }
  205. break;
  206. case INFYPWR_GROUP_SHIFT | MODULE_CAP:
  207. {
  208. // 回傳輸出能力 : 最大電壓、最小電壓、最大電流、額定功率
  209. address = frame.can_id & 0x000000FF;
  210. short maxVol = ((frame.data[0] << 8) + frame.data[1]) * 10;
  211. short minVol = ((frame.data[2] << 8) + frame.data[3]) * 10;
  212. short maxCur = (frame.data[4] << 8) + frame.data[5];
  213. short totalPow = ((frame.data[6] << 8) + frame.data[7]) / 10;
  214. return_available_cap(address, maxVol, minVol, maxCur, totalPow);
  215. // PRINTF_LIB_FUNC("address = %d, maxVol = %d, minVol = %d, maxCur = %d, totalPow = %d \n",
  216. // address, maxVol, minVol, maxCur, totalPow);
  217. }
  218. break;
  219. case INFYPWR_GROUP_SHIFT | MODULE_OUTPUT_VOL_CUR:
  220. {
  221. // 回傳當前輸出電壓電流
  222. address = frame.can_id & 0x000000FF;
  223. int outputVol = ((frame.data[0] << 24) + (frame.data[1] << 16) + (frame.data[2] << 8) + frame.data[3]) / 100;
  224. int outputCur = ((frame.data[4] << 24) + (frame.data[5] << 16) + (frame.data[6] << 8) + frame.data[7]) / 100;
  225. return_get_output(address, outputVol, outputCur);
  226. //PRINTF_LIB_FUNC("address = %d, outputVol = %d, outputCur = %d \n", address, outputVol, outputCur);
  227. }
  228. break;
  229. case INFYPWR_GROUP_SHIFT | MODULE_OUTPUT_VOL_CUR_FLOAT:
  230. {
  231. group = frame.can_id & 0x000000FF;
  232. byte vol[4], cur[4];
  233. memcpy(vol, frame.data, 4);
  234. memcpy(cur, frame.data + 4, 4);
  235. float _Vol = IEEE_754_to_float(vol);
  236. float _Cur = IEEE_754_to_float(cur);
  237. return_get_output_float(group, _Vol, _Cur);
  238. }
  239. break;
  240. case INFYPWR_GROUP_SHIFT | MODULE_IAVAILABLE:
  241. case MODULE_IAVAILABLE:
  242. {
  243. // 回傳降載後的電流
  244. address = frame.can_id & 0x000000FF;
  245. unsigned short vextVol = ((frame.data[0] << 8) + frame.data[1]);
  246. unsigned short iAvailCur = ((frame.data[2] << 8) + frame.data[3]);
  247. return_iavail_info(address, iAvailCur, vextVol);
  248. //PRINTF_LIB_FUNC("address = %d, iAvailCur = %d \n", address, iAvailCur);
  249. }
  250. break;
  251. case INFYPWR_GROUP_SHIFT | MODULE_MIS_INFO:
  252. {
  253. address = frame.can_id & 0x000000FF;
  254. float FanSpeed;
  255. byte value[4];
  256. memcpy(value, frame.data + 4, sizeof(value));
  257. if (frame.data[0] == ((FAN_SPEED_CMD >> 8) & 0xFF) && frame.data[1] == (FAN_SPEED_CMD & 0xFF))
  258. {
  259. FanSpeed = IEEE_754_to_float(value);
  260. return_fanspeed_info(address, FanSpeed);
  261. //PRINTF_LIB_FUNC("address = %d, FanSpeed = %f \n", address, FanSpeed);
  262. }
  263. }
  264. break;
  265. case INFYPWR_GROUP_SHIFT | MODULE_VER:
  266. {
  267. // 回傳版號 : 無系統回覆功能
  268. address = frame.can_id & 0x000000FF;
  269. short dcSwVer = ((frame.data[0] << 8) + frame.data[1]);
  270. short pfcSwVer = ((frame.data[2] << 8) + frame.data[3]);
  271. short hwVer = ((frame.data[4] << 8) + frame.data[5]);
  272. return_fw_version(address, dcSwVer, pfcSwVer, hwVer);
  273. //PRINTF_LIB_FUNC("address = %d, DC %d, PFC %d, HW %d \n", address, dcSwVer, pfcSwVer, hwVer);
  274. }
  275. break;
  276. case INFYPWR_GROUP_SHIFT | MODULE_BARCODE:
  277. {
  278. // 回傳BarCode
  279. }
  280. break;
  281. case INFYPWR_GROUP_SHIFT | MODULE_INPUT:
  282. {
  283. // 回傳三向輸入電壓
  284. address = frame.can_id & 0x000000FF;
  285. short abVol = ((frame.data[0] << 8) + frame.data[1]) / 10;
  286. short bcVol = ((frame.data[2] << 8) + frame.data[3]) / 10;
  287. short caVol = ((frame.data[4] << 8) + frame.data[5]) / 10;
  288. return_input_vol(address, abVol, bcVol, caVol);
  289. //PRINTF_LIB_FUNC("address = %d, abVol = %d, bcVol = %d, caVol = %d \n", address, abVol, bcVol, caVol);
  290. }
  291. break;
  292. case INFYPWR_GROUP_SHIFT | AUTO_OUTPUT_TEMP:
  293. {
  294. /*Test mode used*/
  295. // 回傳輸出值與入風口溫度
  296. address = frame.can_id & 0x000000FF;
  297. short outputVol = ((frame.data[0] << 8) + frame.data[1]);
  298. short outputCur = ((frame.data[2] << 8) + frame.data[3]);
  299. short outputPow = ((frame.data[4] << 8) + frame.data[5]);
  300. byte temp = frame.data[6];
  301. return_output_temp(address, outputVol, outputCur, outputPow, temp);
  302. //PRINTF_LIB_FUNC("address = %d, abVol = %d, bcVol = %d, caVol = %d \n", address, abVol, bcVol, caVol);
  303. }
  304. break;
  305. case INFYPWR_GROUP_SHIFT | AUTO_MODULE_STATUS:
  306. {
  307. /*Test mode used*/
  308. // 回傳輸出值與入風口溫度
  309. address = frame.can_id & 0x000000FF;
  310. byte isErr = (frame.data[0] >> 0) & 0x01;
  311. byte status = (frame.data[0] >> 1) & 0x01;
  312. byte err1 = frame.data[2];
  313. byte err2 = frame.data[3];
  314. byte err3 = frame.data[4];
  315. byte err4 = frame.data[5];
  316. return_module_status(address, isErr, status, err1, err2, err3, err4);
  317. //PRINTF_LIB_FUNC("address = %d, abVol = %d, bcVol = %d, caVol = %d \n", address, abVol, bcVol, caVol);
  318. }
  319. break;
  320. case INFYPWR_GROUP_SHIFT | AUTO_MODULE_INPUT:
  321. {
  322. /*Test mode used*/
  323. // 回傳輸出值與入風口溫度
  324. address = frame.can_id & 0x000000FF;
  325. short vR = ((frame.data[0] << 8) + frame.data[1]);
  326. short vS = ((frame.data[2] << 8) + frame.data[3]);
  327. short vT = ((frame.data[4] << 8) + frame.data[5]);
  328. return_module_input(address, vR, vS, vT);
  329. //PRINTF_LIB_FUNC("address = %d, abVol = %d, bcVol = %d, caVol = %d \n", address, abVol, bcVol, caVol);
  330. }
  331. break;
  332. }
  333. }
  334. usleep(10000);
  335. }
  336. }
  337. //================================================
  338. // Private Function
  339. //================================================
  340. void SendCmdToPsu(int cmd, byte *data, byte dataLen)
  341. {
  342. struct can_frame frame;
  343. //設定 CANBSU 2.0B 長封包
  344. cmd = cmd | 0x80000000;
  345. frame.can_id = cmd;
  346. frame.can_dlc = dataLen;
  347. memcpy(frame.data, data, dataLen);
  348. write(CanFd, &frame, sizeof(struct can_frame));
  349. usleep(CMD_DELAY_TIME);
  350. }
  351. bool InitialCommunication()
  352. {
  353. CanFd = InitCanBus();
  354. if(CanFd < 0)
  355. {
  356. PRINTF_LIB_FUNC("Init can bus fail.\n");
  357. return false;
  358. }
  359. recFork = fork();
  360. if(recFork > 0)
  361. {
  362. ReceiveDataFromCanBus();
  363. }
  364. else if(recFork > 0)
  365. {
  366. PRINTF_LIB_FUNC("fork fail\n");
  367. }
  368. return true;
  369. }
  370. //================================================
  371. // API Function
  372. //================================================
  373. void SwitchPower(byte group, byte value)
  374. {
  375. byte data[8];
  376. uint cmd = INFYPWR_CMD | SWITCH_POWER;
  377. memset(data, 0x00, ARRAY_SIZE(data));
  378. // 1 : 關機
  379. // 0 : 開機
  380. data[0] = value;
  381. if (group == SYSTEM_CMD)
  382. cmd |= INFYPWR_BROADCAST | INFYPWR_DEFAULT;
  383. else
  384. cmd |= INFYPWR_GROUP_SHIFT | (group << 8) | INFYPWR_DEFAULT;
  385. SendCmdToPsu(cmd, data, sizeof(data));
  386. }
  387. void SleepMode(byte group, byte value)
  388. {
  389. byte data[8];
  390. uint cmd = INFYPWR_CMD | SLEEP_MODE;
  391. memset(data, 0x00, ARRAY_SIZE(data));
  392. // 1 : 休眠
  393. // 0 : 起床
  394. data[0] = value;
  395. if (group == SYSTEM_CMD)
  396. cmd |= INFYPWR_BROADCAST | INFYPWR_DEFAULT;
  397. else
  398. cmd |= INFYPWR_GROUP_SHIFT | (group << 8) | INFYPWR_DEFAULT;
  399. SendCmdToPsu(cmd, data, sizeof(data));
  400. }
  401. void FlashLed(byte group, byte value)
  402. {
  403. byte data[8];
  404. uint cmd = INFYPWR_CMD | FLASH_LED;
  405. memset(data, 0x00, ARRAY_SIZE(data));
  406. // 1 : 閃爍
  407. // 0 : 正常
  408. data[0] = value;
  409. if (group == SYSTEM_CMD)
  410. cmd |= INFYPWR_BROADCAST | INFYPWR_DEFAULT;
  411. else
  412. cmd |= INFYPWR_GROUP_SHIFT | (group << 8) | INFYPWR_DEFAULT;
  413. SendCmdToPsu(cmd, data, sizeof(data));
  414. }
  415. void PresentOutputVol(byte group, int voltage, int current)
  416. {
  417. byte data[8];
  418. uint cmd = INFYPWR_CMD | PRESENT_OUT_VOL;
  419. int Vol = voltage * 100;
  420. int Cur = current * 100;
  421. memset(data, 0x00, ARRAY_SIZE(data));
  422. // 輸出電壓
  423. data[0] = (Vol >> 24) & 0xFF;
  424. data[1] = (Vol >> 16) & 0xFF;
  425. data[2] = (Vol >> 8) & 0xFF;
  426. data[3] = Vol & 0xFF;
  427. // 輸出電流
  428. data[4] = (Cur >> 24) & 0xFF;
  429. data[5] = (Cur >> 16) & 0xFF;
  430. data[6] = (Cur >> 8) & 0xFF;
  431. data[7] = Cur & 0xFF;
  432. if (group == SYSTEM_CMD)
  433. cmd |= INFYPWR_BROADCAST | INFYPWR_DEFAULT;
  434. else
  435. cmd |= INFYPWR_GROUP_SHIFT | (group << 8) | INFYPWR_DEFAULT;
  436. SendCmdToPsu(cmd, data, sizeof(data));
  437. }
  438. void FanNoiseInfo(byte group, byte value)
  439. {
  440. byte data[8];
  441. uint cmd = INFYPWR_CMD | MIS_INFO;
  442. memset(data, 0x00, ARRAY_SIZE(data));
  443. // 風扇低噪音
  444. data[0] = 0x11;
  445. data[1] = 0x13;
  446. // 0xA0 power poriority mode
  447. // 0xA1 denoise mode
  448. // 0xA2 quiet mode
  449. data[7] = value;
  450. if (group == SYSTEM_CMD)
  451. cmd |= INFYPWR_BROADCAST | INFYPWR_DEFAULT;
  452. else
  453. cmd |= INFYPWR_GROUP_SHIFT | (group << 8) | INFYPWR_DEFAULT;
  454. SendCmdToPsu(cmd, data, sizeof(data));
  455. }
  456. void SetWalkInConfig(byte group, byte enable, byte sec)
  457. {
  458. byte data[8];
  459. uint cmd = INFYPWR_CMD | WALK_IN_MODE;
  460. memset(data, 0x00, ARRAY_SIZE(data));
  461. unsigned short _Sec = sec * 100;
  462. // Walk-in mode enable
  463. data[0] = enable;
  464. // Walk-in time (default == 5s)
  465. data[6] = (_Sec >> 8) & 0xFF;
  466. data[7] = _Sec & 0xFF;
  467. if (group == SYSTEM_CMD)
  468. cmd |= INFYPWR_BROADCAST | INFYPWR_DEFAULT;
  469. else
  470. cmd |= (group << 8) | INFYPWR_DEFAULT;
  471. //printf("walk in cmd = %x \n", cmd);
  472. SendCmdToPsu(cmd, data, sizeof(data));
  473. }
  474. void SetDirModulePresentOutput(byte group, int voltage, int current, byte _switch, byte _interRelay)
  475. {
  476. byte data[8];
  477. uint cmd = TEST_PRESENT_OUT; //0x180100E5
  478. memset(data, 0x00, ARRAY_SIZE(data));
  479. // 輸出電壓
  480. data[0] = (voltage >> 8) & 0xFF;
  481. data[1] = voltage & 0xFF;
  482. // 輸出電流
  483. data[2] = (current >> 8) & 0xFF;
  484. data[3] = current & 0xFF;
  485. // 開 / 關
  486. data[4] = _switch;
  487. // Internal Relay
  488. data[5] = _interRelay;
  489. if (group == SYSTEM_CMD)
  490. cmd |= INFYPWR_BROADCAST;
  491. else
  492. cmd |= (group << 8);
  493. SendCmdToPsu(cmd, data, sizeof(data));
  494. }
  495. /**********************************************************************************/
  496. /*** ***/
  497. /*** Get ***/
  498. /*** ***/
  499. /**********************************************************************************/
  500. void GetStatus(byte group)
  501. {
  502. byte data[8];
  503. uint cmd = INFYPWR_CMD | STATUS;
  504. memset(data, 0x00, ARRAY_SIZE(data));
  505. cmd |= INFYPWR_GROUP_SHIFT | (group << 8) | INFYPWR_DEFAULT;
  506. SendCmdToPsu(cmd, data, sizeof(data));
  507. }
  508. void GetFanSpeed(byte group)
  509. {
  510. uint cmd;
  511. byte data[8];
  512. cmd = INFYPWR_CMD | MODULE_MIS_INFO;
  513. memset(data, 0x00, ARRAY_SIZE(data));
  514. data[0] = (FAN_SPEED_CMD >> 8) & 0xFF;
  515. data[1] = FAN_SPEED_CMD & 0xFF;
  516. if (group == (INFYPWR_BROADCAST >> 8))
  517. cmd |= INFYPWR_BROADCAST | INFYPWR_DEFAULT;
  518. else
  519. cmd |= INFYPWR_GROUP_SHIFT | (group << 8) | INFYPWR_DEFAULT;
  520. SendCmdToPsu(cmd, data, sizeof(data));
  521. }
  522. void GetModuleCount(byte group)
  523. {
  524. byte data[8];
  525. uint cmd = INFYPWR_CMD | MODULE_COUNT;
  526. memset(data, 0x00, ARRAY_SIZE(data));
  527. if (group == SYSTEM_CMD)
  528. cmd |= INFYPWR_BROADCAST | INFYPWR_DEFAULT;
  529. else
  530. cmd |= INFYPWR_GROUP_SHIFT | (group << 8) | INFYPWR_DEFAULT;
  531. SendCmdToPsu(cmd, data, sizeof(data));
  532. }
  533. void GetModuleVer(byte group)
  534. {
  535. // 無系統廣播功能
  536. byte data[8];
  537. uint cmd = INFYPWR_CMD | MODULE_VER;
  538. memset(data, 0x00, ARRAY_SIZE(data));
  539. cmd |= INFYPWR_GROUP_SHIFT | (group << 8) | INFYPWR_DEFAULT;
  540. //PRINTF_LIB_FUNC("GetModuleVer cmd = %x\n", cmd);
  541. SendCmdToPsu(cmd, data, sizeof(data));
  542. }
  543. void GetModuleCap(byte group)
  544. {
  545. byte data[8];
  546. uint cmd = INFYPWR_CMD | MODULE_CAP;
  547. memset(data, 0x00, ARRAY_SIZE(data));
  548. cmd |= INFYPWR_GROUP_SHIFT | (group << 8) | INFYPWR_DEFAULT;
  549. //PRINTF_LIB_FUNC("GetModuleCap cmd = %x\n", cmd);
  550. SendCmdToPsu(cmd, data, sizeof(data));
  551. }
  552. void GetModuleBarCode(byte group)
  553. {
  554. // 無系統廣播功能
  555. byte data[8];
  556. uint cmd = INFYPWR_CMD | MODULE_BARCODE;
  557. memset(data, 0x00, ARRAY_SIZE(data));
  558. cmd |= INFYPWR_GROUP_SHIFT | (group << 8) | INFYPWR_DEFAULT;
  559. SendCmdToPsu(cmd, data, sizeof(data));
  560. }
  561. void GetModuleInput(byte group)
  562. {
  563. // 無系統廣播功能
  564. byte data[8];
  565. uint cmd = INFYPWR_CMD | MODULE_INPUT;
  566. memset(data, 0x00, ARRAY_SIZE(data));
  567. cmd |= INFYPWR_GROUP_SHIFT | (group << 8) | INFYPWR_DEFAULT;
  568. SendCmdToPsu(cmd, data, sizeof(data));
  569. }
  570. void GetModuleIavailable(byte group)
  571. {
  572. byte data[8];
  573. uint cmd = INFYPWR_CMD | MODULE_IAVAILABLE;
  574. memset(data, 0x00, ARRAY_SIZE(data));
  575. if (group == SYSTEM_CMD)
  576. cmd |= INFYPWR_BROADCAST | INFYPWR_DEFAULT;
  577. else
  578. cmd |= INFYPWR_GROUP_SHIFT | (group << 8) | INFYPWR_DEFAULT;
  579. SendCmdToPsu(cmd, data, sizeof(data));
  580. }
  581. void GetModuleOutput(byte group)
  582. {
  583. byte data[8];
  584. uint cmd = INFYPWR_CMD | MODULE_OUTPUT_VOL_CUR;
  585. memset(data, 0x00, ARRAY_SIZE(data));
  586. if (group == SYSTEM_CMD)
  587. cmd |= INFYPWR_BROADCAST | INFYPWR_DEFAULT;
  588. else
  589. cmd |= INFYPWR_GROUP_SHIFT | (group << 8) | INFYPWR_DEFAULT;
  590. SendCmdToPsu(cmd, data, sizeof(data));
  591. }
  592. void GetModuleOutputF(byte group)
  593. {
  594. byte data[8];
  595. uint cmd = INFYPWR_CMD | MODULE_OUTPUT_VOL_CUR_FLOAT;
  596. memset(data, 0x00, ARRAY_SIZE(data));
  597. if (group == SYSTEM_CMD)
  598. cmd |= INFYPWR_BROADCAST | INFYPWR_DEFAULT;
  599. else
  600. cmd |= INFYPWR_GROUP_SHIFT | (group << 8) | INFYPWR_DEFAULT;
  601. SendCmdToPsu(cmd, data, sizeof(data));
  602. }
  603. /**********************************************************************************/
  604. /*** ***/
  605. /*** Upgrate ***/
  606. /*** ***/
  607. /**********************************************************************************/
  608. void ChangePsuBaudrate(short baudrate)
  609. {
  610. byte data[8];
  611. uint cmd = CHANGE_BAUDRATE; //0x180100E5
  612. memset(data, 0x00, ARRAY_SIZE(data));
  613. data[0] = 0x11;
  614. data[1] = 0x26;
  615. if (baudrate == 125)
  616. data[7] = 0xA0;
  617. else if (baudrate == 250)
  618. data[7] = 0xA1;
  619. else if (baudrate == 500)
  620. data[7] = 0xA2;
  621. cmd |= INFYPWR_BROADCAST | INFYPWR_DEFAULT;
  622. SendCmdToPsu(cmd, data, sizeof(data));
  623. }