mavlink_msg_hil_controls.h 23 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540
  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
  115. * @param system_id ID of this system
  116. * @param component_id ID of this component (e.g. 200 for IMU)
  117. * @param status MAVLink status structure
  118. * @param msg The MAVLink message to compress the data into
  119. *
  120. * @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.
  121. * @param roll_ailerons Control output -1 .. 1
  122. * @param pitch_elevator Control output -1 .. 1
  123. * @param yaw_rudder Control output -1 .. 1
  124. * @param throttle Throttle 0 .. 1
  125. * @param aux1 Aux 1, -1 .. 1
  126. * @param aux2 Aux 2, -1 .. 1
  127. * @param aux3 Aux 3, -1 .. 1
  128. * @param aux4 Aux 4, -1 .. 1
  129. * @param mode System mode.
  130. * @param nav_mode Navigation mode (MAV_NAV_MODE)
  131. * @return length of the message in bytes (excluding serial stream start sign)
  132. */
  133. static inline uint16_t mavlink_msg_hil_controls_pack_status(uint8_t system_id, uint8_t component_id, mavlink_status_t *_status, 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. #if MAVLINK_CRC_EXTRA
  167. return mavlink_finalize_message_buffer(msg, system_id, component_id, _status, MAVLINK_MSG_ID_HIL_CONTROLS_MIN_LEN, MAVLINK_MSG_ID_HIL_CONTROLS_LEN, MAVLINK_MSG_ID_HIL_CONTROLS_CRC);
  168. #else
  169. return mavlink_finalize_message_buffer(msg, system_id, component_id, _status, MAVLINK_MSG_ID_HIL_CONTROLS_MIN_LEN, MAVLINK_MSG_ID_HIL_CONTROLS_LEN);
  170. #endif
  171. }
  172. /**
  173. * @brief Pack a hil_controls message on a channel
  174. * @param system_id ID of this system
  175. * @param component_id ID of this component (e.g. 200 for IMU)
  176. * @param chan The MAVLink channel this message will be sent over
  177. * @param msg The MAVLink message to compress the data into
  178. * @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.
  179. * @param roll_ailerons Control output -1 .. 1
  180. * @param pitch_elevator Control output -1 .. 1
  181. * @param yaw_rudder Control output -1 .. 1
  182. * @param throttle Throttle 0 .. 1
  183. * @param aux1 Aux 1, -1 .. 1
  184. * @param aux2 Aux 2, -1 .. 1
  185. * @param aux3 Aux 3, -1 .. 1
  186. * @param aux4 Aux 4, -1 .. 1
  187. * @param mode System mode.
  188. * @param nav_mode Navigation mode (MAV_NAV_MODE)
  189. * @return length of the message in bytes (excluding serial stream start sign)
  190. */
  191. static inline uint16_t mavlink_msg_hil_controls_pack_chan(uint8_t system_id, uint8_t component_id, uint8_t chan,
  192. mavlink_message_t* msg,
  193. 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)
  194. {
  195. #if MAVLINK_NEED_BYTE_SWAP || !MAVLINK_ALIGNED_FIELDS
  196. char buf[MAVLINK_MSG_ID_HIL_CONTROLS_LEN];
  197. _mav_put_uint64_t(buf, 0, time_usec);
  198. _mav_put_float(buf, 8, roll_ailerons);
  199. _mav_put_float(buf, 12, pitch_elevator);
  200. _mav_put_float(buf, 16, yaw_rudder);
  201. _mav_put_float(buf, 20, throttle);
  202. _mav_put_float(buf, 24, aux1);
  203. _mav_put_float(buf, 28, aux2);
  204. _mav_put_float(buf, 32, aux3);
  205. _mav_put_float(buf, 36, aux4);
  206. _mav_put_uint8_t(buf, 40, mode);
  207. _mav_put_uint8_t(buf, 41, nav_mode);
  208. memcpy(_MAV_PAYLOAD_NON_CONST(msg), buf, MAVLINK_MSG_ID_HIL_CONTROLS_LEN);
  209. #else
  210. mavlink_hil_controls_t packet;
  211. packet.time_usec = time_usec;
  212. packet.roll_ailerons = roll_ailerons;
  213. packet.pitch_elevator = pitch_elevator;
  214. packet.yaw_rudder = yaw_rudder;
  215. packet.throttle = throttle;
  216. packet.aux1 = aux1;
  217. packet.aux2 = aux2;
  218. packet.aux3 = aux3;
  219. packet.aux4 = aux4;
  220. packet.mode = mode;
  221. packet.nav_mode = nav_mode;
  222. memcpy(_MAV_PAYLOAD_NON_CONST(msg), &packet, MAVLINK_MSG_ID_HIL_CONTROLS_LEN);
  223. #endif
  224. msg->msgid = MAVLINK_MSG_ID_HIL_CONTROLS;
  225. 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);
  226. }
  227. /**
  228. * @brief Encode a hil_controls struct
  229. *
  230. * @param system_id ID of this system
  231. * @param component_id ID of this component (e.g. 200 for IMU)
  232. * @param msg The MAVLink message to compress the data into
  233. * @param hil_controls C-struct to read the message contents from
  234. */
  235. 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)
  236. {
  237. 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);
  238. }
  239. /**
  240. * @brief Encode a hil_controls struct on a channel
  241. *
  242. * @param system_id ID of this system
  243. * @param component_id ID of this component (e.g. 200 for IMU)
  244. * @param chan The MAVLink channel this message will be sent over
  245. * @param msg The MAVLink message to compress the data into
  246. * @param hil_controls C-struct to read the message contents from
  247. */
  248. 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)
  249. {
  250. 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);
  251. }
  252. /**
  253. * @brief Encode a hil_controls struct with provided status structure
  254. *
  255. * @param system_id ID of this system
  256. * @param component_id ID of this component (e.g. 200 for IMU)
  257. * @param status MAVLink status structure
  258. * @param msg The MAVLink message to compress the data into
  259. * @param hil_controls C-struct to read the message contents from
  260. */
  261. static inline uint16_t mavlink_msg_hil_controls_encode_status(uint8_t system_id, uint8_t component_id, mavlink_status_t* _status, mavlink_message_t* msg, const mavlink_hil_controls_t* hil_controls)
  262. {
  263. return mavlink_msg_hil_controls_pack_status(system_id, component_id, _status, 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);
  264. }
  265. /**
  266. * @brief Send a hil_controls message
  267. * @param chan MAVLink channel to send the message
  268. *
  269. * @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.
  270. * @param roll_ailerons Control output -1 .. 1
  271. * @param pitch_elevator Control output -1 .. 1
  272. * @param yaw_rudder Control output -1 .. 1
  273. * @param throttle Throttle 0 .. 1
  274. * @param aux1 Aux 1, -1 .. 1
  275. * @param aux2 Aux 2, -1 .. 1
  276. * @param aux3 Aux 3, -1 .. 1
  277. * @param aux4 Aux 4, -1 .. 1
  278. * @param mode System mode.
  279. * @param nav_mode Navigation mode (MAV_NAV_MODE)
  280. */
  281. #ifdef MAVLINK_USE_CONVENIENCE_FUNCTIONS
  282. 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)
  283. {
  284. #if MAVLINK_NEED_BYTE_SWAP || !MAVLINK_ALIGNED_FIELDS
  285. char buf[MAVLINK_MSG_ID_HIL_CONTROLS_LEN];
  286. _mav_put_uint64_t(buf, 0, time_usec);
  287. _mav_put_float(buf, 8, roll_ailerons);
  288. _mav_put_float(buf, 12, pitch_elevator);
  289. _mav_put_float(buf, 16, yaw_rudder);
  290. _mav_put_float(buf, 20, throttle);
  291. _mav_put_float(buf, 24, aux1);
  292. _mav_put_float(buf, 28, aux2);
  293. _mav_put_float(buf, 32, aux3);
  294. _mav_put_float(buf, 36, aux4);
  295. _mav_put_uint8_t(buf, 40, mode);
  296. _mav_put_uint8_t(buf, 41, nav_mode);
  297. _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);
  298. #else
  299. mavlink_hil_controls_t packet;
  300. packet.time_usec = time_usec;
  301. packet.roll_ailerons = roll_ailerons;
  302. packet.pitch_elevator = pitch_elevator;
  303. packet.yaw_rudder = yaw_rudder;
  304. packet.throttle = throttle;
  305. packet.aux1 = aux1;
  306. packet.aux2 = aux2;
  307. packet.aux3 = aux3;
  308. packet.aux4 = aux4;
  309. packet.mode = mode;
  310. packet.nav_mode = nav_mode;
  311. _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);
  312. #endif
  313. }
  314. /**
  315. * @brief Send a hil_controls message
  316. * @param chan MAVLink channel to send the message
  317. * @param struct The MAVLink struct to serialize
  318. */
  319. static inline void mavlink_msg_hil_controls_send_struct(mavlink_channel_t chan, const mavlink_hil_controls_t* hil_controls)
  320. {
  321. #if MAVLINK_NEED_BYTE_SWAP || !MAVLINK_ALIGNED_FIELDS
  322. 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);
  323. #else
  324. _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);
  325. #endif
  326. }
  327. #if MAVLINK_MSG_ID_HIL_CONTROLS_LEN <= MAVLINK_MAX_PAYLOAD_LEN
  328. /*
  329. This variant of _send() can be used to save stack space by re-using
  330. memory from the receive buffer. The caller provides a
  331. mavlink_message_t which is the size of a full mavlink message. This
  332. is usually the receive buffer for the channel, and allows a reply to an
  333. incoming message with minimum stack space usage.
  334. */
  335. 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)
  336. {
  337. #if MAVLINK_NEED_BYTE_SWAP || !MAVLINK_ALIGNED_FIELDS
  338. char *buf = (char *)msgbuf;
  339. _mav_put_uint64_t(buf, 0, time_usec);
  340. _mav_put_float(buf, 8, roll_ailerons);
  341. _mav_put_float(buf, 12, pitch_elevator);
  342. _mav_put_float(buf, 16, yaw_rudder);
  343. _mav_put_float(buf, 20, throttle);
  344. _mav_put_float(buf, 24, aux1);
  345. _mav_put_float(buf, 28, aux2);
  346. _mav_put_float(buf, 32, aux3);
  347. _mav_put_float(buf, 36, aux4);
  348. _mav_put_uint8_t(buf, 40, mode);
  349. _mav_put_uint8_t(buf, 41, nav_mode);
  350. _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);
  351. #else
  352. mavlink_hil_controls_t *packet = (mavlink_hil_controls_t *)msgbuf;
  353. packet->time_usec = time_usec;
  354. packet->roll_ailerons = roll_ailerons;
  355. packet->pitch_elevator = pitch_elevator;
  356. packet->yaw_rudder = yaw_rudder;
  357. packet->throttle = throttle;
  358. packet->aux1 = aux1;
  359. packet->aux2 = aux2;
  360. packet->aux3 = aux3;
  361. packet->aux4 = aux4;
  362. packet->mode = mode;
  363. packet->nav_mode = nav_mode;
  364. _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);
  365. #endif
  366. }
  367. #endif
  368. #endif
  369. // MESSAGE HIL_CONTROLS UNPACKING
  370. /**
  371. * @brief Get field time_usec from hil_controls message
  372. *
  373. * @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.
  374. */
  375. static inline uint64_t mavlink_msg_hil_controls_get_time_usec(const mavlink_message_t* msg)
  376. {
  377. return _MAV_RETURN_uint64_t(msg, 0);
  378. }
  379. /**
  380. * @brief Get field roll_ailerons from hil_controls message
  381. *
  382. * @return Control output -1 .. 1
  383. */
  384. static inline float mavlink_msg_hil_controls_get_roll_ailerons(const mavlink_message_t* msg)
  385. {
  386. return _MAV_RETURN_float(msg, 8);
  387. }
  388. /**
  389. * @brief Get field pitch_elevator from hil_controls message
  390. *
  391. * @return Control output -1 .. 1
  392. */
  393. static inline float mavlink_msg_hil_controls_get_pitch_elevator(const mavlink_message_t* msg)
  394. {
  395. return _MAV_RETURN_float(msg, 12);
  396. }
  397. /**
  398. * @brief Get field yaw_rudder from hil_controls message
  399. *
  400. * @return Control output -1 .. 1
  401. */
  402. static inline float mavlink_msg_hil_controls_get_yaw_rudder(const mavlink_message_t* msg)
  403. {
  404. return _MAV_RETURN_float(msg, 16);
  405. }
  406. /**
  407. * @brief Get field throttle from hil_controls message
  408. *
  409. * @return Throttle 0 .. 1
  410. */
  411. static inline float mavlink_msg_hil_controls_get_throttle(const mavlink_message_t* msg)
  412. {
  413. return _MAV_RETURN_float(msg, 20);
  414. }
  415. /**
  416. * @brief Get field aux1 from hil_controls message
  417. *
  418. * @return Aux 1, -1 .. 1
  419. */
  420. static inline float mavlink_msg_hil_controls_get_aux1(const mavlink_message_t* msg)
  421. {
  422. return _MAV_RETURN_float(msg, 24);
  423. }
  424. /**
  425. * @brief Get field aux2 from hil_controls message
  426. *
  427. * @return Aux 2, -1 .. 1
  428. */
  429. static inline float mavlink_msg_hil_controls_get_aux2(const mavlink_message_t* msg)
  430. {
  431. return _MAV_RETURN_float(msg, 28);
  432. }
  433. /**
  434. * @brief Get field aux3 from hil_controls message
  435. *
  436. * @return Aux 3, -1 .. 1
  437. */
  438. static inline float mavlink_msg_hil_controls_get_aux3(const mavlink_message_t* msg)
  439. {
  440. return _MAV_RETURN_float(msg, 32);
  441. }
  442. /**
  443. * @brief Get field aux4 from hil_controls message
  444. *
  445. * @return Aux 4, -1 .. 1
  446. */
  447. static inline float mavlink_msg_hil_controls_get_aux4(const mavlink_message_t* msg)
  448. {
  449. return _MAV_RETURN_float(msg, 36);
  450. }
  451. /**
  452. * @brief Get field mode from hil_controls message
  453. *
  454. * @return System mode.
  455. */
  456. static inline uint8_t mavlink_msg_hil_controls_get_mode(const mavlink_message_t* msg)
  457. {
  458. return _MAV_RETURN_uint8_t(msg, 40);
  459. }
  460. /**
  461. * @brief Get field nav_mode from hil_controls message
  462. *
  463. * @return Navigation mode (MAV_NAV_MODE)
  464. */
  465. static inline uint8_t mavlink_msg_hil_controls_get_nav_mode(const mavlink_message_t* msg)
  466. {
  467. return _MAV_RETURN_uint8_t(msg, 41);
  468. }
  469. /**
  470. * @brief Decode a hil_controls message into a struct
  471. *
  472. * @param msg The message to decode
  473. * @param hil_controls C-struct to decode the message contents into
  474. */
  475. static inline void mavlink_msg_hil_controls_decode(const mavlink_message_t* msg, mavlink_hil_controls_t* hil_controls)
  476. {
  477. #if MAVLINK_NEED_BYTE_SWAP || !MAVLINK_ALIGNED_FIELDS
  478. hil_controls->time_usec = mavlink_msg_hil_controls_get_time_usec(msg);
  479. hil_controls->roll_ailerons = mavlink_msg_hil_controls_get_roll_ailerons(msg);
  480. hil_controls->pitch_elevator = mavlink_msg_hil_controls_get_pitch_elevator(msg);
  481. hil_controls->yaw_rudder = mavlink_msg_hil_controls_get_yaw_rudder(msg);
  482. hil_controls->throttle = mavlink_msg_hil_controls_get_throttle(msg);
  483. hil_controls->aux1 = mavlink_msg_hil_controls_get_aux1(msg);
  484. hil_controls->aux2 = mavlink_msg_hil_controls_get_aux2(msg);
  485. hil_controls->aux3 = mavlink_msg_hil_controls_get_aux3(msg);
  486. hil_controls->aux4 = mavlink_msg_hil_controls_get_aux4(msg);
  487. hil_controls->mode = mavlink_msg_hil_controls_get_mode(msg);
  488. hil_controls->nav_mode = mavlink_msg_hil_controls_get_nav_mode(msg);
  489. #else
  490. uint8_t len = msg->len < MAVLINK_MSG_ID_HIL_CONTROLS_LEN? msg->len : MAVLINK_MSG_ID_HIL_CONTROLS_LEN;
  491. memset(hil_controls, 0, MAVLINK_MSG_ID_HIL_CONTROLS_LEN);
  492. memcpy(hil_controls, _MAV_PAYLOAD(msg), len);
  493. #endif
  494. }