-
Notifications
You must be signed in to change notification settings - Fork 3
/
bin_command_def.h
358 lines (322 loc) · 10.5 KB
/
bin_command_def.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
#ifndef __BIN_COMMAND_H__
#define __BIN_COMMAND_H__
typedef uint8_t u8_t;
typedef uint16_t u16_t;
typedef uint32_t u32_t;
//成功与否,实际上只占一位
#define CMD_ACK_OK 0x01
#define CMD_ACK_KO 0x00
#define CMD_REQ_START 0
#define CMD_REQ_NEXT 1
#define CMD_REQ_DONE 2
#define CMD_CURRENT_START 0
#define CMD_CURRENT_DOING 1
#define CMD_CURRENT_DONE 2
extern uint8_t command_state;
#define CMD_GET_IO_OUT_VALUE 1
#define CMD_GET_IO_IN_VALUE 2
#define CMD_SET_IO_OUT_VALUE 3
#define CMD_GET_IO_NAME 4
#define CMD_SET_IO_NAME 5
#define CMD_GET_TIMING_INFO 6
#define CMD_SET_TIMING_INFO 7
#define CMD_GET_RTC_VALUE 8
#define CMD_SET_RTC_VALUE 9
#define CMD_SET_TIMING_ON_MSK 10
#define CMD_GET_TIMING_ON_MSK 11
#define CMD_SET_INPUT_CTL_ON_MSK 12
#define CMD_GET_INPUT_CTL_ON_MSK 13
#define CMD_SET_HOST_ADDRESS 14
#define CMD_GET_HOST_ADDRESS 15
#define CMD_SET_SYSTEM_RESET 16
#define CMD_REV_IO_SOME_BIT 36
#define CMD_SET_IO_ONE_BIT 37 //
#define CMD_CLR_IO_ONE_BIT 38 //
#define CMD_REV_IO_ONE_BIT 39 //
#define CMD_SET_IP_CONFIG 33
#define CMD_GET_IP_CONFIG 34
#define CMD_GET_INPUT_CTL_MODE_INDEX 40
#define CMD_SET_INPUT_CTL_MODE_INDEX 41
#define CMD_SET_INPUT_CTL_MODE 42
#define CMD_GET_INPUT_CTL_MODE 43
//新增定时器接口
#define CMD_READ_REGISTER 80
#define CMD_WRITE_REGISTER 81
//PLC程序读写
#define CMD_PLC_READ 82 //0x52
#define CMD_PLC_WRITE 83 //0x53
#if 0
typedef struct _CmdHead
{
uint8_t cmd;
uint16_t cmd_index;
uint8_t cmd_option;
uint16_t cmd_len;
uint8_t data_checksum;
} CmdHead;
#else
typedef struct _CmdHead
{
uint8_t cmd;
uint16_t cmd_index;
uint8_t cmd_option;
#if 0
uint8_t pad;
uint8_t cmd_len;
#else
uint8_t cmd_len;
uint8_t pad;
#endif
uint8_t data_checksum;
} CmdHead;
#endif
//2b 00 00 01 09 44 11 00 07 00 0a 00 00 00 00 00
//读写寄存器的通用接口
typedef struct _CmdRegister
{
uint8_t reg_addr_hi;
uint8_t reg_addr_lo;
uint8_t reg_len_hi;
uint8_t reg_len_lo;
uint8_t reg_base;
} CmdRegister;
//读写新控制模式专用数据结构
typedef struct _CmdInputControl
{
unsigned char index;
unsigned char mode;
unsigned char input_filter_time_hi;
unsigned char input_filter_time_lo;
unsigned char input_trig_front_time_hi;
unsigned char input_trig_front_time_lo;
unsigned char input_trig_after_time_hi;
unsigned char input_trig_after_time_lo;
unsigned char input_trig_io_number;
} CmdInputControl;
#define GET_CMD_DATA(pCmd) ((void *)(((char *)pCmd)+sizeof(CmdHead)))
#define GET_CMD_OK(pcmd) (((pcmd)->cmd_option)&CMD_ACK_OK)
#define SET_CMD_OK(pcmd,ok) do{if(!ok){(pcmd)->cmd_option &= ~CMD_ACK_OK;}else{(pcmd)->cmd_option |= CMD_ACK_OK;}}while(0)
#define GET_CMD_STATE(pcmd) ((((pcmd)->cmd_option)&0xF0)>>4)
#define SET_CMD_STATE(pcmd,mode) do{(pcmd)->cmd_option &= ~0xF0;(pcmd)->cmd_option |= ((mode)&0xF)<<4; }while(0)
typedef struct _CmdIoOneBit
{
uint8_t io_bitnum[2];
} CmdIoOneBit;
typedef struct _CmdIoIndex
{
uint8_t io_msk[4];
} CmdIobitmap;
typedef struct _CmdMode
{
uint8_t mode;
} CmdMode;
typedef struct _CmdInputMode
{
uint8_t mode[8];
} CmdInputMode;
typedef struct _CmdInputModeIndex
{
uint8_t index;
uint8_t mode;
} CmdInputModeIndex;
#define INPUT_TRIGGER_FLIP_MODE 0x00 //触发反转模式
#define INPUT_SINGLE_TRIGGER_MODE 0x01 //单触发模式
#define INPUT_TRIGGER_TO_OPEN_MODE 0x02 //触发开通模式
#define INPUT_TRIGGER_TO_OFF_MODE 0x03 //触发关闭模式
#define INPUT_EDGE_TRIG_MODE 0x04 //边沿触发模式
#define INPUT_LEVEL_CTL_ON_MODE 0x05 //输入电平控制开模式
#define INPUT_LEVEL_CTL_OFF_MODE 0x06 //输入电平控制关模式
#define INPUT_TRIGGER_OFF_MODE 0x07 //控制关闭
typedef struct _CmdIoValidMsk
{
uint8_t valid_msk[4];
uint8_t invalid_msk[4];
} CmdIoValidMsk;
typedef struct _CmdIpConfigData
{
uint8_t ipaddr[4];
uint8_t netmask[4];
uint8_t gateway[4];
uint8_t dns[4];
uint16_t port;
uint16_t webport;
} CmdIpConfigData;
//加密功能
typedef struct _CmdMcuId
{
uint8_t IdLength;
uint8_t IdValue[1];
} CmdMcuId;
typedef struct _CmdIoValue
{
uint8_t io_count;
uint8_t io_value[4];
} CmdIoValue;
typedef struct _CmdIoBit
{
uint8_t io_index;
uint8_t io_enable;
} CmdIoBit;
typedef struct _CmdBoardInfo
{
uint8_t version;
uint8_t option; //是否带锁
uint8_t board_name[20];
uint8_t password[20];
} CmdBoardInfo;
typedef struct _CmdIoName
{
uint8_t io_addr[2];
uint8_t io_name[20];
} CmdIoName;
//定时的读写时序描述
//定义定时时间参数
typedef struct _time_type
{
uint8_t year;
uint8_t mon;
uint8_t day;
uint8_t hour;
uint8_t min;
uint8_t sec;
} time_type;
typedef struct _time_type_e
{
uint8_t year;
uint8_t mon;
uint8_t day;
uint8_t hour;
uint8_t min;
uint8_t sec;
uint8_t week;
} time_type_e;
typedef struct _timing_node
{
uint8_t addr[2]; //定时端口地址编码(板上输出口地址范围为[0][0] ~ [0][16]),第5路输出就是addr[0]=4,addr[1]=0
uint16_t option; //选项,第0位:1表示定时有效,0表示无效,第1位:1表示小循环开启,0关闭。第[8:11]位表示循环类型,类型值如下
//
time_type start_time; //循环开启时间(精确到秒,以板上实时时间为准)
time_type end_time; //循环关闭时间(精确到秒,以板上实时时间为准)
//
uint32_t duty_cycle; //小循环中打开继电器的时间周期,即使开通时间长度,毫秒为单位,最小10毫秒,最长数十天(49天)
uint32_t period; //小循环一个周期的时间长度,毫秒为单位,最小10毫秒,最长数十天(49天)
//记录状态
uint8_t state; //内部使用,写0
} timing_node;
//定时节点的个数,
typedef struct _timint_info
{
uint16_t time_max_count;
} timint_info;
//定义读写的时候定时数据正文
typedef struct _CmdTimingNode
{
uint16_t index;
timing_node node;
} CmdTimingNode;
//定时只在时间到的时候触发输出控制,只有在开或关的瞬间发生触发
//多个定时节点对同一路输出控制,以最后一路(发送写命令为顺序)定时节点的触发信号会覆盖前面节点触发的状态。
//定时时间设定必须先写timint_info数据
//然后连续调用写CmdTimingNode命令,直到完成为止.
//CmdTimingNode钟字段index的范围是0-(time_max_count-1)
//写的过程分三个阶段,
//第一:SendCommand(CMD_SET_TIMING_INFO,CMD_REQ_START,data),data是数据正文,类型为timint_info
//第二阶段:SendCommand(CMD_SET_TIMING_INFO,CMD_REQ_NEXT,data),datas是正文,类型为CmdTimingNode,连续写完time_max_count个命令
//第三阶段:SendCommand(CMD_SET_TIMING_INFO,CMD_REQ_DONE,data);data是正文,长度为零,通知下位机完成写事务
//参数CMD_REQ_START是报文头的cmd_option的第[4:7]位,定义如下
//#define CMD_REQ_START 0
//#define CMD_REQ_NEXT 1
//#define CMD_REQ_DONE 2
//应答包则对应的,也在cmd_option中设置了[4:7]位,表明上一命令的状态
//用C语言描述表示如下:
//#define GET_CMD_STATE(pcmd) ((((pcmd)->cmd_option)&0xF0)>>4)
//#define SET_CMD_STATE(pcmd,mode) do{(pcmd)->cmd_option &= ~0xF0;(pcmd)->cmd_option |= ((mode)&0xF)<<4; }while(0)
//-----------------
//读定时则和写定时时序相当,也是三个阶段,三个状态,只是数据命令不同而正文数据长度为零而已。
//各个定义如下:
//1,SendCommand(CMD_GET_TIMING_INFO,CMD_REQ_START,data);
//2,SendCommand(CMD_GET_TIMING_INFO,CMD_REQ_NEXT,data);
//3,SendCommand(CMD_GET_TIMING_INFO,CMD_REQ_DONE,data);
//注意,定时读的应答正文数据的格式是timing_node,而不是CmdTimingNode
//以下是各个参数的定义
//timing_node的option字段
#define VALID 1
#define INVALID 0
//state
#define TIME_NO_COME 0
#define TIME_DOING 1
#define TIME_SUBDO_ON 2
#define TIME_SUBDO_OFF 3
#define TIME_OVER 4
//
//option
#define CYCLE_YEAR 0
#define CYCLE_MONTH 1
#define CYCLE_DAY 2
#define CYCLE_HOUR 3
#define CYCLE_MINITH 4
#define CYCLE_SECOND 5
#define CYCLE_WEEK 6
#define CYCLE_USER 7
#define CYCLE_ONCE 8
//option
#define TIME_VALID 0x01
#define TIME_SUBCYCLE 0x02
#define TIME_HOLD_IO 0x04
#define TIME_DONE 0x08
//-------------------------------------------------------------
#define SET_IO_TIME_VALID(ptime,valid) \
do{ \
if(valid) { (ptime)->option |= TIME_VALID; } else { (ptime)->option &= ~TIME_VALID; } \
} while(0)
#define GET_IO_TIME_VALID(ptime) \
(((ptime)->option)&TIME_VALID)
//-------------------------------------------------------------
//-------------------------------------------------------------
#define SET_IO_TIME_SUBCYCLEON(ptime,valid) \
do{ \
if(valid) { (ptime)->option |= TIME_SUBCYCLE; } else { (ptime)->option &= ~TIME_SUBCYCLE; } \
} while(0)
#define GET_IO_TIME_SUBCYCLEON(ptime) \
((((ptime)->option)&TIME_SUBCYCLE)?1:0)
//-------------------------------------------------------------
#define SET_IO_TIME_HOLD_IO(ptime,valid) \
do{ \
if(valid) { (ptime)->option |= TIME_HOLD_IO; } else { (ptime)->option &= ~TIME_HOLD_IO; } \
} while(0)
#define GET_IO_TIME_HOLD_IO(ptime) \
(((ptime)->option)&TIME_MS_TICK)
//-------------------------------------------------------------
//-------------------------------------------------------------
#define SET_IO_TIME_CYCLE_TYPE(ptime,type) \
do{ (ptime)->option &= ~(0xF<<8);(ptime)->option |= (((type)&0xF)<<8); } while(0)
#define GET_IO_TIME_CYCLE_TYPE(ptime) \
((((ptime)->option)>>8)&0xF)
//-------------------------------------------------------------
#define SET_IO_TIME_IO_ON_OFF(ptime,valid) \
do{ \
if(valid) { (ptime)->option |= TIME_ON_OFF; } else { (ptime)->option &= ~TIME_ON_OFF; } \
} while(0)
#define GET_IO_TIME_IO_ON_OFF(ptime) \
(((ptime)->option)&TIME_ON_OFF)
//-------------------------------------------------------------
#define SET_IO_TIME_DONE(ptime,valid) \
do{ \
if(valid) { (ptime)->option |= TIME_DONE; } else { (ptime)->option &= ~TIME_DONE; } \
} while(0)
#define GET_IO_TIME_DONE(ptime) \
(((ptime)->option)&TIME_DONE)
typedef struct _host_address
{
u8_t type; //type = 0:192.168.1.111....,type = 1 : www.hostaddr.com
char host_address[64];
u16_t port;
} host_address;
#define HOST_ADDR_IS_IP_MODE 0
#define HOST_ADDR_IS_DOMAIN_MODE 1
//
#define HOST_IS_UDP 0
#define HOST_IS_TCP_SERVER 1
#define HOST_IS_TCP_CLIENT 2
//-------------------------------------------------------------
#endif