/**
|
******************************************************************************
|
* @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 "KWireless2.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;i<nSize;i++)
|
{
|
k^=((unsigned char *)pData)[i];
|
}
|
return k;
|
}
|
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->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 (nLen1<DataLen+sizeof(stKLReqPktHdr))
|
{
|
//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)
|
// {
|
// 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;
|
#if (ENABLE_PLC)
|
unsigned short nValue=0;
|
#endif
|
//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;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; }
|
#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 = (uint32_t)&(((pstPortDef)(0))->pInstance);
|
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;
|
}
|