RflySimSDK v3.05
RflySimSDK说明文档
载入中...
搜索中...
未找到
mavlink_msg_aq_esc_telemetry.h
1#pragma once
2// MESSAGE AQ_ESC_TELEMETRY PACKING
3
4#define MAVLINK_MSG_ID_AQ_ESC_TELEMETRY 152
5
6MAVPACKED(
7typedef struct __mavlink_aq_esc_telemetry_t {
8 uint32_t time_boot_ms; /*< Timestamp of the component clock since boot time in ms.*/
9 uint32_t data0[4]; /*< Data bits 1-32 for each ESC.*/
10 uint32_t data1[4]; /*< Data bits 33-64 for each ESC.*/
11 uint16_t status_age[4]; /*< Age of each ESC telemetry reading in ms compared to boot time. A value of 0xFFFF means timeout/no data.*/
12 uint8_t seq; /*< Sequence number of message (first set of 4 motors is #1, next 4 is #2, etc).*/
13 uint8_t num_motors; /*< Total number of active ESCs/motors on the system.*/
14 uint8_t num_in_seq; /*< Number of active ESCs in this sequence (1 through this many array members will be populated with data)*/
15 uint8_t escid[4]; /*< ESC/Motor ID*/
16 uint8_t data_version[4]; /*< Version of data structure (determines contents).*/
17}) mavlink_aq_esc_telemetry_t;
18
19#define MAVLINK_MSG_ID_AQ_ESC_TELEMETRY_LEN 55
20#define MAVLINK_MSG_ID_AQ_ESC_TELEMETRY_MIN_LEN 55
21#define MAVLINK_MSG_ID_152_LEN 55
22#define MAVLINK_MSG_ID_152_MIN_LEN 55
23
24#define MAVLINK_MSG_ID_AQ_ESC_TELEMETRY_CRC 115
25#define MAVLINK_MSG_ID_152_CRC 115
26
27#define MAVLINK_MSG_AQ_ESC_TELEMETRY_FIELD_DATA0_LEN 4
28#define MAVLINK_MSG_AQ_ESC_TELEMETRY_FIELD_DATA1_LEN 4
29#define MAVLINK_MSG_AQ_ESC_TELEMETRY_FIELD_STATUS_AGE_LEN 4
30#define MAVLINK_MSG_AQ_ESC_TELEMETRY_FIELD_ESCID_LEN 4
31#define MAVLINK_MSG_AQ_ESC_TELEMETRY_FIELD_DATA_VERSION_LEN 4
32
33#if MAVLINK_COMMAND_24BIT
34#define MAVLINK_MESSAGE_INFO_AQ_ESC_TELEMETRY { \
35 152, \
36 "AQ_ESC_TELEMETRY", \
37 9, \
38 { { "time_boot_ms", NULL, MAVLINK_TYPE_UINT32_T, 0, 0, offsetof(mavlink_aq_esc_telemetry_t, time_boot_ms) }, \
39 { "seq", NULL, MAVLINK_TYPE_UINT8_T, 0, 44, offsetof(mavlink_aq_esc_telemetry_t, seq) }, \
40 { "num_motors", NULL, MAVLINK_TYPE_UINT8_T, 0, 45, offsetof(mavlink_aq_esc_telemetry_t, num_motors) }, \
41 { "num_in_seq", NULL, MAVLINK_TYPE_UINT8_T, 0, 46, offsetof(mavlink_aq_esc_telemetry_t, num_in_seq) }, \
42 { "escid", NULL, MAVLINK_TYPE_UINT8_T, 4, 47, offsetof(mavlink_aq_esc_telemetry_t, escid) }, \
43 { "status_age", NULL, MAVLINK_TYPE_UINT16_T, 4, 36, offsetof(mavlink_aq_esc_telemetry_t, status_age) }, \
44 { "data_version", NULL, MAVLINK_TYPE_UINT8_T, 4, 51, offsetof(mavlink_aq_esc_telemetry_t, data_version) }, \
45 { "data0", NULL, MAVLINK_TYPE_UINT32_T, 4, 4, offsetof(mavlink_aq_esc_telemetry_t, data0) }, \
46 { "data1", NULL, MAVLINK_TYPE_UINT32_T, 4, 20, offsetof(mavlink_aq_esc_telemetry_t, data1) }, \
47 } \
48}
49#else
50#define MAVLINK_MESSAGE_INFO_AQ_ESC_TELEMETRY { \
51 "AQ_ESC_TELEMETRY", \
52 9, \
53 { { "time_boot_ms", NULL, MAVLINK_TYPE_UINT32_T, 0, 0, offsetof(mavlink_aq_esc_telemetry_t, time_boot_ms) }, \
54 { "seq", NULL, MAVLINK_TYPE_UINT8_T, 0, 44, offsetof(mavlink_aq_esc_telemetry_t, seq) }, \
55 { "num_motors", NULL, MAVLINK_TYPE_UINT8_T, 0, 45, offsetof(mavlink_aq_esc_telemetry_t, num_motors) }, \
56 { "num_in_seq", NULL, MAVLINK_TYPE_UINT8_T, 0, 46, offsetof(mavlink_aq_esc_telemetry_t, num_in_seq) }, \
57 { "escid", NULL, MAVLINK_TYPE_UINT8_T, 4, 47, offsetof(mavlink_aq_esc_telemetry_t, escid) }, \
58 { "status_age", NULL, MAVLINK_TYPE_UINT16_T, 4, 36, offsetof(mavlink_aq_esc_telemetry_t, status_age) }, \
59 { "data_version", NULL, MAVLINK_TYPE_UINT8_T, 4, 51, offsetof(mavlink_aq_esc_telemetry_t, data_version) }, \
60 { "data0", NULL, MAVLINK_TYPE_UINT32_T, 4, 4, offsetof(mavlink_aq_esc_telemetry_t, data0) }, \
61 { "data1", NULL, MAVLINK_TYPE_UINT32_T, 4, 20, offsetof(mavlink_aq_esc_telemetry_t, data1) }, \
62 } \
63}
64#endif
65
83static inline uint16_t mavlink_msg_aq_esc_telemetry_pack(uint8_t system_id, uint8_t component_id, mavlink_message_t* msg,
84 uint32_t time_boot_ms, uint8_t seq, uint8_t num_motors, uint8_t num_in_seq, const uint8_t *escid, const uint16_t *status_age, const uint8_t *data_version, const uint32_t *data0, const uint32_t *data1)
85{
86#if MAVLINK_NEED_BYTE_SWAP || !MAVLINK_ALIGNED_FIELDS
87 char buf[MAVLINK_MSG_ID_AQ_ESC_TELEMETRY_LEN];
88 _mav_put_uint32_t(buf, 0, time_boot_ms);
89 _mav_put_uint8_t(buf, 44, seq);
90 _mav_put_uint8_t(buf, 45, num_motors);
91 _mav_put_uint8_t(buf, 46, num_in_seq);
92 _mav_put_uint32_t_array(buf, 4, data0, 4);
93 _mav_put_uint32_t_array(buf, 20, data1, 4);
94 _mav_put_uint16_t_array(buf, 36, status_age, 4);
95 _mav_put_uint8_t_array(buf, 47, escid, 4);
96 _mav_put_uint8_t_array(buf, 51, data_version, 4);
97 memcpy(_MAV_PAYLOAD_NON_CONST(msg), buf, MAVLINK_MSG_ID_AQ_ESC_TELEMETRY_LEN);
98#else
99 mavlink_aq_esc_telemetry_t packet;
100 packet.time_boot_ms = time_boot_ms;
101 packet.seq = seq;
102 packet.num_motors = num_motors;
103 packet.num_in_seq = num_in_seq;
104 mav_array_memcpy(packet.data0, data0, sizeof(uint32_t)*4);
105 mav_array_memcpy(packet.data1, data1, sizeof(uint32_t)*4);
106 mav_array_memcpy(packet.status_age, status_age, sizeof(uint16_t)*4);
107 mav_array_memcpy(packet.escid, escid, sizeof(uint8_t)*4);
108 mav_array_memcpy(packet.data_version, data_version, sizeof(uint8_t)*4);
109 memcpy(_MAV_PAYLOAD_NON_CONST(msg), &packet, MAVLINK_MSG_ID_AQ_ESC_TELEMETRY_LEN);
110#endif
111
112 msg->msgid = MAVLINK_MSG_ID_AQ_ESC_TELEMETRY;
113 return mavlink_finalize_message(msg, system_id, component_id, MAVLINK_MSG_ID_AQ_ESC_TELEMETRY_MIN_LEN, MAVLINK_MSG_ID_AQ_ESC_TELEMETRY_LEN, MAVLINK_MSG_ID_AQ_ESC_TELEMETRY_CRC);
114}
115
133static inline uint16_t mavlink_msg_aq_esc_telemetry_pack_chan(uint8_t system_id, uint8_t component_id, uint8_t chan,
134 mavlink_message_t* msg,
135 uint32_t time_boot_ms,uint8_t seq,uint8_t num_motors,uint8_t num_in_seq,const uint8_t *escid,const uint16_t *status_age,const uint8_t *data_version,const uint32_t *data0,const uint32_t *data1)
136{
137#if MAVLINK_NEED_BYTE_SWAP || !MAVLINK_ALIGNED_FIELDS
138 char buf[MAVLINK_MSG_ID_AQ_ESC_TELEMETRY_LEN];
139 _mav_put_uint32_t(buf, 0, time_boot_ms);
140 _mav_put_uint8_t(buf, 44, seq);
141 _mav_put_uint8_t(buf, 45, num_motors);
142 _mav_put_uint8_t(buf, 46, num_in_seq);
143 _mav_put_uint32_t_array(buf, 4, data0, 4);
144 _mav_put_uint32_t_array(buf, 20, data1, 4);
145 _mav_put_uint16_t_array(buf, 36, status_age, 4);
146 _mav_put_uint8_t_array(buf, 47, escid, 4);
147 _mav_put_uint8_t_array(buf, 51, data_version, 4);
148 memcpy(_MAV_PAYLOAD_NON_CONST(msg), buf, MAVLINK_MSG_ID_AQ_ESC_TELEMETRY_LEN);
149#else
150 mavlink_aq_esc_telemetry_t packet;
151 packet.time_boot_ms = time_boot_ms;
152 packet.seq = seq;
153 packet.num_motors = num_motors;
154 packet.num_in_seq = num_in_seq;
155 mav_array_memcpy(packet.data0, data0, sizeof(uint32_t)*4);
156 mav_array_memcpy(packet.data1, data1, sizeof(uint32_t)*4);
157 mav_array_memcpy(packet.status_age, status_age, sizeof(uint16_t)*4);
158 mav_array_memcpy(packet.escid, escid, sizeof(uint8_t)*4);
159 mav_array_memcpy(packet.data_version, data_version, sizeof(uint8_t)*4);
160 memcpy(_MAV_PAYLOAD_NON_CONST(msg), &packet, MAVLINK_MSG_ID_AQ_ESC_TELEMETRY_LEN);
161#endif
162
163 msg->msgid = MAVLINK_MSG_ID_AQ_ESC_TELEMETRY;
164 return mavlink_finalize_message_chan(msg, system_id, component_id, chan, MAVLINK_MSG_ID_AQ_ESC_TELEMETRY_MIN_LEN, MAVLINK_MSG_ID_AQ_ESC_TELEMETRY_LEN, MAVLINK_MSG_ID_AQ_ESC_TELEMETRY_CRC);
165}
166
175static inline uint16_t mavlink_msg_aq_esc_telemetry_encode(uint8_t system_id, uint8_t component_id, mavlink_message_t* msg, const mavlink_aq_esc_telemetry_t* aq_esc_telemetry)
176{
177 return mavlink_msg_aq_esc_telemetry_pack(system_id, component_id, msg, aq_esc_telemetry->time_boot_ms, aq_esc_telemetry->seq, aq_esc_telemetry->num_motors, aq_esc_telemetry->num_in_seq, aq_esc_telemetry->escid, aq_esc_telemetry->status_age, aq_esc_telemetry->data_version, aq_esc_telemetry->data0, aq_esc_telemetry->data1);
178}
179
189static inline uint16_t mavlink_msg_aq_esc_telemetry_encode_chan(uint8_t system_id, uint8_t component_id, uint8_t chan, mavlink_message_t* msg, const mavlink_aq_esc_telemetry_t* aq_esc_telemetry)
190{
191 return mavlink_msg_aq_esc_telemetry_pack_chan(system_id, component_id, chan, msg, aq_esc_telemetry->time_boot_ms, aq_esc_telemetry->seq, aq_esc_telemetry->num_motors, aq_esc_telemetry->num_in_seq, aq_esc_telemetry->escid, aq_esc_telemetry->status_age, aq_esc_telemetry->data_version, aq_esc_telemetry->data0, aq_esc_telemetry->data1);
192}
193
208#ifdef MAVLINK_USE_CONVENIENCE_FUNCTIONS
209
210static inline void mavlink_msg_aq_esc_telemetry_send(mavlink_channel_t chan, uint32_t time_boot_ms, uint8_t seq, uint8_t num_motors, uint8_t num_in_seq, const uint8_t *escid, const uint16_t *status_age, const uint8_t *data_version, const uint32_t *data0, const uint32_t *data1)
211{
212#if MAVLINK_NEED_BYTE_SWAP || !MAVLINK_ALIGNED_FIELDS
213 char buf[MAVLINK_MSG_ID_AQ_ESC_TELEMETRY_LEN];
214 _mav_put_uint32_t(buf, 0, time_boot_ms);
215 _mav_put_uint8_t(buf, 44, seq);
216 _mav_put_uint8_t(buf, 45, num_motors);
217 _mav_put_uint8_t(buf, 46, num_in_seq);
218 _mav_put_uint32_t_array(buf, 4, data0, 4);
219 _mav_put_uint32_t_array(buf, 20, data1, 4);
220 _mav_put_uint16_t_array(buf, 36, status_age, 4);
221 _mav_put_uint8_t_array(buf, 47, escid, 4);
222 _mav_put_uint8_t_array(buf, 51, data_version, 4);
223 _mav_finalize_message_chan_send(chan, MAVLINK_MSG_ID_AQ_ESC_TELEMETRY, buf, MAVLINK_MSG_ID_AQ_ESC_TELEMETRY_MIN_LEN, MAVLINK_MSG_ID_AQ_ESC_TELEMETRY_LEN, MAVLINK_MSG_ID_AQ_ESC_TELEMETRY_CRC);
224#else
225 mavlink_aq_esc_telemetry_t packet;
226 packet.time_boot_ms = time_boot_ms;
227 packet.seq = seq;
228 packet.num_motors = num_motors;
229 packet.num_in_seq = num_in_seq;
230 mav_array_memcpy(packet.data0, data0, sizeof(uint32_t)*4);
231 mav_array_memcpy(packet.data1, data1, sizeof(uint32_t)*4);
232 mav_array_memcpy(packet.status_age, status_age, sizeof(uint16_t)*4);
233 mav_array_memcpy(packet.escid, escid, sizeof(uint8_t)*4);
234 mav_array_memcpy(packet.data_version, data_version, sizeof(uint8_t)*4);
235 _mav_finalize_message_chan_send(chan, MAVLINK_MSG_ID_AQ_ESC_TELEMETRY, (const char *)&packet, MAVLINK_MSG_ID_AQ_ESC_TELEMETRY_MIN_LEN, MAVLINK_MSG_ID_AQ_ESC_TELEMETRY_LEN, MAVLINK_MSG_ID_AQ_ESC_TELEMETRY_CRC);
236#endif
237}
238
244static inline void mavlink_msg_aq_esc_telemetry_send_struct(mavlink_channel_t chan, const mavlink_aq_esc_telemetry_t* aq_esc_telemetry)
245{
246#if MAVLINK_NEED_BYTE_SWAP || !MAVLINK_ALIGNED_FIELDS
247 mavlink_msg_aq_esc_telemetry_send(chan, aq_esc_telemetry->time_boot_ms, aq_esc_telemetry->seq, aq_esc_telemetry->num_motors, aq_esc_telemetry->num_in_seq, aq_esc_telemetry->escid, aq_esc_telemetry->status_age, aq_esc_telemetry->data_version, aq_esc_telemetry->data0, aq_esc_telemetry->data1);
248#else
249 _mav_finalize_message_chan_send(chan, MAVLINK_MSG_ID_AQ_ESC_TELEMETRY, (const char *)aq_esc_telemetry, MAVLINK_MSG_ID_AQ_ESC_TELEMETRY_MIN_LEN, MAVLINK_MSG_ID_AQ_ESC_TELEMETRY_LEN, MAVLINK_MSG_ID_AQ_ESC_TELEMETRY_CRC);
250#endif
251}
252
253#if MAVLINK_MSG_ID_AQ_ESC_TELEMETRY_LEN <= MAVLINK_MAX_PAYLOAD_LEN
254/*
255 This varient of _send() can be used to save stack space by re-using
256 memory from the receive buffer. The caller provides a
257 mavlink_message_t which is the size of a full mavlink message. This
258 is usually the receive buffer for the channel, and allows a reply to an
259 incoming message with minimum stack space usage.
260 */
261static inline void mavlink_msg_aq_esc_telemetry_send_buf(mavlink_message_t *msgbuf, mavlink_channel_t chan, uint32_t time_boot_ms, uint8_t seq, uint8_t num_motors, uint8_t num_in_seq, const uint8_t *escid, const uint16_t *status_age, const uint8_t *data_version, const uint32_t *data0, const uint32_t *data1)
262{
263#if MAVLINK_NEED_BYTE_SWAP || !MAVLINK_ALIGNED_FIELDS
264 char *buf = (char *)msgbuf;
265 _mav_put_uint32_t(buf, 0, time_boot_ms);
266 _mav_put_uint8_t(buf, 44, seq);
267 _mav_put_uint8_t(buf, 45, num_motors);
268 _mav_put_uint8_t(buf, 46, num_in_seq);
269 _mav_put_uint32_t_array(buf, 4, data0, 4);
270 _mav_put_uint32_t_array(buf, 20, data1, 4);
271 _mav_put_uint16_t_array(buf, 36, status_age, 4);
272 _mav_put_uint8_t_array(buf, 47, escid, 4);
273 _mav_put_uint8_t_array(buf, 51, data_version, 4);
274 _mav_finalize_message_chan_send(chan, MAVLINK_MSG_ID_AQ_ESC_TELEMETRY, buf, MAVLINK_MSG_ID_AQ_ESC_TELEMETRY_MIN_LEN, MAVLINK_MSG_ID_AQ_ESC_TELEMETRY_LEN, MAVLINK_MSG_ID_AQ_ESC_TELEMETRY_CRC);
275#else
276 mavlink_aq_esc_telemetry_t *packet = (mavlink_aq_esc_telemetry_t *)msgbuf;
277 packet->time_boot_ms = time_boot_ms;
278 packet->seq = seq;
279 packet->num_motors = num_motors;
280 packet->num_in_seq = num_in_seq;
281 mav_array_memcpy(packet->data0, data0, sizeof(uint32_t)*4);
282 mav_array_memcpy(packet->data1, data1, sizeof(uint32_t)*4);
283 mav_array_memcpy(packet->status_age, status_age, sizeof(uint16_t)*4);
284 mav_array_memcpy(packet->escid, escid, sizeof(uint8_t)*4);
285 mav_array_memcpy(packet->data_version, data_version, sizeof(uint8_t)*4);
286 _mav_finalize_message_chan_send(chan, MAVLINK_MSG_ID_AQ_ESC_TELEMETRY, (const char *)packet, MAVLINK_MSG_ID_AQ_ESC_TELEMETRY_MIN_LEN, MAVLINK_MSG_ID_AQ_ESC_TELEMETRY_LEN, MAVLINK_MSG_ID_AQ_ESC_TELEMETRY_CRC);
287#endif
288}
289#endif
290
291#endif
292
293// MESSAGE AQ_ESC_TELEMETRY UNPACKING
294
295
301static inline uint32_t mavlink_msg_aq_esc_telemetry_get_time_boot_ms(const mavlink_message_t* msg)
302{
303 return _MAV_RETURN_uint32_t(msg, 0);
304}
305
311static inline uint8_t mavlink_msg_aq_esc_telemetry_get_seq(const mavlink_message_t* msg)
312{
313 return _MAV_RETURN_uint8_t(msg, 44);
314}
315
321static inline uint8_t mavlink_msg_aq_esc_telemetry_get_num_motors(const mavlink_message_t* msg)
322{
323 return _MAV_RETURN_uint8_t(msg, 45);
324}
325
331static inline uint8_t mavlink_msg_aq_esc_telemetry_get_num_in_seq(const mavlink_message_t* msg)
332{
333 return _MAV_RETURN_uint8_t(msg, 46);
334}
335
341static inline uint16_t mavlink_msg_aq_esc_telemetry_get_escid(const mavlink_message_t* msg, uint8_t *escid)
342{
343 return _MAV_RETURN_uint8_t_array(msg, escid, 4, 47);
344}
345
351static inline uint16_t mavlink_msg_aq_esc_telemetry_get_status_age(const mavlink_message_t* msg, uint16_t *status_age)
352{
353 return _MAV_RETURN_uint16_t_array(msg, status_age, 4, 36);
354}
355
361static inline uint16_t mavlink_msg_aq_esc_telemetry_get_data_version(const mavlink_message_t* msg, uint8_t *data_version)
362{
363 return _MAV_RETURN_uint8_t_array(msg, data_version, 4, 51);
364}
365
371static inline uint16_t mavlink_msg_aq_esc_telemetry_get_data0(const mavlink_message_t* msg, uint32_t *data0)
372{
373 return _MAV_RETURN_uint32_t_array(msg, data0, 4, 4);
374}
375
381static inline uint16_t mavlink_msg_aq_esc_telemetry_get_data1(const mavlink_message_t* msg, uint32_t *data1)
382{
383 return _MAV_RETURN_uint32_t_array(msg, data1, 4, 20);
384}
385
392static inline void mavlink_msg_aq_esc_telemetry_decode(const mavlink_message_t* msg, mavlink_aq_esc_telemetry_t* aq_esc_telemetry)
393{
394#if MAVLINK_NEED_BYTE_SWAP || !MAVLINK_ALIGNED_FIELDS
395 aq_esc_telemetry->time_boot_ms = mavlink_msg_aq_esc_telemetry_get_time_boot_ms(msg);
396 mavlink_msg_aq_esc_telemetry_get_data0(msg, aq_esc_telemetry->data0);
397 mavlink_msg_aq_esc_telemetry_get_data1(msg, aq_esc_telemetry->data1);
398 mavlink_msg_aq_esc_telemetry_get_status_age(msg, aq_esc_telemetry->status_age);
399 aq_esc_telemetry->seq = mavlink_msg_aq_esc_telemetry_get_seq(msg);
400 aq_esc_telemetry->num_motors = mavlink_msg_aq_esc_telemetry_get_num_motors(msg);
401 aq_esc_telemetry->num_in_seq = mavlink_msg_aq_esc_telemetry_get_num_in_seq(msg);
402 mavlink_msg_aq_esc_telemetry_get_escid(msg, aq_esc_telemetry->escid);
403 mavlink_msg_aq_esc_telemetry_get_data_version(msg, aq_esc_telemetry->data_version);
404#else
405 uint8_t len = msg->len < MAVLINK_MSG_ID_AQ_ESC_TELEMETRY_LEN? msg->len : MAVLINK_MSG_ID_AQ_ESC_TELEMETRY_LEN;
406 memset(aq_esc_telemetry, 0, MAVLINK_MSG_ID_AQ_ESC_TELEMETRY_LEN);
407 memcpy(aq_esc_telemetry, _MAV_PAYLOAD(msg), len);
408#endif
409}