-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathyahdlc.h
156 lines (137 loc) · 4.8 KB
/
yahdlc.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
/**
* @file yahdlc.h
*
* The MIT License (MIT)
*
* Copyright (c) 2015 Bang & Olufsen
*
* Permission is hereby granted, free of charge, to any person obtaining a copy
* of this software and associated documentation files (the "Software"), to deal
* in the Software without restriction, including without limitation the rights
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
* copies of the Software, and to permit persons to whom the Software is
* furnished to do so, subject to the following conditions:
*
* The above copyright notice and this permission notice shall be included in
* all copies or substantial portions of the Software.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
* SOFTWARE.
*
*/
#ifndef YAHDLC_H
#define YAHDLC_H
#include <errno.h>
/** HDLC start/end flag sequence */
#define YAHDLC_FLAG_SEQUENCE 0x7E
/** HDLC control escape value */
#define YAHDLC_CONTROL_ESCAPE 0x7D
/** HDLC all station address */
#define YAHDLC_ALL_STATION_ADDR 0xFF
/** Supported HDLC frame types */
typedef enum {
YAHDLC_FRAME_DATA,
YAHDLC_FRAME_ACK,
YAHDLC_FRAME_NACK,
} yahdlc_frame_t;
/** Control field information */
typedef struct {
yahdlc_frame_t frame;
unsigned char seq_no :3;
} yahdlc_control_t;
/** Variables used in yahdlc_get_data and yahdlc_get_data_with_state
* to keep track of received buffers
*/
typedef struct {
char control_escape;
unsigned short fcs;
int start_index;
int end_index;
int src_index;
int dest_index;
} yahdlc_state_t;
#ifdef __cplusplus
extern "C" {
#endif
/**
* Set the yahdlc state
*
* @param[in] state The new yahdlc state to be used
* @retval 0 Success
* @retval -EINVAL Invalid parameter
*/
int yahdlc_set_state(yahdlc_state_t *state);
/**
* Get current yahdlc state
*
* @param[out] state Current yahdlc state
* @retval 0 Success
* @retval -EINVAL Invalid parameter
*/
int yahdlc_get_state(yahdlc_state_t *state);
/**
* Retrieves data from specified buffer containing the HDLC frame. Frames can be
* parsed from multiple buffers e.g. when received via UART.
*
* @param[out] control Control field structure with frame type and sequence number
* @param[in] src Source buffer with frame
* @param[in] src_len Source buffer length
* @param[out] dest Destination buffer (should be able to contain max frame size)
* @param[out] dest_len Destination buffer length
* @retval >=0 Success (size of returned value should be discarded from source buffer)
* @retval -EINVAL Invalid parameter
* @retval -ENOMSG Invalid message
* @retval -EIO Invalid FCS (size of dest_len should be discarded from source buffer)
*
* @see yahdlc_get_data_with_state
*/
int yahdlc_get_data(yahdlc_control_t *control, const char *src,
unsigned int src_len, char *dest, unsigned int *dest_len);
/**
* Retrieves data from specified buffer containing the HDLC frame. Frames can be
* parsed from multiple buffers e.g. when received via UART.
*
* This function is a variation of @ref yahdlc_get_data
* The difference is only in first argument: yahdlc_state_t *state
* Data under that pointer is used to keep track of internal buffers.
*
* @see yahdlc_get_data
*/
int yahdlc_get_data_with_state(yahdlc_state_t *state, yahdlc_control_t *control, const char *src,
unsigned int src_len, char *dest, unsigned int *dest_len);
/**
* Resets values used in yahdlc_get_data function to keep track of received buffers
*/
void yahdlc_get_data_reset(void);
/**
* This is a variation of @ref yahdlc_get_data_reset
* Resets state values that are under the pointer provided as argument
*
* This function need to be called before the first call to yahdlc_get_data_with_state
* when custom state storage is used.
*
* @see yahdlc_get_data_reset
*/
void yahdlc_get_data_reset_with_state(yahdlc_state_t *state);
/**
* Creates HDLC frame with specified data buffer.
*
* @param[in] control Control field structure with frame type and sequence number
* @param[in] src Source buffer with data
* @param[in] src_len Source buffer length
* @param[out] dest Destination buffer (should be bigger than source buffer)
* @param[out] dest_len Destination buffer length
* @retval 0 Success
* @retval -EINVAL Invalid parameter
*/
int yahdlc_frame_data(yahdlc_control_t *control, const char *src,
unsigned int src_len, char *dest, unsigned int *dest_len);
#ifdef __cplusplus
}
#endif
#endif