| | |
| | | unsigned char KLBufferIn[16]={0};
|
| | | unsigned char KLBufferOut[16]={0};
|
| | |
|
| | | unsigned char nKLAddr=1;
|
| | | unsigned char nKLStationId=1;
|
| | | unsigned char nKLSeq=0;
|
| | |
|
| | | unKLStat nKLStatus ={0};
|
| | |
| | | int KLThisuS=0;
|
| | | int KLRecvTimeuS=0;
|
| | |
|
| | | unsigned char KLBCC(void * pData, int nSize)
|
| | | unsigned char KLBCC(void const * pData, int nSize)
|
| | | {
|
| | | unsigned char k;
|
| | | k=0;
|
| | |
| | | }
|
| | | return k;
|
| | | }
|
| | | int KLMakeRplyPacket(void * pBuf, uchar dst, uchar Status, uchar nCmd, uchar DataLen,void * pData )
|
| | | int KLMakeRplyPacket(void * pBuf, uchar dst, uchar Status, uchar nCmd, uchar DataLen,const void * pData )
|
| | | {
|
| | | pKLRplyPktHdr p1 = (pKLRplyPktHdr)pBuf;
|
| | | int PacketLenth=0;
|
| | | p1->RplyStSgn=KLSignReply;
|
| | | p1->DstAddr=dst;
|
| | | p1->DstHost=dst;
|
| | | p1->nStatus=Status;
|
| | | p1->nRplyCMD=nCmd;
|
| | | p1->nSize1=DataLen;
|
| | | memcpy(p1->Datas,pData,DataLen);
|
| | | p1->Datas[DataLen]=BCC(p1,sizeof(stKLRplyPktHdr)+DataLen-1);
|
| | | p1->Datas[DataLen]=KLBCC(p1,sizeof(stKLRplyPktHdr)+DataLen-1);
|
| | | PacketLenth=sizeof(stKLRplyPktHdr)+DataLen;
|
| | |
|
| | |
|
| | |
| | | case KLCmdRead:
|
| | | // case KLCmdReadReply:
|
| | | //p1->data[DataLen+1]=KLEndSign;
|
| | | //PacketLenth=sizeof(stPacket)+DataLen+1;
|
| | | //PacketLenth=sizeof(stKBPacket)+DataLen+1;
|
| | | break;
|
| | | case KLCmdWrite:
|
| | | // case KLCmdWriteReply:
|
| | |
| | | return PacketLenth;
|
| | | }
|
| | |
|
| | | int KLCheckPacket(void * pBuf,int nLen1)
|
| | | int KLCheckPacket(int nChn, void * pBuf, int nLen1)
|
| | | {
|
| | | pKLReqPktHdr p1 = (pKLReqPktHdr) pBuf;
|
| | | if (p1->ReqStSgn != KLSignStart)
|
| | |
| | | }
|
| | | if (nLen1<DataLen+sizeof(stKLReqPktHdr))
|
| | | {
|
| | | //len4=sprintf(str3,"%d < %d + %d \r\n",len2,DataLen,sizeof(stPacket));
|
| | | //len4=sprintf(str3,"%d < %d + %d \r\n",len2,DataLen,sizeof(stKBPacket));
|
| | | //PutStr(str3,len4);
|
| | | return 3; //not long enough
|
| | | }
|
| | | // if (p1->data[DataLen+1] != EndSign)
|
| | | // {
|
| | | // ChnStats[nCurPollId].NoEndErr++;
|
| | | // KBusChnStats[nCurPollId].NoEndErr++;
|
| | | // Uart2Stat.LengthErr++;
|
| | | // return -2;
|
| | | // }
|
| | |
| | |
|
| | | inline void SetAddrBit(unsigned short * pW, unsigned char bitAddr)
|
| | | {
|
| | | (*pW)|=bitMasks[bitAddr&0xf];
|
| | | (*pW)|=1<<(bitAddr&0xf);
|
| | | }
|
| | |
|
| | | inline void ResetBit(unsigned short * pW, unsigned char bitAddr)
|
| | | {
|
| | | (*pW)&=~bitMasks[bitAddr&0xf];
|
| | | (*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(void * pBuf,int Len1)
|
| | |
|
| | | int KLParseReqPacket(int nChn, void * pBuf, int Len1)
|
| | | {
|
| | | pKLReqPktHdr p1 = (pKLReqPktHdr)pBuf;
|
| | |
|
| | | int nDstAddr=p1->DstAddr;
|
| | | unsigned char nDstHost=p1->DstHost;
|
| | | KLRecvTimeuS=KLThisuS;
|
| | | int nDataType=p1->nType1;
|
| | | int nAddr=0;
|
| | | int DataLen=0; //p1->LoadLen;
|
| | | unsigned char nDataType=p1->nType1;
|
| | | unsigned short nWordAddr=0;
|
| | | unsigned short nByteAddr=0;
|
| | | unsigned short nBitAddr=0;
|
| | | unsigned short DataLen=0; //p1->LoadLen;
|
| | | //int nSrcAddr=p1->SrcAddr;
|
| | |
|
| | | nKLStatus.nSEQ = ((pKLStat)(&(p1->Stat)))->nSEQ;;
|
| | |
| | |
|
| | | int PacketLen=0;
|
| | | KLRecvTimeuS=KLThisuS;
|
| | | if (nDstAddr==nKLAddr || nDstAddr==0xff)
|
| | | if (nDstHost==nKLStationId || nDstHost==0xff)
|
| | | {
|
| | | switch (p1->nCMD)
|
| | | {
|
| | |
| | | DataLen=nDataType;
|
| | | // KLBufferIn[0]=p1->Params[0];
|
| | | // p1->Params[0]=KLBufferOut[0];
|
| | | PacketLen=KLMakeRplyPacket(p2,nDstAddr,nKLStatus.StatByte,KLCmdPing,DataLen,p1->Params);
|
| | | SendPacket1(p2,PacketLen);
|
| | | 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;
|
| | | pData=&KMem.nEventCount;
|
| | | PacketLen=KLMakeRplyPacket(p2,nDstAddr,nKLStatus.StatByte,p1->nCMD,DataLen,pData);
|
| | | SendPacket1(p2,PacketLen); |
| | | break; |
| | | case KLCmdRead:
|
| | | case KLCmdReadDataByte: |
| | | nAddr=p1->Params[0]+ (p1->Params[1]<<8);
|
| | | 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];
|
| | | if (nDataType ==KLDataTypeDT) { pData=KMem.DT+nAddr; }
|
| | | else if (nDataType == KLDataTypeSDT) { pData=KMem.SDT+nAddr; }
|
| | | else if (nDataType == KLDataTypeWX) { pData=KMem.WX+nAddr; }
|
| | | else if (nDataType == KLDataTypeWY) { pData=KMem.WY+nAddr; }
|
| | | else if (nDataType == KLDataTypeWR) { pData=KMem.WR+nAddr; }
|
| | | else if (nDataType == KLDataTypeWLX) { pData=KMem.WLX+nAddr; }
|
| | | else if (nDataType == KLDataTypeWLY) { pData=KMem.WLY+nAddr; }
|
| | | else if (nDataType == KLDataTypeSV) { pData=KMem.SDT+nAddr; }
|
| | | else if (nDataType == KLDataTypeEV) { pData=KMem.SDT+nAddr; }
|
| | | else if (nDataType == KLDataTypeTest) { pData=KMem.SDT+nAddr; }
|
| | | else if (nDataType == KLDataSysCfg) { pData = (unsigned short *)&KMSysCfg + nAddr;}
|
| | | else if (nDataType == KLDataTypeFlash) { pData = (unsigned short *)FLASH_BASE + nAddr;}
|
| | | else { pData=KLBufferOut+nAddr; }
|
| | | //DataLen=16;
|
| | | for (int i=0;i<DataLen;i++)
|
| | | {KLPacketBuf2[i]=p1->Params[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; }
|
| | | else if (nDataType == KLDataTypeSV) { pData=KMem.SV+nWordAddr; }
|
| | | else if (nDataType == KLDataTypeEV) { pData=KMem.EV+nWordAddr; }
|
| | | else if (nDataType == KLDataTypeTest) { pData=KMem.SDT+nWordAddr; }
|
| | | else if (nDataType == KLDataTypeWDT) { pData=KMem.WDT+nWordAddr; }
|
| | | else if (nDataType == KLDataTypeKBD) { pData=(unsigned short *)&KBusChnStats +nWordAddr; }
|
| | | 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,nDstAddr,nKLStatus.StatByte,p1->nCMD,DataLen,pData);
|
| | | SendPacket1(p2,PacketLen);
|
| | | 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);
|
| | | nAddr=p1->Params[0]+ (p1->Params[1]<<8);
|
| | | nWordAddr=p1->Params[0]+ (p1->Params[1]<<8);
|
| | | DataLen= p1->Params[2];
|
| | | if (nDataType ==KLDataTypeDT) { pData=KMem.DT+nAddr; }
|
| | | else if (nDataType == KLDataTypeSDT) { pData=KMem.SDT+nAddr; }
|
| | | else if (nDataType == KLDataTypeWX) { pData=KMem.WX+nAddr; }
|
| | | else if (nDataType == KLDataTypeWY) { pData=KMem.WY+nAddr; }
|
| | | else if (nDataType == KLDataTypeWR) { pData=KMem.WR+nAddr; }
|
| | | else if (nDataType == KLDataTypeWLX) { pData=KMem.WLX+nAddr; }
|
| | | else if (nDataType == KLDataTypeWLY) { pData=KMem.WLY+nAddr; }
|
| | | else if (nDataType == KLDataTypeSV) { pData=KMem.SDT+nAddr; DataLen=0;}
|
| | | else if (nDataType == KLDataTypeEV) { pData=KMem.SDT+nAddr; DataLen=0;}
|
| | | else if (nDataType == KLDataTypeTest) { pData=KMem.SDT+nAddr; DataLen=0;}
|
| | | else if (nDataType == KLDataSysCfg) { pData = (unsigned short *)&KMSysCfg + nAddr;}
|
| | | else if (nDataType == KLDataTypeFlash) { pData = (unsigned short *)FLASH_BASE + nAddr;}
|
| | | else { pData=KLBufferOut+nAddr; DataLen=0; }
|
| | | 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; }
|
| | | else if (nDataType == KLDataTypeSV) { pData=KMem.SV+nWordAddr; DataLen=0;}
|
| | | else if (nDataType == KLDataTypeEV) { pData=KMem.EV+nWordAddr; DataLen=0;}
|
| | | 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 *)KBusChnStats +nWordAddr; DataLen=0;}
|
| | | 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,nDstAddr,nKLStatus.StatByte,p1->nCMD,0,0);
|
| | | SendPacket1(p2,PacketLen); |
| | | PacketLen=KLMakeRplyPacket(p2,nDstHost,nKLStatus.StatByte,p1->nCMD,0,0);
|
| | | SendPacket(nChn, p2, PacketLen); |
| | | break;
|
| | | // case KLCmdWriteReply:
|
| | | // break;
|
| | |
|
| | | case KLCmdRead1Bit:
|
| | | nAddr=p1->Params[0]+ (p1->Params[1]<<8);
|
| | | nBitAddr=p1->Params[0]+ (p1->Params[1]<<8);
|
| | | DataLen = 1;
|
| | | if (nDataType == KLCoilTypeX) { rData[0] = ((KMem.WX[nAddr>>4]&bitMasks[nAddr&0x0f])>0);}
|
| | | else if (nDataType == KLCoilTypeY) { rData[0] = ((KMem.WY[nAddr>>4]&bitMasks[nAddr&0x0f])>0);}
|
| | | else if (nDataType == KLCoilTypeR) { rData[0] = ((KMem.WR[nAddr>>4]&bitMasks[nAddr&0x0f])>0);}
|
| | | else if (nDataType == KLCoilTypeLX) { rData[0] = ((KMem.WLX[nAddr>>4]&bitMasks[nAddr&0x0f])>0);}
|
| | | else if (nDataType == KLCoilTypeLY) { rData[0] = ((KMem.WLY[nAddr>>4]&bitMasks[nAddr&0x0f])>0);}
|
| | | else if (nDataType == KLCoilTypeT) { rData[0] = PLCMem.Timers[nAddr].bTon;}
|
| | | else if (nDataType == KLCoilTypeC) { rData[0] = PLCMem.Timers[nAddr].bTon;}
|
| | | 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);}
|
| | | else if (nDataType == KLCoilTypeT) { rData[0] = KMem.Timers[nBitAddr].bTon;}
|
| | | else if (nDataType == KLCoilTypeC) { rData[0] = KMem.Timers[nBitAddr].bTon;}
|
| | | 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,nDstAddr,nKLStatus.StatByte,KLCmdRead1Bit,DataLen,rData);
|
| | | SendPacket1(p2,PacketLen);
|
| | | PacketLen=KLMakeRplyPacket(p2,nDstHost,nKLStatus.StatByte,KLCmdRead1Bit,DataLen,rData);
|
| | | SendPacket(nChn, p2, PacketLen);
|
| | | break;
|
| | | case KLCmdWrite1Bit:
|
| | | nAddr=p1->Params[0]+ (p1->Params[1]<<8);
|
| | | if (nDataType == KLCoilTypeX) { SetBitValue( &KMem.WX[nAddr>>4],nAddr&0x0f,p1->Params[2]);}
|
| | | else if (nDataType == KLCoilTypeY) { SetBitValue( &KMem.WY[nAddr>>4],nAddr&0x0f,p1->Params[2]);}
|
| | | else if (nDataType == KLCoilTypeR) { SetBitValue( &KMem.WR[nAddr>>4],nAddr&0x0f,p1->Params[2]);}
|
| | | else if (nDataType == KLCoilTypeLX) {SetBitValue( &KMem.WLX[nAddr>>4],nAddr&0x0f,p1->Params[2]);}
|
| | | else if (nDataType == KLCoilTypeLY) {SetBitValue( &KMem.WLY[nAddr>>4],nAddr&0x0f,p1->Params[2]);}
|
| | | else if (nDataType == KLCoilTypeT) { PLCMem.Timers[nAddr].bTon = p1->Params[2];}
|
| | | else if (nDataType == KLCoilTypeC) { PLCMem.Timers[nAddr].bTon = p1->Params[2];}
|
| | | else if (nDataType == KLCoilTypeLR) { ;}
|
| | | 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]);}
|
| | | else if (nDataType == KLCoilTypeT) { KMem.Timers[nBitAddr].bTon = p1->Params[2];}
|
| | | else if (nDataType == KLCoilTypeC) { KMem.Timers[nBitAddr].bTon = p1->Params[2];}
|
| | | else if (nDataType == KLCoilTypeC) { KMem.Timers[nBitAddr].bTon = p1->Params[2];}
|
| | | else if (nDataType == KLCoilTypeLR) { SetBitValue( &KMem.WSR[nBitAddr>>4],nBitAddr&0x0f,p1->Params[2]);;}
|
| | | else {rData[0]=0;}
|
| | | DataLen=0;
|
| | | PacketLen=KLMakeRplyPacket(p2,nDstAddr,nKLStatus.StatByte,KLCmdWrite1Bit,DataLen,rData);
|
| | | SendPacket1(p2,PacketLen);
|
| | | PacketLen=KLMakeRplyPacket(p2,nDstHost,nKLStatus.StatByte,KLCmdWrite1Bit,DataLen,rData);
|
| | | SendPacket(nChn, p2, PacketLen);
|
| | | break;
|
| | | case KLCmdReadBits:
|
| | | break;
|
| | | case KLCmdWriteBits:
|
| | | 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 KLCmdReadProgram:
|
| | | nWordAddr=p1->Params[0]+ (p1->Params[1]<<8);
|
| | | DataLen= p1->Params[2];
|
| | | if (nDataType==0){
|
| | | pData = (unsigned short *)STORE_PRG_BASE + nWordAddr;
|
| | | } else if (nDataType==1){
|
| | | pData = (unsigned short *)ALT_PRG_BASE + nWordAddr;
|
| | | } else if (KMRunStat.nBinProgBank == 0) {
|
| | | pData = (unsigned short *)STORE_PRG_BASE + nWordAddr;
|
| | | }else {
|
| | | pData = (unsigned short *)ALT_PRG_BASE + nWordAddr;
|
| | | }
|
| | | PacketLen=KLMakeRplyPacket(p2,nDstHost,nKLStatus.StatByte,p1->nCMD,DataLen,pData);
|
| | | SendPacket(nChn, p2, PacketLen);
|
| | | |
| | | break;
|
| | | case KLCmdStartProgram:
|
| | | DataLen=nDataType;
|
| | | // KLBufferIn[0]=p1->Params[0];
|
| | | // p1->Params[0]=KLBufferOut[0];
|
| | | if (PLCMem.bPLCRunning) PLCMem.bPLCRunning=0;
|
| | | |
| | | PacketLen=KLMakeRplyPacket(p2,nDstHost,nKLStatus.StatByte,KLCmdStartProgram,0,0);
|
| | | SendPacket(nChn, p2, PacketLen);
|
| | | |
| | | break;
|
| | | case KLCmdWriteProgram:
|
| | | if (PLCMem.bPLCRunning) PLCMem.bPLCRunning=0;
|
| | | nWordAddr=p1->Params[0]+ (p1->Params[1]<<8);
|
| | | DataLen= p1->Params[2];
|
| | |
|
| | | //DataLen=16;
|
| | | for (int i=0;i<DataLen;i++)
|
| | | {KLPacketBuf2[i]=p1->Params[4+i];}
|
| | | WriteProgram(nWordAddr, KLPacketBuf2, DataLen,nDataType);
|
| | | DataLen=4;
|
| | | *((int *)(&rData[0]))=(long)(p1->Params+4);
|
| | | PacketLen=KLMakeRplyPacket(p2,nDstHost,nKLStatus.StatByte,KLCmdWriteProgram,0,0);
|
| | | SendPacket(nChn, p2, PacketLen);
|
| | | break;
|
| | | case KLCmdFinishProgram:
|
| | | nWordAddr=p1->Params[0]+ (p1->Params[1]<<8); //Program Size;
|
| | | DataLen=nDataType;
|
| | | KMRunStat.nBinProgSize=nWordAddr;
|
| | | if (KMRunStat.nBinProgBank ==0) {KMRunStat.nBinProgBank=1;}
|
| | | else {KMRunStat.nBinProgBank=0;}
|
| | | SaveRunStat(&KMRunStat); |
| | | PLCMem.bPLCRunning=1;
|
| | | // KLBufferIn[0]=p1->Params[0];
|
| | | // p1->Params[0]=KLBufferOut[0];
|
| | | PacketLen=KLMakeRplyPacket(p2,nDstHost,nKLStatus.StatByte,KLCmdFinishProgram,0,0);
|
| | | SendPacket(nChn, p2, PacketLen);
|
| | | break;
|
| | | |
| | | 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); |
| | | break;
|
| | | case KLCmdSaveSysCfg:
|
| | | WriteSysCfgToFlash(&KMSysCfg);
|
| | | PacketLen=KLMakeRplyPacket(p2,nDstAddr,nKLStatus.StatByte,KLCmdSaveSysCfg,0,0);
|
| | | SendPacket1(p2,PacketLen);
|
| | | WriteSysCfgToFlash(&storedKMSysCfg);
|
| | | PacketLen=KLMakeRplyPacket(p2,nDstHost,nKLStatus.StatByte,KLCmdSaveSysCfg,0,0);
|
| | | SendPacket(nChn, p2, PacketLen);
|
| | | break;
|
| | | case KLCmdSaveRunStat:
|
| | | SaveRunStat(&KMRunStat);
|
| | | PacketLen=KLMakeRplyPacket(p2,nDstAddr,nKLStatus.StatByte,KLCmdSaveRunStat,0,0);
|
| | | SendPacket1(p2,PacketLen);
|
| | | PacketLen=KLMakeRplyPacket(p2,nDstHost,nKLStatus.StatByte,KLCmdSaveRunStat,0,0);
|
| | | SendPacket(nChn, p2, PacketLen);
|
| | | break;
|
| | | case KLCmdClearRunStat:
|
| | | memset(KBusChnStats,0,sizeof(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,nDstAddr,nKLStatus.StatByte,p1->nCMD,DataLen,pData);
|
| | | SendPacket1(p2,PacketLen);
|
| | | PacketLen=KLMakeRplyPacket(p2,nDstHost,nKLStatus.StatByte,p1->nCMD,DataLen,pData);
|
| | | SendPacket(nChn, p2, PacketLen);
|
| | | break;
|
| | | case KLCmdGetEventLog:
|
| | | nAddr=p1->Params[0]+ (p1->Params[1]<<8);
|
| | | nWordAddr=p1->Params[0]+ (p1->Params[1]<<8);
|
| | | DataLen= p1->Params[2] * sizeof(stEventLog);
|
| | | pData=GetEventLogAddr(nAddr);
|
| | | PacketLen=KLMakeRplyPacket(p2,nDstAddr,nKLStatus.StatByte,p1->nCMD,DataLen,pData);
|
| | | SendPacket1(p2,PacketLen);
|
| | | pData=GetEventLogAddr(nWordAddr);
|
| | | PacketLen=KLMakeRplyPacket(p2,nDstHost,nKLStatus.StatByte,p1->nCMD,DataLen,pData);
|
| | | SendPacket(nChn, p2, PacketLen);
|
| | | break;
|
| | | case KLCmdClearEventLog:
|
| | | ClearEventLog();
|
| | | PacketLen=KLMakeRplyPacket(p2,nDstAddr,nKLStatus.StatByte,KLCmdClearEventLog,0,0);
|
| | | SendPacket1(p2,PacketLen);
|
| | | PacketLen=KLMakeRplyPacket(p2,nDstHost,nKLStatus.StatByte,KLCmdClearEventLog,0,0);
|
| | | SendPacket(nChn, p2, PacketLen);
|
| | | break;
|
| | | default:
|
| | | DataLen=1;
|
| | | rData[0]=KL_UNKNOWN;
|
| | | PacketLen=KLMakeRplyPacket(p2,nKLAddr,nKLStatus.StatByte,KLCmdErrRply,DataLen,rData);
|
| | | SendPacket1(p2,PacketLen); |
| | | PacketLen=KLMakeRplyPacket(p2,nKLStationId,nKLStatus.StatByte,KLCmdErrRply,DataLen,rData);
|
| | | SendPacket(nChn, p2, PacketLen); |
| | | break;
|
| | | }
|
| | | }
|
| | | return 0;
|
| | | }
|
| | | int KLParsePacket(void * pBuf,int Len1)
|
| | | int KLParsePacket(int nChn, void * pBuf, int Len1)
|
| | | {
|
| | | pKLReqPktHdr p1 = (pKLReqPktHdr)pBuf;
|
| | | KLThisuS=GetuS();
|
| | | pKLRplyPktHdr p2=(pKLRplyPktHdr)KLPacketBuf2;
|
| | | // pKLReqPktHdr p1 = (pKLReqPktHdr)pBuf;
|
| | | // KLThisuS=GetuS();
|
| | | // pKLRplyPktHdr p2=(pKLRplyPktHdr)KLPacketBuf2;
|
| | | int PacketLen=Len1;
|
| | | int Result=KLCheckPacket(p1,Len1);
|
| | | int Result=KLCheckPacket(nChn, pBuf, Len1);
|
| | | if (Result != KL_OK)
|
| | | {
|
| | | int DataLen=4;
|
| | | char rData[4];
|
| | | rData[0]=Result;
|
| | |
|
| | | PacketLen=KLMakeRplyPacket(p2,nKLAddr,nKLStatus.StatByte,KLCmdErrRply,DataLen,rData);
|
| | | PacketLen=KLMakeRplyPacket(KLPacketBuf2,nKLStationId,nKLStatus.StatByte,KLCmdErrRply,DataLen,rData);
|
| | | // PacketLen=KLMakePacket(p2,0,nAddr,cmdKLPing,p1->nSEQ,DataLen,rData);
|
| | | SendPacket1(p2,PacketLen);
|
| | | SendPacket(nChn, KLPacketBuf2, PacketLen);
|
| | | return Result;
|
| | | }
|
| | | // if (bMaster) Result=ParseMasterPacket(p1,Len1);
|
| | | // if (bKBusMaster) Result=ParseMasterPacket(p1,Len1);
|
| | | // memcpy(KLPacketBuf2,pBuf,Len1);
|
| | | // SendPacket1(p2,PacketLen);
|
| | | // SendPacket(nChn, KLPacketBuf2, PacketLen);
|
| | |
|
| | | Result=KLParseReqPacket(p1,Len1);
|
| | | Result=KLParseReqPacket(nChn, pBuf, Len1);
|
| | |
|
| | | //int len1=p1->PacketLen;
|
| | | // if (p1->DstAddr!=255&&p1->DstAddr!=2) return -3;
|
| | | // pPacket p2=(pPacket)PacketBuf2;
|
| | | // if (p1->DstHost!=255&&p1->DstHost!=2) return -3;
|
| | | // pKBPacket p2=(pKBPacket)PacketBuf2;
|
| | | // Uart2Stat.OKPacket++;
|
| | |
|
| | | return Result;
|