mavlink_msg_hil_controls.h 19 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463
  1. #pragma once
  2. // MESSAGE HIL_CONTROLS PACKING
  3. #define MAVLINK_MSG_ID_HIL_CONTROLS 91
  4. typedef struct __mavlink_hil_controls_t {
  5. uint64_t time_usec; /*< [us] Timestamp (UNIX Epoch time or time since system boot). The receiving end can infer timestamp format (since 1.1.1970 or since system boot) by checking for the magnitude of the number.*/
  6. float roll_ailerons; /*< Control output -1 .. 1*/
  7. float pitch_elevator; /*< Control output -1 .. 1*/
  8. float yaw_rudder; /*< Control output -1 .. 1*/
  9. float throttle; /*< Throttle 0 .. 1*/
  10. float aux1; /*< Aux 1, -1 .. 1*/
  11. float aux2; /*< Aux 2, -1 .. 1*/
  12. float aux3; /*< Aux 3, -1 .. 1*/
  13. float aux4; /*< Aux 4, -1 .. 1*/
  14. uint8_t mode; /*< System mode.*/
  15. uint8_t nav_mode; /*< Navigation mode (MAV_NAV_MODE)*/
  16. } mavlink_hil_controls_t;
  17. #define MAVLINK_MSG_ID_HIL_CONTROLS_LEN 42
  18. #define MAVLINK_MSG_ID_HIL_CONTROLS_MIN_LEN 42
  19. #define MAVLINK_MSG_ID_91_LEN 42
  20. #define MAVLINK_MSG_ID_91_MIN_LEN 42
  21. #define MAVLINK_MSG_ID_HIL_CONTROLS_CRC 63
  22. #define MAVLINK_MSG_ID_91_CRC 63
  23. #if MAVLINK_COMMAND_24BIT
  24. #define MAVLINK_MESSAGE_INFO_HIL_CONTROLS { \
  25. 91, \
  26. "HIL_CONTROLS", \
  27. 11, \
  28. { { "time_usec", NULL, MAVLINK_TYPE_UINT64_T, 0, 0, offsetof(mavlink_hil_controls_t, time_usec) }, \
  29. { "roll_ailerons", NULL, MAVLINK_TYPE_FLOAT, 0, 8, offsetof(mavlink_hil_controls_t, roll_ailerons) }, \
  30. { "pitch_elevator", NULL, MAVLINK_TYPE_FLOAT, 0, 12, offsetof(mavlink_hil_controls_t, pitch_elevator) }, \
  31. { "yaw_rudder", NULL, MAVLINK_TYPE_FLOAT, 0, 16, offsetof(mavlink_hil_controls_t, yaw_rudder) }, \
  32. { "throttle", NULL, MAVLINK_TYPE_FLOAT, 0, 20, offsetof(mavlink_hil_controls_t, throttle) }, \
  33. { "aux1", NULL, MAVLINK_TYPE_FLOAT, 0, 24, offsetof(mavlink_hil_controls_t, aux1) }, \
  34. { "aux2", NULL, MAVLINK_TYPE_FLOAT, 0, 28, offsetof(mavlink_hil_controls_t, aux2) }, \
  35. { "aux3", NULL, MAVLINK_TYPE_FLOAT, 0, 32, offsetof(mavlink_hil_controls_t, aux3) }, \
  36. { "aux4", NULL, MAVLINK_TYPE_FLOAT, 0, 36, offsetof(mavlink_hil_controls_t, aux4) }, \
  37. { "mode", NULL, MAVLINK_TYPE_UINT8_T, 0, 40, offsetof(mavlink_hil_controls_t, mode) }, \
  38. { "nav_mode", NULL, MAVLINK_TYPE_UINT8_T, 0, 41, offsetof(mavlink_hil_controls_t, nav_mode) }, \
  39. } \
  40. }
  41. #else
  42. #define MAVLINK_MESSAGE_INFO_HIL_CONTROLS { \
  43. "HIL_CONTROLS", \
  44. 11, \
  45. { { "time_usec", NULL, MAVLINK_TYPE_UINT64_T, 0, 0, offsetof(mavlink_hil_controls_t, time_usec) }, \
  46. { "roll_ailerons", NULL, MAVLINK_TYPE_FLOAT, 0, 8, offsetof(mavlink_hil_controls_t, roll_ailerons) }, \
  47. { "pitch_elevator", NULL, MAVLINK_TYPE_FLOAT, 0, 12, offsetof(mavlink_hil_controls_t, pitch_elevator) }, \
  48. { "yaw_rudder", NULL, MAVLINK_TYPE_FLOAT, 0, 16, offsetof(mavlink_hil_controls_t, yaw_rudder) }, \
  49. { "throttle", NULL, MAVLINK_TYPE_FLOAT, 0, 20, offsetof(mavlink_hil_controls_t, throttle) }, \
  50. { "aux1", NULL, MAVLINK_TYPE_FLOAT, 0, 24, offsetof(mavlink_hil_controls_t, aux1) }, \
  51. { "aux2", NULL, MAVLINK_TYPE_FLOAT, 0, 28, offsetof(mavlink_hil_controls_t, aux2) }, \
  52. { "aux3", NULL, MAVLINK_TYPE_FLOAT, 0, 32, offsetof(mavlink_hil_controls_t, aux3) }, \
  53. { "aux4", NULL, MAVLINK_TYPE_FLOAT, 0, 36, offsetof(mavlink_hil_controls_t, aux4) }, \
  54. { "mode", NULL, MAVLINK_TYPE_UINT8_T, 0, 40, offsetof(mavlink_hil_controls_t, mode) }, \
  55. { "nav_mode", NULL, MAVLINK_TYPE_UINT8_T, 0, 41, offsetof(mavlink_hil_controls_t, nav_mode) }, \
  56. } \
  57. }
  58. #endif
  59. /**
  60. * @brief Pack a hil_controls message
  61. * @param system_id ID of this system
  62. * @param component_id ID of this component (e.g. 200 for IMU)
  63. * @param msg The MAVLink message to compress the data into
  64. *
  65. * @param time_usec [us] Timestamp (UNIX Epoch time or time since system boot). The receiving end can infer timestamp format (since 1.1.1970 or since system boot) by checking for the magnitude of the number.
  66. * @param roll_ailerons Control output -1 .. 1
  67. * @param pitch_elevator Control output -1 .. 1
  68. * @param yaw_rudder Control output -1 .. 1
  69. * @param throttle Throttle 0 .. 1
  70. * @param aux1 Aux 1, -1 .. 1
  71. * @param aux2 Aux 2, -1 .. 1
  72. * @param aux3 Aux 3, -1 .. 1
  73. * @param aux4 Aux 4, -1 .. 1
  74. * @param mode System mode.
  75. * @param nav_mode Navigation mode (MAV_NAV_MODE)
  76. * @return length of the message in bytes (excluding serial stream start sign)
  77. */
  78. static inline uint16_t mavlink_msg_hil_controls_pack(uint8_t system_id, uint8_t component_id, mavlink_message_t* msg,
  79. uint64_t time_usec, float roll_ailerons, float pitch_elevator, float yaw_rudder, float throttle, float aux1, float aux2, float aux3, float aux4, uint8_t mode, uint8_t nav_mode)
  80. {
  81. #if MAVLINK_NEED_BYTE_SWAP || !MAVLINK_ALIGNED_FIELDS
  82. char buf[MAVLINK_MSG_ID_HIL_CONTROLS_LEN];
  83. _mav_put_uint64_t(buf, 0, time_usec);
  84. _mav_put_float(buf, 8, roll_ailerons);
  85. _mav_put_float(buf, 12, pitch_elevator);
  86. _mav_put_float(buf, 16, yaw_rudder);
  87. _mav_put_float(buf, 20, throttle);
  88. _mav_put_float(buf, 24, aux1);
  89. _mav_put_float(buf, 28, aux2);
  90. _mav_put_float(buf, 32, aux3);
  91. _mav_put_float(buf, 36, aux4);
  92. _mav_put_uint8_t(buf, 40, mode);
  93. _mav_put_uint8_t(buf, 41, nav_mode);
  94. memcpy(_MAV_PAYLOAD_NON_CONST(msg), buf, MAVLINK_MSG_ID_HIL_CONTROLS_LEN);
  95. #else
  96. mavlink_hil_controls_t packet;
  97. packet.time_usec = time_usec;
  98. packet.roll_ailerons = roll_ailerons;
  99. packet.pitch_elevator = pitch_elevator;
  100. packet.yaw_rudder = yaw_rudder;
  101. packet.throttle = throttle;
  102. packet.aux1 = aux1;
  103. packet.aux2 = aux2;
  104. packet.aux3 = aux3;
  105. packet.aux4 = aux4;
  106. packet.mode = mode;
  107. packet.nav_mode = nav_mode;
  108. memcpy(_MAV_PAYLOAD_NON_CONST(msg), &packet, MAVLINK_MSG_ID_HIL_CONTROLS_LEN);
  109. #endif
  110. msg->msgid = MAVLINK_MSG_ID_HIL_CONTROLS;
  111. return mavlink_finalize_message(msg, system_id, component_id, MAVLINK_MSG_ID_HIL_CONTROLS_MIN_LEN, MAVLINK_MSG_ID_HIL_CONTROLS_LEN, MAVLINK_MSG_ID_HIL_CONTROLS_CRC);
  112. }
  113. /**
  114. * @brief Pack a hil_controls message on a channel
  115. * @param system_id ID of this system
  116. * @param component_id ID of this component (e.g. 200 for IMU)
  117. * @param chan The MAVLink channel this message will be sent over
  118. * @param msg The MAVLink message to compress the data into
  119. * @param time_usec [us] Timestamp (UNIX Epoch time or time since system boot). The receiving end can infer timestamp format (since 1.1.1970 or since system boot) by checking for the magnitude of the number.
  120. * @param roll_ailerons Control output -1 .. 1
  121. * @param pitch_elevator Control output -1 .. 1
  122. * @param yaw_rudder Control output -1 .. 1
  123. * @param throttle Throttle 0 .. 1
  124. * @param aux1 Aux 1, -1 .. 1
  125. * @param aux2 Aux 2, -1 .. 1
  126. * @param aux3 Aux 3, -1 .. 1
  127. * @param aux4 Aux 4, -1 .. 1
  128. * @param mode System mode.
  129. * @param nav_mode Navigation mode (MAV_NAV_MODE)
  130. * @return length of the message in bytes (excluding serial stream start sign)
  131. */
  132. static inline uint16_t mavlink_msg_hil_controls_pack_chan(uint8_t system_id, uint8_t component_id, uint8_t chan,
  133. mavlink_message_t* msg,
  134. uint64_t time_usec,float roll_ailerons,float pitch_elevator,float yaw_rudder,float throttle,float aux1,float aux2,float aux3,float aux4,uint8_t mode,uint8_t nav_mode)
  135. {
  136. #if MAVLINK_NEED_BYTE_SWAP || !MAVLINK_ALIGNED_FIELDS
  137. char buf[MAVLINK_MSG_ID_HIL_CONTROLS_LEN];
  138. _mav_put_uint64_t(buf, 0, time_usec);
  139. _mav_put_float(buf, 8, roll_ailerons);
  140. _mav_put_float(buf, 12, pitch_elevator);
  141. _mav_put_float(buf, 16, yaw_rudder);
  142. _mav_put_float(buf, 20, throttle);
  143. _mav_put_float(buf, 24, aux1);
  144. _mav_put_float(buf, 28, aux2);
  145. _mav_put_float(buf, 32, aux3);
  146. _mav_put_float(buf, 36, aux4);
  147. _mav_put_uint8_t(buf, 40, mode);
  148. _mav_put_uint8_t(buf, 41, nav_mode);
  149. memcpy(_MAV_PAYLOAD_NON_CONST(msg), buf, MAVLINK_MSG_ID_HIL_CONTROLS_LEN);
  150. #else
  151. mavlink_hil_controls_t packet;
  152. packet.time_usec = time_usec;
  153. packet.roll_ailerons = roll_ailerons;
  154. packet.pitch_elevator = pitch_elevator;
  155. packet.yaw_rudder = yaw_rudder;
  156. packet.throttle = throttle;
  157. packet.aux1 = aux1;
  158. packet.aux2 = aux2;
  159. packet.aux3 = aux3;
  160. packet.aux4 = aux4;
  161. packet.mode = mode;
  162. packet.nav_mode = nav_mode;
  163. memcpy(_MAV_PAYLOAD_NON_CONST(msg), &packet, MAVLINK_MSG_ID_HIL_CONTROLS_LEN);
  164. #endif
  165. msg->msgid = MAVLINK_MSG_ID_HIL_CONTROLS;
  166. return mavlink_finalize_message_chan(msg, system_id, component_id, chan, MAVLINK_MSG_ID_HIL_CONTROLS_MIN_LEN, MAVLINK_MSG_ID_HIL_CONTROLS_LEN, MAVLINK_MSG_ID_HIL_CONTROLS_CRC);
  167. }
  168. /**
  169. * @brief Encode a hil_controls struct
  170. *
  171. * @param system_id ID of this system
  172. * @param component_id ID of this component (e.g. 200 for IMU)
  173. * @param msg The MAVLink message to compress the data into
  174. * @param hil_controls C-struct to read the message contents from
  175. */
  176. static inline uint16_t mavlink_msg_hil_controls_encode(uint8_t system_id, uint8_t component_id, mavlink_message_t* msg, const mavlink_hil_controls_t* hil_controls)
  177. {
  178. return mavlink_msg_hil_controls_pack(system_id, component_id, msg, hil_controls->time_usec, hil_controls->roll_ailerons, hil_controls->pitch_elevator, hil_controls->yaw_rudder, hil_controls->throttle, hil_controls->aux1, hil_controls->aux2, hil_controls->aux3, hil_controls->aux4, hil_controls->mode, hil_controls->nav_mode);
  179. }
  180. /**
  181. * @brief Encode a hil_controls struct on a channel
  182. *
  183. * @param system_id ID of this system
  184. * @param component_id ID of this component (e.g. 200 for IMU)
  185. * @param chan The MAVLink channel this message will be sent over
  186. * @param msg The MAVLink message to compress the data into
  187. * @param hil_controls C-struct to read the message contents from
  188. */
  189. static inline uint16_t mavlink_msg_hil_controls_encode_chan(uint8_t system_id, uint8_t component_id, uint8_t chan, mavlink_message_t* msg, const mavlink_hil_controls_t* hil_controls)
  190. {
  191. return mavlink_msg_hil_controls_pack_chan(system_id, component_id, chan, msg, hil_controls->time_usec, hil_controls->roll_ailerons, hil_controls->pitch_elevator, hil_controls->yaw_rudder, hil_controls->throttle, hil_controls->aux1, hil_controls->aux2, hil_controls->aux3, hil_controls->aux4, hil_controls->mode, hil_controls->nav_mode);
  192. }
  193. /**
  194. * @brief Send a hil_controls message
  195. * @param chan MAVLink channel to send the message
  196. *
  197. * @param time_usec [us] Timestamp (UNIX Epoch time or time since system boot). The receiving end can infer timestamp format (since 1.1.1970 or since system boot) by checking for the magnitude of the number.
  198. * @param roll_ailerons Control output -1 .. 1
  199. * @param pitch_elevator Control output -1 .. 1
  200. * @param yaw_rudder Control output -1 .. 1
  201. * @param throttle Throttle 0 .. 1
  202. * @param aux1 Aux 1, -1 .. 1
  203. * @param aux2 Aux 2, -1 .. 1
  204. * @param aux3 Aux 3, -1 .. 1
  205. * @param aux4 Aux 4, -1 .. 1
  206. * @param mode System mode.
  207. * @param nav_mode Navigation mode (MAV_NAV_MODE)
  208. */
  209. #ifdef MAVLINK_USE_CONVENIENCE_FUNCTIONS
  210. static inline void mavlink_msg_hil_controls_send(mavlink_channel_t chan, uint64_t time_usec, float roll_ailerons, float pitch_elevator, float yaw_rudder, float throttle, float aux1, float aux2, float aux3, float aux4, uint8_t mode, uint8_t nav_mode)
  211. {
  212. #if MAVLINK_NEED_BYTE_SWAP || !MAVLINK_ALIGNED_FIELDS
  213. char buf[MAVLINK_MSG_ID_HIL_CONTROLS_LEN];
  214. _mav_put_uint64_t(buf, 0, time_usec);
  215. _mav_put_float(buf, 8, roll_ailerons);
  216. _mav_put_float(buf, 12, pitch_elevator);
  217. _mav_put_float(buf, 16, yaw_rudder);
  218. _mav_put_float(buf, 20, throttle);
  219. _mav_put_float(buf, 24, aux1);
  220. _mav_put_float(buf, 28, aux2);
  221. _mav_put_float(buf, 32, aux3);
  222. _mav_put_float(buf, 36, aux4);
  223. _mav_put_uint8_t(buf, 40, mode);
  224. _mav_put_uint8_t(buf, 41, nav_mode);
  225. _mav_finalize_message_chan_send(chan, MAVLINK_MSG_ID_HIL_CONTROLS, buf, MAVLINK_MSG_ID_HIL_CONTROLS_MIN_LEN, MAVLINK_MSG_ID_HIL_CONTROLS_LEN, MAVLINK_MSG_ID_HIL_CONTROLS_CRC);
  226. #else
  227. mavlink_hil_controls_t packet;
  228. packet.time_usec = time_usec;
  229. packet.roll_ailerons = roll_ailerons;
  230. packet.pitch_elevator = pitch_elevator;
  231. packet.yaw_rudder = yaw_rudder;
  232. packet.throttle = throttle;
  233. packet.aux1 = aux1;
  234. packet.aux2 = aux2;
  235. packet.aux3 = aux3;
  236. packet.aux4 = aux4;
  237. packet.mode = mode;
  238. packet.nav_mode = nav_mode;
  239. _mav_finalize_message_chan_send(chan, MAVLINK_MSG_ID_HIL_CONTROLS, (const char *)&packet, MAVLINK_MSG_ID_HIL_CONTROLS_MIN_LEN, MAVLINK_MSG_ID_HIL_CONTROLS_LEN, MAVLINK_MSG_ID_HIL_CONTROLS_CRC);
  240. #endif
  241. }
  242. /**
  243. * @brief Send a hil_controls message
  244. * @param chan MAVLink channel to send the message
  245. * @param struct The MAVLink struct to serialize
  246. */
  247. static inline void mavlink_msg_hil_controls_send_struct(mavlink_channel_t chan, const mavlink_hil_controls_t* hil_controls)
  248. {
  249. #if MAVLINK_NEED_BYTE_SWAP || !MAVLINK_ALIGNED_FIELDS
  250. mavlink_msg_hil_controls_send(chan, hil_controls->time_usec, hil_controls->roll_ailerons, hil_controls->pitch_elevator, hil_controls->yaw_rudder, hil_controls->throttle, hil_controls->aux1, hil_controls->aux2, hil_controls->aux3, hil_controls->aux4, hil_controls->mode, hil_controls->nav_mode);
  251. #else
  252. _mav_finalize_message_chan_send(chan, MAVLINK_MSG_ID_HIL_CONTROLS, (const char *)hil_controls, MAVLINK_MSG_ID_HIL_CONTROLS_MIN_LEN, MAVLINK_MSG_ID_HIL_CONTROLS_LEN, MAVLINK_MSG_ID_HIL_CONTROLS_CRC);
  253. #endif
  254. }
  255. #if MAVLINK_MSG_ID_HIL_CONTROLS_LEN <= MAVLINK_MAX_PAYLOAD_LEN
  256. /*
  257. This variant of _send() can be used to save stack space by re-using
  258. memory from the receive buffer. The caller provides a
  259. mavlink_message_t which is the size of a full mavlink message. This
  260. is usually the receive buffer for the channel, and allows a reply to an
  261. incoming message with minimum stack space usage.
  262. */
  263. static inline void mavlink_msg_hil_controls_send_buf(mavlink_message_t *msgbuf, mavlink_channel_t chan, uint64_t time_usec, float roll_ailerons, float pitch_elevator, float yaw_rudder, float throttle, float aux1, float aux2, float aux3, float aux4, uint8_t mode, uint8_t nav_mode)
  264. {
  265. #if MAVLINK_NEED_BYTE_SWAP || !MAVLINK_ALIGNED_FIELDS
  266. char *buf = (char *)msgbuf;
  267. _mav_put_uint64_t(buf, 0, time_usec);
  268. _mav_put_float(buf, 8, roll_ailerons);
  269. _mav_put_float(buf, 12, pitch_elevator);
  270. _mav_put_float(buf, 16, yaw_rudder);
  271. _mav_put_float(buf, 20, throttle);
  272. _mav_put_float(buf, 24, aux1);
  273. _mav_put_float(buf, 28, aux2);
  274. _mav_put_float(buf, 32, aux3);
  275. _mav_put_float(buf, 36, aux4);
  276. _mav_put_uint8_t(buf, 40, mode);
  277. _mav_put_uint8_t(buf, 41, nav_mode);
  278. _mav_finalize_message_chan_send(chan, MAVLINK_MSG_ID_HIL_CONTROLS, buf, MAVLINK_MSG_ID_HIL_CONTROLS_MIN_LEN, MAVLINK_MSG_ID_HIL_CONTROLS_LEN, MAVLINK_MSG_ID_HIL_CONTROLS_CRC);
  279. #else
  280. mavlink_hil_controls_t *packet = (mavlink_hil_controls_t *)msgbuf;
  281. packet->time_usec = time_usec;
  282. packet->roll_ailerons = roll_ailerons;
  283. packet->pitch_elevator = pitch_elevator;
  284. packet->yaw_rudder = yaw_rudder;
  285. packet->throttle = throttle;
  286. packet->aux1 = aux1;
  287. packet->aux2 = aux2;
  288. packet->aux3 = aux3;
  289. packet->aux4 = aux4;
  290. packet->mode = mode;
  291. packet->nav_mode = nav_mode;
  292. _mav_finalize_message_chan_send(chan, MAVLINK_MSG_ID_HIL_CONTROLS, (const char *)packet, MAVLINK_MSG_ID_HIL_CONTROLS_MIN_LEN, MAVLINK_MSG_ID_HIL_CONTROLS_LEN, MAVLINK_MSG_ID_HIL_CONTROLS_CRC);
  293. #endif
  294. }
  295. #endif
  296. #endif
  297. // MESSAGE HIL_CONTROLS UNPACKING
  298. /**
  299. * @brief Get field time_usec from hil_controls message
  300. *
  301. * @return [us] Timestamp (UNIX Epoch time or time since system boot). The receiving end can infer timestamp format (since 1.1.1970 or since system boot) by checking for the magnitude of the number.
  302. */
  303. static inline uint64_t mavlink_msg_hil_controls_get_time_usec(const mavlink_message_t* msg)
  304. {
  305. return _MAV_RETURN_uint64_t(msg, 0);
  306. }
  307. /**
  308. * @brief Get field roll_ailerons from hil_controls message
  309. *
  310. * @return Control output -1 .. 1
  311. */
  312. static inline float mavlink_msg_hil_controls_get_roll_ailerons(const mavlink_message_t* msg)
  313. {
  314. return _MAV_RETURN_float(msg, 8);
  315. }
  316. /**
  317. * @brief Get field pitch_elevator from hil_controls message
  318. *
  319. * @return Control output -1 .. 1
  320. */
  321. static inline float mavlink_msg_hil_controls_get_pitch_elevator(const mavlink_message_t* msg)
  322. {
  323. return _MAV_RETURN_float(msg, 12);
  324. }
  325. /**
  326. * @brief Get field yaw_rudder from hil_controls message
  327. *
  328. * @return Control output -1 .. 1
  329. */
  330. static inline float mavlink_msg_hil_controls_get_yaw_rudder(const mavlink_message_t* msg)
  331. {
  332. return _MAV_RETURN_float(msg, 16);
  333. }
  334. /**
  335. * @brief Get field throttle from hil_controls message
  336. *
  337. * @return Throttle 0 .. 1
  338. */
  339. static inline float mavlink_msg_hil_controls_get_throttle(const mavlink_message_t* msg)
  340. {
  341. return _MAV_RETURN_float(msg, 20);
  342. }
  343. /**
  344. * @brief Get field aux1 from hil_controls message
  345. *
  346. * @return Aux 1, -1 .. 1
  347. */
  348. static inline float mavlink_msg_hil_controls_get_aux1(const mavlink_message_t* msg)
  349. {
  350. return _MAV_RETURN_float(msg, 24);
  351. }
  352. /**
  353. * @brief Get field aux2 from hil_controls message
  354. *
  355. * @return Aux 2, -1 .. 1
  356. */
  357. static inline float mavlink_msg_hil_controls_get_aux2(const mavlink_message_t* msg)
  358. {
  359. return _MAV_RETURN_float(msg, 28);
  360. }
  361. /**
  362. * @brief Get field aux3 from hil_controls message
  363. *
  364. * @return Aux 3, -1 .. 1
  365. */
  366. static inline float mavlink_msg_hil_controls_get_aux3(const mavlink_message_t* msg)
  367. {
  368. return _MAV_RETURN_float(msg, 32);
  369. }
  370. /**
  371. * @brief Get field aux4 from hil_controls message
  372. *
  373. * @return Aux 4, -1 .. 1
  374. */
  375. static inline float mavlink_msg_hil_controls_get_aux4(const mavlink_message_t* msg)
  376. {
  377. return _MAV_RETURN_float(msg, 36);
  378. }
  379. /**
  380. * @brief Get field mode from hil_controls message
  381. *
  382. * @return System mode.
  383. */
  384. static inline uint8_t mavlink_msg_hil_controls_get_mode(const mavlink_message_t* msg)
  385. {
  386. return _MAV_RETURN_uint8_t(msg, 40);
  387. }
  388. /**
  389. * @brief Get field nav_mode from hil_controls message
  390. *
  391. * @return Navigation mode (MAV_NAV_MODE)
  392. */
  393. static inline uint8_t mavlink_msg_hil_controls_get_nav_mode(const mavlink_message_t* msg)
  394. {
  395. return _MAV_RETURN_uint8_t(msg, 41);
  396. }
  397. /**
  398. * @brief Decode a hil_controls message into a struct
  399. *
  400. * @param msg The message to decode
  401. * @param hil_controls C-struct to decode the message contents into
  402. */
  403. static inline void mavlink_msg_hil_controls_decode(const mavlink_message_t* msg, mavlink_hil_controls_t* hil_controls)
  404. {
  405. #if MAVLINK_NEED_BYTE_SWAP || !MAVLINK_ALIGNED_FIELDS
  406. hil_controls->time_usec = mavlink_msg_hil_controls_get_time_usec(msg);
  407. hil_controls->roll_ailerons = mavlink_msg_hil_controls_get_roll_ailerons(msg);
  408. hil_controls->pitch_elevator = mavlink_msg_hil_controls_get_pitch_elevator(msg);
  409. hil_controls->yaw_rudder = mavlink_msg_hil_controls_get_yaw_rudder(msg);
  410. hil_controls->throttle = mavlink_msg_hil_controls_get_throttle(msg);
  411. hil_controls->aux1 = mavlink_msg_hil_controls_get_aux1(msg);
  412. hil_controls->aux2 = mavlink_msg_hil_controls_get_aux2(msg);
  413. hil_controls->aux3 = mavlink_msg_hil_controls_get_aux3(msg);
  414. hil_controls->aux4 = mavlink_msg_hil_controls_get_aux4(msg);
  415. hil_controls->mode = mavlink_msg_hil_controls_get_mode(msg);
  416. hil_controls->nav_mode = mavlink_msg_hil_controls_get_nav_mode(msg);
  417. #else
  418. uint8_t len = msg->len < MAVLINK_MSG_ID_HIL_CONTROLS_LEN? msg->len : MAVLINK_MSG_ID_HIL_CONTROLS_LEN;
  419. memset(hil_controls, 0, MAVLINK_MSG_ID_HIL_CONTROLS_LEN);
  420. memcpy(hil_controls, _MAV_PAYLOAD(msg), len);
  421. #endif
  422. }