From a7db3c8485547ec1c6b07c59b2aacc4a45249cfa Mon Sep 17 00:00:00 2001
From: QuakeGod <QuakeGod@sina.com>
Date: 星期一, 17 十月 2022 01:50:48 +0800
Subject: [PATCH] arrange Klink Knet FP0 Radio and merge together

---
 Inc/KLink.h |   84 ++++++++++--------------------------------
 1 files changed, 20 insertions(+), 64 deletions(-)

diff --git a/Inc/KLink.h b/Inc/KLink.h
index ea4bd0e..edf976c 100644
--- a/Inc/KLink.h
+++ b/Inc/KLink.h
@@ -28,8 +28,8 @@
 	
 }	;
 
-enum {KLSignStart='%',
-			KLSignReply='U',
+enum {KLSignStart='%',	//0x25
+			KLSignReply='U',	//0x55
 			KLSignEnd=0x0D,
 			KLMaxPacketLength=64,
 };
@@ -61,7 +61,9 @@
 		KLCmdSetPass,
 		KLCmdEraseAll,
 		KLCmdReadProgram,
+		KLCmdStartProgram,
 		KLCmdWriteProgram,
+		KLCmdFinishProgram,
 
 		KLCmdRead1Bit = 0x21,				//ReadSingleBit
 		KLCmdWrite1Bit = 0x22,				//WriteSingleBit
@@ -90,6 +92,7 @@
 		KLCmdWriteSysCfg,
 		KLCmdSaveSysCfg,
 		KLCmdSaveRunStat,
+		KLCmdReadRunStat,
 		
 		KLCmdEraseFlashPage = 0x61,
 		KLCmdWriteToFlash = 0x62,
@@ -102,8 +105,11 @@
 		KLCmdResetMachine,
 		KLCmdGetUid,
 		KLCmdSetTime,
-		
-		KLCmdMC,
+		KLCmdGetSN,
+		KLCmdReadFactData,
+		KLCmdWriteFactData,
+
+		KLCmdMC = 0x70, 		
 		KLCmdMD,
 		KLCmdMG,
 		
@@ -119,56 +125,6 @@
 		KLInfoTypeEventLogCount = 3,
 	};
 	
-	enum enKLCoilTypes
-	{
-		KLCoilTypeX = 0,		//X Input
-		KLCoilTypeY = 1,		//Y Output
-		KLCoilTypeR = 2,		//R register
-		KLCoilTypeLX = 3,		//Link register
-		KLCoilTypeLY = 4,		//Link register
-		KLCoilTypeT = 5,		//Timer
-		KLCoilTypeC = 5,		//Counter
-		KLCoilTypeLR = 6,		//Link register
-
-	};
-	enum enKLDataTypes
-	{
-		KLDataTypeWX = 0,
-		KLDataTypeWY = 1,
-		KLDataTypeWR = 2,
-		KLDataTypeWLX = 3,
-		KLDataTypeWLY = 4,
-		KLDataTypeDT = 5,
-		KLDataTypeSDT = 6,
-		KLDataTypeWSR = 7,
-		KLDataTypeSV = 8,
-		KLDataTypeEV = 9,
-		KLDataTypeLD = 10,
-		
-		KLDataSysCfg = 25, 
-		KLDataTypeFlash = 33 ,
-		
-		KLDataTypeTest = 254,
-	};
-enum enKLDataCounts
-{
-	KLCoilXCount=256,
-	KLCoilYCount=256,
-	KLCoilRCount=256,
-	KLCoilTCount=64,
-	KLCoilCCount=64,
-	KLCoilLCount=128,
-	KLDataDTCount = 256,
-	KLDataSDTCount = 256,
-	KLDataWXCount = 16,
-	KLDataWYCount = 16,
-	KLDataWRCount = 16,
-	KLDataSVCount = 64,
-	KLDataEVCount = 64,
-	KLDataLDCount = 64,
-	KLDataWLCount = 8,
-}; 
-
 extern unsigned char KLPacketBuf1[256];
 extern unsigned char KLPacketBuf2[256];
 
@@ -204,7 +160,7 @@
 typedef struct tagKLReqPktHdr
 {
 	unsigned char ReqStSgn;		//
-	unsigned char DstAddr;		//
+	unsigned char DstHost;		//
 	unsigned char Stat;				//
 	unsigned char nCMD;				//
 	unsigned char nType1;			//
@@ -214,7 +170,7 @@
 typedef struct tagKLPingReqPkt
 {
 	unsigned char ReqStSgn;		//
-	unsigned char DstAddr;		//
+	unsigned char DstHost;		//
 	unsigned char nCMD;				//
 	unsigned char nSize;			//
 	
@@ -223,7 +179,7 @@
 typedef struct tagKLRplyPktHdr
 {
 	unsigned char RplyStSgn;	//
-	unsigned char DstAddr;		//
+	unsigned char DstHost;		//
 	unsigned char nStatus;		//	
 	unsigned char nRplyCMD;		//
 	unsigned char nSize1;			//
@@ -235,7 +191,7 @@
 {
 		unsigned char StSign;		//起始标记
 		unsigned char SrcAddr;	//源地址
-		unsigned char DstAddr;	//目标地址
+		unsigned char DstHost;	//目标地址
 		unsigned char nCMD;		//命令
 	
 }stKLPtHdr, * pKLPktHdr;
@@ -245,7 +201,7 @@
 {
 		unsigned char StSign;		//起始标记		
 		unsigned char SrcAddr;	//源地址
-		unsigned char DstAddr;	//目标地址
+		unsigned char DstHost;	//目标地址
 		unsigned char nCMD;		//命令
 		unsigned char nType;
 		unsigned char nAddr;	//
@@ -256,7 +212,7 @@
 	{
 		unsigned char StSign;		//起始标记		
 		unsigned char SrcAddr;	//源地址
-		unsigned char DstAddr;	//目标地址
+		unsigned char DstHost;	//目标地址
 		unsigned char nCMD;		//命令
 		unsigned char nSEQ;		//序列号
 		unsigned char LoadLen;	//数据载荷长度	不包括头部5个字节,不包括尾部BCC。
@@ -264,18 +220,18 @@
 	}stKLPacket,* pKLPacket;	
 */
 
-unsigned char KLBCC(void * pData, int nSize);
+unsigned char KLBCC(const void * pData, int nSize);
 //
 
 	/* Make a Packet and return Packet Length */
 int KLMakeReqPacket(void * pBuf1,uchar Src, uchar Dst, uchar nType, uchar nSEQ, uchar DataLen, void *pData );
-int KLMakeRplyPacket(void * pBuf1, uchar Dst, uchar Status, uchar nCmd, uchar DataLen, void *pData );
+int KLMakeRplyPacket(void * pBuf1, uchar Dst, uchar Status, uchar nCmd, uchar DataLen, const void *pData );
 
 /*   */
-int KLCheckPacket(void * pBuf1,int len1);
+int KLCheckPacket(int nChn, void * pBuf1, int len1);
 
 /* */
-int KLParsePacket(void * pBuf1, int Len1);
+int KLParsePacket(int nChn, void * pBuf1, int Len1);
 
 //int ReadData(void);
 

--
Gitblit v1.9.1