rtuprocess.cpp 18 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677
  1. #include "stdafx.h"
  2. #include "rtuprocess.h"
  3. #include "Global.h"
  4. #include "struct.h"
  5. #include "NoticeQueue.h"
  6. #include "SysLib.h"
  7. HANDLE g_RTURequestThread = NULL;
  8. HANDLE g_RTUResponseThread = NULL;
  9. DWORD g_dwRtuVariantTick = 0;
  10. CRITICAL_SECTION g_csRtuReadOneData;
  11. //rtu动态库输出函数
  12. HINSTANCE g_hRTULibModule = NULL;
  13. RTU_DLLInitCom pRTU_DLLInitCom = NULL;
  14. RTU_DLLInit pRTU_DLLInit = NULL;
  15. RTU_DLLUnInit pRTU_DLLUnInit = NULL;
  16. RTU_DLLWrite pRTU_DLLWrite = NULL;
  17. RTU_DLLRequestWrStatusData pRTU_DLLRequestWrStatusData = NULL;
  18. int RtuResponseValue();
  19. int RtuCommandSend();
  20. void UnInitRtuDll();
  21. BOOL LoadRtuDll(CString strpath)
  22. {
  23. char strFile[256] = {0};
  24. g_hRTULibModule = NULL;
  25. sprintf(strFile, "%s\\dll\\modbusrtu.dll", strpath);
  26. InitializeCriticalSection( &g_csRtuReadOneData );
  27. g_hRTULibModule = AfxLoadLibrary(strFile);
  28. //RTU 动态库初始化
  29. if (NULL != g_hRTULibModule)
  30. {
  31. pRTU_DLLInitCom =( RTU_DLLInitCom)::GetProcAddress(g_hRTULibModule, "RTU_DLLInitCom");
  32. pRTU_DLLInit = (RTU_DLLInit)::GetProcAddress(g_hRTULibModule, "RTU_DLLInit");
  33. pRTU_DLLUnInit = (RTU_DLLUnInit)::GetProcAddress(g_hRTULibModule, "RTU_DLLUnInit");
  34. pRTU_DLLWrite = (RTU_DLLWrite)::GetProcAddress(g_hRTULibModule, "RTU_DLLWrite");
  35. pRTU_DLLRequestWrStatusData = (RTU_DLLRequestWrStatusData)::GetProcAddress(g_hRTULibModule, "RTU_DLLRequestWrStatusData");
  36. return TRUE;
  37. }
  38. else
  39. {
  40. return FALSE;
  41. }
  42. }
  43. BOOL InitRtuComm(int iAddr, int iPort, int iBaudrate, int iDataBit, int iStopBit, int iParity, int iIntervals)
  44. {
  45. if( NULL != pRTU_DLLInitCom )
  46. {
  47. //LOG4C((LOG_NOTICE, "Enter pRTU_DLLInitCom"));
  48. if (pRTU_DLLInitCom(iAddr,iPort, iBaudrate, iDataBit, iStopBit, iParity, iIntervals))//初始化串口
  49. return TRUE;
  50. else
  51. return FALSE;
  52. }
  53. else
  54. {
  55. LOG4C((LOG_NOTICE, "pRTU_DLLInitCom is null!"));
  56. return FALSE;
  57. }
  58. }
  59. //用于只发送一次读命令特殊变量的请求
  60. int RtuRequestSpecData(SETBASEPARAM SetBasePara,int nDataLen,int nPort,int nDevAddr,char chDevUid[20], int iVarID,int iSpecialFlag)
  61. {
  62. char chMsg[80] = {0};
  63. if ( pRTU_DLLInit == NULL )
  64. return -1;
  65. int nRet = pRTU_DLLInit(nPort,
  66. nDevAddr,
  67. SetBasePara,
  68. nDataLen,
  69. chMsg);
  70. if ( nRet == 0)
  71. {
  72. //TRACE("Enter AscSingleResponseSpecialVarData\r\n");
  73. nRet = RtuSingleResponseSpecialVarData( chDevUid,
  74. iVarID,
  75. iSpecialFlag,
  76. chMsg);
  77. //TRACE("Leave AscSingleResponseSpecialVarData\r\n");
  78. }
  79. else
  80. {
  81. if( nRet==30005 )
  82. LOG4C((LOG_NOTICE, "校验出错:ID=%d, nRet=%d, %s",iVarID,nRet,chMsg ));
  83. }
  84. //TRACE("Rtu设备请求成功\r\n");
  85. return nRet;
  86. }
  87. int RtuSingleResponseSpecialVarData(char chDevUid[20], int iVarID, int iSpecialFlag, char chMsg[80])
  88. {
  89. int nDeviceIndex = -1, nVarIndex = -1;
  90. BOOL bFind = FindVar(chDevUid, iVarID, nDeviceIndex, nVarIndex);
  91. if( bFind == FALSE ) return -1;
  92. CDevice *pDev = g_pDevicesManager->m_Devices[nDeviceIndex];
  93. CBaseVar *pBaseVar = pDev->m_Vars[nVarIndex];
  94. EnterCriticalSection( &g_csRtuReadOneData );
  95. pDev->m_dwOnlineTick = GetTickCount();
  96. LeaveCriticalSection( &g_csRtuReadOneData );
  97. int nValue = 0;
  98. CString strMemos, strWarnContent;
  99. double fCoef = pBaseVar->m_dbCoefficient;
  100. if (iSpecialFlag == 10004)
  101. {
  102. short int wdValue;
  103. memcpy(&wdValue, chMsg, sizeof(short int));
  104. nValue = ntohs(wdValue);
  105. //pBaseVar->m_dbData = (double)(nValue * fCoef);
  106. if( pBaseVar->m_nMaxValues != 0 || pBaseVar->m_nMinValues != 0 ||
  107. pBaseVar->m_nMaxConvtRate != 0 || pBaseVar->m_nMinConvtRate != 0 )
  108. {
  109. double fScale = 1.0;
  110. if( pBaseVar->m_nMaxValues - pBaseVar->m_nMinValues > 0 )
  111. {
  112. fScale = (double)(pBaseVar->m_nMaxConvtRate - pBaseVar->m_nMinConvtRate) /
  113. (double)(pBaseVar->m_nMaxValues - pBaseVar->m_nMinValues);
  114. }
  115. if( nValue < 0.0 )
  116. {
  117. pBaseVar->m_dbData = 0.0;
  118. }
  119. else
  120. {
  121. pBaseVar->m_dbData = nValue * fCoef * fScale;
  122. }
  123. }
  124. else
  125. {
  126. if( nValue < 0.0 )
  127. {
  128. pBaseVar->m_dbData = 0.0;
  129. }
  130. else
  131. {
  132. pBaseVar->m_dbData = (double)(nValue * fCoef);
  133. }
  134. }
  135. if( pBaseVar->m_nRearm != 0 )
  136. {
  137. pBaseVar->m_dbData = pBaseVar->m_dbData + pBaseVar->m_nRearm;
  138. }
  139. }
  140. if (iSpecialFlag == 10005)
  141. {
  142. short int wdValue;
  143. memcpy(&wdValue, chMsg+2, sizeof(short int));
  144. nValue = ntohs(wdValue);
  145. if( pBaseVar->m_nMaxValues != 0 || pBaseVar->m_nMinValues != 0 ||
  146. pBaseVar->m_nMaxConvtRate != 0 || pBaseVar->m_nMinConvtRate != 0 )
  147. {
  148. double fScale = 1.0;
  149. if( pBaseVar->m_nMaxValues - pBaseVar->m_nMinValues > 0 )
  150. {
  151. fScale = (double)(pBaseVar->m_nMaxConvtRate - pBaseVar->m_nMinConvtRate) /
  152. (double)(pBaseVar->m_nMaxValues - pBaseVar->m_nMinValues);
  153. }
  154. if( nValue < 0.0 )
  155. {
  156. pBaseVar->m_dbData = 0.0;
  157. }
  158. else
  159. {
  160. pBaseVar->m_dbData = nValue *
  161. fCoef *
  162. fScale;
  163. }
  164. }
  165. else
  166. {
  167. if( nValue < 0.0 )
  168. {
  169. pBaseVar->m_dbData = 0.0;
  170. }
  171. else
  172. {
  173. pBaseVar->m_dbData = (double)(nValue * fCoef);
  174. }
  175. }
  176. if( pBaseVar->m_nRearm != 0 )
  177. {
  178. pBaseVar->m_dbData = pBaseVar->m_dbData + pBaseVar->m_nRearm;
  179. }
  180. }
  181. if( 10006 == iSpecialFlag )
  182. {
  183. short int wdValue = 0;
  184. short int whValue = 0, wlValue = 0;
  185. memcpy(&wdValue, chMsg, sizeof(short int));
  186. whValue = ntohs(wdValue);
  187. memcpy(&wdValue, chMsg+2, sizeof(short int));
  188. wlValue = ntohs(wdValue);
  189. //pBaseVar->m_dbData = (double)( (wlValue * 10000 + whValue) * fCoef);
  190. //if( pBaseVar->m_nRearm != 0 )
  191. //{
  192. // pBaseVar->m_dbData = pBaseVar->m_dbData + pBaseVar->m_nRearm;
  193. //}
  194. if( pBaseVar->m_nMaxValues != 0 || pBaseVar->m_nMinValues != 0 ||
  195. pBaseVar->m_nMaxConvtRate != 0 || pBaseVar->m_nMinConvtRate != 0 )
  196. {
  197. double fScale = 1.0;
  198. if( pBaseVar->m_nMaxValues - pBaseVar->m_nMinValues > 0 )
  199. {
  200. fScale = (double)(pBaseVar->m_nMaxConvtRate - pBaseVar->m_nMinConvtRate) /
  201. (double)(pBaseVar->m_nMaxValues - pBaseVar->m_nMinValues);
  202. }
  203. if( nValue < 0.0 )
  204. {
  205. pBaseVar->m_dbData = 0.0;
  206. }
  207. else
  208. {
  209. pBaseVar->m_dbData = (wlValue * 10000 + whValue) *
  210. fCoef *
  211. fScale;
  212. }
  213. }
  214. else
  215. {
  216. if( nValue < 0.0 )
  217. {
  218. pBaseVar->m_dbData = 0.0;
  219. }
  220. else
  221. {
  222. pBaseVar->m_dbData = (double)((wlValue * 10000 + whValue) * fCoef);
  223. }
  224. }
  225. if( pBaseVar->m_nRearm != 0 )
  226. {
  227. pBaseVar->m_dbData = pBaseVar->m_dbData + pBaseVar->m_nRearm;
  228. }
  229. }
  230. EnterCriticalSection(&g_csRtuReadOneData);
  231. pDev->m_dwOnlineTick = GetTickCount();
  232. LeaveCriticalSection(&g_csRtuReadOneData);
  233. return 0;
  234. }
  235. int RtuSingleResponseData(char chDevUid[20], int iVarID, char chMsg[80])
  236. {
  237. int nDeviceIndex = -1, nVarIndex = -1;
  238. BOOL bFind = FindVar(chDevUid, iVarID, nDeviceIndex, nVarIndex);
  239. if( bFind == FALSE )
  240. {
  241. return -1;
  242. }
  243. CDevice *pDev = g_pDevicesManager->m_Devices[nDeviceIndex];
  244. CBaseVar *pBaseVar = pDev->m_Vars[nVarIndex];
  245. EnterCriticalSection(&g_csRtuReadOneData);
  246. pDev->m_dwOnlineTick = GetTickCount();
  247. LeaveCriticalSection(&g_csRtuReadOneData);
  248. int nVarItemID = pBaseVar->m_nVarItemID;
  249. int nDataLen = pBaseVar->m_iDataLen;
  250. int nValue;
  251. DWORD wdValue;
  252. double fCoef = pBaseVar->m_dbCoefficient;
  253. if( nVarItemID > 0 )//BIT位变量
  254. {
  255. int nStartBit = pBaseVar->m_nStartBit;
  256. int nEndBit = pBaseVar->m_nEndBit;
  257. int nStartReg, nEndReg;
  258. if( nEndBit - nStartBit < 7 ) // 一般告警状态会这样子定义,Modbus Ascii码暂时没有碰到,没有经过调试,待测试
  259. {
  260. if( nDataLen == 1 )
  261. {
  262. char chBuffer[8] = {0};
  263. memset(chBuffer, 0, sizeof(chBuffer));
  264. BYTE byValue = chMsg[0];
  265. DigitToBinary(byValue, chBuffer, 8) ;
  266. CString strTemp;
  267. switch( nEndBit - nStartBit )
  268. {
  269. case 0:
  270. strTemp.Format("%c", chBuffer[nStartBit]);
  271. nValue = atoi(strTemp);
  272. break;
  273. case 1:
  274. strTemp.Format("%c%c", chBuffer[nStartBit], chBuffer[nStartBit + 1]);
  275. nValue = AsciiToBYTE(strTemp[0]) * 2 + AsciiToBYTE(strTemp[1]);
  276. break;
  277. case 2:
  278. strTemp.Format("%c%c%c", chBuffer[nStartBit], chBuffer[nStartBit + 1], chBuffer[nStartBit + 2]);
  279. nValue = AsciiToBYTE(strTemp[0]) * 4 + AsciiToBYTE(strTemp[1]) * 2 + AsciiToBYTE(strTemp[2]);
  280. break;
  281. case 3:
  282. strTemp.Format("%c%c%c%c", chBuffer[nStartBit], chBuffer[nStartBit + 1],
  283. chBuffer[nStartBit + 2], chBuffer[nStartBit +3]);
  284. nValue = AsciiToBYTE(strTemp[0]) * 8 + AsciiToBYTE(strTemp[1]) * 4 + AsciiToBYTE(strTemp[2]) * 2 + AsciiToBYTE(strTemp[0]);
  285. break;
  286. case 4:
  287. strTemp.Format("%c%c%c%c%c", chBuffer[nStartBit], chBuffer[nStartBit + 1],
  288. chBuffer[nStartBit + 2], chBuffer[nStartBit + 3], chBuffer[nStartBit + 4]);
  289. break;
  290. case 5:
  291. strTemp.Format("%c%c%c%c%c%c", chBuffer[nStartBit], chBuffer[nStartBit + 1], chBuffer[nStartBit + 2],
  292. chBuffer[nStartBit + 3], chBuffer[nStartBit + 4], chBuffer[nStartBit + 5]);
  293. break;
  294. case 6:
  295. strTemp.Format("%c%c%c%c%c%c%c", chBuffer[nStartBit], chBuffer[nStartBit + 1], chBuffer[nStartBit + 2],
  296. chBuffer[nStartBit + 3], chBuffer[nStartBit + 4], chBuffer[nStartBit + 5], chBuffer[nStartBit + 6]);
  297. break;
  298. default:
  299. LOG4C((LOG_NOTICE, "起始位与终止位不对",pDev->m_strDeviceName, pBaseVar->m_strDesc));
  300. }
  301. //nValue = atoi(strTemp);
  302. //strTemp.Format("%d",
  303. }
  304. else if( nDataLen == 2 )
  305. {
  306. char chBuffer[16] = {0};
  307. //chMsg[0] = 0x00;
  308. //chMsg[2] = 0x00;
  309. //chMsg[2] = 0x0E;
  310. //chMsg[3] = 0x0F;
  311. //WORD wValue = ( ( (AsciiToBYTE(chMsg[0]) << 4) | ( AsciiToBYTE(chMsg[1]) & 0x00FF ) ) << 8 ) |
  312. // ( ( (AsciiToBYTE(chMsg[2]) << 4) | ( AsciiToBYTE(chMsg[3]) & 0x00FF ) ) & 0x0000FFFF );
  313. WORD wValue;
  314. memcpy(&wValue, chMsg, sizeof(WORD));
  315. wValue = ntohs(wValue);
  316. DigitToBinary(wValue, chBuffer, 16) ;
  317. CString strTemp;
  318. switch( nEndBit - nStartBit )
  319. {
  320. case 0:
  321. strTemp.Format("%c", chBuffer[nStartBit]);
  322. nValue = atoi(strTemp);
  323. break;
  324. case 1:
  325. strTemp.Format("%c%c", chBuffer[nStartBit], chBuffer[nStartBit + 1]);
  326. nValue = AsciiToBYTE(strTemp[0]) * 2 + AsciiToBYTE(strTemp[1]);
  327. break;
  328. case 2:
  329. strTemp.Format("%c%c%c", chBuffer[nStartBit], chBuffer[nStartBit + 1], chBuffer[nStartBit + 2]);
  330. nValue = AsciiToBYTE(strTemp[0]) * 4 + AsciiToBYTE(strTemp[1]) * 2 + AsciiToBYTE(strTemp[2]);
  331. break;
  332. case 3:
  333. strTemp.Format("%c%c%c%c", chBuffer[nStartBit], chBuffer[nStartBit + 1],
  334. chBuffer[nStartBit + 2], chBuffer[nStartBit +3]);
  335. nValue = AsciiToBYTE(strTemp[0]) * 8 + AsciiToBYTE(strTemp[1]) * 4 + AsciiToBYTE(strTemp[2]) * 2 + AsciiToBYTE(strTemp[0]);
  336. break;
  337. case 4:
  338. strTemp.Format("%c%c%c%c%c", chBuffer[nStartBit], chBuffer[nStartBit + 1],
  339. chBuffer[nStartBit + 2], chBuffer[nStartBit + 3], chBuffer[nStartBit + 4]);
  340. break;
  341. case 5:
  342. strTemp.Format("%c%c%c%c%c%c", chBuffer[nStartBit], chBuffer[nStartBit + 1], chBuffer[nStartBit + 2],
  343. chBuffer[nStartBit + 3], chBuffer[nStartBit + 4], chBuffer[nStartBit + 5]);
  344. break;
  345. case 6:
  346. strTemp.Format("%c%c%c%c%c%c%c", chBuffer[nStartBit], chBuffer[nStartBit + 1], chBuffer[nStartBit + 2],
  347. chBuffer[nStartBit + 3], chBuffer[nStartBit + 4], chBuffer[nStartBit + 5], chBuffer[nStartBit + 6]);
  348. break;
  349. default:
  350. LOG4C((LOG_NOTICE, "起始位与终止位不对",pDev->m_strDeviceName, pBaseVar->m_strDesc));
  351. }
  352. }
  353. }
  354. // 特殊变量处理(例如,一个命令返回两个变量的情况)
  355. else if( nEndBit - nStartBit == 7 ) // 1个字节的情况
  356. {
  357. nStartReg = (int)nStartBit / 8;
  358. nEndReg = (int)(nEndBit + 1) / 8;
  359. nValue = chMsg[nStartReg];
  360. }
  361. else if( nEndBit - nStartBit == 15 ) // 2个字节的情况
  362. {
  363. nStartReg = (int)nStartBit / 8;
  364. nEndReg = (int)(nEndBit + 1) / 8;
  365. memcpy(&wdValue, chMsg, sizeof(WORD));
  366. nValue = ntohs((WORD)wdValue);
  367. }
  368. EnterCriticalSection( &g_csRtuReadOneData );
  369. pBaseVar->m_dbData = (double)(nValue * fCoef);
  370. if( pBaseVar->m_nRearm != 0 )
  371. {
  372. pBaseVar->m_dbData = pBaseVar->m_dbData + pBaseVar->m_nRearm;
  373. }
  374. LeaveCriticalSection( &g_csRtuReadOneData );
  375. //LOG4C((LOG_NOTICE, "desc = %s, value = %d", pBaseVar->m_strDesc, (int)pBaseVar->m_dbData));
  376. }
  377. else
  378. {
  379. // 联合类型变量做特殊处理
  380. if( pBaseVar->m_nVarTypeID >= UNION_TYPE_MIN_ID && pBaseVar->m_nVarTypeID <= UNION_TYPE_MAX_ID )
  381. {
  382. if( nDataLen == 2 )
  383. {
  384. //int类型
  385. union __UNION_VAR_INT{
  386. char ch[2];
  387. int value;
  388. }unionVarInt;
  389. unionVarInt.ch[0] = chMsg[1];
  390. unionVarInt.ch[1] = chMsg[0];
  391. EnterCriticalSection( &g_csRtuReadOneData );
  392. pBaseVar->m_dbData = (double)(unionVarInt.value * fCoef);
  393. if( pBaseVar->m_nRearm != 0 )
  394. {
  395. pBaseVar->m_dbData = pBaseVar->m_dbData + pBaseVar->m_nRearm;
  396. }
  397. LeaveCriticalSection( &g_csRtuReadOneData );
  398. //TRACE2("联合类型变量ID%d, 值=%d\r\n", iVarID, unionVarInt.value);
  399. }
  400. else if( nDataLen == 4 )
  401. {
  402. //float类型
  403. union __UNION_VAR_FLOAT{
  404. char ch[4];
  405. float value;
  406. }unionVarFloat;
  407. unionVarFloat.ch[0] = chMsg[3];
  408. unionVarFloat.ch[1] = chMsg[2];
  409. unionVarFloat.ch[2] = chMsg[1];
  410. unionVarFloat.ch[3] = chMsg[0];
  411. EnterCriticalSection( &g_csRtuReadOneData );
  412. if( unionVarFloat.value < 0.0 )
  413. {
  414. pBaseVar->m_dbData = 0.0;
  415. }
  416. else
  417. {
  418. pBaseVar->m_dbData = (double)(unionVarFloat.value * fCoef);
  419. }
  420. if( pBaseVar->m_nRearm != 0 )
  421. {
  422. pBaseVar->m_dbData = pBaseVar->m_dbData + pBaseVar->m_nRearm;
  423. }
  424. LeaveCriticalSection( &g_csRtuReadOneData );
  425. //TRACE2("联合类型变量ID%d, 值=%.1f\r\n", iVarID, unionVarFloat.value);
  426. }
  427. else if( nDataLen == 8 )
  428. {
  429. //double类型
  430. union __UNION_VAR_DOUBLE{
  431. char ch[8];
  432. double value;
  433. }unionVarDouble;
  434. unionVarDouble.ch[0] = chMsg[7];
  435. unionVarDouble.ch[1] = chMsg[6];
  436. unionVarDouble.ch[2] = chMsg[5];
  437. unionVarDouble.ch[3] = chMsg[4];
  438. unionVarDouble.ch[4] = chMsg[3];
  439. unionVarDouble.ch[5] = chMsg[2];
  440. unionVarDouble.ch[6] = chMsg[1];
  441. unionVarDouble.ch[7] = chMsg[0];
  442. EnterCriticalSection( &g_csRtuReadOneData );
  443. pBaseVar->m_dbData = (double)(unionVarDouble.value * fCoef);
  444. if( pBaseVar->m_nRearm != 0 )
  445. {
  446. pBaseVar->m_dbData = pBaseVar->m_dbData + pBaseVar->m_nRearm;
  447. }
  448. LeaveCriticalSection( &g_csRtuReadOneData );
  449. //TRACE2("联合类型变量ID%d, 值=%.1f\r\n", iVarID, unionVarDouble.value);
  450. }
  451. }
  452. else
  453. {
  454. switch( nDataLen )
  455. {
  456. case 1:
  457. nValue = chMsg[0];
  458. break;
  459. case 2:
  460. short int wdValue;
  461. memcpy(&wdValue, chMsg, sizeof(short int));
  462. nValue = ntohs(wdValue);
  463. break;
  464. case 3: // 一般为字符串类型,不作处理
  465. LOG4C((LOG_NOTICE, "保留,暂时没有用到"));
  466. break;
  467. case 4: // 保留,暂时不知道什么处理
  468. LOG4C((LOG_NOTICE, "保留,暂时没有用到"));
  469. break;
  470. case 5: // 一般为字符串类型,不作处理
  471. LOG4C((LOG_NOTICE, "保留,暂时没有用到"));
  472. break;
  473. case 6: // 一般为字符串类型,不作处理
  474. LOG4C((LOG_NOTICE, "保留,暂时没有用到"));
  475. break;
  476. case 7: // 一般为字符串类型,不作处理
  477. LOG4C((LOG_NOTICE, "保留,暂时没有用到"));
  478. break;
  479. case 8: // 保留,暂时没有用到
  480. LOG4C((LOG_NOTICE, "保留,暂时没有用到"));
  481. break;
  482. }
  483. if( pBaseVar->m_nVarTypeID==7 )
  484. {
  485. float fTemp = 0.0;
  486. memcpy(&fTemp, chMsg, sizeof(float));
  487. CString str;str.Format( "%f",fTemp );
  488. LOG4C((LOG_NOTICE, "变量类型为float,从动态库得到的值 = %s", str ));
  489. EnterCriticalSection( &g_csRtuReadOneData );
  490. if( pBaseVar->m_nMaxValues != 0 || pBaseVar->m_nMinValues != 0 ||
  491. pBaseVar->m_nMaxConvtRate != 0 || pBaseVar->m_nMinConvtRate != 0 )
  492. {
  493. double fScale = 1.0;
  494. if( pBaseVar->m_nMaxValues - pBaseVar->m_nMinValues > 0 )
  495. {
  496. fScale = (double)(pBaseVar->m_nMaxConvtRate - pBaseVar->m_nMinConvtRate) /
  497. (double)(pBaseVar->m_nMaxValues - pBaseVar->m_nMinValues);
  498. }
  499. if( nValue < 0.0 )
  500. {
  501. pBaseVar->m_dbData = 0.0;
  502. }
  503. else
  504. {
  505. pBaseVar->m_dbData = fTemp *
  506. fCoef *
  507. fScale;
  508. }
  509. }
  510. else
  511. {
  512. if( nValue < 0.0 )
  513. {
  514. pBaseVar->m_dbData = 0.0;
  515. }
  516. else
  517. {
  518. pBaseVar->m_dbData = (double)(fTemp * fCoef);
  519. }
  520. }
  521. if( pBaseVar->m_nRearm != 0 )
  522. {
  523. pBaseVar->m_dbData = pBaseVar->m_dbData + pBaseVar->m_nRearm;
  524. }
  525. LeaveCriticalSection( &g_csRtuReadOneData );
  526. }
  527. else
  528. {
  529. EnterCriticalSection( &g_csRtuReadOneData );
  530. if( pBaseVar->m_nMaxValues != 0 || pBaseVar->m_nMinValues != 0 ||
  531. pBaseVar->m_nMaxConvtRate != 0 || pBaseVar->m_nMinConvtRate != 0 )
  532. {
  533. double fScale = 1.0;
  534. if( pBaseVar->m_nMaxValues - pBaseVar->m_nMinValues > 0 )
  535. {
  536. fScale = (double)(pBaseVar->m_nMaxConvtRate - pBaseVar->m_nMinConvtRate) /
  537. (double)(pBaseVar->m_nMaxValues - pBaseVar->m_nMinValues);
  538. }
  539. if( nValue < 0.0 )
  540. {
  541. pBaseVar->m_dbData = 0.0;
  542. }
  543. else
  544. {
  545. pBaseVar->m_dbData = nValue *
  546. fCoef *
  547. fScale;
  548. }
  549. }
  550. else
  551. {
  552. if( nValue < 0.0 )
  553. {
  554. pBaseVar->m_dbData = 0.0;
  555. }
  556. else
  557. {
  558. pBaseVar->m_dbData = (double)(nValue * fCoef);
  559. }
  560. }
  561. if( pBaseVar->m_nRearm != 0 )
  562. {
  563. pBaseVar->m_dbData = pBaseVar->m_dbData + pBaseVar->m_nRearm;
  564. }
  565. //LOG4C((LOG_NOTICE, "desc = %s, value = %d", pBaseVar->m_strDesc, (int)pBaseVar->m_dbData));
  566. //g_RtuReadOneData.dbData = (double)(nValue * fCoef);
  567. LeaveCriticalSection( &g_csRtuReadOneData );
  568. }
  569. }
  570. }
  571. EnterCriticalSection(&g_csRtuReadOneData);
  572. pDev->m_dwOnlineTick = GetTickCount();
  573. LeaveCriticalSection(&g_csRtuReadOneData);
  574. return 0;
  575. }
  576. void UnInitRtuDll()
  577. {
  578. if (g_hRTULibModule != NULL && ( NULL != pRTU_DLLUnInit ))
  579. {
  580. pRTU_DLLUnInit();
  581. }
  582. DeleteCriticalSection( &g_csRtuReadOneData );
  583. if (g_hRTULibModule!= NULL)
  584. {
  585. AfxFreeLibrary(g_hRTULibModule);
  586. g_hRTULibModule = NULL;
  587. }
  588. }
  589. int RtuRequestWrData(char chDevUid[20], int iVarID, double data)//用于请求写命令操作
  590. {
  591. SETBASEPARAM SetBasePara;
  592. memset( &SetBasePara, 0, sizeof(SETBASEPARAM) );
  593. int nDeviceIndex = -1, nVarIndex = -1;
  594. BOOL bFind = FindVar(chDevUid, iVarID, nDeviceIndex, nVarIndex);
  595. if( bFind == FALSE ) return -1;
  596. CDevice *pDev = g_pDevicesManager->m_Devices[nDeviceIndex];
  597. CBaseVar *pBaseVar = pDev->m_Vars[nVarIndex];
  598. SetBasePara.nAddr = pDev->m_iDevideaddr;
  599. SetBasePara.nRegNum = pBaseVar->m_iRegisterNum;
  600. SetBasePara.nStartAddr = pBaseVar->m_nRegStartAddr;
  601. SetBasePara.FuncCode = pBaseVar->m_iFuncID;
  602. if (pRTU_DLLWrite(pDev->m_iPort, pDev->m_iDevideaddr, SetBasePara, data, pBaseVar->m_iDataLen) == 0)
  603. return 0;
  604. else
  605. return -1;
  606. }
  607. double RtuSingleResponseWriteData(char chDevUid[20], int iVarID)
  608. {
  609. return 0;
  610. }