Daikin_020701R2.cpp 29 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031
  1. #include "StdAfx.h"
  2. #include ".\Daikin_020701R2.h"
  3. CDaiKin_020701R2::CDaiKin_020701R2(char *szPath,char *szIniName,int nCommPort, int nAddr,int nRate, int nDataBit,int nStopBit, int nParity,int nInterval)
  4. {
  5. #if IS_USE_READMSG_CS
  6. InitializeCriticalSection(&m_csReadMsg);
  7. #endif
  8. MTVERIFY(m_hSemComm = CreateEvent(NULL, TRUE, TRUE, 0));
  9. for (int i = 0; i < MAX_ADDR ; i++)
  10. {
  11. memset(m_sz42Msg[i], 0, sizeof(m_sz42Msg[i]));
  12. memset(m_sz43Msg[i], 0, sizeof(m_sz43Msg[i]));
  13. memset(m_sz45Msg[i], 0, sizeof(m_sz45Msg[i]));
  14. memset(m_sz47Msg[i], 0, sizeof(m_sz47Msg[i]));
  15. memset(m_sz49Msg[i], 0, sizeof(m_sz49Msg[i]));
  16. m_dwOnlineTick[i] = 0;
  17. m_devOnline[i] = TRUE;
  18. }
  19. }
  20. CDaiKin_020701R2::~CDaiKin_020701R2(void)
  21. {
  22. #if IS_USE_READMSG_CS
  23. DeleteCriticalSection(& m_csReadMsg);
  24. #endif
  25. MTVERIFY(CloseHandle(m_hSemComm));
  26. CloseComm();
  27. }
  28. BOOL CDaiKin_020701R2::OpenUPSComm(int nCommPort, int nAddr, int nRate, int nDataBit, int nStopBit, int nParity, int nInterval)
  29. {
  30. BOOL bResult = FALSE;
  31. //LOG4C((LOG_NOTICE,"->OpenUPSComm"));
  32. bResult = OpenComm( nCommPort, nAddr, nRate, nDataBit, nStopBit, nParity, nInterval );
  33. return bResult;
  34. }
  35. int CDaiKin_020701R2::GetIniInfo(char *szPath,char *szIniName,char *szCmd,char *IniSendCMD, int &IniSendlen, char *nType,int &nIndex,int &nLen)
  36. {
  37. CHAR szFile[MAX_PATH + 1] = "";
  38. wsprintf(szFile, "%s\\config\\%s", szPath, szIniName);
  39. TRACE("szFile =%s\n",szFile);
  40. IniSendlen = GetPrivateProfileString(szCmd, "SendCmd", "", IniSendCMD, 10, szFile); // 返回的字符串是以\0结束的;
  41. GetPrivateProfileString(szCmd, "type", "", nType, 10, szFile);
  42. nType[strlen(nType)] = '\0';
  43. nIndex = GetPrivateProfileInt(szCmd, "Index", 0, szFile);
  44. nLen = GetPrivateProfileInt(szCmd, "Len", 0, szFile);
  45. return 0;
  46. }
  47. int CDaiKin_020701R2::SendReadRequest(
  48. char *szPath,
  49. char *szIniName,
  50. int nCommPort,
  51. int nAddr,
  52. char *szCmd,
  53. char *szMsg,
  54. int nReversed1,
  55. int nReversed2,
  56. int nReversed3,
  57. int nReversed4,
  58. int nReversed5,
  59. float fReversed1,
  60. float fReversed2,
  61. float fReversed3,
  62. char *szReversed1,
  63. char *szReversed2,
  64. char *szReversed3,
  65. char *szReversed4,
  66. char *szReversed5 )
  67. {
  68. //LOG4C((LOG_NOTICE,"->SendReadRequest"));
  69. CCommProcess *pComm = FindComm(nCommPort);
  70. if( pComm == NULL ) return -1;
  71. int nRet(-1);
  72. int nIndex(0), nLen(0), IniSendlen(0);
  73. char IniSendCMD[MAX_CMD] = {0}, szDataType[CMD_TYPE] = {0};
  74. GetIniInfo(szPath,szIniName,szCmd,IniSendCMD,IniSendlen,szDataType,nIndex,nLen);
  75. int iCmd = atoi(szCmd + 4);
  76. if ( iCmd == 1)
  77. {
  78. Send_ReadCommand_42H(nAddr, pComm,IniSendCMD,IniSendlen,szCmd);
  79. }else if ( iCmd >= 2 && iCmd <=8)
  80. {
  81. Send_ReadCommand_43H(nAddr, pComm,IniSendCMD,IniSendlen,szCmd);
  82. }else if ( iCmd == 10 )
  83. {
  84. Send_WriteCommand_45H(nAddr,pComm,szMsg,szCmd);
  85. }else if ( iCmd == 11)
  86. {
  87. }
  88. Get_42Msg(nAddr,szCmd,szMsg,nIndex,nLen,szDataType);
  89. Get_43Msg(nAddr,szCmd,szMsg,nIndex,nLen,szDataType);
  90. Get_45Msg(nAddr,szCmd,szMsg,nIndex,nLen,szDataType);
  91. Get_47Msg(nAddr,szCmd,szMsg,nIndex,nLen,szDataType);
  92. Get_49Msg(nAddr,szCmd,szMsg,nIndex,nLen,szDataType);
  93. LOG4C((LOG_NOTICE,"nRet = %d,cmd = %s,值 = %s",nRet,szCmd,szMsg));
  94. return nRet;
  95. }
  96. // 发送写设置;
  97. int CDaiKin_020701R2::SendSetReuest(
  98. char *szPath,
  99. char *szIniName,
  100. int nCommPort,
  101. int nAddr,
  102. char *szCmd,
  103. char *szMsg,
  104. int nReversed1,
  105. int nReversed2,
  106. int nReversed3,
  107. int nReversed4,
  108. int nReversed5,
  109. float fReversed1,
  110. float fReversed2,
  111. float fReversed3,
  112. char *szReversed1,
  113. char *szReversed2,
  114. char *szReversed3,
  115. char *szReversed4,
  116. char *szReversed5
  117. )
  118. {
  119. return 0;
  120. }
  121. int CDaiKin_020701R2::GetDeviceParam(int naddr, CCommProcess *pComm,char *IniSendCMD,const int &IniSendlen ,char *szCmd)
  122. {
  123. //LOG4C((LOG_NOTICE,"->GetDeviceParam"));
  124. int nRet(-1);
  125. nRet = Send_ReadDeviceData(naddr, pComm, IniSendCMD, IniSendlen);
  126. if( nRet != 0 ) {
  127. return nRet;
  128. }
  129. nRet = Recv_ReadDeviceData(naddr, pComm, szCmd);
  130. return nRet;
  131. }
  132. int CDaiKin_020701R2::Send_ReadCommand_42H(int nAddr,CCommProcess *pComm,const char *IniSendCMD,const int &IniSendlen, char *szCmd)
  133. {
  134. #if DEBUG_DAIKIN_020701R2
  135. // *********************发送请求数据****************************
  136. char chChkSum[5] = {0};
  137. BYTE byArySend[120] = {0};
  138. byArySend[0] = 0x7E;
  139. byArySend[1] = 0x32;
  140. byArySend[2] = 0x30;
  141. byArySend[3] = ByteToAscii((nAddr>>4) & 0x0f);
  142. byArySend[4] = ByteToAscii(nAddr & 0x0f);
  143. //Cid1
  144. byArySend[5] = 0x36;
  145. byArySend[6] = 0x30;
  146. //Cid2
  147. byArySend[7] = 0x34;
  148. byArySend[8] = 0x32;
  149. // lengchk;
  150. byArySend[9] = 0x30;
  151. byArySend[10] = 0x30;
  152. byArySend[11] = 0x30;
  153. byArySend[12] = 0x30;
  154. GetEmersonCheck((char *)byArySend + 1, chChkSum, 12 );
  155. memcpy(byArySend + 13, chChkSum, 4);
  156. byArySend[17] = 0x0D;
  157. if (WaitForSingleObject(m_hSemComm,0) == WAIT_OBJECT_0 )
  158. {
  159. ResetEvent(m_hSemComm);
  160. int nResult = pComm->Write(byArySend, 17);
  161. if (nResult != 17)
  162. {
  163. SetEvent(m_hSemComm);
  164. return EER_CODE_COM_REGNUM;
  165. }
  166. }
  167. else
  168. {
  169. return ERR_CODE_COM_BUSY;
  170. }
  171. // *********************接收返回的数据******************;
  172. int nProcessLen(0),nReadLen(0);
  173. char *pBuff = new char[MAX_RECE_MSG];
  174. memset(pBuff, 0 , MAX_RECE_MSG);
  175. nReadLen = pComm->Read((BYTE *)pBuff,MAX_RECE_MSG);
  176. int nRet = RtnCheck(pBuff, nReadLen);
  177. if (nRet != 0)
  178. {
  179. SetEvent( m_hSemComm );
  180. if( pBuff != NULL)
  181. {
  182. delete[] pBuff;
  183. pBuff = NULL;
  184. }
  185. LOG4C((LOG_NOTICE,"->RTN校验出错:%d",nRet));
  186. return nRet; //RTN校验出错
  187. }
  188. if (nReadLen <= 0)
  189. {
  190. SetEvent(m_hSemComm);
  191. if (pBuff != NULL)
  192. {
  193. delete [] pBuff;
  194. pBuff = NULL;
  195. }
  196. LOG4C((LOG_NOTICE,"->串口没有读到数据"));
  197. return ERR_CODE_COM_READ_NO_DATA;
  198. } //长度校验出错 ;
  199. //LOG4C((LOG_NOTICE,"->**1**"));
  200. m_dwOnlineTick[nAddr -1] = GetTickCount();
  201. #if IS_USE_READMSG_CS
  202. EnterCriticalSection(&m_csReadMsg);
  203. #endif
  204. memcpy(m_szE1Msg[nAddr -1], pBuff, sizeof(m_szE1Msg[nAddr -1]));
  205. #if IS_USE_READMSG_CS
  206. LeaveCriticalSection(&m_csReadMsg);
  207. #endif
  208. SetEvent( m_hSemComm );
  209. if( pBuff != NULL)
  210. {
  211. delete[] pBuff;
  212. pBuff = NULL;
  213. }
  214. #endif
  215. return 0;
  216. }
  217. int CDaiKin_020701R2::Send_ReadCommand_43H(int nAddr,CCommProcess *pComm,const char *IniSendCMD,const int &IniSendlen, char *szCmd)
  218. {
  219. #if DEBUG_DAIKIN_020701R2
  220. char chChkSum[5] = {0};
  221. BYTE byArySend[120] = {0};
  222. byArySend[0] = 0x7E;
  223. byArySend[1] = 0x32;
  224. byArySend[2] = 0x30;
  225. byArySend[3] = ByteToAscii((nAddr>>4) & 0x0f);
  226. byArySend[4] = ByteToAscii(nAddr & 0x0f);
  227. //Cid1
  228. byArySend[5] = 0x36;
  229. byArySend[6] = 0x30;
  230. //Cid2
  231. byArySend[7] = 0x34;
  232. byArySend[8] = 0x33;
  233. // lengchk;
  234. byArySend[9] = 0x30;
  235. byArySend[10] = 0x30;
  236. byArySend[11] = 0x30;
  237. byArySend[12] = 0x30;
  238. GetEmersonCheck((char *)byArySend + 1, chChkSum, 12 );
  239. memcpy(byArySend + 13, chChkSum, 4);
  240. byArySend[17] = 0x0D;
  241. if (WaitForSingleObject(m_hSemComm,0) == WAIT_OBJECT_0 )
  242. {
  243. ResetEvent(m_hSemComm);
  244. int nResult = pComm->Write(byArySend, 17);
  245. if (nResult != 17)
  246. {
  247. SetEvent(m_hSemComm);
  248. return EER_CODE_COM_REGNUM;
  249. }
  250. }
  251. else
  252. {
  253. return ERR_CODE_COM_BUSY;
  254. }
  255. #endif
  256. return 0;
  257. }
  258. int CDaiKin_020701R2::Send_WriteCommand_45H(int nAddr,CCommProcess *pComm,char *InPutCommand, char *szCmd)
  259. {
  260. #if DEBUG_DAIKIN_020701R2
  261. int iSendLen = 0;
  262. char chLength[4] = {0};
  263. char chChkSum[5] = {0};
  264. BYTE byArySend[120] = {0};
  265. byArySend[0] = 0x7E;
  266. byArySend[1] = 0x32;
  267. byArySend[2] = 0x30;
  268. byArySend[3] = ByteToAscii((nAddr>>4) & 0x0f);
  269. byArySend[4] = ByteToAscii(nAddr & 0x0f);
  270. //Cid1
  271. byArySend[5] = 0x36;
  272. byArySend[6] = 0x30;
  273. //Cid2
  274. byArySend[7] = 0x34;
  275. byArySend[8] = 0x35;
  276. //memcpy(byArySend + 7, szCid2, 2);
  277. byArySend[9] = 0x45;
  278. byArySend[10] = 0x30;
  279. byArySend[11] = 0x30;
  280. byArySend[12] = 0x32;
  281. int iCtrl = atoi(InPutCommand);
  282. memset(InPutCommand,0,strlen(InPutCommand));
  283. itoa(iCtrl,InPutCommand,16);
  284. for (int i(0); i < 2 ; i++)
  285. lowcase2uppcase((BYTE &)InPutCommand[i]);
  286. memcpy(byArySend + 13, InPutCommand, 2);
  287. GetEmersonCheck((char *)byArySend + 1, chChkSum, 14 );
  288. memcpy(byArySend + 15, chChkSum, 4);
  289. byArySend[19] = 0x0D;
  290. iSendLen = 20;
  291. if (WaitForSingleObject(m_hSemComm,0) == WAIT_OBJECT_0 )
  292. {
  293. ResetEvent(m_hSemComm);
  294. int nResult = pComm->Write(byArySend, iSendLen);
  295. if (nResult != iSendLen)
  296. {
  297. SetEvent(m_hSemComm);
  298. return EER_CODE_COM_REGNUM;
  299. }
  300. }
  301. else
  302. {
  303. return ERR_CODE_COM_BUSY;
  304. }
  305. #endif
  306. return 0;
  307. }
  308. int CDaiKin_020701R2::Send_ReadCommand_47H(int nAddr,CCommProcess *pComm,const char *IniSendCMD,const int &IniSendlen, char *szCmd)
  309. {
  310. #if DEBUG_DAIKIN_020701R2
  311. char chChkSum[5] = {0};
  312. BYTE byArySend[120] = {0};
  313. byArySend[0] = 0x7E;
  314. byArySend[1] = 0x32;
  315. byArySend[2] = 0x30;
  316. byArySend[3] = ByteToAscii((nAddr>>4) & 0x0f);
  317. byArySend[4] = ByteToAscii(nAddr & 0x0f);
  318. //Cid1
  319. byArySend[5] = 0x36;
  320. byArySend[6] = 0x30;
  321. //Cid2
  322. byArySend[7] = 0x34;
  323. byArySend[8] = 0x37;
  324. // lengchk;
  325. byArySend[9] = 0x30;
  326. byArySend[10] = 0x30;
  327. byArySend[11] = 0x30;
  328. byArySend[12] = 0x30;
  329. GetEmersonCheck((char *)byArySend + 1, chChkSum, 12 );
  330. memcpy(byArySend + 13, chChkSum, 4);
  331. byArySend[17] = 0x0D;
  332. if (WaitForSingleObject(m_hSemComm,0) == WAIT_OBJECT_0 )
  333. {
  334. ResetEvent(m_hSemComm);
  335. int nResult = pComm->Write(byArySend, 17);
  336. if (nResult != 17)
  337. {
  338. SetEvent(m_hSemComm);
  339. return EER_CODE_COM_REGNUM;
  340. }
  341. }
  342. else
  343. {
  344. return ERR_CODE_COM_BUSY;
  345. }
  346. #endif
  347. return 0;
  348. }
  349. int CDaiKin_020701R2::Send_WriteCommand_49H(int nAddr,CCommProcess *pComm,char *InPutCommand, char *szCmd)
  350. {
  351. #if DEBUG_DAIKIN_020701R2
  352. int iSendLen = 0;
  353. char chLength[4] = {0};
  354. char chChkSum[5] = {0};
  355. BYTE byArySend[120] = {0};
  356. byArySend[0] = 0x7E;
  357. byArySend[1] = 0x32;
  358. byArySend[2] = 0x30;
  359. byArySend[3] = ByteToAscii((nAddr>>4) & 0x0f);
  360. byArySend[4] = ByteToAscii(nAddr & 0x0f);
  361. //Cid1
  362. byArySend[5] = 0x36;
  363. byArySend[6] = 0x30;
  364. //Cid2
  365. byArySend[7] = 0x34;
  366. byArySend[8] = 0x39;
  367. //memcpy(byArySend + 7, szCid2, 2);
  368. byArySend[9] = 0x41;
  369. byArySend[10] = 0x30;
  370. byArySend[11] = 0x30;
  371. byArySend[12] = 0x36;
  372. if ( strcmp(szCmd,"cmd-17") == 0) // 设定开机温度;
  373. {
  374. byArySend[13] = 0x80;
  375. }else if ( strcmp(szCmd,"cmd-18") == 0) // 设定关机温度;
  376. {
  377. byArySend[13] = 0x81;
  378. }else if ( strcmp(szCmd,"cmd-19") == 0) // 设定回风温度上限;
  379. {
  380. byArySend[13] = 0x82;
  381. }else if ( strcmp(szCmd,"cmd-20") == 0) // 设定回风温度下限;
  382. {
  383. byArySend[13] = 0x83;
  384. }else if ( strcmp(szCmd,"cmd-21") == 0) // 设定回风湿度上限;
  385. {
  386. byArySend[13] = 0x84;
  387. }else if ( strcmp(szCmd,"cmd-22") == 0) // 设定回风湿度下限;
  388. {
  389. byArySend[13] = 0x85;
  390. }
  391. char szTemp[10] = {0};
  392. int iRealLen = strlen(InPutCommand);
  393. memcpy(szTemp,InPutCommand,iRealLen);
  394. if (iRealLen > 4)
  395. {
  396. LOG4C((LOG_NOTICE,"非法指令长度:%s",szMsg));
  397. return -1;
  398. }
  399. if (iRealLen == 2)
  400. {
  401. memcpy(InPutCommand + 1, szTemp,iRealLen);
  402. InPutCommand[0] = 48;
  403. }else if (iRealLen == 1)
  404. {
  405. memcpy(InPutCommand + 2, szTemp,iRealLen);
  406. InPutCommand[0] = 48;
  407. InPutCommand[1] = 48;
  408. }
  409. for (int i(0); i < 3 ; i++)
  410. lowcase2uppcase((BYTE &)InPutCommand[i]);
  411. memcpy(byArySend + 14, InPutCommand, 3);
  412. GetEmersonCheck((char *)byArySend + 1, chChkSum, 16 );
  413. memcpy(byArySend + 17, chChkSum, 4);
  414. byArySend[21] = 0x0D;
  415. iSendLen = 22;
  416. if (WaitForSingleObject(m_hSemComm,0) == WAIT_OBJECT_0 )
  417. {
  418. ResetEvent(m_hSemComm);
  419. int nResult = pComm->Write(byArySend, iSendLen);
  420. if (nResult != iSendLen)
  421. {
  422. SetEvent(m_hSemComm);
  423. return EER_CODE_COM_REGNUM;
  424. }
  425. }
  426. else
  427. {
  428. return ERR_CODE_COM_BUSY;
  429. }
  430. #endif
  431. return 0;
  432. }
  433. int CDaiKin_020701R2::Send_ReadDeviceData(int nAddr,CCommProcess *pComm,const char *IniSendCMD,const int &IniSendlen)
  434. {
  435. #if DEBUG_DAIKIN_020701R2
  436. char chLength[4] = {0};
  437. char chChkSum[5] = {0};
  438. BYTE byArySend[120] = {0};
  439. byArySend[0] = 0x7E;
  440. byArySend[1] = 0x32;
  441. byArySend[2] = 0x30;
  442. byArySend[3] = ByteToAscii((nAddr>>4) & 0x0f);
  443. byArySend[4] = ByteToAscii(nAddr & 0x0f);
  444. //Cid1
  445. byArySend[5] = 0x36;
  446. byArySend[6] = 0x30;
  447. //Cid2
  448. byArySend[7] = 0x45;
  449. byArySend[8] = 0x30;
  450. byArySend[9] = 0x45;
  451. byArySend[10] = 0x30;
  452. byArySend[11] = 0x30;
  453. byArySend[12] = 0x32;
  454. memcpy(byArySend + 13, szMsg, 2);
  455. GetEmersonCheck((char *)byArySend + 1, chChkSum, 14 );
  456. memcpy(byArySend + 15, chChkSum, 4);
  457. /*byArySend[0] = chChkSum[0];
  458. byArySend[1] = chChkSum[1];
  459. byArySend[2] = chChkSum[2];
  460. byArySend[3] = chChkSum[3]; */
  461. byArySend[19] = 0x0D;
  462. // 对数组进行赋值;
  463. int iLen = strlen((char*)szSendMSG);
  464. if (WaitForSingleObject(m_hSemComm,0) == WAIT_OBJECT_0 ) {
  465. ResetEvent(m_hSemComm);
  466. int nResult = pComm->Write(szSendMSG, iLen);
  467. if (nResult != iLen){
  468. SetEvent(m_hSemComm);
  469. return EER_CODE_COM_REGNUM;
  470. }
  471. }
  472. else{
  473. return ERR_CODE_COM_BUSY;
  474. }
  475. #endif
  476. return 0;
  477. }
  478. int CDaiKin_020701R2::Recv_ReadDeviceData(int nAddr,CCommProcess *pComm,char *szCmd, char *cRecvData)
  479. {
  480. #if DEBUG_DAIKIN_020701R2
  481. //LOG4C((LOG_NOTICE,"->Recv_ReadDeviceData"));
  482. int nProcessLen(0),nReadLen(0);
  483. char *pBuff = new char[MAX_RECE_MSG];
  484. memset(pBuff, 0 , MAX_RECE_MSG);
  485. nReadLen = pComm->Read((BYTE *)pBuff,MAX_RECE_MSG);
  486. int nRet = RtnCheck(pBuff, nReadLen);
  487. if (nRet != 0)
  488. {
  489. SetEvent( m_hSemComm );
  490. if( pBuff != NULL)
  491. {
  492. delete[] pBuff;
  493. pBuff = NULL;
  494. }
  495. LOG4C((LOG_NOTICE,"->RTN校验出错:%d",nRet));
  496. return nRet; //RTN校验出错
  497. }
  498. if (nReadLen <= 0){
  499. SetEvent(m_hSemComm);
  500. if (pBuff != NULL) {
  501. delete [] pBuff;
  502. pBuff = NULL;
  503. }
  504. LOG4C((LOG_NOTICE,"->串口没有读到数据"));
  505. return ERR_CODE_COM_READ_NO_DATA;
  506. } //长度校验出错 ;
  507. //LOG4C((LOG_NOTICE,"->**0**"));
  508. CopyUPS_41_Msg(nAddr, szCmd, pBuff);
  509. CopyUPS_E1_Msg(nAddr, szCmd, pBuff);
  510. CopyUPS_E2_Msg(nAddr, szCmd, pBuff);
  511. CopyUPS_E3_Msg(nAddr, szCmd, pBuff);
  512. CopyUPS_E7_Msg(nAddr, szCmd, pBuff);
  513. CopyUPS_43_Msg(nAddr, szCmd, pBuff);
  514. CopyUPS_44_Msg(nAddr, szCmd, pBuff);
  515. //LOG4C((LOG_NOTICE,"->**1**"));
  516. m_dwOnlineTick[nAddr -1] = GetTickCount();
  517. SetEvent( m_hSemComm );
  518. if( pBuff != NULL) {
  519. delete[] pBuff;
  520. pBuff = NULL;
  521. }
  522. #else
  523. SimulationCommData(nAddr);
  524. #endif
  525. return 0;
  526. }
  527. void CDaiKin_020701R2::ReturnID(CCommProcess *pComm, const int &iAddr, char* szID)
  528. {
  529. BYTE byArSend[6] = {0};
  530. byArSend[0] = 2;
  531. byArSend[1] = '1';
  532. byArSend[2] = '0';
  533. byArSend[3] = '0';
  534. byArSend[4] = 3;
  535. for ( int i = 0; i < 5; i++ )
  536. byArSend[5] += byArSend[i];
  537. //WaitForSingObject();等待有信号;
  538. if( WaitForSingleObject( m_hSemComm, 0 ) == WAIT_OBJECT_0 )
  539. {
  540. //ResetEvent()设置无信号状态
  541. ResetEvent( m_hSemComm );
  542. int nResult = pComm->Write(byArSend, 6);
  543. if( nResult != 6 )
  544. {
  545. //SetEvent设置有信号;
  546. SetEvent( m_hSemComm );
  547. //返回 错误值;
  548. return ;
  549. }
  550. }
  551. else
  552. {
  553. //如果m_hSemCom无信号,返回错误;
  554. return ;
  555. }
  556. /************************************************************************/
  557. /* readfile ; */
  558. /************************************************************************/
  559. int nRecvLen = 0;
  560. BYTE byArRecv[23] = {0};
  561. nRecvLen = pComm->Read(byArRecv,23);
  562. SetEvent( m_hSemComm );
  563. memset(szID, 0, 17);
  564. sprintf(szID,"%s",byArRecv+3);
  565. szID[16] = 0;
  566. LOG4C((LOG_NOTICE,"Authorization Sucess"));
  567. }
  568. int CDaiKin_020701R2::PassWordCheck(CCommProcess *pComm, const int &iAddr, BYTE *byArPaWd)
  569. {
  570. BYTE byArSend[15] = {0};
  571. byArSend[0] = 2;
  572. byArSend[1] = '1';
  573. byArSend[2] = '1';
  574. byArSend[3] = '0';
  575. memcpy(byArSend,byArPaWd,8);
  576. byArSend[12] = 3;
  577. for ( int i = 0; i < 13; i++ )
  578. byArSend[13] += byArSend[i];
  579. //WaitForSingObject();等待有信号;
  580. if( WaitForSingleObject( m_hSemComm, 0 ) == WAIT_OBJECT_0 )
  581. {
  582. //ResetEvent()设置无信号状态
  583. ResetEvent( m_hSemComm );
  584. int nResult = pComm->Write(byArSend, 14);
  585. if( nResult != 6 )
  586. {
  587. //SetEvent设置有信号;
  588. SetEvent( m_hSemComm );
  589. //返回 错误值;
  590. return -1 ;
  591. }
  592. }
  593. else
  594. {
  595. //如果m_hSemCom无信号,返回错误;
  596. return -1;
  597. }
  598. /************************************************************************/
  599. /* readfile ; */
  600. /************************************************************************/
  601. int nRecvLen = 0;
  602. BYTE byArRecv[7] = {0};
  603. nRecvLen = pComm->Read(byArRecv,7);
  604. SetEvent( m_hSemComm );
  605. if ( nRecvLen == 0)
  606. return -1;
  607. LOG4C((LOG_NOTICE,"Authorization Sucess"));
  608. return byArRecv[4];
  609. }
  610. int CDaiKin_020701R2::Get_400Msg(int nAddr, char *szCmd, char *szMsg, int &nIndex, int &nLen, char *szType )
  611. {
  612. int nRet(0);
  613. if (strcmp(szCmd, "cmd-1") ==0 || strcmp(szCmd, "cmd-2") ==0 || strcmp(szCmd, "cmd-3") ==0 ||
  614. strcmp(szCmd, "cmd-4") ==0 || strcmp(szCmd, "cmd-5") ==0 || strcmp(szCmd, "cmd-6") ==0 ||
  615. strcmp(szCmd, "cmd-7") ==0 || strcmp(szCmd, "cmd-8") ==0 || strcmp(szCmd, "cmd-9") ==0 ||
  616. strcmp(szCmd, "cmd-10") ==0 || strcmp(szCmd, "cmd-11") ==0 || strcmp(szCmd, "cmd-12") ==0 ||
  617. strcmp(szCmd, "cmd-13") ==0 || strcmp(szCmd, "cmd-14") ==0 || strcmp(szCmd, "cmd-15") ==0 )
  618. {
  619. #if IS_USE_READMSG_CS
  620. EnterCriticalSection(&m_csReadMsg);
  621. #endif
  622. DataConversion(szType, m_sz41Msg[nAddr -1] + nIndex, szMsg, nLen);
  623. #if IS_USE_READMSG_CS
  624. LeaveCriticalSection(&m_csReadMsg);
  625. #endif
  626. nRet = 0;
  627. }
  628. return nRet;
  629. }
  630. int CDaiKin_020701R2::GetUPS_E1Msg(int nAddr, char *szCmd, char *szMsg, int &nIndex, int &nLen, char *szType )
  631. {
  632. int nRet(0);
  633. if (strcmp(szCmd, "cmd-16") ==0 || strcmp(szCmd, "cmd-17") ==0 || strcmp(szCmd, "cmd-18") ==0 ||
  634. strcmp(szCmd, "cmd-19") ==0 || strcmp(szCmd, "cmd-20") ==0 || strcmp(szCmd, "cmd-21") ==0 ||
  635. strcmp(szCmd, "cmd-22") ==0 || strcmp(szCmd, "cmd-23") ==0 || strcmp(szCmd, "cmd-24") ==0 ||
  636. strcmp(szCmd, "cmd-25") ==0 || strcmp(szCmd, "cmd-26") ==0 || strcmp(szCmd, "cmd-27") ==0 ||
  637. strcmp(szCmd, "cmd-28") ==0 || strcmp(szCmd, "cmd-29") ==0 || strcmp(szCmd, "cmd-30") ==0 ||
  638. strcmp(szCmd, "cmd-31") ==0 )
  639. {
  640. #if IS_USE_READMSG_CS
  641. EnterCriticalSection(&m_csReadMsg);
  642. #endif
  643. DataConversion(szType, m_szE1Msg[nAddr -1] + nIndex, szMsg, nLen);
  644. #if IS_USE_READMSG_CS
  645. LeaveCriticalSection(&m_csReadMsg);
  646. #endif
  647. nRet = 0;
  648. }
  649. return nRet;
  650. }
  651. int CDaiKin_020701R2::GetUPS_E2Msg(int nAddr, char *szCmd, char *szMsg, int &nIndex, int &nLen, char *szType )
  652. {
  653. int nRet(0);
  654. if (strcmp(szCmd, "cmd-32") == 0 ||
  655. strcmp(szCmd, "cmd-33") == 0 || strcmp(szCmd, "cmd-34") == 0 || strcmp(szCmd, "cmd-35") == 0 ||
  656. strcmp(szCmd, "cmd-36") == 0 || strcmp(szCmd, "cmd-37") == 0 || strcmp(szCmd, "cmd-38") == 0 ||
  657. strcmp(szCmd, "cmd-39") == 0 || strcmp(szCmd, "cmd-40") == 0 || strcmp(szCmd, "cmd-41") == 0 ||
  658. strcmp(szCmd, "cmd-42") == 0 || strcmp(szCmd, "cmd-43") == 0 || strcmp(szCmd, "cmd-44") == 0 ||
  659. strcmp(szCmd, "cmd-45") == 0 || strcmp(szCmd, "cmd-46") == 0 || strcmp(szCmd, "cmd-47") == 0 ||
  660. strcmp(szCmd, "cmd-48") == 0 || strcmp(szCmd, "cmd-49") == 0 || strcmp(szCmd, "cmd-50") == 0 ||
  661. strcmp(szCmd, "cmd-51") == 0 )
  662. {
  663. #if IS_USE_READMSG_CS
  664. EnterCriticalSection(&m_csReadMsg);
  665. #endif
  666. DataConversion(szType, m_szE2Msg[nAddr -1] + nIndex, szMsg, nLen);
  667. #if IS_USE_READMSG_CS
  668. LeaveCriticalSection(&m_csReadMsg);
  669. #endif
  670. nRet = 0;
  671. }
  672. return nRet;
  673. }
  674. int CDaiKin_020701R2::GetUPS_E3Msg(int nAddr, char *szCmd, char *szMsg, int &nIndex, int &nLen, char *szType )
  675. {
  676. int nRet(0);
  677. if ( strcmp(szCmd, "cmd-52") == 0 || strcmp(szCmd, "cmd-53") == 0 || strcmp(szCmd, "cmd-54") == 0 ||
  678. strcmp(szCmd, "cmd-55") == 0 || strcmp(szCmd, "cmd-56") == 0 || strcmp(szCmd, "cmd-57") == 0 ||
  679. strcmp(szCmd, "cmd-58") == 0 || strcmp(szCmd, "cmd-59") == 0 || strcmp(szCmd, "cmd-60") == 0 ||
  680. strcmp(szCmd, "cmd-61") == 0 )
  681. {
  682. #if IS_USE_READMSG_CS
  683. EnterCriticalSection(&m_csReadMsg);
  684. #endif
  685. DataConversion(szType, m_szE3Msg[nAddr -1] + nIndex, szMsg, nLen);
  686. #if IS_USE_READMSG_CS
  687. LeaveCriticalSection(&m_csReadMsg);
  688. #endif
  689. nRet = 0;
  690. }
  691. return nRet;
  692. }
  693. int CDaiKin_020701R2::GetUPS_E7Msg(int nAddr, char *szCmd, char *szMsg, int &nIndex, int &nLen, char *szType )
  694. {
  695. int nRet(0);
  696. if ( strcmp(szCmd, "cmd-62") ==0 || strcmp(szCmd, "cmd-63") ==0 || strcmp(szCmd, "cmd-64") ==0 ||
  697. strcmp(szCmd, "cmd-65") ==0 || strcmp(szCmd, "cmd-66") ==0 || strcmp(szCmd, "cmd-67") ==0 ||
  698. strcmp(szCmd, "cmd-68") ==0 || strcmp(szCmd, "cmd-69") ==0 || strcmp(szCmd, "cmd-70") ==0 )
  699. {
  700. #if IS_USE_READMSG_CS
  701. EnterCriticalSection(&m_csReadMsg);
  702. #endif
  703. DataConversion(szType, m_szE7Msg[nAddr -1] + nIndex, szMsg, nLen);
  704. #if IS_USE_READMSG_CS
  705. LeaveCriticalSection(&m_csReadMsg);
  706. #endif
  707. nRet = 0;
  708. }
  709. return nRet;
  710. }
  711. int CDaiKin_020701R2::GetUPS_43Msg(int nAddr, char *szCmd, char *szMsg, int &nIndex, int &nLen, char *szType )
  712. {
  713. int nRet(0);
  714. if (strcmp(szCmd, "cmd-71") ==0 || strcmp(szCmd, "cmd-72") ==0 || strcmp(szCmd, "cmd-73") ==0 ||
  715. strcmp(szCmd, "cmd-74") ==0 || strcmp(szCmd, "cmd-75") ==0 || strcmp(szCmd, "cmd-76") ==0 ||
  716. strcmp(szCmd, "cmd-77") ==0 || strcmp(szCmd, "cmd-78") ==0 || strcmp(szCmd, "cmd-79") ==0 ||
  717. strcmp(szCmd, "cmd-80") ==0 || strcmp(szCmd, "cmd-81") ==0 || strcmp(szCmd, "cmd-82") ==0 ||
  718. strcmp(szCmd, "cmd-83") ==0 || strcmp(szCmd, "cmd-84") ==0 || strcmp(szCmd, "cmd-85") ==0 ||
  719. strcmp(szCmd, "cmd-86") ==0 || strcmp(szCmd, "cmd-87") ==0 || strcmp(szCmd, "cmd-88") ==0 ||
  720. strcmp(szCmd, "cmd-89") ==0 || strcmp(szCmd, "cmd-90") ==0 || strcmp(szCmd, "cmd-91") ==0 ||
  721. strcmp(szCmd, "cmd-92") ==0 || strcmp(szCmd, "cmd-93") ==0 || strcmp(szCmd, "cmd-94") ==0 ||
  722. strcmp(szCmd, "cmd-95") ==0 )
  723. {
  724. #if IS_USE_READMSG_CS
  725. EnterCriticalSection(&m_csReadMsg);
  726. #endif
  727. DataConversion(szType, m_sz43Msg[nAddr -1] + nIndex, szMsg, nLen);
  728. #if IS_USE_READMSG_CS
  729. LeaveCriticalSection(&m_csReadMsg);
  730. #endif
  731. nRet = 0;
  732. }
  733. return nRet;
  734. }
  735. int CDaiKin_020701R2::GetUPS_44Msg(int nAddr,char *szCmd, char *szMsg, int &nIndex, int &nLen, char *szType )
  736. {
  737. int nRet(0);
  738. if (strcmp(szCmd, "cmd-96") ==0 || strcmp(szCmd, "cmd-97") ==0 || strcmp(szCmd, "cmd-98") ==0 ||
  739. strcmp(szCmd, "cmd-99") ==0 || strcmp(szCmd, "cmd-100") ==0 || strcmp(szCmd, "cmd-101") ==0 ||
  740. strcmp(szCmd, "cmd-102") ==0 || strcmp(szCmd, "cmd-103") ==0 || strcmp(szCmd, "cmd-104") ==0 ||
  741. strcmp(szCmd, "cmd-105") ==0 || strcmp(szCmd, "cmd-106") ==0 || strcmp(szCmd, "cmd-107") ==0 ||
  742. strcmp(szCmd, "cmd-108") ==0 || strcmp(szCmd, "cmd-109") ==0 || strcmp(szCmd, "cmd-110") ==0 ||
  743. strcmp(szCmd, "cmd-111") ==0 || strcmp(szCmd, "cmd-112") ==0 || strcmp(szCmd, "cmd-113") ==0 ||
  744. strcmp(szCmd, "cmd-114") ==0 || strcmp(szCmd, "cmd-115") ==0 || strcmp(szCmd, "cmd-116") ==0 ||
  745. strcmp(szCmd, "cmd-117") ==0 || strcmp(szCmd, "cmd-118") ==0 || strcmp(szCmd, "cmd-119") ==0 ||
  746. strcmp(szCmd, "cmd-120") ==0 || strcmp(szCmd, "cmd-121") ==0 || strcmp(szCmd, "cmd-122") ==0 ||
  747. strcmp(szCmd, "cmd-123") ==0 || strcmp(szCmd, "cmd-124") ==0 || strcmp(szCmd, "cmd-125") ==0 ||
  748. strcmp(szCmd, "cmd-126") ==0 || strcmp(szCmd, "cmd-127") ==0 || strcmp(szCmd, "cmd-128") ==0 ||
  749. strcmp(szCmd, "cmd-129") ==0 || strcmp(szCmd, "cmd-130") ==0 || strcmp(szCmd, "cmd-131") ==0 ||
  750. strcmp(szCmd, "cmd-132") ==0 || strcmp(szCmd, "cmd-133") ==0 || strcmp(szCmd, "cmd-134") ==0 ||
  751. strcmp(szCmd, "cmd-135") ==0 || strcmp(szCmd, "cmd-136") ==0 || strcmp(szCmd, "cmd-137") ==0 ||
  752. strcmp(szCmd, "cmd-138") ==0 || strcmp(szCmd, "cmd-139") ==0 || strcmp(szCmd, "cmd-140") ==0 ||
  753. strcmp(szCmd, "cmd-141") ==0 || strcmp(szCmd, "cmd-142") ==0 || strcmp(szCmd, "cmd-143") ==0 ||
  754. strcmp(szCmd, "cmd-144") ==0 || strcmp(szCmd, "cmd-145") ==0 || strcmp(szCmd, "cmd-146") ==0 ||
  755. strcmp(szCmd, "cmd-147") ==0 || strcmp(szCmd, "cmd-148") ==0 || strcmp(szCmd, "cmd-149") ==0 ||
  756. strcmp(szCmd, "cmd-150") ==0 || strcmp(szCmd, "cmd-151") ==0 || strcmp(szCmd, "cmd-152") ==0 ||
  757. strcmp(szCmd, "cmd-153") ==0 || strcmp(szCmd, "cmd-154") ==0 || strcmp(szCmd, "cmd-155") ==0 ||
  758. strcmp(szCmd, "cmd-156") ==0 || strcmp(szCmd, "cmd-157") ==0 || strcmp(szCmd, "cmd-158") ==0 ||
  759. strcmp(szCmd, "cmd-159") ==0 || strcmp(szCmd, "cmd-160") ==0 || strcmp(szCmd, "cmd-161") ==0 ||
  760. strcmp(szCmd, "cmd-162") ==0 || strcmp(szCmd, "cmd-163") ==0 || strcmp(szCmd, "cmd-164") ==0 ||
  761. strcmp(szCmd, "cmd-165") ==0 || strcmp(szCmd, "cmd-166") ==0 || strcmp(szCmd, "cmd-167") ==0 ||
  762. strcmp(szCmd, "cmd-168") ==0 || strcmp(szCmd, "cmd-169") ==0 || strcmp(szCmd, "cmd-170") ==0 ||
  763. strcmp(szCmd, "cmd-171") ==0 || strcmp(szCmd, "cmd-172") ==0 || strcmp(szCmd, "cmd-173") ==0 ||
  764. strcmp(szCmd, "cmd-174") ==0 || strcmp(szCmd, "cmd-175") ==0 || strcmp(szCmd, "cmd-176") ==0 ||
  765. strcmp(szCmd, "cmd-177") ==0 || strcmp(szCmd, "cmd-178") ==0 || strcmp(szCmd, "cmd-179") ==0 ||
  766. strcmp(szCmd, "cmd-180") ==0 || strcmp(szCmd, "cmd-181") ==0 )
  767. {
  768. #if IS_USE_READMSG_CS
  769. EnterCriticalSection(&m_csReadMsg);
  770. #endif
  771. DataConversion(szType, m_sz44Msg[nAddr -1] + nIndex, szMsg, nLen);
  772. #if IS_USE_READMSG_CS
  773. LeaveCriticalSection(&m_csReadMsg);
  774. #endif
  775. nRet = 0;
  776. }
  777. return nRet;
  778. }
  779. void CDaiKin_020701R2::lowcase2uppcase(BYTE &btSrc)
  780. {
  781. if( btSrc >= 'a' && btSrc <= 'z' )
  782. {
  783. btSrc = btSrc - 'a' + 'A';
  784. }
  785. }
  786. void CDaiKin_020701R2::GetEmersonLength(const int &iLenID, char *szLegth)
  787. {
  788. int ilengthchecksum(0);
  789. int it = iLenID;
  790. ilengthchecksum = it & 0x00F ; it = iLenID;
  791. ilengthchecksum += (it &0x0F0) >> 4; it = iLenID;
  792. ilengthchecksum += (it &0xF00 ) >> 8;
  793. ilengthchecksum = ilengthchecksum%16;
  794. ilengthchecksum = ~ilengthchecksum +17;
  795. int ilength = (ilengthchecksum & 0x000F) << 12 ;
  796. ilength = ilength | iLenID;
  797. itoa(ilength,szLegth,16 );
  798. for (int i(0) ; i < 5 ; i++)
  799. {
  800. lowercase2uppercase((BYTE &)szLegth[i]);
  801. }
  802. }
  803. void CDaiKin_020701R2::GetEmersonCheck(char *szData, char *szCheck ,int nlen /* = 12 */)
  804. {
  805. DWORD dwSum(0);
  806. nlen = strlen(szData);
  807. for (int i(0); i < nlen; i++)
  808. {
  809. dwSum += szData[i] ;
  810. }
  811. WORD iCompliment = dwSum;
  812. iCompliment = ~iCompliment;//取反
  813. iCompliment++;
  814. itoa(iCompliment, szCheck, 16);
  815. for (int i(0); i < 5 ; i++)
  816. {
  817. lowcase2uppcase((BYTE &)szCheck[i]);
  818. }
  819. }
  820. WORD CDaiKin_020701R2::RtnCheck(char *szMsg,int len)
  821. {
  822. char ch[2] = {0};
  823. ch[0] = szMsg[7];
  824. ch[1] = szMsg[8];
  825. if (atoi(ch) == 0)
  826. {
  827. return ERR_CODE_RTN_NATURAL;
  828. }
  829. else if (atoi(ch) ==1)
  830. {
  831. return ERR_CODE_RTN_VER_ERROR;
  832. }
  833. else if (atoi(ch) ==2)
  834. {
  835. return ERR_CODE_RTN_CHKSUM_ERROR;
  836. }
  837. else if (atoi(ch) ==3)
  838. {
  839. return ERR_CODE_RTN_LCHKSUM_ERROR;
  840. }
  841. else if (atoi(ch) ==4)
  842. {
  843. return ERR_CODE_RTN_CID_ERROR;
  844. }
  845. else if (atoi(ch) ==5)
  846. {
  847. return ERR_CODE_RTN_COMMAND_FORMAT;
  848. }
  849. else if (atoi(ch) ==6)
  850. {
  851. return ERR_CODE_RTN_INVALID_DATA;
  852. }
  853. else if (atoi(ch) ==16)
  854. {
  855. return ERR_CODE_RTN_INVALID_LIMIT;
  856. }
  857. else if (atoi(ch) ==17)
  858. {
  859. return ERR_CODE_RTN_OPERATE_FAIL;
  860. }
  861. else if (atoi(ch) ==18)
  862. {
  863. return ERR_CODE_RTN_EQUIT_FAIL;
  864. }
  865. return -1;
  866. }
  867. void CDaiKin_020701R2::SimulationCommData(int nAddr)
  868. {
  869. //~10012A0020680033335F439A1963439A99644366665C4333335A4333335D433333B33F0000C03FCDCC8C3F33B3DA43CDCC474200000033B3DA43E71D.
  870. memcpy(m_sz41Msg[nAddr -1], "~10012A0020680033335F439A1963439A99644366665C4333335A4333335D433333B33F0000C03FCDCC8C3F33B3DA43CDCC474200000033B3DA43E71D.", sizeof("~10012A0020680033335F439A1963439A99644366665C4333335A4333335D433333B33F0000C03FCDCC8C3F33B3DA43CDCC474200000033B3DA43E71D."));
  871. //~10012A00307600000E66A6C2439A19C5439A59C3436666663FCDCC4C3F0000803FC3F547423333333FA4703D3F1F852B3F9A995F43CD4C614333B35E4348E14742E3B1.
  872. memcpy(m_szE1Msg[nAddr -1], "~10012A00307600000E66A6C2439A19C5439A59C3436666663FCDCC4C3F0000803FC3F547423333333FA4703D3F1F852B3F9A995F43CD4C614333B35E4348E14742E3B1.", sizeof("~10012A00307600000E66A6C2439A19C5439A59C3436666663FCDCC4C3F0000803FC3F547423333333FA4703D3F1F852B3F9A995F43CD4C614333B35E4348E14742E3B1."));
  873. //~10012A00109600001285EB113F1F856B3F000000003333334000000040CDCCCC3FCDCCCC3D9A99993E00000000CDCC4C3ECDCC4C3ECDCCCC3D9A99993ECDCCCC3ECDCCCC3D9A9979409A99D9403333F33FDB96.
  874. memcpy(m_szE2Msg[nAddr -1], "~10012A00109600001285EB113F1F856B3F000000003333334000000040CDCCCC3FCDCCCC3D9A99993E00000000CDCC4C3ECDCC4C3ECDCCCC3D9A99993ECDCCCC3ECDCCCC3D9A9979409A99D9403333F33FDB96.", sizeof("~10012A00109600001285EB113F1F856B3F000000003333334000000040CDCCCC3FCDCCCC3D9A99993E00000000CDCC4C3ECDCC4C3ECDCCCC3D9A99993ECDCCCC3ECDCCCC3D9A9979409A99D9403333F33FDB96."));
  875. //~10012A00004C0009000000000000000000000000000000000000000000000000000000000000000000000000EF4B.
  876. memcpy(m_szE3Msg[nAddr -1], "~10012A00004C0009000000000000000000000000000000000000000000000000000000000000000000000000EF4B.", sizeof("~10012A00004C0009000000000000000000000000000000000000000000000000000000000000000000000000EF4B."));
  877. //~10012A00604600010800009644CD4C5A430AD7233E66E65A430AD7233E0000803F0000C8410000C841EEC9.
  878. memcpy(m_szE7Msg[nAddr -1], "~10012A00604600010800009644CD4C5A430AD7233E66E65A430AD7233E0000803F0000C8410000C841EEC9.", sizeof("~10012A00604600010800009644CD4C5A430AD7233E66E65A430AD7233E0000803F0000C8410000C841EEC9."));
  879. //~10012A009034000117E1E0E1E0E1E1E0E1E1E0E2E1E2E0E1E1E1E1E1E1E1E1E1F1D2.
  880. memcpy(m_sz43Msg[nAddr -1], "~10012A009034000117E1E0E1E0E1E1E0E1E1E0E2E1E2E0E1E1E1E1E1E1E1E1E1F1D2.", sizeof("~10012A009034000117E1E0E1E0E1E1E0E1E1E0E2E1E2E0E1E1E1E1E1E1E1E1E1F1D2."));
  881. //~10012A00B0BA000000000000000054000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000DA8D.
  882. memcpy(m_sz44Msg[nAddr -1], "~10012A00B0BA000000000000000054000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000DA8D.", sizeof("~10012A00B0BA000000000000000054000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000DA8D."));
  883. }
  884. /////////