| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031 |
- #include "StdAfx.h"
- #include ".\Daikin_020701R2.h"
- CDaiKin_020701R2::CDaiKin_020701R2(char *szPath,char *szIniName,int nCommPort, int nAddr,int nRate, int nDataBit,int nStopBit, int nParity,int nInterval)
- {
- #if IS_USE_READMSG_CS
- InitializeCriticalSection(&m_csReadMsg);
- #endif
- MTVERIFY(m_hSemComm = CreateEvent(NULL, TRUE, TRUE, 0));
- for (int i = 0; i < MAX_ADDR ; i++)
- {
- memset(m_sz42Msg[i], 0, sizeof(m_sz42Msg[i]));
- memset(m_sz43Msg[i], 0, sizeof(m_sz43Msg[i]));
- memset(m_sz45Msg[i], 0, sizeof(m_sz45Msg[i]));
- memset(m_sz47Msg[i], 0, sizeof(m_sz47Msg[i]));
- memset(m_sz49Msg[i], 0, sizeof(m_sz49Msg[i]));
- m_dwOnlineTick[i] = 0;
- m_devOnline[i] = TRUE;
- }
- }
- CDaiKin_020701R2::~CDaiKin_020701R2(void)
- {
- #if IS_USE_READMSG_CS
- DeleteCriticalSection(& m_csReadMsg);
- #endif
- MTVERIFY(CloseHandle(m_hSemComm));
- CloseComm();
- }
- BOOL CDaiKin_020701R2::OpenUPSComm(int nCommPort, int nAddr, int nRate, int nDataBit, int nStopBit, int nParity, int nInterval)
- {
- BOOL bResult = FALSE;
- //LOG4C((LOG_NOTICE,"->OpenUPSComm"));
- bResult = OpenComm( nCommPort, nAddr, nRate, nDataBit, nStopBit, nParity, nInterval );
- return bResult;
- }
- int CDaiKin_020701R2::GetIniInfo(char *szPath,char *szIniName,char *szCmd,char *IniSendCMD, int &IniSendlen, char *nType,int &nIndex,int &nLen)
- {
- CHAR szFile[MAX_PATH + 1] = "";
- wsprintf(szFile, "%s\\config\\%s", szPath, szIniName);
- TRACE("szFile =%s\n",szFile);
- IniSendlen = GetPrivateProfileString(szCmd, "SendCmd", "", IniSendCMD, 10, szFile); // 返回的字符串是以\0结束的;
- GetPrivateProfileString(szCmd, "type", "", nType, 10, szFile);
- nType[strlen(nType)] = '\0';
- nIndex = GetPrivateProfileInt(szCmd, "Index", 0, szFile);
- nLen = GetPrivateProfileInt(szCmd, "Len", 0, szFile);
- return 0;
- }
- int CDaiKin_020701R2::SendReadRequest(
- char *szPath,
- char *szIniName,
- int nCommPort,
- int nAddr,
- char *szCmd,
- char *szMsg,
- int nReversed1,
- int nReversed2,
- int nReversed3,
- int nReversed4,
- int nReversed5,
- float fReversed1,
- float fReversed2,
- float fReversed3,
- char *szReversed1,
- char *szReversed2,
- char *szReversed3,
- char *szReversed4,
- char *szReversed5 )
- {
- //LOG4C((LOG_NOTICE,"->SendReadRequest"));
- CCommProcess *pComm = FindComm(nCommPort);
- if( pComm == NULL ) return -1;
- int nRet(-1);
- int nIndex(0), nLen(0), IniSendlen(0);
- char IniSendCMD[MAX_CMD] = {0}, szDataType[CMD_TYPE] = {0};
- GetIniInfo(szPath,szIniName,szCmd,IniSendCMD,IniSendlen,szDataType,nIndex,nLen);
- int iCmd = atoi(szCmd + 4);
- if ( iCmd == 1)
- {
- Send_ReadCommand_42H(nAddr, pComm,IniSendCMD,IniSendlen,szCmd);
- }else if ( iCmd >= 2 && iCmd <=8)
- {
- Send_ReadCommand_43H(nAddr, pComm,IniSendCMD,IniSendlen,szCmd);
- }else if ( iCmd == 10 )
- {
- Send_WriteCommand_45H(nAddr,pComm,szMsg,szCmd);
- }else if ( iCmd == 11)
- {
- }
- Get_42Msg(nAddr,szCmd,szMsg,nIndex,nLen,szDataType);
- Get_43Msg(nAddr,szCmd,szMsg,nIndex,nLen,szDataType);
- Get_45Msg(nAddr,szCmd,szMsg,nIndex,nLen,szDataType);
- Get_47Msg(nAddr,szCmd,szMsg,nIndex,nLen,szDataType);
- Get_49Msg(nAddr,szCmd,szMsg,nIndex,nLen,szDataType);
- LOG4C((LOG_NOTICE,"nRet = %d,cmd = %s,值 = %s",nRet,szCmd,szMsg));
- return nRet;
- }
- // 发送写设置;
- int CDaiKin_020701R2::SendSetReuest(
- char *szPath,
- char *szIniName,
- int nCommPort,
- int nAddr,
- char *szCmd,
- char *szMsg,
- int nReversed1,
- int nReversed2,
- int nReversed3,
- int nReversed4,
- int nReversed5,
- float fReversed1,
- float fReversed2,
- float fReversed3,
- char *szReversed1,
- char *szReversed2,
- char *szReversed3,
- char *szReversed4,
- char *szReversed5
- )
- {
- return 0;
- }
- int CDaiKin_020701R2::GetDeviceParam(int naddr, CCommProcess *pComm,char *IniSendCMD,const int &IniSendlen ,char *szCmd)
- {
- //LOG4C((LOG_NOTICE,"->GetDeviceParam"));
- int nRet(-1);
- nRet = Send_ReadDeviceData(naddr, pComm, IniSendCMD, IniSendlen);
- if( nRet != 0 ) {
- return nRet;
- }
- nRet = Recv_ReadDeviceData(naddr, pComm, szCmd);
- return nRet;
- }
- int CDaiKin_020701R2::Send_ReadCommand_42H(int nAddr,CCommProcess *pComm,const char *IniSendCMD,const int &IniSendlen, char *szCmd)
- {
- #if DEBUG_DAIKIN_020701R2
- // *********************发送请求数据****************************
- char chChkSum[5] = {0};
- BYTE byArySend[120] = {0};
- byArySend[0] = 0x7E;
- byArySend[1] = 0x32;
- byArySend[2] = 0x30;
- byArySend[3] = ByteToAscii((nAddr>>4) & 0x0f);
- byArySend[4] = ByteToAscii(nAddr & 0x0f);
- //Cid1
- byArySend[5] = 0x36;
- byArySend[6] = 0x30;
- //Cid2
- byArySend[7] = 0x34;
- byArySend[8] = 0x32;
- // lengchk;
- byArySend[9] = 0x30;
- byArySend[10] = 0x30;
- byArySend[11] = 0x30;
- byArySend[12] = 0x30;
- GetEmersonCheck((char *)byArySend + 1, chChkSum, 12 );
- memcpy(byArySend + 13, chChkSum, 4);
- byArySend[17] = 0x0D;
- if (WaitForSingleObject(m_hSemComm,0) == WAIT_OBJECT_0 )
- {
- ResetEvent(m_hSemComm);
- int nResult = pComm->Write(byArySend, 17);
- if (nResult != 17)
- {
- SetEvent(m_hSemComm);
- return EER_CODE_COM_REGNUM;
- }
- }
- else
- {
- return ERR_CODE_COM_BUSY;
- }
- // *********************接收返回的数据******************;
- int nProcessLen(0),nReadLen(0);
- char *pBuff = new char[MAX_RECE_MSG];
- memset(pBuff, 0 , MAX_RECE_MSG);
- nReadLen = pComm->Read((BYTE *)pBuff,MAX_RECE_MSG);
- int nRet = RtnCheck(pBuff, nReadLen);
- if (nRet != 0)
- {
- SetEvent( m_hSemComm );
- if( pBuff != NULL)
- {
- delete[] pBuff;
- pBuff = NULL;
- }
- LOG4C((LOG_NOTICE,"->RTN校验出错:%d",nRet));
- return nRet; //RTN校验出错
- }
- if (nReadLen <= 0)
- {
- SetEvent(m_hSemComm);
- if (pBuff != NULL)
- {
- delete [] pBuff;
- pBuff = NULL;
- }
- LOG4C((LOG_NOTICE,"->串口没有读到数据"));
- return ERR_CODE_COM_READ_NO_DATA;
- } //长度校验出错 ;
- //LOG4C((LOG_NOTICE,"->**1**"));
- m_dwOnlineTick[nAddr -1] = GetTickCount();
- #if IS_USE_READMSG_CS
- EnterCriticalSection(&m_csReadMsg);
- #endif
- memcpy(m_szE1Msg[nAddr -1], pBuff, sizeof(m_szE1Msg[nAddr -1]));
- #if IS_USE_READMSG_CS
- LeaveCriticalSection(&m_csReadMsg);
- #endif
- SetEvent( m_hSemComm );
- if( pBuff != NULL)
- {
- delete[] pBuff;
- pBuff = NULL;
- }
- #endif
- return 0;
- }
- int CDaiKin_020701R2::Send_ReadCommand_43H(int nAddr,CCommProcess *pComm,const char *IniSendCMD,const int &IniSendlen, char *szCmd)
- {
- #if DEBUG_DAIKIN_020701R2
- char chChkSum[5] = {0};
- BYTE byArySend[120] = {0};
- byArySend[0] = 0x7E;
- byArySend[1] = 0x32;
- byArySend[2] = 0x30;
- byArySend[3] = ByteToAscii((nAddr>>4) & 0x0f);
- byArySend[4] = ByteToAscii(nAddr & 0x0f);
- //Cid1
- byArySend[5] = 0x36;
- byArySend[6] = 0x30;
- //Cid2
- byArySend[7] = 0x34;
- byArySend[8] = 0x33;
- // lengchk;
- byArySend[9] = 0x30;
- byArySend[10] = 0x30;
- byArySend[11] = 0x30;
- byArySend[12] = 0x30;
- GetEmersonCheck((char *)byArySend + 1, chChkSum, 12 );
- memcpy(byArySend + 13, chChkSum, 4);
- byArySend[17] = 0x0D;
- if (WaitForSingleObject(m_hSemComm,0) == WAIT_OBJECT_0 )
- {
- ResetEvent(m_hSemComm);
- int nResult = pComm->Write(byArySend, 17);
- if (nResult != 17)
- {
- SetEvent(m_hSemComm);
- return EER_CODE_COM_REGNUM;
- }
- }
- else
- {
- return ERR_CODE_COM_BUSY;
- }
- #endif
- return 0;
- }
- int CDaiKin_020701R2::Send_WriteCommand_45H(int nAddr,CCommProcess *pComm,char *InPutCommand, char *szCmd)
- {
- #if DEBUG_DAIKIN_020701R2
- int iSendLen = 0;
- char chLength[4] = {0};
- char chChkSum[5] = {0};
- BYTE byArySend[120] = {0};
- byArySend[0] = 0x7E;
- byArySend[1] = 0x32;
- byArySend[2] = 0x30;
- byArySend[3] = ByteToAscii((nAddr>>4) & 0x0f);
- byArySend[4] = ByteToAscii(nAddr & 0x0f);
- //Cid1
- byArySend[5] = 0x36;
- byArySend[6] = 0x30;
- //Cid2
- byArySend[7] = 0x34;
- byArySend[8] = 0x35;
- //memcpy(byArySend + 7, szCid2, 2);
- byArySend[9] = 0x45;
- byArySend[10] = 0x30;
- byArySend[11] = 0x30;
- byArySend[12] = 0x32;
- int iCtrl = atoi(InPutCommand);
- memset(InPutCommand,0,strlen(InPutCommand));
- itoa(iCtrl,InPutCommand,16);
- for (int i(0); i < 2 ; i++)
- lowcase2uppcase((BYTE &)InPutCommand[i]);
- memcpy(byArySend + 13, InPutCommand, 2);
- GetEmersonCheck((char *)byArySend + 1, chChkSum, 14 );
- memcpy(byArySend + 15, chChkSum, 4);
- byArySend[19] = 0x0D;
- iSendLen = 20;
- if (WaitForSingleObject(m_hSemComm,0) == WAIT_OBJECT_0 )
- {
- ResetEvent(m_hSemComm);
- int nResult = pComm->Write(byArySend, iSendLen);
- if (nResult != iSendLen)
- {
- SetEvent(m_hSemComm);
- return EER_CODE_COM_REGNUM;
- }
- }
- else
- {
- return ERR_CODE_COM_BUSY;
- }
- #endif
- return 0;
- }
- int CDaiKin_020701R2::Send_ReadCommand_47H(int nAddr,CCommProcess *pComm,const char *IniSendCMD,const int &IniSendlen, char *szCmd)
- {
- #if DEBUG_DAIKIN_020701R2
- char chChkSum[5] = {0};
- BYTE byArySend[120] = {0};
- byArySend[0] = 0x7E;
- byArySend[1] = 0x32;
- byArySend[2] = 0x30;
- byArySend[3] = ByteToAscii((nAddr>>4) & 0x0f);
- byArySend[4] = ByteToAscii(nAddr & 0x0f);
- //Cid1
- byArySend[5] = 0x36;
- byArySend[6] = 0x30;
- //Cid2
- byArySend[7] = 0x34;
- byArySend[8] = 0x37;
- // lengchk;
- byArySend[9] = 0x30;
- byArySend[10] = 0x30;
- byArySend[11] = 0x30;
- byArySend[12] = 0x30;
- GetEmersonCheck((char *)byArySend + 1, chChkSum, 12 );
- memcpy(byArySend + 13, chChkSum, 4);
- byArySend[17] = 0x0D;
- if (WaitForSingleObject(m_hSemComm,0) == WAIT_OBJECT_0 )
- {
- ResetEvent(m_hSemComm);
- int nResult = pComm->Write(byArySend, 17);
- if (nResult != 17)
- {
- SetEvent(m_hSemComm);
- return EER_CODE_COM_REGNUM;
- }
- }
- else
- {
- return ERR_CODE_COM_BUSY;
- }
- #endif
- return 0;
- }
- int CDaiKin_020701R2::Send_WriteCommand_49H(int nAddr,CCommProcess *pComm,char *InPutCommand, char *szCmd)
- {
- #if DEBUG_DAIKIN_020701R2
- int iSendLen = 0;
- char chLength[4] = {0};
- char chChkSum[5] = {0};
- BYTE byArySend[120] = {0};
- byArySend[0] = 0x7E;
- byArySend[1] = 0x32;
- byArySend[2] = 0x30;
- byArySend[3] = ByteToAscii((nAddr>>4) & 0x0f);
- byArySend[4] = ByteToAscii(nAddr & 0x0f);
- //Cid1
- byArySend[5] = 0x36;
- byArySend[6] = 0x30;
- //Cid2
- byArySend[7] = 0x34;
- byArySend[8] = 0x39;
- //memcpy(byArySend + 7, szCid2, 2);
- byArySend[9] = 0x41;
- byArySend[10] = 0x30;
- byArySend[11] = 0x30;
- byArySend[12] = 0x36;
- if ( strcmp(szCmd,"cmd-17") == 0) // 设定开机温度;
- {
- byArySend[13] = 0x80;
- }else if ( strcmp(szCmd,"cmd-18") == 0) // 设定关机温度;
- {
- byArySend[13] = 0x81;
- }else if ( strcmp(szCmd,"cmd-19") == 0) // 设定回风温度上限;
- {
- byArySend[13] = 0x82;
- }else if ( strcmp(szCmd,"cmd-20") == 0) // 设定回风温度下限;
- {
- byArySend[13] = 0x83;
- }else if ( strcmp(szCmd,"cmd-21") == 0) // 设定回风湿度上限;
- {
- byArySend[13] = 0x84;
- }else if ( strcmp(szCmd,"cmd-22") == 0) // 设定回风湿度下限;
- {
- byArySend[13] = 0x85;
- }
- char szTemp[10] = {0};
- int iRealLen = strlen(InPutCommand);
- memcpy(szTemp,InPutCommand,iRealLen);
- if (iRealLen > 4)
- {
- LOG4C((LOG_NOTICE,"非法指令长度:%s",szMsg));
- return -1;
- }
- if (iRealLen == 2)
- {
- memcpy(InPutCommand + 1, szTemp,iRealLen);
- InPutCommand[0] = 48;
- }else if (iRealLen == 1)
- {
- memcpy(InPutCommand + 2, szTemp,iRealLen);
- InPutCommand[0] = 48;
- InPutCommand[1] = 48;
- }
- for (int i(0); i < 3 ; i++)
- lowcase2uppcase((BYTE &)InPutCommand[i]);
- memcpy(byArySend + 14, InPutCommand, 3);
- GetEmersonCheck((char *)byArySend + 1, chChkSum, 16 );
- memcpy(byArySend + 17, chChkSum, 4);
- byArySend[21] = 0x0D;
- iSendLen = 22;
- if (WaitForSingleObject(m_hSemComm,0) == WAIT_OBJECT_0 )
- {
- ResetEvent(m_hSemComm);
- int nResult = pComm->Write(byArySend, iSendLen);
- if (nResult != iSendLen)
- {
- SetEvent(m_hSemComm);
- return EER_CODE_COM_REGNUM;
- }
- }
- else
- {
- return ERR_CODE_COM_BUSY;
- }
- #endif
- return 0;
- }
- int CDaiKin_020701R2::Send_ReadDeviceData(int nAddr,CCommProcess *pComm,const char *IniSendCMD,const int &IniSendlen)
- {
- #if DEBUG_DAIKIN_020701R2
- char chLength[4] = {0};
- char chChkSum[5] = {0};
- BYTE byArySend[120] = {0};
- byArySend[0] = 0x7E;
- byArySend[1] = 0x32;
- byArySend[2] = 0x30;
- byArySend[3] = ByteToAscii((nAddr>>4) & 0x0f);
- byArySend[4] = ByteToAscii(nAddr & 0x0f);
- //Cid1
- byArySend[5] = 0x36;
- byArySend[6] = 0x30;
- //Cid2
- byArySend[7] = 0x45;
- byArySend[8] = 0x30;
- byArySend[9] = 0x45;
- byArySend[10] = 0x30;
- byArySend[11] = 0x30;
- byArySend[12] = 0x32;
- memcpy(byArySend + 13, szMsg, 2);
- GetEmersonCheck((char *)byArySend + 1, chChkSum, 14 );
- memcpy(byArySend + 15, chChkSum, 4);
- /*byArySend[0] = chChkSum[0];
- byArySend[1] = chChkSum[1];
- byArySend[2] = chChkSum[2];
- byArySend[3] = chChkSum[3]; */
- byArySend[19] = 0x0D;
- // 对数组进行赋值;
- int iLen = strlen((char*)szSendMSG);
- if (WaitForSingleObject(m_hSemComm,0) == WAIT_OBJECT_0 ) {
- ResetEvent(m_hSemComm);
- int nResult = pComm->Write(szSendMSG, iLen);
- if (nResult != iLen){
- SetEvent(m_hSemComm);
- return EER_CODE_COM_REGNUM;
- }
- }
- else{
- return ERR_CODE_COM_BUSY;
- }
-
- #endif
- return 0;
- }
- int CDaiKin_020701R2::Recv_ReadDeviceData(int nAddr,CCommProcess *pComm,char *szCmd, char *cRecvData)
- {
- #if DEBUG_DAIKIN_020701R2
- //LOG4C((LOG_NOTICE,"->Recv_ReadDeviceData"));
- int nProcessLen(0),nReadLen(0);
- char *pBuff = new char[MAX_RECE_MSG];
- memset(pBuff, 0 , MAX_RECE_MSG);
- nReadLen = pComm->Read((BYTE *)pBuff,MAX_RECE_MSG);
- int nRet = RtnCheck(pBuff, nReadLen);
- if (nRet != 0)
- {
- SetEvent( m_hSemComm );
- if( pBuff != NULL)
- {
- delete[] pBuff;
- pBuff = NULL;
- }
- LOG4C((LOG_NOTICE,"->RTN校验出错:%d",nRet));
- return nRet; //RTN校验出错
- }
- if (nReadLen <= 0){
- SetEvent(m_hSemComm);
- if (pBuff != NULL) {
- delete [] pBuff;
- pBuff = NULL;
- }
- LOG4C((LOG_NOTICE,"->串口没有读到数据"));
- return ERR_CODE_COM_READ_NO_DATA;
- } //长度校验出错 ;
- //LOG4C((LOG_NOTICE,"->**0**"));
- CopyUPS_41_Msg(nAddr, szCmd, pBuff);
- CopyUPS_E1_Msg(nAddr, szCmd, pBuff);
- CopyUPS_E2_Msg(nAddr, szCmd, pBuff);
- CopyUPS_E3_Msg(nAddr, szCmd, pBuff);
- CopyUPS_E7_Msg(nAddr, szCmd, pBuff);
- CopyUPS_43_Msg(nAddr, szCmd, pBuff);
- CopyUPS_44_Msg(nAddr, szCmd, pBuff);
- //LOG4C((LOG_NOTICE,"->**1**"));
- m_dwOnlineTick[nAddr -1] = GetTickCount();
- SetEvent( m_hSemComm );
- if( pBuff != NULL) {
- delete[] pBuff;
- pBuff = NULL;
- }
- #else
- SimulationCommData(nAddr);
- #endif
- return 0;
- }
- void CDaiKin_020701R2::ReturnID(CCommProcess *pComm, const int &iAddr, char* szID)
- {
- BYTE byArSend[6] = {0};
- byArSend[0] = 2;
- byArSend[1] = '1';
- byArSend[2] = '0';
- byArSend[3] = '0';
- byArSend[4] = 3;
- for ( int i = 0; i < 5; i++ )
- byArSend[5] += byArSend[i];
- //WaitForSingObject();等待有信号;
- if( WaitForSingleObject( m_hSemComm, 0 ) == WAIT_OBJECT_0 )
- {
- //ResetEvent()设置无信号状态
- ResetEvent( m_hSemComm );
- int nResult = pComm->Write(byArSend, 6);
- if( nResult != 6 )
- {
- //SetEvent设置有信号;
- SetEvent( m_hSemComm );
- //返回 错误值;
- return ;
- }
- }
- else
- {
- //如果m_hSemCom无信号,返回错误;
- return ;
- }
- /************************************************************************/
- /* readfile ; */
- /************************************************************************/
- int nRecvLen = 0;
- BYTE byArRecv[23] = {0};
- nRecvLen = pComm->Read(byArRecv,23);
- SetEvent( m_hSemComm );
- memset(szID, 0, 17);
- sprintf(szID,"%s",byArRecv+3);
- szID[16] = 0;
- LOG4C((LOG_NOTICE,"Authorization Sucess"));
- }
- int CDaiKin_020701R2::PassWordCheck(CCommProcess *pComm, const int &iAddr, BYTE *byArPaWd)
- {
- BYTE byArSend[15] = {0};
- byArSend[0] = 2;
- byArSend[1] = '1';
- byArSend[2] = '1';
- byArSend[3] = '0';
- memcpy(byArSend,byArPaWd,8);
- byArSend[12] = 3;
- for ( int i = 0; i < 13; i++ )
- byArSend[13] += byArSend[i];
- //WaitForSingObject();等待有信号;
- if( WaitForSingleObject( m_hSemComm, 0 ) == WAIT_OBJECT_0 )
- {
- //ResetEvent()设置无信号状态
- ResetEvent( m_hSemComm );
- int nResult = pComm->Write(byArSend, 14);
- if( nResult != 6 )
- {
- //SetEvent设置有信号;
- SetEvent( m_hSemComm );
- //返回 错误值;
- return -1 ;
- }
- }
- else
- {
- //如果m_hSemCom无信号,返回错误;
- return -1;
- }
- /************************************************************************/
- /* readfile ; */
- /************************************************************************/
- int nRecvLen = 0;
- BYTE byArRecv[7] = {0};
- nRecvLen = pComm->Read(byArRecv,7);
- SetEvent( m_hSemComm );
- if ( nRecvLen == 0)
- return -1;
- LOG4C((LOG_NOTICE,"Authorization Sucess"));
- return byArRecv[4];
- }
- int CDaiKin_020701R2::Get_400Msg(int nAddr, char *szCmd, char *szMsg, int &nIndex, int &nLen, char *szType )
- {
- int nRet(0);
- if (strcmp(szCmd, "cmd-1") ==0 || strcmp(szCmd, "cmd-2") ==0 || strcmp(szCmd, "cmd-3") ==0 ||
- strcmp(szCmd, "cmd-4") ==0 || strcmp(szCmd, "cmd-5") ==0 || strcmp(szCmd, "cmd-6") ==0 ||
- strcmp(szCmd, "cmd-7") ==0 || strcmp(szCmd, "cmd-8") ==0 || strcmp(szCmd, "cmd-9") ==0 ||
- strcmp(szCmd, "cmd-10") ==0 || strcmp(szCmd, "cmd-11") ==0 || strcmp(szCmd, "cmd-12") ==0 ||
- strcmp(szCmd, "cmd-13") ==0 || strcmp(szCmd, "cmd-14") ==0 || strcmp(szCmd, "cmd-15") ==0 )
- {
- #if IS_USE_READMSG_CS
- EnterCriticalSection(&m_csReadMsg);
- #endif
- DataConversion(szType, m_sz41Msg[nAddr -1] + nIndex, szMsg, nLen);
- #if IS_USE_READMSG_CS
- LeaveCriticalSection(&m_csReadMsg);
- #endif
- nRet = 0;
- }
- return nRet;
- }
- int CDaiKin_020701R2::GetUPS_E1Msg(int nAddr, char *szCmd, char *szMsg, int &nIndex, int &nLen, char *szType )
- {
- int nRet(0);
- if (strcmp(szCmd, "cmd-16") ==0 || strcmp(szCmd, "cmd-17") ==0 || strcmp(szCmd, "cmd-18") ==0 ||
- strcmp(szCmd, "cmd-19") ==0 || strcmp(szCmd, "cmd-20") ==0 || strcmp(szCmd, "cmd-21") ==0 ||
- strcmp(szCmd, "cmd-22") ==0 || strcmp(szCmd, "cmd-23") ==0 || strcmp(szCmd, "cmd-24") ==0 ||
- strcmp(szCmd, "cmd-25") ==0 || strcmp(szCmd, "cmd-26") ==0 || strcmp(szCmd, "cmd-27") ==0 ||
- strcmp(szCmd, "cmd-28") ==0 || strcmp(szCmd, "cmd-29") ==0 || strcmp(szCmd, "cmd-30") ==0 ||
- strcmp(szCmd, "cmd-31") ==0 )
- {
- #if IS_USE_READMSG_CS
- EnterCriticalSection(&m_csReadMsg);
- #endif
- DataConversion(szType, m_szE1Msg[nAddr -1] + nIndex, szMsg, nLen);
- #if IS_USE_READMSG_CS
- LeaveCriticalSection(&m_csReadMsg);
- #endif
- nRet = 0;
- }
- return nRet;
- }
- int CDaiKin_020701R2::GetUPS_E2Msg(int nAddr, char *szCmd, char *szMsg, int &nIndex, int &nLen, char *szType )
- {
- int nRet(0);
- if (strcmp(szCmd, "cmd-32") == 0 ||
- strcmp(szCmd, "cmd-33") == 0 || strcmp(szCmd, "cmd-34") == 0 || strcmp(szCmd, "cmd-35") == 0 ||
- strcmp(szCmd, "cmd-36") == 0 || strcmp(szCmd, "cmd-37") == 0 || strcmp(szCmd, "cmd-38") == 0 ||
- strcmp(szCmd, "cmd-39") == 0 || strcmp(szCmd, "cmd-40") == 0 || strcmp(szCmd, "cmd-41") == 0 ||
- strcmp(szCmd, "cmd-42") == 0 || strcmp(szCmd, "cmd-43") == 0 || strcmp(szCmd, "cmd-44") == 0 ||
- strcmp(szCmd, "cmd-45") == 0 || strcmp(szCmd, "cmd-46") == 0 || strcmp(szCmd, "cmd-47") == 0 ||
- strcmp(szCmd, "cmd-48") == 0 || strcmp(szCmd, "cmd-49") == 0 || strcmp(szCmd, "cmd-50") == 0 ||
- strcmp(szCmd, "cmd-51") == 0 )
- {
- #if IS_USE_READMSG_CS
- EnterCriticalSection(&m_csReadMsg);
- #endif
- DataConversion(szType, m_szE2Msg[nAddr -1] + nIndex, szMsg, nLen);
- #if IS_USE_READMSG_CS
- LeaveCriticalSection(&m_csReadMsg);
- #endif
- nRet = 0;
- }
- return nRet;
- }
- int CDaiKin_020701R2::GetUPS_E3Msg(int nAddr, char *szCmd, char *szMsg, int &nIndex, int &nLen, char *szType )
- {
- int nRet(0);
- if ( strcmp(szCmd, "cmd-52") == 0 || strcmp(szCmd, "cmd-53") == 0 || strcmp(szCmd, "cmd-54") == 0 ||
- strcmp(szCmd, "cmd-55") == 0 || strcmp(szCmd, "cmd-56") == 0 || strcmp(szCmd, "cmd-57") == 0 ||
- strcmp(szCmd, "cmd-58") == 0 || strcmp(szCmd, "cmd-59") == 0 || strcmp(szCmd, "cmd-60") == 0 ||
- strcmp(szCmd, "cmd-61") == 0 )
- {
- #if IS_USE_READMSG_CS
- EnterCriticalSection(&m_csReadMsg);
- #endif
- DataConversion(szType, m_szE3Msg[nAddr -1] + nIndex, szMsg, nLen);
- #if IS_USE_READMSG_CS
- LeaveCriticalSection(&m_csReadMsg);
- #endif
- nRet = 0;
- }
- return nRet;
- }
- int CDaiKin_020701R2::GetUPS_E7Msg(int nAddr, char *szCmd, char *szMsg, int &nIndex, int &nLen, char *szType )
- {
- int nRet(0);
- if ( strcmp(szCmd, "cmd-62") ==0 || strcmp(szCmd, "cmd-63") ==0 || strcmp(szCmd, "cmd-64") ==0 ||
- strcmp(szCmd, "cmd-65") ==0 || strcmp(szCmd, "cmd-66") ==0 || strcmp(szCmd, "cmd-67") ==0 ||
- strcmp(szCmd, "cmd-68") ==0 || strcmp(szCmd, "cmd-69") ==0 || strcmp(szCmd, "cmd-70") ==0 )
- {
- #if IS_USE_READMSG_CS
- EnterCriticalSection(&m_csReadMsg);
- #endif
- DataConversion(szType, m_szE7Msg[nAddr -1] + nIndex, szMsg, nLen);
- #if IS_USE_READMSG_CS
- LeaveCriticalSection(&m_csReadMsg);
- #endif
- nRet = 0;
- }
- return nRet;
- }
- int CDaiKin_020701R2::GetUPS_43Msg(int nAddr, char *szCmd, char *szMsg, int &nIndex, int &nLen, char *szType )
- {
- int nRet(0);
- if (strcmp(szCmd, "cmd-71") ==0 || strcmp(szCmd, "cmd-72") ==0 || strcmp(szCmd, "cmd-73") ==0 ||
- strcmp(szCmd, "cmd-74") ==0 || strcmp(szCmd, "cmd-75") ==0 || strcmp(szCmd, "cmd-76") ==0 ||
- strcmp(szCmd, "cmd-77") ==0 || strcmp(szCmd, "cmd-78") ==0 || strcmp(szCmd, "cmd-79") ==0 ||
- strcmp(szCmd, "cmd-80") ==0 || strcmp(szCmd, "cmd-81") ==0 || strcmp(szCmd, "cmd-82") ==0 ||
- strcmp(szCmd, "cmd-83") ==0 || strcmp(szCmd, "cmd-84") ==0 || strcmp(szCmd, "cmd-85") ==0 ||
- strcmp(szCmd, "cmd-86") ==0 || strcmp(szCmd, "cmd-87") ==0 || strcmp(szCmd, "cmd-88") ==0 ||
- strcmp(szCmd, "cmd-89") ==0 || strcmp(szCmd, "cmd-90") ==0 || strcmp(szCmd, "cmd-91") ==0 ||
- strcmp(szCmd, "cmd-92") ==0 || strcmp(szCmd, "cmd-93") ==0 || strcmp(szCmd, "cmd-94") ==0 ||
- strcmp(szCmd, "cmd-95") ==0 )
- {
- #if IS_USE_READMSG_CS
- EnterCriticalSection(&m_csReadMsg);
- #endif
- DataConversion(szType, m_sz43Msg[nAddr -1] + nIndex, szMsg, nLen);
- #if IS_USE_READMSG_CS
- LeaveCriticalSection(&m_csReadMsg);
- #endif
- nRet = 0;
- }
- return nRet;
- }
- int CDaiKin_020701R2::GetUPS_44Msg(int nAddr,char *szCmd, char *szMsg, int &nIndex, int &nLen, char *szType )
- {
- int nRet(0);
- if (strcmp(szCmd, "cmd-96") ==0 || strcmp(szCmd, "cmd-97") ==0 || strcmp(szCmd, "cmd-98") ==0 ||
- strcmp(szCmd, "cmd-99") ==0 || strcmp(szCmd, "cmd-100") ==0 || strcmp(szCmd, "cmd-101") ==0 ||
- strcmp(szCmd, "cmd-102") ==0 || strcmp(szCmd, "cmd-103") ==0 || strcmp(szCmd, "cmd-104") ==0 ||
- strcmp(szCmd, "cmd-105") ==0 || strcmp(szCmd, "cmd-106") ==0 || strcmp(szCmd, "cmd-107") ==0 ||
- strcmp(szCmd, "cmd-108") ==0 || strcmp(szCmd, "cmd-109") ==0 || strcmp(szCmd, "cmd-110") ==0 ||
- strcmp(szCmd, "cmd-111") ==0 || strcmp(szCmd, "cmd-112") ==0 || strcmp(szCmd, "cmd-113") ==0 ||
- strcmp(szCmd, "cmd-114") ==0 || strcmp(szCmd, "cmd-115") ==0 || strcmp(szCmd, "cmd-116") ==0 ||
- strcmp(szCmd, "cmd-117") ==0 || strcmp(szCmd, "cmd-118") ==0 || strcmp(szCmd, "cmd-119") ==0 ||
- strcmp(szCmd, "cmd-120") ==0 || strcmp(szCmd, "cmd-121") ==0 || strcmp(szCmd, "cmd-122") ==0 ||
- strcmp(szCmd, "cmd-123") ==0 || strcmp(szCmd, "cmd-124") ==0 || strcmp(szCmd, "cmd-125") ==0 ||
- strcmp(szCmd, "cmd-126") ==0 || strcmp(szCmd, "cmd-127") ==0 || strcmp(szCmd, "cmd-128") ==0 ||
- strcmp(szCmd, "cmd-129") ==0 || strcmp(szCmd, "cmd-130") ==0 || strcmp(szCmd, "cmd-131") ==0 ||
- strcmp(szCmd, "cmd-132") ==0 || strcmp(szCmd, "cmd-133") ==0 || strcmp(szCmd, "cmd-134") ==0 ||
- strcmp(szCmd, "cmd-135") ==0 || strcmp(szCmd, "cmd-136") ==0 || strcmp(szCmd, "cmd-137") ==0 ||
- strcmp(szCmd, "cmd-138") ==0 || strcmp(szCmd, "cmd-139") ==0 || strcmp(szCmd, "cmd-140") ==0 ||
- strcmp(szCmd, "cmd-141") ==0 || strcmp(szCmd, "cmd-142") ==0 || strcmp(szCmd, "cmd-143") ==0 ||
- strcmp(szCmd, "cmd-144") ==0 || strcmp(szCmd, "cmd-145") ==0 || strcmp(szCmd, "cmd-146") ==0 ||
- strcmp(szCmd, "cmd-147") ==0 || strcmp(szCmd, "cmd-148") ==0 || strcmp(szCmd, "cmd-149") ==0 ||
- strcmp(szCmd, "cmd-150") ==0 || strcmp(szCmd, "cmd-151") ==0 || strcmp(szCmd, "cmd-152") ==0 ||
- strcmp(szCmd, "cmd-153") ==0 || strcmp(szCmd, "cmd-154") ==0 || strcmp(szCmd, "cmd-155") ==0 ||
- strcmp(szCmd, "cmd-156") ==0 || strcmp(szCmd, "cmd-157") ==0 || strcmp(szCmd, "cmd-158") ==0 ||
- strcmp(szCmd, "cmd-159") ==0 || strcmp(szCmd, "cmd-160") ==0 || strcmp(szCmd, "cmd-161") ==0 ||
- strcmp(szCmd, "cmd-162") ==0 || strcmp(szCmd, "cmd-163") ==0 || strcmp(szCmd, "cmd-164") ==0 ||
- strcmp(szCmd, "cmd-165") ==0 || strcmp(szCmd, "cmd-166") ==0 || strcmp(szCmd, "cmd-167") ==0 ||
- strcmp(szCmd, "cmd-168") ==0 || strcmp(szCmd, "cmd-169") ==0 || strcmp(szCmd, "cmd-170") ==0 ||
- strcmp(szCmd, "cmd-171") ==0 || strcmp(szCmd, "cmd-172") ==0 || strcmp(szCmd, "cmd-173") ==0 ||
- strcmp(szCmd, "cmd-174") ==0 || strcmp(szCmd, "cmd-175") ==0 || strcmp(szCmd, "cmd-176") ==0 ||
- strcmp(szCmd, "cmd-177") ==0 || strcmp(szCmd, "cmd-178") ==0 || strcmp(szCmd, "cmd-179") ==0 ||
- strcmp(szCmd, "cmd-180") ==0 || strcmp(szCmd, "cmd-181") ==0 )
- {
- #if IS_USE_READMSG_CS
- EnterCriticalSection(&m_csReadMsg);
- #endif
- DataConversion(szType, m_sz44Msg[nAddr -1] + nIndex, szMsg, nLen);
- #if IS_USE_READMSG_CS
- LeaveCriticalSection(&m_csReadMsg);
- #endif
- nRet = 0;
- }
- return nRet;
- }
- void CDaiKin_020701R2::lowcase2uppcase(BYTE &btSrc)
- {
- if( btSrc >= 'a' && btSrc <= 'z' )
- {
- btSrc = btSrc - 'a' + 'A';
- }
- }
- void CDaiKin_020701R2::GetEmersonLength(const int &iLenID, char *szLegth)
- {
- int ilengthchecksum(0);
- int it = iLenID;
- ilengthchecksum = it & 0x00F ; it = iLenID;
- ilengthchecksum += (it &0x0F0) >> 4; it = iLenID;
- ilengthchecksum += (it &0xF00 ) >> 8;
- ilengthchecksum = ilengthchecksum%16;
- ilengthchecksum = ~ilengthchecksum +17;
- int ilength = (ilengthchecksum & 0x000F) << 12 ;
- ilength = ilength | iLenID;
- itoa(ilength,szLegth,16 );
- for (int i(0) ; i < 5 ; i++)
- {
- lowercase2uppercase((BYTE &)szLegth[i]);
- }
- }
- void CDaiKin_020701R2::GetEmersonCheck(char *szData, char *szCheck ,int nlen /* = 12 */)
- {
- DWORD dwSum(0);
- nlen = strlen(szData);
- for (int i(0); i < nlen; i++)
- {
- dwSum += szData[i] ;
- }
- WORD iCompliment = dwSum;
- iCompliment = ~iCompliment;//取反
- iCompliment++;
- itoa(iCompliment, szCheck, 16);
- for (int i(0); i < 5 ; i++)
- {
- lowcase2uppcase((BYTE &)szCheck[i]);
- }
- }
- WORD CDaiKin_020701R2::RtnCheck(char *szMsg,int len)
- {
- char ch[2] = {0};
- ch[0] = szMsg[7];
- ch[1] = szMsg[8];
- if (atoi(ch) == 0)
- {
- return ERR_CODE_RTN_NATURAL;
- }
- else if (atoi(ch) ==1)
- {
- return ERR_CODE_RTN_VER_ERROR;
- }
- else if (atoi(ch) ==2)
- {
- return ERR_CODE_RTN_CHKSUM_ERROR;
- }
- else if (atoi(ch) ==3)
- {
- return ERR_CODE_RTN_LCHKSUM_ERROR;
- }
- else if (atoi(ch) ==4)
- {
- return ERR_CODE_RTN_CID_ERROR;
- }
- else if (atoi(ch) ==5)
- {
- return ERR_CODE_RTN_COMMAND_FORMAT;
- }
- else if (atoi(ch) ==6)
- {
- return ERR_CODE_RTN_INVALID_DATA;
- }
- else if (atoi(ch) ==16)
- {
- return ERR_CODE_RTN_INVALID_LIMIT;
- }
- else if (atoi(ch) ==17)
- {
- return ERR_CODE_RTN_OPERATE_FAIL;
- }
- else if (atoi(ch) ==18)
- {
- return ERR_CODE_RTN_EQUIT_FAIL;
- }
- return -1;
- }
- void CDaiKin_020701R2::SimulationCommData(int nAddr)
- {
- //~10012A0020680033335F439A1963439A99644366665C4333335A4333335D433333B33F0000C03FCDCC8C3F33B3DA43CDCC474200000033B3DA43E71D.
- memcpy(m_sz41Msg[nAddr -1], "~10012A0020680033335F439A1963439A99644366665C4333335A4333335D433333B33F0000C03FCDCC8C3F33B3DA43CDCC474200000033B3DA43E71D.", sizeof("~10012A0020680033335F439A1963439A99644366665C4333335A4333335D433333B33F0000C03FCDCC8C3F33B3DA43CDCC474200000033B3DA43E71D."));
-
- //~10012A00307600000E66A6C2439A19C5439A59C3436666663FCDCC4C3F0000803FC3F547423333333FA4703D3F1F852B3F9A995F43CD4C614333B35E4348E14742E3B1.
- memcpy(m_szE1Msg[nAddr -1], "~10012A00307600000E66A6C2439A19C5439A59C3436666663FCDCC4C3F0000803FC3F547423333333FA4703D3F1F852B3F9A995F43CD4C614333B35E4348E14742E3B1.", sizeof("~10012A00307600000E66A6C2439A19C5439A59C3436666663FCDCC4C3F0000803FC3F547423333333FA4703D3F1F852B3F9A995F43CD4C614333B35E4348E14742E3B1."));
- //~10012A00109600001285EB113F1F856B3F000000003333334000000040CDCCCC3FCDCCCC3D9A99993E00000000CDCC4C3ECDCC4C3ECDCCCC3D9A99993ECDCCCC3ECDCCCC3D9A9979409A99D9403333F33FDB96.
- memcpy(m_szE2Msg[nAddr -1], "~10012A00109600001285EB113F1F856B3F000000003333334000000040CDCCCC3FCDCCCC3D9A99993E00000000CDCC4C3ECDCC4C3ECDCCCC3D9A99993ECDCCCC3ECDCCCC3D9A9979409A99D9403333F33FDB96.", sizeof("~10012A00109600001285EB113F1F856B3F000000003333334000000040CDCCCC3FCDCCCC3D9A99993E00000000CDCC4C3ECDCC4C3ECDCCCC3D9A99993ECDCCCC3ECDCCCC3D9A9979409A99D9403333F33FDB96."));
- //~10012A00004C0009000000000000000000000000000000000000000000000000000000000000000000000000EF4B.
- memcpy(m_szE3Msg[nAddr -1], "~10012A00004C0009000000000000000000000000000000000000000000000000000000000000000000000000EF4B.", sizeof("~10012A00004C0009000000000000000000000000000000000000000000000000000000000000000000000000EF4B."));
- //~10012A00604600010800009644CD4C5A430AD7233E66E65A430AD7233E0000803F0000C8410000C841EEC9.
- memcpy(m_szE7Msg[nAddr -1], "~10012A00604600010800009644CD4C5A430AD7233E66E65A430AD7233E0000803F0000C8410000C841EEC9.", sizeof("~10012A00604600010800009644CD4C5A430AD7233E66E65A430AD7233E0000803F0000C8410000C841EEC9."));
- //~10012A009034000117E1E0E1E0E1E1E0E1E1E0E2E1E2E0E1E1E1E1E1E1E1E1E1F1D2.
- memcpy(m_sz43Msg[nAddr -1], "~10012A009034000117E1E0E1E0E1E1E0E1E1E0E2E1E2E0E1E1E1E1E1E1E1E1E1F1D2.", sizeof("~10012A009034000117E1E0E1E0E1E1E0E1E1E0E2E1E2E0E1E1E1E1E1E1E1E1E1F1D2."));
- //~10012A00B0BA000000000000000054000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000DA8D.
- memcpy(m_sz44Msg[nAddr -1], "~10012A00B0BA000000000000000054000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000DA8D.", sizeof("~10012A00B0BA000000000000000054000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000DA8D."));
- }
- /////////
|