| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150 |
- // ProtocolPMC916.cpp: implementation of the CProtocolModbus class.
- //
- //////////////////////////////////////////////////////////////////////
- #include "stdafx.h"
- #include "ProtocolModbus.h"
- #include "winsock2.h"
- #ifdef _DEBUG
- #undef THIS_FILE
- static char THIS_FILE[]=__FILE__;
- #define new DEBUG_NEW
- #endif
- //////////////////////////////////////////////////////////////////////
- // Construction/Destruction
- //////////////////////////////////////////////////////////////////////
- CProtocolModbus::CProtocolModbus() : CProtocol()
- {
- InitializeCriticalSection( &m_csReadFinished );
- InitializeCriticalSection( &m_csWrFinished );
- MTVERIFY( m_hSemComm = CreateEvent( NULL, TRUE, TRUE, "DLL_UpsParaDigmComm" ) );
- }
- CProtocolModbus::~CProtocolModbus()
- {
- DeleteCriticalSection( &m_csReadFinished );
- DeleteCriticalSection( &m_csWrFinished );
- MTVERIFY( CloseHandle( m_hSemComm ) );
- }
- int CProtocolModbus::WorkMain(
- int nAddr, //地址
- int nVer, //版本号
- int nCid1, //控制标识码
- int nCid2, //命令信息
- WORD wLenId, //INFO字节长度
- int nCmdID, //命令ID
- int nDataLen, //请求数据长度
- int nCmdPos, //变量索引
- int nCmdLen, //变量长度
- char chMsg[80], //读到的变量值
- char *byDataFlag) //保留未用
- {
- if(!m_pComm)
- return ERR_CODE_DAIKIN_COM_FAULT; // 串口通信故障
- int nRet;
- #if 1
- nRet = RequestStatus(nAddr,
- nVer,
- nCid1,
- nCid2,
- wLenId,
- nCmdID,
- nDataLen,
- nCmdPos,
- nCmdLen,
- chMsg,
- byDataFlag);
- if( nRet != 0 )
- {
- return nRet; // 串口忙
- }
- nRet = ResponseStatus(nDataLen, nCmdPos, nCmdLen,chMsg, byDataFlag);
- #else
- if( nCid2 == 0x44 || nCid2 == 0x42 || nCid2 == 0x43 )
- {
- nRet = ResponseStatus(nDataLen, nCmdPos, nCmdLen,chMsg, byDataFlag);
- }
- else
- {
- nRet = -1;
- }
- #endif
- return nRet;
- }
- int CProtocolModbus::WriteCommand(
- int nCommPort, //端口
- int nAddr, //地址
- int nVer, //版本号
- int nCid1, //控制标识码
- int nCid2, //命令信息
- WORD wLenId, //INFO字节长度
- int nCmdType, //命令类型
- int nSetValue) //设定值
- {
- int iResult = 0;
- if(!m_pComm)
- return ERR_CODE_DAIKIN_COM_FAULT;
- iResult = RequestSetParam( nCommPort,
- nAddr,
- nVer,
- nCid1,
- nCid2,
- wLenId,
- nCmdType,
- nSetValue);
- if (iResult == 0)
- {
- return ResponseSetParam( nCommPort,
- nAddr,
- nVer,
- nCid1,
- nCid2,
- wLenId,
- nCmdType,
- nSetValue);
- }
- else
- {
- return iResult;
- }
- }
- int CProtocolModbus::WriteCommand(
- int nCommPort, //端口
- int nAddr, //地址
- int nSetType, //设定类型
- int nSetIndex, //设定值索引,只针对特殊变量(例如:空调制冷、制热温度)
- int nSetValue) //设定值
- {
- int iResult = 0;
- if(!m_pComm)
- return ERR_CODE_DAIKIN_COM_FAULT;
- iResult = RequestRemoteCtrl( nCommPort,
- nAddr,
- nSetType,
- nSetIndex,
- nSetValue);
- if (iResult == 0)
- {
- return ResponseRemoteCtrl( nCommPort,
- nAddr,
- nSetType,
- nSetIndex,
- nSetValue);
- }
- else
- {
- return iResult;
- }
- }
- int CProtocolModbus::RequestSetParam(
- int nCommPort, //端口
- int nAddr, //地址
- int nVer, //版本号
- int nCid1, //控制标识码
- int nCid2, //命令信息
- WORD wLenId, //INFO字节长度
- int nCmdType, //命令类型
- int nSetValue) //设定值
- {
- int nLen = sizeof(CHILD);
- char chLength[4] = {0};
- char chChkSum[5] = {0};
- CHILD tagRequestChild;
- memset( &tagRequestChild, 0, nLen );
- //起始位
- tagRequestChild.bySoi = 0x7E;
- //设备地址描述
- tagRequestChild.byAdr[0] = ByteToAscii((nAddr>>4) & 0x0f);
- tagRequestChild.byAdr[1] = ByteToAscii(nAddr & 0x0f);
- //通讯协议版本
- tagRequestChild.byVer[0] = ByteToAscii((nVer>>4) & 0x0f);
- tagRequestChild.byVer[1] = ByteToAscii(nVer & 0x0f);
- //Cid1
- tagRequestChild.byCid1[0] = ByteToAscii((nCid1>>4) & 0x0f);
- tagRequestChild.byCid1[1] = ByteToAscii(nCid1 & 0x0f);
- //Cid2
- tagRequestChild.byCid2[0] = ByteToAscii((nCid2 >> 4) & 0x0f);
- tagRequestChild.byCid2[1] = ByteToAscii(nCid2 & 0x0f);
- GetDataLength(wLenId, chLength);//取数据长度
- tagRequestChild.byLength[0] = ByteToAscii(chLength[0]);
- tagRequestChild.byLength[1] = chLength[1];
- tagRequestChild.byLength[2] = chLength[2];
- tagRequestChild.byLength[3] = chLength[3];
- BYTE *pDataBuf = NULL;
- int nWriteLen = 0;
- REQUESTSETPARAM tagRequestSetParam;
- int nSetParamLen = sizeof(REQUESTSETPARAM);
- memset( &tagRequestSetParam, 0, nSetParamLen);
- memcpy( &tagRequestSetParam.RequestChild, &tagRequestChild, nLen );
- //设置命令
- tagRequestSetParam.szCmdType[0] = ByteToAscii((nCmdType >> 4) & 0x0f);
- tagRequestSetParam.szCmdType[1] = ByteToAscii(nCmdType & 0x0f);
- //设置内容
- tagRequestSetParam.szCmdInfo[0] = ByteToAscii( (nSetValue >> 12) & 0x000f );
- tagRequestSetParam.szCmdInfo[1] = ByteToAscii( (nSetValue >> 8) & 0x000f );
- tagRequestSetParam.szCmdInfo[2] = ByteToAscii( (nSetValue >> 4) & 0x000f );
- tagRequestSetParam.szCmdInfo[3] = ByteToAscii( nSetValue & 0x000f );
- nWriteLen = nSetParamLen - sizeof(tagRequestSetParam.byCheckSum) -
- sizeof(tagRequestSetParam.byEoi);
- pDataBuf = new BYTE[ nWriteLen ];
- memset( pDataBuf, 0, nWriteLen );
- memcpy( pDataBuf, &tagRequestSetParam, nWriteLen );
- //校验码
- GetCheckSum( (char *)pDataBuf + 1, chChkSum, nWriteLen - 1 );
- tagRequestSetParam.byCheckSum[0] = chChkSum[0];
- tagRequestSetParam.byCheckSum[1] = chChkSum[1];
- tagRequestSetParam.byCheckSum[2] = chChkSum[2];
- tagRequestSetParam.byCheckSum[3] = chChkSum[3];
- tagRequestSetParam.byEoi = 0x0D;
- if( WaitForSingleObject( m_hSemComm, 0 ) == WAIT_OBJECT_0 ) // 有信号才写串口
- {
- ResetEvent( m_hSemComm );
- int nResult = WriteMessage( (BYTE *)&tagRequestSetParam, nLen );
-
- if( nResult == nLen )
- {
- }
- else
- {
- delete []pDataBuf;
- SetEvent( m_hSemComm );
- return EER_CODE_DAIKIN_COM_WRITE_DATA;
- }
- }
- else
- {
- delete []pDataBuf;
- return ERR_CODE_DAIKIN_COM_BUSY;
- }
- if( pDataBuf )
- {
- delete[] pDataBuf;
- pDataBuf = NULL;
- }
- return 0;
- }
- int CProtocolModbus::ResponseSetParam(
- int nCommPort, //端口
- int nAddr, //地址
- int nVer, //版本号
- int nCid1, //控制标识码
- int nCid2, //命令信息
- WORD wLenId, //INFO字节长度
- int nCmdType, //命令类型
- int nSetValue) //设定值
- {
- RESPONSE_STRUCT structResponse;
- memset( &structResponse, 0, sizeof(RESPONSE_STRUCT) );
- int nLen = sizeof(RESPONSE_STRUCT) - sizeof(structResponse.byRtnMsg);
-
- char *pBuffer = new char[ nLen ];
- memset(pBuffer, 0, nLen);
- int nProcessLen = 0;
- int nReadLen = 0;
- nReadLen = ReadMessage((BYTE *)pBuffer, nLen);
- if( nReadLen <= 0)
- {
- // 串口没有读到数据
- TRACE("串口没有读到数据!\r\n");
- SetEvent( m_hSemComm );
- if( pBuffer != NULL)
- {
- delete[] pBuffer;
- pBuffer = NULL;
- }
- return ERR_CODE_DAIKIN_COM_READ_NO_DATA;
- }
- else if( nReadLen < nLen )
- {
- TRACE("长度没有收够,断续接收,止到收完为止!\r\n");
- #if DEBUG_PROTOCOL
- SetEvent( m_hSemComm );
- if( pBuffer )
- {
- delete[] pBuffer;
- pBuffer = NULL;
- }
- return ERR_CODE_DAIKIN_COM_FAULT;
- #else
- nProcessLen += nReadLen;
- nReadLen = ReadMessage( (BYTE *)(pBuffer + nProcessLen), nLen - nProcessLen );
- while( nReadLen != nLen - nProcessLen )
- {
- if( nReadLen == 0 )
- {
- SetEvent( m_hSemComm );
- if( pBuffer )
- {
- delete[] pBuffer;
- pBuffer = NULL;
- }
- return ERR_CODE_UPS_PARADIGM_COM_READ_NO_DATA; // 还是没有收到数据,直接返回
- }
- nProcessLen += nReadLen;
- nReadLen = ReadMessage( (BYTE *)(pBuffer + nProcessLen), nLen - nProcessLen);
- }
- if( nReadLen == nLen )
- {
- //goto NormalProcess;
- if( pBuffer != NULL)
- {
- delete[] pBuffer;
- pBuffer = NULL;
- }
- return ERR_CODE_UPS_PARADIGM_COM_FAULT;
- }
- #endif
- }
- else if( nReadLen > nLen )
- {
- // 完全代码,不一定能执行到
- TRACE("接收的长度超时所需的长度,认为是非法包,扔掉\r\n");
- SetEvent( m_hSemComm );
-
- if( pBuffer != NULL)
- {
- delete[] pBuffer;
- pBuffer = NULL;
- }
- return ERR_CODE_DAIKIN_COM_READ_LEN_OVER;
- }
- // 判断校验
- char chChkSum[5] = {0};
- BYTE chTmpChkSum[4] = {0};
- GetCheckSum(pBuffer + 1, chChkSum, nLen - sizeof(structResponse.byCheckSum) - 2 );
- chTmpChkSum[0] = chChkSum[0];
- chTmpChkSum[1] = chChkSum[1];
- chTmpChkSum[2] = chChkSum[2];
- chTmpChkSum[3] = chChkSum[3];
- if (!((chTmpChkSum[0] ==(byte)pBuffer[nLen - 4]) &&
- (chTmpChkSum[1] ==(byte)pBuffer[nLen - 3]) &&
- (chTmpChkSum[2] ==(byte)pBuffer[nLen - 2]) &&
- (chTmpChkSum[3] ==(byte)pBuffer[nLen - 1])))
- {
- TRACE("校验失败!\r\n");
- SetEvent( m_hSemComm );
-
- if( pBuffer != NULL)
- {
- delete[] pBuffer;
- pBuffer = NULL;
- }
- return ERR_CODE_DAIKIN_COM_LRC_LOST;
- }
- // 设置串口等待事件为有信号
- SetEvent( m_hSemComm );
-
- if( pBuffer != NULL)
- {
- delete[] pBuffer;
- pBuffer = NULL;
- }
- return 0;
- }
- int CProtocolModbus::RequestRemoteCtrl(
- int nCommPort, //端口
- int nAddr, //地址
- int nSetType, //设定类型
- int nSetIndex, //设定值索引,只针对特殊变量(例如:空调制冷、制热温度)
- int nSetValue) //设定值
- {
- int nLen = sizeof(CHILD);
- char chLength[4] = {0};
- char chChkSum[5] = {0};
- CHILD tagRequestChild;
- int nCid1 = 0x60;
- int nCid2 = 0x45;
- memset( &tagRequestChild, 0, nLen );
- //起始位
- tagRequestChild.bySoi = 0x7E;
- //设备地址描述
- tagRequestChild.byAdr[0] = ByteToAscii((nAddr>>4) & 0x0f);
- tagRequestChild.byAdr[1] = ByteToAscii(nAddr & 0x0f);
- //通讯协议版本
- tagRequestChild.byVer[0] = '2';
- tagRequestChild.byVer[1] = '0';
- //Cid1
- tagRequestChild.byCid1[0] = ByteToAscii((nCid1>>4) & 0x0f);
- tagRequestChild.byCid1[1] = ByteToAscii(nCid1 & 0x0f);
- //Cid2
- tagRequestChild.byCid2[0] = ByteToAscii((nCid2 >> 4) & 0x0f);
- tagRequestChild.byCid2[1] = ByteToAscii(nCid2 & 0x0f);
- //GetDataLength(5, chLength);//取数据长度
- tagRequestChild.byLength[0] = 'E';
- tagRequestChild.byLength[1] = '0';
- tagRequestChild.byLength[2] = '0';
- tagRequestChild.byLength[3] = '2';
- BYTE *pDataBuf = NULL;
- int nWriteLen = 0;
- REQUEST_CTRL tagRequestCtrl;
- int nRemoteCtrlLen = sizeof(REQUEST_CTRL);
- memset( &tagRequestCtrl, 0, nRemoteCtrlLen);
- memcpy( &tagRequestCtrl.RequestChild, &tagRequestChild, nLen );
- //设置命令
- tagRequestCtrl.szCmdType[0] = ByteToAscii((nSetValue >> 4) & 0x0f);
- tagRequestCtrl.szCmdType[1] = ByteToAscii(nSetValue & 0x0f);;
- nWriteLen = nRemoteCtrlLen - sizeof(tagRequestCtrl.byCheckSum) -
- sizeof(tagRequestCtrl.byEoi);
- pDataBuf = new BYTE[ nWriteLen ];
- memset( pDataBuf, 0, nWriteLen );
- memcpy( pDataBuf, &tagRequestCtrl, nWriteLen );
- //校验码
- GetCheckSum( (char *)pDataBuf + 1, chChkSum, nWriteLen - 1 );
- tagRequestCtrl.byCheckSum[0] = chChkSum[0];
- tagRequestCtrl.byCheckSum[1] = chChkSum[1];
- tagRequestCtrl.byCheckSum[2] = chChkSum[2];
- tagRequestCtrl.byCheckSum[3] = chChkSum[3];
- tagRequestCtrl.byEoi = 0x0D;
- if( WaitForSingleObject( m_hSemComm, 0 ) == WAIT_OBJECT_0 ) // 有信号才写串口
- {
- ResetEvent( m_hSemComm );
- int nResult = WriteMessage( (BYTE *)&tagRequestCtrl, nRemoteCtrlLen );
-
- if( nResult == nRemoteCtrlLen )
- {
- }
- else
- {
- delete []pDataBuf;
- SetEvent( m_hSemComm );
- return EER_CODE_DAIKIN_COM_WRITE_DATA;
- }
- }
- else
- {
- delete []pDataBuf;
- return ERR_CODE_DAIKIN_COM_BUSY;
- }
- if( pDataBuf )
- {
- delete[] pDataBuf;
- pDataBuf = NULL;
- }
- return 0;
- }
- int CProtocolModbus::ResponseRemoteCtrl(
- int nCommPort, //端口
- int nAddr, //地址
- int nSetType, //设定类型
- int nSetIndex, //设定值索引,只针对特殊变量(例如:空调制冷、制热温度)
- int nSetValue) //设定值
- {
- RESPONSE_STRUCT structResponse;
- memset( &structResponse, 0, sizeof(RESPONSE_STRUCT) );
- int nLen = sizeof(RESPONSE_STRUCT) - sizeof(structResponse.byRtnMsg);
-
- char *pBuffer = new char[ nLen ];
- memset(pBuffer, 0, nLen);
- int nProcessLen = 0;
- int nReadLen = 0;
- nReadLen = ReadMessage((BYTE *)pBuffer, nLen);
- if( nReadLen <= 0)
- {
- // 串口没有读到数据
- TRACE("串口没有读到数据!\r\n");
- SetEvent( m_hSemComm );
- if( pBuffer != NULL)
- {
- delete[] pBuffer;
- pBuffer = NULL;
- }
- return ERR_CODE_DAIKIN_COM_READ_NO_DATA;
- }
- else if( nReadLen < nLen )
- {
- TRACE("长度没有收够,断续接收,止到收完为止!\r\n");
- SetEvent( m_hSemComm );
- if( pBuffer )
- {
- delete[] pBuffer;
- pBuffer = NULL;
- }
- return ERR_CODE_DAIKIN_COM_FAULT;
- }
- else if( nReadLen > nLen )
- {
- // 完全代码,不一定能执行到
- TRACE("接收的长度超时所需的长度,认为是非法包,扔掉\r\n");
- SetEvent( m_hSemComm );
-
- if( pBuffer != NULL)
- {
- delete[] pBuffer;
- pBuffer = NULL;
- }
- return ERR_CODE_DAIKIN_COM_READ_LEN_OVER;
- }
- // 判断校验
- char chChkSum[5] = {0};
- BYTE chTmpChkSum[4] = {0};
- GetCheckSum(pBuffer + 1, chChkSum, nLen - sizeof(structResponse.byCheckSum) - 2 );
- chTmpChkSum[0] = chChkSum[0];
- chTmpChkSum[1] = chChkSum[1];
- chTmpChkSum[2] = chChkSum[2];
- chTmpChkSum[3] = chChkSum[3];
- if (!((chTmpChkSum[0] ==(byte)pBuffer[nLen - 5]) &&
- (chTmpChkSum[1] ==(byte)pBuffer[nLen - 4]) &&
- (chTmpChkSum[2] ==(byte)pBuffer[nLen - 3]) &&
- (chTmpChkSum[3] ==(byte)pBuffer[nLen - 2])))
- {
- TRACE("校验失败!\r\n");
- SetEvent( m_hSemComm );
-
- if( pBuffer != NULL)
- {
- delete[] pBuffer;
- pBuffer = NULL;
- }
- return ERR_CODE_DAIKIN_COM_LRC_LOST;
- }
- // 设置串口等待事件为有信号
- SetEvent( m_hSemComm );
-
- if( pBuffer != NULL)
- {
- delete[] pBuffer;
- pBuffer = NULL;
- }
- return 0;
- }
- int CProtocolModbus::ResponseStatus( int nDataLen, int iCmdPos, int iCmdLen, char chMsg[80], char *byDataFlag)
- {
- #if 1
- RESPONSE_STRUCT structResponse;
- memset( &structResponse, 0, sizeof(RESPONSE_STRUCT) );
- if (nDataLen <= 0)
- {
- TRACE("变量长度小于等于0,为非法变量");
- return ERR_CODE_DAIKIN_COM_VARLEN;
- }
- int nLen = sizeof(RESPONSE_STRUCT) - sizeof(structResponse.byRtnMsg) + nDataLen;
-
- char *pBuffer = new char[ nLen ];
- memset(pBuffer, 0, nLen);
- int nProcessLen = 0;
- int nReadLen = 0;
- nReadLen = ReadMessage((BYTE *)pBuffer, nLen);
- if( nReadLen <= 0)
- {
- // 串口没有读到数据
- TRACE("串口没有读到数据!\r\n");
- SetEvent( m_hSemComm );
- if( pBuffer != NULL)
- {
- delete[] pBuffer;
- pBuffer = NULL;
- }
- return ERR_CODE_DAIKIN_COM_READ_NO_DATA;
- }
- else if( nReadLen < nLen )
- {
- TRACE("长度没有收够,断续接收,止到收完为止!\r\n");
- SetEvent( m_hSemComm );
- if( pBuffer )
- {
- delete[] pBuffer;
- pBuffer = NULL;
- }
- return ERR_CODE_DAIKIN_COM_FAULT;
- }
- else if( nReadLen > nLen )
- {
- // 完全代码,不一定能执行到
- TRACE("接收的长度超时所需的长度,认为是非法包,扔掉\r\n");
- SetEvent( m_hSemComm );
-
- if( pBuffer != NULL)
- {
- delete[] pBuffer;
- pBuffer = NULL;
- }
- return ERR_CODE_DAIKIN_COM_READ_LEN_OVER;
- }
- #else
- //7E 32 30 30 31 36 30 30 30 39 30 33 34 30 30 20 ~20016000903400
- //20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
- //20 20 20 20 20 20 20 20 20 20 20 30 38 44 31 20 08D1
- //20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 30 0
- //30 46 36 38 41 0D 0F68A.
- RESPONSE_STRUCT structResponse;
- memset( &structResponse, 0, sizeof(RESPONSE_STRUCT) );
- #if 0
- int nLen = 70;
-
- char *pBuffer = new char[ nLen ];
- memset(pBuffer, 0, nLen);
- pBuffer[0] = 0x7E;
- pBuffer[1] = 0x32;
- pBuffer[2] = 0x30;
- pBuffer[3] = 0x30;
- pBuffer[4] = 0x31;
- pBuffer[5] = 0x36;
- pBuffer[6] = 0x30;
- pBuffer[7] = 0x30;
- pBuffer[8] = 0x30;
- pBuffer[9] = 0x39;
- pBuffer[10] = 0x30;
- pBuffer[11] = 0x33;
- pBuffer[12] = 0x34;
- pBuffer[13] = 0x30;
- pBuffer[14] = 0x30;
- pBuffer[15] = 0x20;
- pBuffer[16] = 0x20;
- pBuffer[17] = 0x20;
- pBuffer[18] = 0x20;
- pBuffer[19] = 0x20;
- pBuffer[20] = 0x20;
- pBuffer[21] = 0x20;
- pBuffer[22] = 0x20;
- pBuffer[23] = 0x20;
- pBuffer[24] = 0x20;
- pBuffer[25] = 0x20;
- pBuffer[26] = 0x20;
- pBuffer[27] = 0x20;
- pBuffer[28] = 0x20;
- pBuffer[29] = 0x20;
- pBuffer[30] = 0x20;
- pBuffer[31] = 0x20;
- pBuffer[32] = 0x20;
- pBuffer[33] = 0x20;
- pBuffer[34] = 0x20;
- pBuffer[35] = 0x20;
- pBuffer[36] = 0x20;
- pBuffer[37] = 0x20;
- pBuffer[38] = 0x20;
- pBuffer[39] = 0x20;
- pBuffer[40] = 0x20;
- pBuffer[41] = 0x20;
- pBuffer[42] = 0x20;
- pBuffer[43] = 0x30;
- pBuffer[44] = 0x38;
- pBuffer[45] = 0x44;
- pBuffer[46] = 0x31;
- pBuffer[47] = 0x20;
- pBuffer[48] = 0x20;
- pBuffer[49] = 0x20;
- pBuffer[50] = 0x20;
- pBuffer[51] = 0x20;
- pBuffer[52] = 0x20;
- pBuffer[53] = 0x20;
- pBuffer[54] = 0x20;
- pBuffer[55] = 0x20;
- pBuffer[56] = 0x20;
- pBuffer[57] = 0x20;
- pBuffer[58] = 0x20;
- pBuffer[59] = 0x20;
- pBuffer[60] = 0x20;
- pBuffer[61] = 0x20;
- pBuffer[62] = 0x20;
- pBuffer[63] = 0x30;
- pBuffer[64] = 0x30;
- pBuffer[65] = 0x46;
- pBuffer[66] = 0x36;
- pBuffer[67] = 0x38;
- pBuffer[68] = 0x41;
- pBuffer[69] = 0x0D;
- #endif
- //7E 32 30 30 32 36 30 34 33 30 30 30 30 46 44 41
- //46 0D
- int nLen = 18;
-
- char *pBuffer = new char[ nLen ];
- memset(pBuffer, 0, nLen);
- pBuffer[0] = 0x7E;
- pBuffer[1] = 0x32;
- pBuffer[2] = 0x30;
- pBuffer[3] = 0x30;
- pBuffer[4] = 0x32;
- pBuffer[5] = 0x36;
- pBuffer[6] = 0x30;
- pBuffer[7] = 0x34;
- pBuffer[8] = 0x33;
- pBuffer[9] = 0x30;
- pBuffer[10] = 0x30;
- pBuffer[11] = 0x30;
- pBuffer[12] = 0x30;
- pBuffer[13] = 0x46;
- pBuffer[14] = 0x44;
- pBuffer[15] = 0x41;
- pBuffer[16] = 0x46;
- pBuffer[17] = 0x0D;
- #endif
- // 判断校验
- char chChkSum[5] = {0};
- BYTE chTmpChkSum[4] = {0};
- GetCheckSum(pBuffer + 1, chChkSum, nLen - sizeof(structResponse.byCheckSum) - 2 );
- chTmpChkSum[0] = chChkSum[0];
- chTmpChkSum[1] = chChkSum[1];
- chTmpChkSum[2] = chChkSum[2];
- chTmpChkSum[3] = chChkSum[3];
- if (!((chTmpChkSum[0] ==(byte)pBuffer[nLen - 5]) &&
- (chTmpChkSum[1] ==(byte)pBuffer[nLen - 4]) &&
- (chTmpChkSum[2] ==(byte)pBuffer[nLen - 3]) &&
- (chTmpChkSum[3] ==(byte)pBuffer[nLen - 2])))
- {
- TRACE("校验失败!\r\n");
- SetEvent( m_hSemComm );
-
- if( pBuffer != NULL)
- {
- delete[] pBuffer;
- pBuffer = NULL;
- }
- return ERR_CODE_DAIKIN_COM_LRC_LOST;
- }
- //取变量数据
- EnterCriticalSection( &m_csWrFinished );
- memcpy( &m_structResponse.RequestChild, pBuffer, sizeof(CHILD) );
- byDataFlag[0] = pBuffer[sizeof(CHILD)];
- for( int i = 0; i < iCmdLen; i++ )
- {
- //if( iCmdPos > nLen - sizeof(CHILD) ) break;
- chMsg[i] = pBuffer[sizeof(CHILD) + iCmdPos + i];
- }
- LeaveCriticalSection(&m_csWrFinished);
- // 设置串口等待事件为有信号
- SetEvent( m_hSemComm );
-
- if( pBuffer != NULL)
- {
- delete[] pBuffer;
- pBuffer = NULL;
- }
- return 0;
- }
- int CProtocolModbus::RequestStatus
- (
- int nAddr, //地址
- int nVer, //版本号
- int nCid1, //控制标识码
- int nCid2, //命令信息
- WORD wLenId, //INFO字节长度
- int nCmdID, //命令ID
- int nDataLen, //请求数据长度
- int nCmdPos, //变量索引
- int nCmdLen, //变量长度
- char chMsg[80], //读到的变量值
- char *byDataFlag)
- {
- int iLen = sizeof(REQUESTPARAM);
- char chLength[4] = {0};
- char chChkSum[5] = {0};
- REQUESTPARAM RequestPara;
- memset( &RequestPara, 0, iLen );
- //起始位
- RequestPara.RequestChild.bySoi = 0x7E;
-
- //通讯协议版本
- itoa(nVer, (char *)RequestPara.RequestChild.byVer, 10);
- //设备地址描述
- itoa(nAddr, (char *)RequestPara.RequestChild.byAdr, 10);
- RequestPara.RequestChild.byAdr[0] = ByteToAscii((nAddr>>4) & 0x0f);
- RequestPara.RequestChild.byAdr[1] = ByteToAscii(nAddr & 0x0f);
- //Cid1
- RequestPara.RequestChild.byCid1[0] = ByteToAscii((nCid1>>4) & 0x0f);
- RequestPara.RequestChild.byCid1[1] = ByteToAscii(nCid1 & 0x0f);
- //Cid2
- RequestPara.RequestChild.byCid2[0] = ByteToAscii((nCid2 >> 4) & 0x0f);
- RequestPara.RequestChild.byCid2[1] = ByteToAscii(nCid2 & 0x0f);
- GetDataLength(wLenId, chLength);//取数据长度
- RequestPara.RequestChild.byLength[0] = ByteToAscii(chLength[0]);
- RequestPara.RequestChild.byLength[1] = chLength[1];
- RequestPara.RequestChild.byLength[2] = chLength[2];
- RequestPara.RequestChild.byLength[3] = chLength[3];
- //校验码
- BYTE *pDataBuf = new BYTE[ iLen - sizeof(RequestPara.byCheckSum) - 1 ];
- memset(pDataBuf, 0, iLen - sizeof(RequestPara.byCheckSum) - 1 );
-
- memcpy(pDataBuf, &RequestPara, iLen - sizeof(RequestPara.byCheckSum) - 1 );
- GetCheckSum((char *)pDataBuf + 1, chChkSum, iLen - sizeof(RequestPara.byCheckSum) - 2 );
- RequestPara.byCheckSum[0] = chChkSum[0];
- RequestPara.byCheckSum[1] = chChkSum[1];
- RequestPara.byCheckSum[2] = chChkSum[2];
- RequestPara.byCheckSum[3] = chChkSum[3];
-
- //结束符
- RequestPara.byEoi = 0x0D;
- if( WaitForSingleObject( m_hSemComm, 0 ) == WAIT_OBJECT_0 ) // 有信号才写串口
- {
- ResetEvent( m_hSemComm );
- int nResult = WriteMessage( (BYTE *)&RequestPara, iLen );
-
- if( nResult == iLen )
- {
- }
- else
- {
- delete []pDataBuf;
- SetEvent( m_hSemComm );
- return EER_CODE_DAIKIN_COM_WRITE_DATA;
- }
- }
- else
- {
- delete []pDataBuf;
- return ERR_CODE_DAIKIN_COM_BUSY;
- }
- delete[]pDataBuf;
- return 0;
- }
- UINT CProtocolModbus::GetCheckSum(char *pBuf, char chDest[5], int len)
- {
- WORD iSum = 0;
- //unsigned char chCompliment[2] = {0};
- for(int i=0; i<len; i++)//求和
- {
- //TRACE("%x\r\n", pBuf[i]);
- iSum += pBuf[i];
- }
- WORD iCompliment = iSum;
- iCompliment = ~iCompliment;//取反
- iCompliment++;
- //DigitToBinary(iCompliment, chDest, sizeof(chDest));
- itoa(iCompliment, chDest, 16);
- chDest[0] = lowercase2uppercase(chDest[0]);
- chDest[1] = lowercase2uppercase(chDest[1]);
- chDest[2] = lowercase2uppercase(chDest[2]);
- chDest[3] = lowercase2uppercase(chDest[3]);
- return atoi(chDest);
- }
- WORD CProtocolModbus::GetDataLength(const WORD wLENID, char chLength[4])
- {
- char szLenID[3] = {0};
- //int nLen = 10;
- DigitToBinary(wLENID, szLenID, sizeof(szLenID));
- char chCheckSum = GetLCheckSum(szLenID, sizeof(szLenID));
- chLength[0] = chCheckSum;
- chLength[1] = szLenID[0];
- chLength[2] = szLenID[1];
- chLength[3] = szLenID[2];
- return 0;
- }
- void CProtocolModbus::GetNotvalue(const char *pSrc, char *pDest, int iLen)
- {
- for(int i=0; i<iLen; i++)
- if (pSrc[i] == '1')
- pDest[i] = '0';
- else
- pDest[i] = '1';
- }
- BOOL CProtocolModbus::InitParam(PPORTPARAM pPortParam, CCommAsyn *pComm)
- {
- int addr=pPortParam->StartAddr;
- m_pComm=pComm;
- return TRUE;
- }
- int DigitToBinary(WORD wdSource, char* pDes, int iBit)
- {
- char pTmpBuf[16] = {0};
- char chBuffer[16] = {0};
- //wdSource =htonl(wdSource);
- itoa(wdSource, pTmpBuf, 2);
- int iLen = (int)strlen(pTmpBuf) - 1;
- char chValue[16] = {0};
- strcpy(chValue, pTmpBuf);
- for (int i =0; i<=iLen; i++)
- {
- pTmpBuf[i] = chValue[iLen - i];
- }
- for (int k = 0; k<iBit; k++)
- {
- if ( 0x00 == pTmpBuf[iBit - k - 1])
- chBuffer[k] = 0x30;
- else
- chBuffer[k] = pTmpBuf[iBit - k - 1];
- }
- memcpy(pDes, chBuffer, iBit);
- return 0;
- }
- void strReverse( char *str )
- {
- int l = (int)strlen(str);
- for( int i = 0; i < l; i++ )
- {
- for(int i = 0; i < l; i++)
- {
- if( str[i] >= 'A' && str[i] <= 'Z' )
- {
- str[i] += 32;
- }
- else if(str[i] >= 'a' && str[i] <= 'z')
- {
- str[i] -= 32;
- }
- }
- }
- }
- char lowercase2uppercase(BYTE btSrc)
- {
- if( btSrc >= 'a' && btSrc <= 'z' )
- {
- return btSrc - 'a' + 'A';
- }
- return btSrc;
- }
- char ByteToAscii(BYTE btSrc)
- {
- char chDest;
- if( btSrc < 10 )
- {
- chDest = (char)(btSrc % 10 + '0');
- chDest = lowercase2uppercase(chDest);
- return chDest;
- }
- else
- {
- chDest = ByteToAscii( btSrc / 10 ) + (char)( btSrc % 10 + '0' );
- chDest = lowercase2uppercase(chDest);
- return chDest;
- }
- }
- WORD AsciiToBYTE(BYTE btSrc)
- {
- WORD chDest = (WORD)btSrc;
- if ((btSrc >= 'A')&&(btSrc <= 'F'))
- {
- chDest = chDest - 'A' + 10;
- }
- else if ((btSrc >= 'a')&&(btSrc <= 'f'))
- {
- chDest = chDest - 'a' + 10;
- }
- else if ((btSrc >= '0')&&(btSrc <= '9'))
- {
- chDest -= '0';
- }
- return chDest;
- }
- /*
- Convert a binary data buffer to a hex string
- str: output (a string like “20ef9a“)
- bin: input (a data buffer)
- binlen: input (the length of the data buffer)
- */
- void bin2str(char *str, const unsigned char *bin, int binlen)
- {
- int i;
- for(i=0; i<binlen; i++)
- {
- str[2*i] = ((bin[i] & 0xF0) >> 4);
- str[2*i] = (str[2*i] > 9) ? (str[2*i] + 'A' - 10) : (str[2*i] + '0');
- str[2*i+1] = (bin[i] & 0x0F);
- str[2*i+1] = (str[2*i+1] > 9) ? (str[2*i+1] + 'A' - 10) : (str[2*i+1] + '0');
- }
- str[2*i] = '\0';
- }
- char CProtocolModbus::GetLCheckSum(char *pBuf, int len)
- {
- //WORD iSum = 0;
- char chCompliment = 0;
- //unsigned char chCompliment[2] = {0};
- for(int i=0; i<len; i++)//求和
- {
- chCompliment += AsciiToBYTE(pBuf[i]);
- //chCompliment += pBuf[i];
- }
- chCompliment = ~chCompliment;//取反
- chCompliment++;
- return chCompliment;
- }
- char CProtocolModbus::GetEvenCheckSum(char *pBuf, int nLen)
- {
- char szEven;
- for( int i = 0; i < nLen; i++ )
- {
- //szEven = szEven ^ AsciiToBYTE(pBuf[i]);
- szEven = szEven ^ pBuf[i];
- }
- //szEven = ByteToAscii(szEven);
- return szEven;
- #if 0
- unsigned int tmp, *dwp, *dwpend;
- unsigned char b;
- if(nLen==0) return 0;
- dwp=(unsigned int *)pBuf;
- dwpend=(unsigned int*)(pBuf+((nLen>>(sizeof(unsigned int)>>1))
- <<(sizeof(unsigned int)>>1)));
- if(dwp<dwpend)
- {
- tmp=*dwp;
- while(++dwp<dwpend)
- {
- tmp^=*dwp;
- };
- b =*((unsigned char*)(&tmp));
- b^=*((unsigned char*)(&tmp)+1);
- b^=*((unsigned char*)(&tmp)+2);
- b^=*((unsigned char*)(&tmp)+3);
- }
- else
- b=0;
- pBuf+=nLen-1;
- while(pBuf>=(char*)dwpend)
- b^=*pBuf--;
- return b;
- #endif
- }
|