/** ****************************************************************************** * @file : KLink.c * @brief : K-Link Protocol program body ****************************************************************************** */ #include "KLink.h" #include "functions.h" #include "string.h" #include "PLCFunctions.h" #include "stm32f0xx_hal.h" #include "main.h" #ifdef KWLESS #include "KWireless.h" #endif //extern stWLRunStat KwRunStat; //unsigned char KLPacketBuf1[256]; unsigned char KLPacketBuf2[256]; unsigned char KLBufferIn[16]={0}; unsigned char KLBufferOut[16]={0}; unsigned char nKLStationId=1; unsigned char nKLSeq=0; unKLStat nKLStatus ={0}; int KLThisuS=0; int KLRecvTimeuS=0; stPortDef KLinkPortReg1 = {.nPortHardType = 3,.nPortUseType = 2, .bEnable = 1, .bRunning =1, .StationId = 1, .bMaster = 0}; int KLinkInit(int n) { KMRegisterPort(0,&KLinkPortReg1); return 0; } unsigned char KLBCC(void const * pData, int nSize) { unsigned char k; k=0; for (int i=0;iRplyStSgn=KLSignReply; p1->DstHost=dst; p1->nStatus=Status; p1->nRplyCMD=nCmd; p1->nSize1=DataLen; if (nCmd == KLCmdErrRply) { DataLen = 0; p1->Datas[DataLen]=KLBCC(p1,sizeof(stKLRplyPktHdr)+DataLen-1); PacketLenth=sizeof(stKLRplyPktHdr)+DataLen; } else { memcpy(p1->Datas,pData,DataLen); p1->Datas[DataLen]=KLBCC(p1,sizeof(stKLRplyPktHdr)+DataLen-1); PacketLenth=sizeof(stKLRplyPktHdr)+DataLen; } switch (nCmd) { case KLCmdNone: PacketLenth=0; break; case KLCmdPing: // case KLCmdPingReply: //p1->data[DataLen+1]=KLEndSign; //PacketLenth=sizeof(stKLPacket)+DataLen+1; break; case KLCmdRead: // case KLCmdReadReply: //p1->data[DataLen+1]=KLEndSign; //PacketLenth=sizeof(stKBPacket)+DataLen+1; break; case KLCmdWrite: // case KLCmdWriteReply: break; case KLCmdErrRply: break; default: break; } return PacketLenth; } int KLCheckPacket(int nChn, void * pBuf, int nLen1) { pKLReqPktHdr p1 = (pKLReqPktHdr) pBuf; if (p1->ReqStSgn != KLSignStart) { return 1; } int DataLen=0; //p1->LoadLen; if (DataLen>KLMaxPacketLength) { return 2; } if (nLen1data[DataLen+1] != EndSign) // { // KBusChnStats[nCurPollId].NoEndErr++; // Uart2Stat.LengthErr++; // return -2; // } unsigned char thisBCC=KLBCC(p1,nLen1-1); if (thisBCC != ((uchar *)pBuf)[nLen1-1]) {//BCC Error; return 4; } return 0; } inline void SetAddrBit(unsigned short * pW, unsigned char bitAddr) { (*pW)|=1<<(bitAddr&0xf); } inline void ResetBit(unsigned short * pW, unsigned char bitAddr) { (*pW)&=~(1<<(bitAddr&0xf)); } static inline void SetBitValue(unsigned short * pW, unsigned char bitAddr, unsigned char Value) { if (Value) { SetAddrBit(pW, bitAddr);} else {ResetBit(pW, bitAddr);} } int KLParseReqPacket(int nChn, void * pBuf, int Len1) { pKLReqPktHdr p1 = (pKLReqPktHdr)pBuf; unsigned char nDstHost=p1->DstHost; KLRecvTimeuS=KLThisuS; unsigned char nDataType=p1->nType1; unsigned short nWordAddr=0; unsigned short nByteAddr=0; unsigned short nBitAddr=0; unsigned short DataLen=0; //p1->LoadLen; unsigned short nValue=0; //int nSrcAddr=p1->SrcAddr; nKLStatus.nSEQ = ((pKLStat)(&(p1->Stat)))->nSEQ;; void * pData=0; pKLRplyPktHdr p2=(pKLRplyPktHdr)KLPacketBuf2; char rData[4]; int res = 0 ; int PacketLen=0; KLRecvTimeuS=KLThisuS; if (nDstHost==nKLStationId || nDstHost==0xff) { switch (p1->nCMD) { case KLCmdNone: break; case KLCmdPing: DataLen=nDataType; // KLBufferIn[0]=p1->Params[0]; // p1->Params[0]=KLBufferOut[0]; PacketLen=KLMakeRplyPacket(p2,nDstHost,nKLStatus.StatByte,KLCmdPing,DataLen,p1->Params); SendPacket(nChn, p2, PacketLen); break; // case KLCmdPingReply: // break; case KLCmdInfo: //if (nDataType == KLDataTypeDT) DataLen= sizeof(KMInfoBlock); PacketLen=KLMakeRplyPacket(p2,nDstHost,nKLStatus.StatByte,p1->nCMD,DataLen,&KMInfoBlock); SendPacket(nChn, p2, PacketLen); break; case KLCmdGetUid: //if (nDataType == KLDataTypeDT) DataLen= 12; PacketLen=KLMakeRplyPacket(p2,nDstHost,nKLStatus.StatByte,p1->nCMD,DataLen,(uint32_t *)UID_BASE); SendPacket(nChn, p2, PacketLen); break; case KLCmdGetSN: //if (nDataType == KLDataTypeDT) DataLen= 4; PacketLen=KLMakeRplyPacket(p2,nDstHost,nKLStatus.StatByte,p1->nCMD,DataLen,&((pFactoryData)FACTORY_DATA_BASE)->SN1); SendPacket(nChn, p2, PacketLen); break; case KLCmdGetFactoryData: DataLen= sizeof(stFactoryData); PacketLen=KLMakeRplyPacket(p2,nDstHost,nKLStatus.StatByte,p1->nCMD,DataLen,(pFactoryData)FACTORY_DATA_BASE); SendPacket(nChn, p2, PacketLen); break; case KLCmdWriteFactoryData: nWordAddr=p1->Params[0]+ (p1->Params[1]<<8); DataLen= p1->Params[2]; //DataLen=16; for (int i=0;iParams[4+i];} WriteFactoryData(KLPacketBuf2, DataLen); PacketLen=KLMakeRplyPacket(p2,nDstHost,nKLStatus.StatByte,p1->nCMD,0,0); SendPacket(nChn, p2, PacketLen); break; case KLCmdRead: case KLCmdReadDataWord: case KLCmdReadDataByte: nWordAddr=p1->Params[0]+ (p1->Params[1]<<8); DataLen= p1->Params[2]; if (nDataType ==KLDataTypeDT) { pData=KMem.DT+nWordAddr; } else if (nDataType == KLDataTypeSDT) { pData=KMem.SDT+nWordAddr; } else if (nDataType == KLDataTypeWSR) { pData=KMem.WSR+nWordAddr; } else if (nDataType == KLDataTypeWX) { pData=KMem.WX+nWordAddr; } else if (nDataType == KLDataTypeWY) { pData=KMem.WY+nWordAddr; } else if (nDataType == KLDataTypeWR) { pData=KMem.WR+nWordAddr; } else if (nDataType == KLDataTypeWLX) { pData=KMem.WLX+nWordAddr; } else if (nDataType == KLDataTypeWLY) { pData=KMem.WLY+nWordAddr; } #if (ENABLE_PLC) else if (nDataType == KLDataTypeSV) { pData=PLCMem.SV+nWordAddr; } else if (nDataType == KLDataTypeEV) { pData=PLCMem.EV+nWordAddr; } #endif else if (nDataType == KLDataTypeTest) { pData=KMem.SDT+nWordAddr; } else if (nDataType == KLDataTypeWDT) { pData=KMem.WDT+nWordAddr; } else if (nDataType == KLDataTypeKBD) { pData=(unsigned short *)&KBus1.KBusChnStats +nWordAddr; } #ifdef KWLESS else if (nDataType == KLDataTypeKWLD) { pData=(unsigned short *)&KwRunStat +nWordAddr; } #endif else if (nDataType == KLDataSysCfg) { pData = (unsigned short *)&storedKMSysCfg.theKMSysCfg + nWordAddr;} else if (nDataType == KLDataTypeFlash) { pData = (unsigned short *)FLASH_BASE + nWordAddr;} else { pData=KLBufferOut+nWordAddr; } PacketLen=KLMakeRplyPacket(p2,nDstHost,nKLStatus.StatByte,p1->nCMD,DataLen,pData); SendPacket(nChn, p2, PacketLen); break; // case KLCmdReadReply: // break; case KLCmdWrite: case KLCmdWriteDataWord: case KLCmdWriteDataByte: //memcpy(DispBuf,p1->data,DataLen); nWordAddr=p1->Params[0]+ (p1->Params[1]<<8); DataLen= p1->Params[2]; if (nDataType ==KLDataTypeDT) { pData=KMem.DT+nWordAddr; } else if (nDataType == KLDataTypeSDT) { pData=KMem.SDT+nWordAddr; } else if (nDataType == KLDataTypeWSR) { pData=KMem.WSR+nWordAddr; } else if (nDataType == KLDataTypeWX) { pData=KMem.WX+nWordAddr; } else if (nDataType == KLDataTypeWY) { pData=KMem.WY+nWordAddr; } else if (nDataType == KLDataTypeWR) { pData=KMem.WR+nWordAddr; } else if (nDataType == KLDataTypeWLX) { pData=KMem.WLX+nWordAddr; } else if (nDataType == KLDataTypeWLY) { pData=KMem.WLY+nWordAddr; } #if (ENABLE_PLC) else if (nDataType == KLDataTypeSV) { pData=PLCMem.SV+nWordAddr; DataLen=0;} else if (nDataType == KLDataTypeEV) { pData=PLCMem.EV+nWordAddr; DataLen=0;} #endif else if (nDataType == KLDataTypeTest) { pData=KMem.SDT+nWordAddr; DataLen=0;} else if (nDataType == KLDataTypeWDT) { pData=KMem.WDT+nWordAddr; DataLen=0;} else if (nDataType == KLDataTypeKBD) { pData=(unsigned short *)KBus1.KBusChnStats +nWordAddr; DataLen=0;} #ifdef KWLESS else if (nDataType == KLDataTypeKWLD) { pData=(unsigned short *)&KwRunStat +nWordAddr; } #endif else if (nDataType == KLDataSysCfg) { pData = (unsigned short *)&(storedKMSysCfg) + nWordAddr;} else if (nDataType == KLDataTypeFlash) { pData = (unsigned short *)FLASH_BASE + nWordAddr;} else { pData=KLBufferOut+nWordAddr; DataLen=0; } memcpy(pData,p1->Params+4,DataLen); PacketLen=KLMakeRplyPacket(p2,nDstHost,nKLStatus.StatByte,p1->nCMD,0,0); SendPacket(nChn, p2, PacketLen); break; // case KLCmdWriteReply: // break; case KLCmdRead1Bit: nBitAddr=p1->Params[0]+ (p1->Params[1]<<8); DataLen = 1; if (nDataType == KLCoilTypeX) { rData[0] = ((KMem.WX[nBitAddr>>4]&(1<<(nBitAddr&0x0f)))>0);} else if (nDataType == KLCoilTypeY) { rData[0] = ((KMem.WY[nBitAddr>>4]&(1<<(nBitAddr&0x0f)))>0);} else if (nDataType == KLCoilTypeR) { rData[0] = ((KMem.WR[nBitAddr>>4]&(1<<(nBitAddr&0x0f)))>0);} else if (nDataType == KLCoilTypeLX) { rData[0] = ((KMem.WLX[nBitAddr>>4]&(1<<(nBitAddr&0x0f)))>0);} else if (nDataType == KLCoilTypeLY) { rData[0] = ((KMem.WLY[nBitAddr>>4]&(1<<(nBitAddr&0x0f)))>0);} #if (ENABLE_PLC) else if (nDataType == KLCoilTypeT) { rData[0] = PLCMem.Timers[nBitAddr].bTon;} else if (nDataType == KLCoilTypeC) { rData[0] = PLCMem.Timers[nBitAddr].bTon;} #endif else if (nDataType == KLCoilTypeSR) {rData[0] = ((KMem.WSR[nBitAddr>>4]&(1<<(nBitAddr&0x0f)))>0);} else if (nDataType == KLCoilTypeLR) { rData[0] = 0;} else {rData[0]=0;} PacketLen=KLMakeRplyPacket(p2,nDstHost,nKLStatus.StatByte,KLCmdRead1Bit,DataLen,rData); SendPacket(nChn, p2, PacketLen); break; case KLCmdWrite1Bit: nBitAddr=p1->Params[0]+ (p1->Params[1]<<8); if (nDataType == KLCoilTypeX) { SetBitValue( &KMem.WX[nBitAddr>>4],nBitAddr&0x0f,p1->Params[2]);} else if (nDataType == KLCoilTypeY) { SetBitValue( &KMem.WY[nBitAddr>>4],nBitAddr&0x0f,p1->Params[2]);} else if (nDataType == KLCoilTypeR) { SetBitValue( &KMem.WR[nBitAddr>>4],nBitAddr&0x0f,p1->Params[2]);} else if (nDataType == KLCoilTypeLX) {SetBitValue( &KMem.WLX[nBitAddr>>4],nBitAddr&0x0f,p1->Params[2]);} else if (nDataType == KLCoilTypeLY) {SetBitValue( &KMem.WLY[nBitAddr>>4],nBitAddr&0x0f,p1->Params[2]);} #if (ENABLE_PLC) else if (nDataType == KLCoilTypeT) { PLCMem.Timers[nBitAddr].bTon = p1->Params[2];} else if (nDataType == KLCoilTypeC) { PLCMem.Timers[nBitAddr].bTon = p1->Params[2];} #endif else if (nDataType == KLCoilTypeLR) { SetBitValue( &KMem.WSR[nBitAddr>>4],nBitAddr&0x0f,p1->Params[2]);;} else {rData[0]=0;} DataLen=0; PacketLen=KLMakeRplyPacket(p2,nDstHost,nKLStatus.StatByte,KLCmdWrite1Bit,DataLen,rData); SendPacket(nChn, p2, PacketLen); break; case KLCmdReadBits: break; case KLCmdWriteBits: break; #if (ENABLE_PLC) case KLCmdGetMode: rData[0]= PLCMem.bPLCRunning; PacketLen=KLMakeRplyPacket(p2,nDstHost,nKLStatus.StatByte,p1->nCMD,1,rData); SendPacket(nChn, p2, PacketLen); break; case KLCmdChgMode: if (nDataType ==0) {StopPLC();} if (nDataType == 1) {StartPLC();} PacketLen=KLMakeRplyPacket(p2,nDstHost,nKLStatus.StatByte,p1->nCMD,0,0); SendPacket(nChn, p2, PacketLen); break; case KLCmdReadPLCProgram: nWordAddr=p1->Params[0]+ (p1->Params[1]<<8); DataLen= p1->Params[2]; if (nDataType==0){ pData = (unsigned short *)(&((stStoredBinProgs *)STORE_PRG_BASE)->BinInstrcns) + nWordAddr; } else if (nDataType==1){ pData = (unsigned short *)(&((stStoredBinProgs *)ALT_PRG_BASE)->BinInstrcns) + nWordAddr; } else if (KMRunStat.nBinProgBank == 0) { pData = (unsigned short *)(&((stStoredBinProgs *)STORE_PRG_BASE)->BinInstrcns) + nWordAddr; }else { pData = (unsigned short *)(&((stStoredBinProgs *)ALT_PRG_BASE)->BinInstrcns) + nWordAddr; } PacketLen=KLMakeRplyPacket(p2,nDstHost,nKLStatus.StatByte,p1->nCMD,DataLen,pData); SendPacket(nChn, p2, PacketLen); break; case KLCmdStartPLCProgram: DataLen=p1->Params[0] + (p1->Params[1] <<8); //Program Size nValue = p1->Params[2] + (p1->Params[3] <<8); // CRC //if (PLCMem.bPLCRunning) StopPLC(); StartPLCProgram(nDataType, DataLen, nValue); PacketLen=KLMakeRplyPacket(p2,nDstHost,nKLStatus.StatByte,KLCmdStartPLCProgram,0,0); SendPacket(nChn, p2, PacketLen); break; case KLCmdWritePLCProgram: if (PLCMem.bPLCRunning) PLCMem.bPLCRunning=0; nWordAddr=p1->Params[0]+ (p1->Params[1]<<8); DataLen= p1->Params[2]; WritePLCProgram(nDataType, nWordAddr, &p1->Params[4], DataLen); DataLen=4; // *((int *)(&rData[0]))=(long)(p1->Params+4); PacketLen=KLMakeRplyPacket(p2,nDstHost,nKLStatus.StatByte,KLCmdWritePLCProgram,0,0); SendPacket(nChn, p2, PacketLen); break; case KLCmdFinishPLCProgram: DataLen=p1->Params[0]+ (p1->Params[1]<<8); //Program Size; nValue = p1->Params[2] + (p1->Params[3] <<8); //CRC FinishiPLCProgram(nDataType, DataLen, nValue); PacketLen=KLMakeRplyPacket(p2,nDstHost,nKLStatus.StatByte,KLCmdFinishPLCProgram,0,0); SendPacket(nChn, p2, PacketLen); break; case KLCmdReadPLCAnno: nByteAddr=p1->Params[0]+ (p1->Params[1]<<8); DataLen= p1->Params[2]; pData = ((stStoredAnno *)STORE_PLC_ANNO_BASE)->Annos + nByteAddr; PacketLen=KLMakeRplyPacket(p2,nDstHost,nKLStatus.StatByte,p1->nCMD,DataLen,pData); SendPacket(nChn, p2, PacketLen); break; case KLCmdStartPLCAnno: nWordAddr=p1->Params[0]+ (p1->Params[1]<<8); DataLen= p1->Params[2]; StartPLCAnno(nDataType, DataLen, nValue); DataLen=4; // *((int *)(&rData[0]))=(long)(p1->Params+4); PacketLen=KLMakeRplyPacket(p2,nDstHost,nKLStatus.StatByte,KLCmdStartPLCAnno,0,0); SendPacket(nChn, p2, PacketLen); break; case KLCmdWritePLCAnno: nByteAddr=p1->Params[0]+ (p1->Params[1]<<8); ; DataLen = p1->Params[2]; //CRC WritePLCAnno(nDataType, nByteAddr, &p1->Params[4], DataLen); PacketLen=KLMakeRplyPacket(p2,nDstHost,nKLStatus.StatByte,KLCmdWritePLCAnno,0,0); SendPacket(nChn, p2, PacketLen); break; case KLCmdFinishPLCAnno: DataLen=p1->Params[0]+ (p1->Params[1]<<8); //Program Size; nValue = p1->Params[2] + (p1->Params[3] <<8); //CRC FinishiPLCAnno(nDataType, DataLen, nValue); PacketLen=KLMakeRplyPacket(p2,nDstHost,nKLStatus.StatByte,KLCmdFinishPLCAnno,0,0); SendPacket(nChn, p2, PacketLen); break; #endif // ENABLE_PLC case KLCmdBlinkLED: DataLen=nDataType; KMRunStat.bLEDFlick=DataLen; PacketLen=KLMakeRplyPacket(p2,nDstHost,nKLStatus.StatByte,p1->nCMD,0,0); SendPacket(nChn, p2, PacketLen); break; case KLCmdStopBlinkLED: DataLen=nDataType; KMRunStat.bLEDFlick=0; PacketLen=KLMakeRplyPacket(p2,nDstHost,nKLStatus.StatByte,p1->nCMD,0,0); SendPacket(nChn, p2, PacketLen); break; case KLCmdReadRunStat: DataLen= sizeof(stRunStat); pData=&KMRunStat; PacketLen=KLMakeRplyPacket(p2,nDstHost,nKLStatus.StatByte,p1->nCMD,DataLen,pData); SendPacket(nChn, p2, PacketLen); break; case KLCmdReadSysCfg: nByteAddr=p1->Params[0]+ (p1->Params[1]<<8); pData=(UCHAR *)(&storedKMSysCfg.theKMSysCfg)+nByteAddr; DataLen = p1->Params[2]; if (nByteAddr >= sizeof(stKMSysCfg)) {DataLen=0;} else { if (DataLen + nByteAddr >sizeof(stKMSysCfg)) DataLen= sizeof(stKMSysCfg) - nByteAddr; } PacketLen=KLMakeRplyPacket(p2,nDstHost,nKLStatus.StatByte,p1->nCMD,DataLen,pData); SendPacket(nChn, p2, PacketLen); break; case KLCmdWriteSysCfg: nByteAddr=p1->Params[0]+ (p1->Params[1]<<8); pData=(UCHAR *)(&storedKMSysCfg.theKMSysCfg)+nByteAddr; DataLen = p1->Params[2]; if (nByteAddr >= sizeof(stKMSysCfg)) {DataLen=0;} else { if (DataLen + nByteAddr >sizeof(stKMSysCfg)) DataLen= sizeof(stKMSysCfg) - nByteAddr; } memcpy(pData,p1->Params+4,DataLen); PacketLen=KLMakeRplyPacket(p2,nDstHost,nKLStatus.StatByte,p1->nCMD,0,0); SendPacket(nChn, p2, PacketLen); WriteSysCfgToFlash(&storedKMSysCfg); break; case KLCmdSaveSysCfg: WriteSysCfgToFlash(&storedKMSysCfg); PacketLen=KLMakeRplyPacket(p2,nDstHost,nKLStatus.StatByte,KLCmdSaveSysCfg,0,0); SendPacket(nChn, p2, PacketLen); break; case KLCmdSaveRunStat: SaveRunStat(&KMRunStat); PacketLen=KLMakeRplyPacket(p2,nDstHost,nKLStatus.StatByte,KLCmdSaveRunStat,0,0); SendPacket(nChn, p2, PacketLen); break; case KLCmdClearRunStat: memset(KBus1.KBusChnStats,0,sizeof(KBus1.KBusChnStats)); PacketLen=KLMakeRplyPacket(p2,nDstHost,nKLStatus.StatByte,p1->nCMD,0,0); SendPacket(nChn, p2, PacketLen); break; case KLCmdGetEventLogCount: DataLen= 4; pData=&KMem.nEventCount; PacketLen=KLMakeRplyPacket(p2,nDstHost,nKLStatus.StatByte,p1->nCMD,DataLen,pData); SendPacket(nChn, p2, PacketLen); break; case KLCmdGetEventLog: nWordAddr=p1->Params[0]+ (p1->Params[1]<<8); DataLen= p1->Params[2] * sizeof(stEventLog); pData=GetEventLogAddr(nWordAddr); PacketLen=KLMakeRplyPacket(p2,nDstHost,nKLStatus.StatByte,p1->nCMD,DataLen,pData); SendPacket(nChn, p2, PacketLen); break; case KLCmdClearEventLog: ClearEventLog(); PacketLen=KLMakeRplyPacket(p2,nDstHost,nKLStatus.StatByte,KLCmdClearEventLog,0,0); SendPacket(nChn, p2, PacketLen); break; case KLCmdResetMachine: PacketLen=KLMakeRplyPacket(p2,nDstHost,nKLStatus.StatByte,KLCmdClearEventLog,0,0); SendPacket(nChn, p2, PacketLen); KMRunService(ReqReset,0,0,0,0); break; case KLCmdWriteFirmware: nByteAddr=p1->Params[0]+ (p1->Params[1]<<8); //pData=(UCHAR *)(&storedKMSysCfg.theKMSysCfg)+nByteAddr; DataLen = p1->Params[2]; pData = p1->Params + 4 ; res = KMRunService(ReqUpdateFirm,nByteAddr,0,&pData,&DataLen); // res = WriteNewApp(nByteAddr,p1->Params+4,DataLen); // res = 0; if (res) { PacketLen=KLMakeRplyPacket(p2,nKLStationId,nKLStatus.StatByte,KLCmdErrRply,res,rData); }else { PacketLen=KLMakeRplyPacket(p2,nDstHost,nKLStatus.StatByte,p1->nCMD,0,0); } SendPacket(nChn, p2, PacketLen); break; case KLCmdWriteFirmInfo: nByteAddr=p1->Params[0]+ (p1->Params[1]<<8); //pData=(UCHAR *)(&storedKMSysCfg.theKMSysCfg)+nByteAddr; DataLen = p1->Params[2]; pData = p1->Params + 4 ; res = KMRunService(ReqUpdateFirmInfo,nByteAddr,0,&pData,&DataLen); PacketLen=KLMakeRplyPacket(p2,nDstHost,nKLStatus.StatByte,p1->nCMD,0,0); SendPacket(nChn, p2, PacketLen); // WriteNewAppInfo(nByteAddr,p1->Params+4,DataLen); break; case KLCmdGetPortInfo: nByteAddr=p1->Params[0] + (p1->Params[1]<<8); //pData=(UCHAR *)(&storedKMSysCfg.theKMSysCfg)+nByteAddr; pData = KMem.pPorts[nDataType]; DataLen = sizeof(stPortDef); PacketLen=KLMakeRplyPacket(p2,nDstHost,nKLStatus.StatByte,p1->nCMD,DataLen,pData); SendPacket(nChn, p2, PacketLen); break; case KLCmdGetPortChnInfo: nByteAddr=p1->Params[0] + (p1->Params[1]<<8); // nDataType --> port // nByteAddr --> ChildId //pData=(UCHAR *)(&storedKMSysCfg.theKMSysCfg)+nByteAddr; KMPortReqFunc(nDataType,ReqPortChnInfo,nByteAddr,0,&pData,&DataLen); PacketLen=KLMakeRplyPacket(p2,nDstHost,nKLStatus.StatByte,p1->nCMD,DataLen,pData); SendPacket(nChn, p2, PacketLen); break; case KLCmdGetPortChildInfo: nByteAddr=p1->Params[0] + (p1->Params[1]<<8); // nDataType --> port // nByteAddr --> ChildId //pData=(UCHAR *)(&storedKMSysCfg.theKMSysCfg)+nByteAddr; KMPortReqFunc(nDataType,ReqPortChildInfo,nByteAddr,0,&pData,&DataLen); //DataLen = sizeof(stPortDef); PacketLen=KLMakeRplyPacket(p2,nDstHost,nKLStatus.StatByte,p1->nCMD,DataLen,pData); SendPacket(nChn, p2, PacketLen); break; case KLCmdPortRemoteReq: // Ô¶³Ì·þÎñÇëÇó //p1->nType1 -> ReqId; //p1->Params[0] -> Port; //p1->Params[1] -> Child; //p1->params[2] -> Param; //p1->params[3] -> nAddr % 256; //p1->params[4] -> nAddr / 256; //p1->params[5] -> nCount; pData = &p1->Params[3]; DataLen = p1->Params[5]+3; KMPortReqFunc(p1->Params[0],nDataType,p1->Params[1],p1->Params[2],&pData,&DataLen); DataLen=0; PacketLen=KLMakeRplyPacket(p2,nDstHost,nKLStatus.StatByte,p1->nCMD,DataLen,pData); SendPacket(nChn, p2, PacketLen); break; default: //DataLen=1; DataLen=KL_UNKNOWN; rData[0]=KL_UNKNOWN; PacketLen=KLMakeRplyPacket(p2,nKLStationId,nKLStatus.StatByte,KLCmdErrRply,DataLen,rData); SendPacket(nChn, p2, PacketLen); break; } } return 0; } int KLParsePacket(int nChn, void * pBuf, int Len1) { // pKLReqPktHdr p1 = (pKLReqPktHdr)pBuf; // KLThisuS=GetuS(); // pKLRplyPktHdr p2=(pKLRplyPktHdr)KLPacketBuf2; int PacketLen=Len1; int Result=KLCheckPacket(nChn, pBuf, Len1); if (Result != KL_OK) { int DataLen=4; char rData[4]; rData[0]=Result; DataLen = Result; PacketLen=KLMakeRplyPacket(KLPacketBuf2,nKLStationId,nKLStatus.StatByte,KLCmdErrRply,DataLen,rData); // PacketLen=KLMakePacket(p2,0,nAddr,cmdKLPing,p1->nSEQ,DataLen,rData); SendPacket(nChn, KLPacketBuf2, PacketLen); return Result; } // if (bKBusMaster) Result=ParseMasterPacket(p1,Len1); // memcpy(KLPacketBuf2,pBuf,Len1); // SendPacket(nChn, KLPacketBuf2, PacketLen); Result=KLParseReqPacket(nChn, pBuf, Len1); //int len1=p1->PacketLen; // if (p1->DstHost!=255&&p1->DstHost!=2) return -3; // pKBPacket p2=(pKBPacket)PacketBuf2; // Uart2Stat.OKPacket++; return Result; }