mavlink_msg_vibration.h
Go to the documentation of this file.
1 // MESSAGE VIBRATION PACKING
2 
3 #define MAVLINK_MSG_ID_VIBRATION 241
4 
5 typedef struct __mavlink_vibration_t
6 {
7  uint64_t time_usec; /*< Timestamp (micros since boot or Unix epoch)*/
8  float vibration_x; /*< Vibration levels on X-axis*/
9  float vibration_y; /*< Vibration levels on Y-axis*/
10  float vibration_z; /*< Vibration levels on Z-axis*/
11  uint32_t clipping_0; /*< first accelerometer clipping count*/
12  uint32_t clipping_1; /*< second accelerometer clipping count*/
13  uint32_t clipping_2; /*< third accelerometer clipping count*/
15 
16 #define MAVLINK_MSG_ID_VIBRATION_LEN 32
17 #define MAVLINK_MSG_ID_241_LEN 32
18 
19 #define MAVLINK_MSG_ID_VIBRATION_CRC 90
20 #define MAVLINK_MSG_ID_241_CRC 90
21 
22 
23 
24 #define MAVLINK_MESSAGE_INFO_VIBRATION { \
25  "VIBRATION", \
26  7, \
27  { { "time_usec", NULL, MAVLINK_TYPE_UINT64_T, 0, 0, offsetof(mavlink_vibration_t, time_usec) }, \
28  { "vibration_x", NULL, MAVLINK_TYPE_FLOAT, 0, 8, offsetof(mavlink_vibration_t, vibration_x) }, \
29  { "vibration_y", NULL, MAVLINK_TYPE_FLOAT, 0, 12, offsetof(mavlink_vibration_t, vibration_y) }, \
30  { "vibration_z", NULL, MAVLINK_TYPE_FLOAT, 0, 16, offsetof(mavlink_vibration_t, vibration_z) }, \
31  { "clipping_0", NULL, MAVLINK_TYPE_UINT32_T, 0, 20, offsetof(mavlink_vibration_t, clipping_0) }, \
32  { "clipping_1", NULL, MAVLINK_TYPE_UINT32_T, 0, 24, offsetof(mavlink_vibration_t, clipping_1) }, \
33  { "clipping_2", NULL, MAVLINK_TYPE_UINT32_T, 0, 28, offsetof(mavlink_vibration_t, clipping_2) }, \
34  } \
35 }
36 
37 
53 static inline uint16_t mavlink_msg_vibration_pack(uint8_t system_id, uint8_t component_id, mavlink_message_t* msg,
54  uint64_t time_usec, float vibration_x, float vibration_y, float vibration_z, uint32_t clipping_0, uint32_t clipping_1, uint32_t clipping_2)
55 {
56 #if MAVLINK_NEED_BYTE_SWAP || !MAVLINK_ALIGNED_FIELDS
58  _mav_put_uint64_t(buf, 0, time_usec);
59  _mav_put_float(buf, 8, vibration_x);
60  _mav_put_float(buf, 12, vibration_y);
61  _mav_put_float(buf, 16, vibration_z);
62  _mav_put_uint32_t(buf, 20, clipping_0);
63  _mav_put_uint32_t(buf, 24, clipping_1);
64  _mav_put_uint32_t(buf, 28, clipping_2);
65 
67 #else
68  mavlink_vibration_t packet;
69  packet.time_usec = time_usec;
70  packet.vibration_x = vibration_x;
71  packet.vibration_y = vibration_y;
72  packet.vibration_z = vibration_z;
73  packet.clipping_0 = clipping_0;
74  packet.clipping_1 = clipping_1;
75  packet.clipping_2 = clipping_2;
76 
78 #endif
79 
80  msg->msgid = MAVLINK_MSG_ID_VIBRATION;
81 #if MAVLINK_CRC_EXTRA
83 #else
84  return mavlink_finalize_message(msg, system_id, component_id, MAVLINK_MSG_ID_VIBRATION_LEN);
85 #endif
86 }
87 
103 static inline uint16_t mavlink_msg_vibration_pack_chan(uint8_t system_id, uint8_t component_id, uint8_t chan,
104  mavlink_message_t* msg,
105  uint64_t time_usec,float vibration_x,float vibration_y,float vibration_z,uint32_t clipping_0,uint32_t clipping_1,uint32_t clipping_2)
106 {
107 #if MAVLINK_NEED_BYTE_SWAP || !MAVLINK_ALIGNED_FIELDS
109  _mav_put_uint64_t(buf, 0, time_usec);
110  _mav_put_float(buf, 8, vibration_x);
111  _mav_put_float(buf, 12, vibration_y);
112  _mav_put_float(buf, 16, vibration_z);
113  _mav_put_uint32_t(buf, 20, clipping_0);
114  _mav_put_uint32_t(buf, 24, clipping_1);
115  _mav_put_uint32_t(buf, 28, clipping_2);
116 
118 #else
119  mavlink_vibration_t packet;
120  packet.time_usec = time_usec;
121  packet.vibration_x = vibration_x;
122  packet.vibration_y = vibration_y;
123  packet.vibration_z = vibration_z;
124  packet.clipping_0 = clipping_0;
125  packet.clipping_1 = clipping_1;
126  packet.clipping_2 = clipping_2;
127 
129 #endif
130 
131  msg->msgid = MAVLINK_MSG_ID_VIBRATION;
132 #if MAVLINK_CRC_EXTRA
134 #else
135  return mavlink_finalize_message_chan(msg, system_id, component_id, chan, MAVLINK_MSG_ID_VIBRATION_LEN);
136 #endif
137 }
138 
147 static inline uint16_t mavlink_msg_vibration_encode(uint8_t system_id, uint8_t component_id, mavlink_message_t* msg, const mavlink_vibration_t* vibration)
148 {
149  return mavlink_msg_vibration_pack(system_id, component_id, msg, vibration->time_usec, vibration->vibration_x, vibration->vibration_y, vibration->vibration_z, vibration->clipping_0, vibration->clipping_1, vibration->clipping_2);
150 }
151 
161 static inline uint16_t mavlink_msg_vibration_encode_chan(uint8_t system_id, uint8_t component_id, uint8_t chan, mavlink_message_t* msg, const mavlink_vibration_t* vibration)
162 {
163  return mavlink_msg_vibration_pack_chan(system_id, component_id, chan, msg, vibration->time_usec, vibration->vibration_x, vibration->vibration_y, vibration->vibration_z, vibration->clipping_0, vibration->clipping_1, vibration->clipping_2);
164 }
165 
178 #ifdef MAVLINK_USE_CONVENIENCE_FUNCTIONS
179 
180 static inline void mavlink_msg_vibration_send(mavlink_channel_t chan, uint64_t time_usec, float vibration_x, float vibration_y, float vibration_z, uint32_t clipping_0, uint32_t clipping_1, uint32_t clipping_2)
181 {
182 #if MAVLINK_NEED_BYTE_SWAP || !MAVLINK_ALIGNED_FIELDS
184  _mav_put_uint64_t(buf, 0, time_usec);
185  _mav_put_float(buf, 8, vibration_x);
186  _mav_put_float(buf, 12, vibration_y);
187  _mav_put_float(buf, 16, vibration_z);
188  _mav_put_uint32_t(buf, 20, clipping_0);
189  _mav_put_uint32_t(buf, 24, clipping_1);
190  _mav_put_uint32_t(buf, 28, clipping_2);
191 
192 #if MAVLINK_CRC_EXTRA
193  _mav_finalize_message_chan_send(chan, MAVLINK_MSG_ID_VIBRATION, buf, MAVLINK_MSG_ID_VIBRATION_LEN, MAVLINK_MSG_ID_VIBRATION_CRC);
194 #else
195  _mav_finalize_message_chan_send(chan, MAVLINK_MSG_ID_VIBRATION, buf, MAVLINK_MSG_ID_VIBRATION_LEN);
196 #endif
197 #else
198  mavlink_vibration_t packet;
199  packet.time_usec = time_usec;
200  packet.vibration_x = vibration_x;
201  packet.vibration_y = vibration_y;
202  packet.vibration_z = vibration_z;
203  packet.clipping_0 = clipping_0;
204  packet.clipping_1 = clipping_1;
205  packet.clipping_2 = clipping_2;
206 
207 #if MAVLINK_CRC_EXTRA
208  _mav_finalize_message_chan_send(chan, MAVLINK_MSG_ID_VIBRATION, (const char *)&packet, MAVLINK_MSG_ID_VIBRATION_LEN, MAVLINK_MSG_ID_VIBRATION_CRC);
209 #else
210  _mav_finalize_message_chan_send(chan, MAVLINK_MSG_ID_VIBRATION, (const char *)&packet, MAVLINK_MSG_ID_VIBRATION_LEN);
211 #endif
212 #endif
213 }
214 
215 #if MAVLINK_MSG_ID_VIBRATION_LEN <= MAVLINK_MAX_PAYLOAD_LEN
216 /*
217  This varient of _send() can be used to save stack space by re-using
218  memory from the receive buffer. The caller provides a
219  mavlink_message_t which is the size of a full mavlink message. This
220  is usually the receive buffer for the channel, and allows a reply to an
221  incoming message with minimum stack space usage.
222  */
223 static inline void mavlink_msg_vibration_send_buf(mavlink_message_t *msgbuf, mavlink_channel_t chan, uint64_t time_usec, float vibration_x, float vibration_y, float vibration_z, uint32_t clipping_0, uint32_t clipping_1, uint32_t clipping_2)
224 {
225 #if MAVLINK_NEED_BYTE_SWAP || !MAVLINK_ALIGNED_FIELDS
226  char *buf = (char *)msgbuf;
227  _mav_put_uint64_t(buf, 0, time_usec);
228  _mav_put_float(buf, 8, vibration_x);
229  _mav_put_float(buf, 12, vibration_y);
230  _mav_put_float(buf, 16, vibration_z);
231  _mav_put_uint32_t(buf, 20, clipping_0);
232  _mav_put_uint32_t(buf, 24, clipping_1);
233  _mav_put_uint32_t(buf, 28, clipping_2);
234 
235 #if MAVLINK_CRC_EXTRA
236  _mav_finalize_message_chan_send(chan, MAVLINK_MSG_ID_VIBRATION, buf, MAVLINK_MSG_ID_VIBRATION_LEN, MAVLINK_MSG_ID_VIBRATION_CRC);
237 #else
238  _mav_finalize_message_chan_send(chan, MAVLINK_MSG_ID_VIBRATION, buf, MAVLINK_MSG_ID_VIBRATION_LEN);
239 #endif
240 #else
241  mavlink_vibration_t *packet = (mavlink_vibration_t *)msgbuf;
242  packet->time_usec = time_usec;
243  packet->vibration_x = vibration_x;
244  packet->vibration_y = vibration_y;
245  packet->vibration_z = vibration_z;
246  packet->clipping_0 = clipping_0;
247  packet->clipping_1 = clipping_1;
248  packet->clipping_2 = clipping_2;
249 
250 #if MAVLINK_CRC_EXTRA
251  _mav_finalize_message_chan_send(chan, MAVLINK_MSG_ID_VIBRATION, (const char *)packet, MAVLINK_MSG_ID_VIBRATION_LEN, MAVLINK_MSG_ID_VIBRATION_CRC);
252 #else
253  _mav_finalize_message_chan_send(chan, MAVLINK_MSG_ID_VIBRATION, (const char *)packet, MAVLINK_MSG_ID_VIBRATION_LEN);
254 #endif
255 #endif
256 }
257 #endif
258 
259 #endif
260 
261 // MESSAGE VIBRATION UNPACKING
262 
263 
269 static inline uint64_t mavlink_msg_vibration_get_time_usec(const mavlink_message_t* msg)
270 {
271  return _MAV_RETURN_uint64_t(msg, 0);
272 }
273 
279 static inline float mavlink_msg_vibration_get_vibration_x(const mavlink_message_t* msg)
280 {
281  return _MAV_RETURN_float(msg, 8);
282 }
283 
289 static inline float mavlink_msg_vibration_get_vibration_y(const mavlink_message_t* msg)
290 {
291  return _MAV_RETURN_float(msg, 12);
292 }
293 
299 static inline float mavlink_msg_vibration_get_vibration_z(const mavlink_message_t* msg)
300 {
301  return _MAV_RETURN_float(msg, 16);
302 }
303 
309 static inline uint32_t mavlink_msg_vibration_get_clipping_0(const mavlink_message_t* msg)
310 {
311  return _MAV_RETURN_uint32_t(msg, 20);
312 }
313 
319 static inline uint32_t mavlink_msg_vibration_get_clipping_1(const mavlink_message_t* msg)
320 {
321  return _MAV_RETURN_uint32_t(msg, 24);
322 }
323 
329 static inline uint32_t mavlink_msg_vibration_get_clipping_2(const mavlink_message_t* msg)
330 {
331  return _MAV_RETURN_uint32_t(msg, 28);
332 }
333 
340 static inline void mavlink_msg_vibration_decode(const mavlink_message_t* msg, mavlink_vibration_t* vibration)
341 {
342 #if MAVLINK_NEED_BYTE_SWAP
350 #else
351  memcpy(vibration, _MAV_PAYLOAD(msg), MAVLINK_MSG_ID_VIBRATION_LEN);
352 #endif
353 }
#define _mav_put_float(buf, wire_offset, b)
Definition: protocol.h:151
#define _mav_put_uint64_t(buf, wire_offset, b)
Definition: protocol.h:149
#define _mav_put_uint32_t(buf, wire_offset, b)
Definition: protocol.h:147


rosflight
Author(s): Daniel Koch , James Jackson
autogenerated on Thu Apr 15 2021 05:09:26