2
0

mavlink_msg_command_long_stamped.h 24 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513
  1. #pragma once
  2. // MESSAGE COMMAND_LONG_STAMPED PACKING
  3. #define MAVLINK_MSG_ID_COMMAND_LONG_STAMPED 79
  4. typedef struct __mavlink_command_long_stamped_t {
  5. uint64_t vehicle_timestamp; /*< Microseconds elapsed since vehicle boot*/
  6. uint32_t utc_time; /*< UTC time, seconds elapsed since 01.01.1970*/
  7. float param1; /*< Parameter 1, as defined by MAV_CMD enum.*/
  8. float param2; /*< Parameter 2, as defined by MAV_CMD enum.*/
  9. float param3; /*< Parameter 3, as defined by MAV_CMD enum.*/
  10. float param4; /*< Parameter 4, as defined by MAV_CMD enum.*/
  11. float param5; /*< Parameter 5, as defined by MAV_CMD enum.*/
  12. float param6; /*< Parameter 6, as defined by MAV_CMD enum.*/
  13. float param7; /*< Parameter 7, as defined by MAV_CMD enum.*/
  14. uint16_t command; /*< Command ID, as defined by MAV_CMD enum.*/
  15. uint8_t target_system; /*< System which should execute the command*/
  16. uint8_t target_component; /*< Component which should execute the command, 0 for all components*/
  17. uint8_t confirmation; /*< 0: First transmission of this command. 1-255: Confirmation transmissions (e.g. for kill command)*/
  18. } mavlink_command_long_stamped_t;
  19. #define MAVLINK_MSG_ID_COMMAND_LONG_STAMPED_LEN 45
  20. #define MAVLINK_MSG_ID_COMMAND_LONG_STAMPED_MIN_LEN 45
  21. #define MAVLINK_MSG_ID_79_LEN 45
  22. #define MAVLINK_MSG_ID_79_MIN_LEN 45
  23. #define MAVLINK_MSG_ID_COMMAND_LONG_STAMPED_CRC 102
  24. #define MAVLINK_MSG_ID_79_CRC 102
  25. #if MAVLINK_COMMAND_24BIT
  26. #define MAVLINK_MESSAGE_INFO_COMMAND_LONG_STAMPED { \
  27. 79, \
  28. "COMMAND_LONG_STAMPED", \
  29. 13, \
  30. { { "utc_time", NULL, MAVLINK_TYPE_UINT32_T, 0, 8, offsetof(mavlink_command_long_stamped_t, utc_time) }, \
  31. { "vehicle_timestamp", NULL, MAVLINK_TYPE_UINT64_T, 0, 0, offsetof(mavlink_command_long_stamped_t, vehicle_timestamp) }, \
  32. { "target_system", NULL, MAVLINK_TYPE_UINT8_T, 0, 42, offsetof(mavlink_command_long_stamped_t, target_system) }, \
  33. { "target_component", NULL, MAVLINK_TYPE_UINT8_T, 0, 43, offsetof(mavlink_command_long_stamped_t, target_component) }, \
  34. { "command", NULL, MAVLINK_TYPE_UINT16_T, 0, 40, offsetof(mavlink_command_long_stamped_t, command) }, \
  35. { "confirmation", NULL, MAVLINK_TYPE_UINT8_T, 0, 44, offsetof(mavlink_command_long_stamped_t, confirmation) }, \
  36. { "param1", NULL, MAVLINK_TYPE_FLOAT, 0, 12, offsetof(mavlink_command_long_stamped_t, param1) }, \
  37. { "param2", NULL, MAVLINK_TYPE_FLOAT, 0, 16, offsetof(mavlink_command_long_stamped_t, param2) }, \
  38. { "param3", NULL, MAVLINK_TYPE_FLOAT, 0, 20, offsetof(mavlink_command_long_stamped_t, param3) }, \
  39. { "param4", NULL, MAVLINK_TYPE_FLOAT, 0, 24, offsetof(mavlink_command_long_stamped_t, param4) }, \
  40. { "param5", NULL, MAVLINK_TYPE_FLOAT, 0, 28, offsetof(mavlink_command_long_stamped_t, param5) }, \
  41. { "param6", NULL, MAVLINK_TYPE_FLOAT, 0, 32, offsetof(mavlink_command_long_stamped_t, param6) }, \
  42. { "param7", NULL, MAVLINK_TYPE_FLOAT, 0, 36, offsetof(mavlink_command_long_stamped_t, param7) }, \
  43. } \
  44. }
  45. #else
  46. #define MAVLINK_MESSAGE_INFO_COMMAND_LONG_STAMPED { \
  47. "COMMAND_LONG_STAMPED", \
  48. 13, \
  49. { { "utc_time", NULL, MAVLINK_TYPE_UINT32_T, 0, 8, offsetof(mavlink_command_long_stamped_t, utc_time) }, \
  50. { "vehicle_timestamp", NULL, MAVLINK_TYPE_UINT64_T, 0, 0, offsetof(mavlink_command_long_stamped_t, vehicle_timestamp) }, \
  51. { "target_system", NULL, MAVLINK_TYPE_UINT8_T, 0, 42, offsetof(mavlink_command_long_stamped_t, target_system) }, \
  52. { "target_component", NULL, MAVLINK_TYPE_UINT8_T, 0, 43, offsetof(mavlink_command_long_stamped_t, target_component) }, \
  53. { "command", NULL, MAVLINK_TYPE_UINT16_T, 0, 40, offsetof(mavlink_command_long_stamped_t, command) }, \
  54. { "confirmation", NULL, MAVLINK_TYPE_UINT8_T, 0, 44, offsetof(mavlink_command_long_stamped_t, confirmation) }, \
  55. { "param1", NULL, MAVLINK_TYPE_FLOAT, 0, 12, offsetof(mavlink_command_long_stamped_t, param1) }, \
  56. { "param2", NULL, MAVLINK_TYPE_FLOAT, 0, 16, offsetof(mavlink_command_long_stamped_t, param2) }, \
  57. { "param3", NULL, MAVLINK_TYPE_FLOAT, 0, 20, offsetof(mavlink_command_long_stamped_t, param3) }, \
  58. { "param4", NULL, MAVLINK_TYPE_FLOAT, 0, 24, offsetof(mavlink_command_long_stamped_t, param4) }, \
  59. { "param5", NULL, MAVLINK_TYPE_FLOAT, 0, 28, offsetof(mavlink_command_long_stamped_t, param5) }, \
  60. { "param6", NULL, MAVLINK_TYPE_FLOAT, 0, 32, offsetof(mavlink_command_long_stamped_t, param6) }, \
  61. { "param7", NULL, MAVLINK_TYPE_FLOAT, 0, 36, offsetof(mavlink_command_long_stamped_t, param7) }, \
  62. } \
  63. }
  64. #endif
  65. /**
  66. * @brief Pack a command_long_stamped message
  67. * @param system_id ID of this system
  68. * @param component_id ID of this component (e.g. 200 for IMU)
  69. * @param msg The MAVLink message to compress the data into
  70. *
  71. * @param utc_time UTC time, seconds elapsed since 01.01.1970
  72. * @param vehicle_timestamp Microseconds elapsed since vehicle boot
  73. * @param target_system System which should execute the command
  74. * @param target_component Component which should execute the command, 0 for all components
  75. * @param command Command ID, as defined by MAV_CMD enum.
  76. * @param confirmation 0: First transmission of this command. 1-255: Confirmation transmissions (e.g. for kill command)
  77. * @param param1 Parameter 1, as defined by MAV_CMD enum.
  78. * @param param2 Parameter 2, as defined by MAV_CMD enum.
  79. * @param param3 Parameter 3, as defined by MAV_CMD enum.
  80. * @param param4 Parameter 4, as defined by MAV_CMD enum.
  81. * @param param5 Parameter 5, as defined by MAV_CMD enum.
  82. * @param param6 Parameter 6, as defined by MAV_CMD enum.
  83. * @param param7 Parameter 7, as defined by MAV_CMD enum.
  84. * @return length of the message in bytes (excluding serial stream start sign)
  85. */
  86. static inline uint16_t mavlink_msg_command_long_stamped_pack(uint8_t system_id, uint8_t component_id, mavlink_message_t* msg,
  87. uint32_t utc_time, uint64_t vehicle_timestamp, uint8_t target_system, uint8_t target_component, uint16_t command, uint8_t confirmation, float param1, float param2, float param3, float param4, float param5, float param6, float param7)
  88. {
  89. #if MAVLINK_NEED_BYTE_SWAP || !MAVLINK_ALIGNED_FIELDS
  90. char buf[MAVLINK_MSG_ID_COMMAND_LONG_STAMPED_LEN];
  91. _mav_put_uint64_t(buf, 0, vehicle_timestamp);
  92. _mav_put_uint32_t(buf, 8, utc_time);
  93. _mav_put_float(buf, 12, param1);
  94. _mav_put_float(buf, 16, param2);
  95. _mav_put_float(buf, 20, param3);
  96. _mav_put_float(buf, 24, param4);
  97. _mav_put_float(buf, 28, param5);
  98. _mav_put_float(buf, 32, param6);
  99. _mav_put_float(buf, 36, param7);
  100. _mav_put_uint16_t(buf, 40, command);
  101. _mav_put_uint8_t(buf, 42, target_system);
  102. _mav_put_uint8_t(buf, 43, target_component);
  103. _mav_put_uint8_t(buf, 44, confirmation);
  104. memcpy(_MAV_PAYLOAD_NON_CONST(msg), buf, MAVLINK_MSG_ID_COMMAND_LONG_STAMPED_LEN);
  105. #else
  106. mavlink_command_long_stamped_t packet;
  107. packet.vehicle_timestamp = vehicle_timestamp;
  108. packet.utc_time = utc_time;
  109. packet.param1 = param1;
  110. packet.param2 = param2;
  111. packet.param3 = param3;
  112. packet.param4 = param4;
  113. packet.param5 = param5;
  114. packet.param6 = param6;
  115. packet.param7 = param7;
  116. packet.command = command;
  117. packet.target_system = target_system;
  118. packet.target_component = target_component;
  119. packet.confirmation = confirmation;
  120. memcpy(_MAV_PAYLOAD_NON_CONST(msg), &packet, MAVLINK_MSG_ID_COMMAND_LONG_STAMPED_LEN);
  121. #endif
  122. msg->msgid = MAVLINK_MSG_ID_COMMAND_LONG_STAMPED;
  123. return mavlink_finalize_message(msg, system_id, component_id, MAVLINK_MSG_ID_COMMAND_LONG_STAMPED_MIN_LEN, MAVLINK_MSG_ID_COMMAND_LONG_STAMPED_LEN, MAVLINK_MSG_ID_COMMAND_LONG_STAMPED_CRC);
  124. }
  125. /**
  126. * @brief Pack a command_long_stamped message on a channel
  127. * @param system_id ID of this system
  128. * @param component_id ID of this component (e.g. 200 for IMU)
  129. * @param chan The MAVLink channel this message will be sent over
  130. * @param msg The MAVLink message to compress the data into
  131. * @param utc_time UTC time, seconds elapsed since 01.01.1970
  132. * @param vehicle_timestamp Microseconds elapsed since vehicle boot
  133. * @param target_system System which should execute the command
  134. * @param target_component Component which should execute the command, 0 for all components
  135. * @param command Command ID, as defined by MAV_CMD enum.
  136. * @param confirmation 0: First transmission of this command. 1-255: Confirmation transmissions (e.g. for kill command)
  137. * @param param1 Parameter 1, as defined by MAV_CMD enum.
  138. * @param param2 Parameter 2, as defined by MAV_CMD enum.
  139. * @param param3 Parameter 3, as defined by MAV_CMD enum.
  140. * @param param4 Parameter 4, as defined by MAV_CMD enum.
  141. * @param param5 Parameter 5, as defined by MAV_CMD enum.
  142. * @param param6 Parameter 6, as defined by MAV_CMD enum.
  143. * @param param7 Parameter 7, as defined by MAV_CMD enum.
  144. * @return length of the message in bytes (excluding serial stream start sign)
  145. */
  146. static inline uint16_t mavlink_msg_command_long_stamped_pack_chan(uint8_t system_id, uint8_t component_id, uint8_t chan,
  147. mavlink_message_t* msg,
  148. uint32_t utc_time,uint64_t vehicle_timestamp,uint8_t target_system,uint8_t target_component,uint16_t command,uint8_t confirmation,float param1,float param2,float param3,float param4,float param5,float param6,float param7)
  149. {
  150. #if MAVLINK_NEED_BYTE_SWAP || !MAVLINK_ALIGNED_FIELDS
  151. char buf[MAVLINK_MSG_ID_COMMAND_LONG_STAMPED_LEN];
  152. _mav_put_uint64_t(buf, 0, vehicle_timestamp);
  153. _mav_put_uint32_t(buf, 8, utc_time);
  154. _mav_put_float(buf, 12, param1);
  155. _mav_put_float(buf, 16, param2);
  156. _mav_put_float(buf, 20, param3);
  157. _mav_put_float(buf, 24, param4);
  158. _mav_put_float(buf, 28, param5);
  159. _mav_put_float(buf, 32, param6);
  160. _mav_put_float(buf, 36, param7);
  161. _mav_put_uint16_t(buf, 40, command);
  162. _mav_put_uint8_t(buf, 42, target_system);
  163. _mav_put_uint8_t(buf, 43, target_component);
  164. _mav_put_uint8_t(buf, 44, confirmation);
  165. memcpy(_MAV_PAYLOAD_NON_CONST(msg), buf, MAVLINK_MSG_ID_COMMAND_LONG_STAMPED_LEN);
  166. #else
  167. mavlink_command_long_stamped_t packet;
  168. packet.vehicle_timestamp = vehicle_timestamp;
  169. packet.utc_time = utc_time;
  170. packet.param1 = param1;
  171. packet.param2 = param2;
  172. packet.param3 = param3;
  173. packet.param4 = param4;
  174. packet.param5 = param5;
  175. packet.param6 = param6;
  176. packet.param7 = param7;
  177. packet.command = command;
  178. packet.target_system = target_system;
  179. packet.target_component = target_component;
  180. packet.confirmation = confirmation;
  181. memcpy(_MAV_PAYLOAD_NON_CONST(msg), &packet, MAVLINK_MSG_ID_COMMAND_LONG_STAMPED_LEN);
  182. #endif
  183. msg->msgid = MAVLINK_MSG_ID_COMMAND_LONG_STAMPED;
  184. return mavlink_finalize_message_chan(msg, system_id, component_id, chan, MAVLINK_MSG_ID_COMMAND_LONG_STAMPED_MIN_LEN, MAVLINK_MSG_ID_COMMAND_LONG_STAMPED_LEN, MAVLINK_MSG_ID_COMMAND_LONG_STAMPED_CRC);
  185. }
  186. /**
  187. * @brief Encode a command_long_stamped struct
  188. *
  189. * @param system_id ID of this system
  190. * @param component_id ID of this component (e.g. 200 for IMU)
  191. * @param msg The MAVLink message to compress the data into
  192. * @param command_long_stamped C-struct to read the message contents from
  193. */
  194. static inline uint16_t mavlink_msg_command_long_stamped_encode(uint8_t system_id, uint8_t component_id, mavlink_message_t* msg, const mavlink_command_long_stamped_t* command_long_stamped)
  195. {
  196. return mavlink_msg_command_long_stamped_pack(system_id, component_id, msg, command_long_stamped->utc_time, command_long_stamped->vehicle_timestamp, command_long_stamped->target_system, command_long_stamped->target_component, command_long_stamped->command, command_long_stamped->confirmation, command_long_stamped->param1, command_long_stamped->param2, command_long_stamped->param3, command_long_stamped->param4, command_long_stamped->param5, command_long_stamped->param6, command_long_stamped->param7);
  197. }
  198. /**
  199. * @brief Encode a command_long_stamped struct on a channel
  200. *
  201. * @param system_id ID of this system
  202. * @param component_id ID of this component (e.g. 200 for IMU)
  203. * @param chan The MAVLink channel this message will be sent over
  204. * @param msg The MAVLink message to compress the data into
  205. * @param command_long_stamped C-struct to read the message contents from
  206. */
  207. static inline uint16_t mavlink_msg_command_long_stamped_encode_chan(uint8_t system_id, uint8_t component_id, uint8_t chan, mavlink_message_t* msg, const mavlink_command_long_stamped_t* command_long_stamped)
  208. {
  209. return mavlink_msg_command_long_stamped_pack_chan(system_id, component_id, chan, msg, command_long_stamped->utc_time, command_long_stamped->vehicle_timestamp, command_long_stamped->target_system, command_long_stamped->target_component, command_long_stamped->command, command_long_stamped->confirmation, command_long_stamped->param1, command_long_stamped->param2, command_long_stamped->param3, command_long_stamped->param4, command_long_stamped->param5, command_long_stamped->param6, command_long_stamped->param7);
  210. }
  211. /**
  212. * @brief Send a command_long_stamped message
  213. * @param chan MAVLink channel to send the message
  214. *
  215. * @param utc_time UTC time, seconds elapsed since 01.01.1970
  216. * @param vehicle_timestamp Microseconds elapsed since vehicle boot
  217. * @param target_system System which should execute the command
  218. * @param target_component Component which should execute the command, 0 for all components
  219. * @param command Command ID, as defined by MAV_CMD enum.
  220. * @param confirmation 0: First transmission of this command. 1-255: Confirmation transmissions (e.g. for kill command)
  221. * @param param1 Parameter 1, as defined by MAV_CMD enum.
  222. * @param param2 Parameter 2, as defined by MAV_CMD enum.
  223. * @param param3 Parameter 3, as defined by MAV_CMD enum.
  224. * @param param4 Parameter 4, as defined by MAV_CMD enum.
  225. * @param param5 Parameter 5, as defined by MAV_CMD enum.
  226. * @param param6 Parameter 6, as defined by MAV_CMD enum.
  227. * @param param7 Parameter 7, as defined by MAV_CMD enum.
  228. */
  229. #ifdef MAVLINK_USE_CONVENIENCE_FUNCTIONS
  230. static inline void mavlink_msg_command_long_stamped_send(mavlink_channel_t chan, uint32_t utc_time, uint64_t vehicle_timestamp, uint8_t target_system, uint8_t target_component, uint16_t command, uint8_t confirmation, float param1, float param2, float param3, float param4, float param5, float param6, float param7)
  231. {
  232. #if MAVLINK_NEED_BYTE_SWAP || !MAVLINK_ALIGNED_FIELDS
  233. char buf[MAVLINK_MSG_ID_COMMAND_LONG_STAMPED_LEN];
  234. _mav_put_uint64_t(buf, 0, vehicle_timestamp);
  235. _mav_put_uint32_t(buf, 8, utc_time);
  236. _mav_put_float(buf, 12, param1);
  237. _mav_put_float(buf, 16, param2);
  238. _mav_put_float(buf, 20, param3);
  239. _mav_put_float(buf, 24, param4);
  240. _mav_put_float(buf, 28, param5);
  241. _mav_put_float(buf, 32, param6);
  242. _mav_put_float(buf, 36, param7);
  243. _mav_put_uint16_t(buf, 40, command);
  244. _mav_put_uint8_t(buf, 42, target_system);
  245. _mav_put_uint8_t(buf, 43, target_component);
  246. _mav_put_uint8_t(buf, 44, confirmation);
  247. _mav_finalize_message_chan_send(chan, MAVLINK_MSG_ID_COMMAND_LONG_STAMPED, buf, MAVLINK_MSG_ID_COMMAND_LONG_STAMPED_MIN_LEN, MAVLINK_MSG_ID_COMMAND_LONG_STAMPED_LEN, MAVLINK_MSG_ID_COMMAND_LONG_STAMPED_CRC);
  248. #else
  249. mavlink_command_long_stamped_t packet;
  250. packet.vehicle_timestamp = vehicle_timestamp;
  251. packet.utc_time = utc_time;
  252. packet.param1 = param1;
  253. packet.param2 = param2;
  254. packet.param3 = param3;
  255. packet.param4 = param4;
  256. packet.param5 = param5;
  257. packet.param6 = param6;
  258. packet.param7 = param7;
  259. packet.command = command;
  260. packet.target_system = target_system;
  261. packet.target_component = target_component;
  262. packet.confirmation = confirmation;
  263. _mav_finalize_message_chan_send(chan, MAVLINK_MSG_ID_COMMAND_LONG_STAMPED, (const char *)&packet, MAVLINK_MSG_ID_COMMAND_LONG_STAMPED_MIN_LEN, MAVLINK_MSG_ID_COMMAND_LONG_STAMPED_LEN, MAVLINK_MSG_ID_COMMAND_LONG_STAMPED_CRC);
  264. #endif
  265. }
  266. /**
  267. * @brief Send a command_long_stamped message
  268. * @param chan MAVLink channel to send the message
  269. * @param struct The MAVLink struct to serialize
  270. */
  271. static inline void mavlink_msg_command_long_stamped_send_struct(mavlink_channel_t chan, const mavlink_command_long_stamped_t* command_long_stamped)
  272. {
  273. #if MAVLINK_NEED_BYTE_SWAP || !MAVLINK_ALIGNED_FIELDS
  274. mavlink_msg_command_long_stamped_send(chan, command_long_stamped->utc_time, command_long_stamped->vehicle_timestamp, command_long_stamped->target_system, command_long_stamped->target_component, command_long_stamped->command, command_long_stamped->confirmation, command_long_stamped->param1, command_long_stamped->param2, command_long_stamped->param3, command_long_stamped->param4, command_long_stamped->param5, command_long_stamped->param6, command_long_stamped->param7);
  275. #else
  276. _mav_finalize_message_chan_send(chan, MAVLINK_MSG_ID_COMMAND_LONG_STAMPED, (const char *)command_long_stamped, MAVLINK_MSG_ID_COMMAND_LONG_STAMPED_MIN_LEN, MAVLINK_MSG_ID_COMMAND_LONG_STAMPED_LEN, MAVLINK_MSG_ID_COMMAND_LONG_STAMPED_CRC);
  277. #endif
  278. }
  279. #if MAVLINK_MSG_ID_COMMAND_LONG_STAMPED_LEN <= MAVLINK_MAX_PAYLOAD_LEN
  280. /*
  281. This varient of _send() can be used to save stack space by re-using
  282. memory from the receive buffer. The caller provides a
  283. mavlink_message_t which is the size of a full mavlink message. This
  284. is usually the receive buffer for the channel, and allows a reply to an
  285. incoming message with minimum stack space usage.
  286. */
  287. static inline void mavlink_msg_command_long_stamped_send_buf(mavlink_message_t *msgbuf, mavlink_channel_t chan, uint32_t utc_time, uint64_t vehicle_timestamp, uint8_t target_system, uint8_t target_component, uint16_t command, uint8_t confirmation, float param1, float param2, float param3, float param4, float param5, float param6, float param7)
  288. {
  289. #if MAVLINK_NEED_BYTE_SWAP || !MAVLINK_ALIGNED_FIELDS
  290. char *buf = (char *)msgbuf;
  291. _mav_put_uint64_t(buf, 0, vehicle_timestamp);
  292. _mav_put_uint32_t(buf, 8, utc_time);
  293. _mav_put_float(buf, 12, param1);
  294. _mav_put_float(buf, 16, param2);
  295. _mav_put_float(buf, 20, param3);
  296. _mav_put_float(buf, 24, param4);
  297. _mav_put_float(buf, 28, param5);
  298. _mav_put_float(buf, 32, param6);
  299. _mav_put_float(buf, 36, param7);
  300. _mav_put_uint16_t(buf, 40, command);
  301. _mav_put_uint8_t(buf, 42, target_system);
  302. _mav_put_uint8_t(buf, 43, target_component);
  303. _mav_put_uint8_t(buf, 44, confirmation);
  304. _mav_finalize_message_chan_send(chan, MAVLINK_MSG_ID_COMMAND_LONG_STAMPED, buf, MAVLINK_MSG_ID_COMMAND_LONG_STAMPED_MIN_LEN, MAVLINK_MSG_ID_COMMAND_LONG_STAMPED_LEN, MAVLINK_MSG_ID_COMMAND_LONG_STAMPED_CRC);
  305. #else
  306. mavlink_command_long_stamped_t *packet = (mavlink_command_long_stamped_t *)msgbuf;
  307. packet->vehicle_timestamp = vehicle_timestamp;
  308. packet->utc_time = utc_time;
  309. packet->param1 = param1;
  310. packet->param2 = param2;
  311. packet->param3 = param3;
  312. packet->param4 = param4;
  313. packet->param5 = param5;
  314. packet->param6 = param6;
  315. packet->param7 = param7;
  316. packet->command = command;
  317. packet->target_system = target_system;
  318. packet->target_component = target_component;
  319. packet->confirmation = confirmation;
  320. _mav_finalize_message_chan_send(chan, MAVLINK_MSG_ID_COMMAND_LONG_STAMPED, (const char *)packet, MAVLINK_MSG_ID_COMMAND_LONG_STAMPED_MIN_LEN, MAVLINK_MSG_ID_COMMAND_LONG_STAMPED_LEN, MAVLINK_MSG_ID_COMMAND_LONG_STAMPED_CRC);
  321. #endif
  322. }
  323. #endif
  324. #endif
  325. // MESSAGE COMMAND_LONG_STAMPED UNPACKING
  326. /**
  327. * @brief Get field utc_time from command_long_stamped message
  328. *
  329. * @return UTC time, seconds elapsed since 01.01.1970
  330. */
  331. static inline uint32_t mavlink_msg_command_long_stamped_get_utc_time(const mavlink_message_t* msg)
  332. {
  333. return _MAV_RETURN_uint32_t(msg, 8);
  334. }
  335. /**
  336. * @brief Get field vehicle_timestamp from command_long_stamped message
  337. *
  338. * @return Microseconds elapsed since vehicle boot
  339. */
  340. static inline uint64_t mavlink_msg_command_long_stamped_get_vehicle_timestamp(const mavlink_message_t* msg)
  341. {
  342. return _MAV_RETURN_uint64_t(msg, 0);
  343. }
  344. /**
  345. * @brief Get field target_system from command_long_stamped message
  346. *
  347. * @return System which should execute the command
  348. */
  349. static inline uint8_t mavlink_msg_command_long_stamped_get_target_system(const mavlink_message_t* msg)
  350. {
  351. return _MAV_RETURN_uint8_t(msg, 42);
  352. }
  353. /**
  354. * @brief Get field target_component from command_long_stamped message
  355. *
  356. * @return Component which should execute the command, 0 for all components
  357. */
  358. static inline uint8_t mavlink_msg_command_long_stamped_get_target_component(const mavlink_message_t* msg)
  359. {
  360. return _MAV_RETURN_uint8_t(msg, 43);
  361. }
  362. /**
  363. * @brief Get field command from command_long_stamped message
  364. *
  365. * @return Command ID, as defined by MAV_CMD enum.
  366. */
  367. static inline uint16_t mavlink_msg_command_long_stamped_get_command(const mavlink_message_t* msg)
  368. {
  369. return _MAV_RETURN_uint16_t(msg, 40);
  370. }
  371. /**
  372. * @brief Get field confirmation from command_long_stamped message
  373. *
  374. * @return 0: First transmission of this command. 1-255: Confirmation transmissions (e.g. for kill command)
  375. */
  376. static inline uint8_t mavlink_msg_command_long_stamped_get_confirmation(const mavlink_message_t* msg)
  377. {
  378. return _MAV_RETURN_uint8_t(msg, 44);
  379. }
  380. /**
  381. * @brief Get field param1 from command_long_stamped message
  382. *
  383. * @return Parameter 1, as defined by MAV_CMD enum.
  384. */
  385. static inline float mavlink_msg_command_long_stamped_get_param1(const mavlink_message_t* msg)
  386. {
  387. return _MAV_RETURN_float(msg, 12);
  388. }
  389. /**
  390. * @brief Get field param2 from command_long_stamped message
  391. *
  392. * @return Parameter 2, as defined by MAV_CMD enum.
  393. */
  394. static inline float mavlink_msg_command_long_stamped_get_param2(const mavlink_message_t* msg)
  395. {
  396. return _MAV_RETURN_float(msg, 16);
  397. }
  398. /**
  399. * @brief Get field param3 from command_long_stamped message
  400. *
  401. * @return Parameter 3, as defined by MAV_CMD enum.
  402. */
  403. static inline float mavlink_msg_command_long_stamped_get_param3(const mavlink_message_t* msg)
  404. {
  405. return _MAV_RETURN_float(msg, 20);
  406. }
  407. /**
  408. * @brief Get field param4 from command_long_stamped message
  409. *
  410. * @return Parameter 4, as defined by MAV_CMD enum.
  411. */
  412. static inline float mavlink_msg_command_long_stamped_get_param4(const mavlink_message_t* msg)
  413. {
  414. return _MAV_RETURN_float(msg, 24);
  415. }
  416. /**
  417. * @brief Get field param5 from command_long_stamped message
  418. *
  419. * @return Parameter 5, as defined by MAV_CMD enum.
  420. */
  421. static inline float mavlink_msg_command_long_stamped_get_param5(const mavlink_message_t* msg)
  422. {
  423. return _MAV_RETURN_float(msg, 28);
  424. }
  425. /**
  426. * @brief Get field param6 from command_long_stamped message
  427. *
  428. * @return Parameter 6, as defined by MAV_CMD enum.
  429. */
  430. static inline float mavlink_msg_command_long_stamped_get_param6(const mavlink_message_t* msg)
  431. {
  432. return _MAV_RETURN_float(msg, 32);
  433. }
  434. /**
  435. * @brief Get field param7 from command_long_stamped message
  436. *
  437. * @return Parameter 7, as defined by MAV_CMD enum.
  438. */
  439. static inline float mavlink_msg_command_long_stamped_get_param7(const mavlink_message_t* msg)
  440. {
  441. return _MAV_RETURN_float(msg, 36);
  442. }
  443. /**
  444. * @brief Decode a command_long_stamped message into a struct
  445. *
  446. * @param msg The message to decode
  447. * @param command_long_stamped C-struct to decode the message contents into
  448. */
  449. static inline void mavlink_msg_command_long_stamped_decode(const mavlink_message_t* msg, mavlink_command_long_stamped_t* command_long_stamped)
  450. {
  451. #if MAVLINK_NEED_BYTE_SWAP || !MAVLINK_ALIGNED_FIELDS
  452. command_long_stamped->vehicle_timestamp = mavlink_msg_command_long_stamped_get_vehicle_timestamp(msg);
  453. command_long_stamped->utc_time = mavlink_msg_command_long_stamped_get_utc_time(msg);
  454. command_long_stamped->param1 = mavlink_msg_command_long_stamped_get_param1(msg);
  455. command_long_stamped->param2 = mavlink_msg_command_long_stamped_get_param2(msg);
  456. command_long_stamped->param3 = mavlink_msg_command_long_stamped_get_param3(msg);
  457. command_long_stamped->param4 = mavlink_msg_command_long_stamped_get_param4(msg);
  458. command_long_stamped->param5 = mavlink_msg_command_long_stamped_get_param5(msg);
  459. command_long_stamped->param6 = mavlink_msg_command_long_stamped_get_param6(msg);
  460. command_long_stamped->param7 = mavlink_msg_command_long_stamped_get_param7(msg);
  461. command_long_stamped->command = mavlink_msg_command_long_stamped_get_command(msg);
  462. command_long_stamped->target_system = mavlink_msg_command_long_stamped_get_target_system(msg);
  463. command_long_stamped->target_component = mavlink_msg_command_long_stamped_get_target_component(msg);
  464. command_long_stamped->confirmation = mavlink_msg_command_long_stamped_get_confirmation(msg);
  465. #else
  466. uint8_t len = msg->len < MAVLINK_MSG_ID_COMMAND_LONG_STAMPED_LEN? msg->len : MAVLINK_MSG_ID_COMMAND_LONG_STAMPED_LEN;
  467. memset(command_long_stamped, 0, MAVLINK_MSG_ID_COMMAND_LONG_STAMPED_LEN);
  468. memcpy(command_long_stamped, _MAV_PAYLOAD(msg), len);
  469. #endif
  470. }