testsuite.h 76 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443
  1. /** @file
  2. * @brief MAVLink comm protocol testsuite generated from VKFly.xml
  3. * @see https://mavlink.io/en/
  4. */
  5. #pragma once
  6. #ifndef VKFLY_TESTSUITE_H
  7. #define VKFLY_TESTSUITE_H
  8. #ifdef __cplusplus
  9. extern "C" {
  10. #endif
  11. #ifndef MAVLINK_TEST_ALL
  12. #define MAVLINK_TEST_ALL
  13. static void mavlink_test_common(uint8_t, uint8_t, mavlink_message_t *last_msg);
  14. static void mavlink_test_VKFly(uint8_t, uint8_t, mavlink_message_t *last_msg);
  15. static void mavlink_test_all(uint8_t system_id, uint8_t component_id, mavlink_message_t *last_msg)
  16. {
  17. mavlink_test_common(system_id, component_id, last_msg);
  18. mavlink_test_VKFly(system_id, component_id, last_msg);
  19. }
  20. #endif
  21. #include "../common/testsuite.h"
  22. static void mavlink_test_vkins_status(uint8_t system_id, uint8_t component_id, mavlink_message_t *last_msg)
  23. {
  24. #ifdef MAVLINK_STATUS_FLAG_OUT_MAVLINK1
  25. mavlink_status_t *status = mavlink_get_channel_status(MAVLINK_COMM_0);
  26. if ((status->flags & MAVLINK_STATUS_FLAG_OUT_MAVLINK1) && MAVLINK_MSG_ID_VKINS_STATUS >= 256) {
  27. return;
  28. }
  29. #endif
  30. mavlink_message_t msg;
  31. uint8_t buffer[MAVLINK_MAX_PACKET_LEN];
  32. uint16_t i;
  33. mavlink_vkins_status_t packet_in = {
  34. 963497464,45.0,963497880,963498088,129.0,157.0,18483,211,22,89,156,223,34,101,168,235,46,113
  35. };
  36. mavlink_vkins_status_t packet1, packet2;
  37. memset(&packet1, 0, sizeof(packet1));
  38. packet1.time_boot_ms = packet_in.time_boot_ms;
  39. packet1.g0 = packet_in.g0;
  40. packet1.raw_latitude = packet_in.raw_latitude;
  41. packet1.raw_longitude = packet_in.raw_longitude;
  42. packet1.baro_alt = packet_in.baro_alt;
  43. packet1.raw_gps_alt = packet_in.raw_gps_alt;
  44. packet1.temperature = packet_in.temperature;
  45. packet1.nav_status = packet_in.nav_status;
  46. packet1.s_flag1 = packet_in.s_flag1;
  47. packet1.s_flag2 = packet_in.s_flag2;
  48. packet1.s_flag3 = packet_in.s_flag3;
  49. packet1.s_flag4 = packet_in.s_flag4;
  50. packet1.s_flag5 = packet_in.s_flag5;
  51. packet1.s_flag6 = packet_in.s_flag6;
  52. packet1.mag_calib_stage = packet_in.mag_calib_stage;
  53. packet1.solv_psat_num = packet_in.solv_psat_num;
  54. packet1.solv_hsat_num = packet_in.solv_hsat_num;
  55. packet1.vibe_coe = packet_in.vibe_coe;
  56. #ifdef MAVLINK_STATUS_FLAG_OUT_MAVLINK1
  57. if (status->flags & MAVLINK_STATUS_FLAG_OUT_MAVLINK1) {
  58. // cope with extensions
  59. memset(MAVLINK_MSG_ID_VKINS_STATUS_MIN_LEN + (char *)&packet1, 0, sizeof(packet1)-MAVLINK_MSG_ID_VKINS_STATUS_MIN_LEN);
  60. }
  61. #endif
  62. memset(&packet2, 0, sizeof(packet2));
  63. mavlink_msg_vkins_status_encode(system_id, component_id, &msg, &packet1);
  64. mavlink_msg_vkins_status_decode(&msg, &packet2);
  65. MAVLINK_ASSERT(memcmp(&packet1, &packet2, sizeof(packet1)) == 0);
  66. memset(&packet2, 0, sizeof(packet2));
  67. mavlink_msg_vkins_status_pack(system_id, component_id, &msg , packet1.time_boot_ms , packet1.nav_status , packet1.s_flag1 , packet1.s_flag2 , packet1.s_flag3 , packet1.s_flag4 , packet1.s_flag5 , packet1.s_flag6 , packet1.mag_calib_stage , packet1.g0 , packet1.raw_latitude , packet1.raw_longitude , packet1.baro_alt , packet1.raw_gps_alt , packet1.solv_psat_num , packet1.solv_hsat_num , packet1.temperature , packet1.vibe_coe );
  68. mavlink_msg_vkins_status_decode(&msg, &packet2);
  69. MAVLINK_ASSERT(memcmp(&packet1, &packet2, sizeof(packet1)) == 0);
  70. memset(&packet2, 0, sizeof(packet2));
  71. mavlink_msg_vkins_status_pack_chan(system_id, component_id, MAVLINK_COMM_0, &msg , packet1.time_boot_ms , packet1.nav_status , packet1.s_flag1 , packet1.s_flag2 , packet1.s_flag3 , packet1.s_flag4 , packet1.s_flag5 , packet1.s_flag6 , packet1.mag_calib_stage , packet1.g0 , packet1.raw_latitude , packet1.raw_longitude , packet1.baro_alt , packet1.raw_gps_alt , packet1.solv_psat_num , packet1.solv_hsat_num , packet1.temperature , packet1.vibe_coe );
  72. mavlink_msg_vkins_status_decode(&msg, &packet2);
  73. MAVLINK_ASSERT(memcmp(&packet1, &packet2, sizeof(packet1)) == 0);
  74. memset(&packet2, 0, sizeof(packet2));
  75. mavlink_msg_to_send_buffer(buffer, &msg);
  76. for (i=0; i<mavlink_msg_get_send_buffer_length(&msg); i++) {
  77. comm_send_ch(MAVLINK_COMM_0, buffer[i]);
  78. }
  79. mavlink_msg_vkins_status_decode(last_msg, &packet2);
  80. MAVLINK_ASSERT(memcmp(&packet1, &packet2, sizeof(packet1)) == 0);
  81. memset(&packet2, 0, sizeof(packet2));
  82. mavlink_msg_vkins_status_send(MAVLINK_COMM_1 , packet1.time_boot_ms , packet1.nav_status , packet1.s_flag1 , packet1.s_flag2 , packet1.s_flag3 , packet1.s_flag4 , packet1.s_flag5 , packet1.s_flag6 , packet1.mag_calib_stage , packet1.g0 , packet1.raw_latitude , packet1.raw_longitude , packet1.baro_alt , packet1.raw_gps_alt , packet1.solv_psat_num , packet1.solv_hsat_num , packet1.temperature , packet1.vibe_coe );
  83. mavlink_msg_vkins_status_decode(last_msg, &packet2);
  84. MAVLINK_ASSERT(memcmp(&packet1, &packet2, sizeof(packet1)) == 0);
  85. #ifdef MAVLINK_HAVE_GET_MESSAGE_INFO
  86. MAVLINK_ASSERT(mavlink_get_message_info_by_name("VKINS_STATUS") != NULL);
  87. MAVLINK_ASSERT(mavlink_get_message_info_by_id(MAVLINK_MSG_ID_VKINS_STATUS) != NULL);
  88. #endif
  89. }
  90. static void mavlink_test_vkfmu_status(uint8_t system_id, uint8_t component_id, mavlink_message_t *last_msg)
  91. {
  92. #ifdef MAVLINK_STATUS_FLAG_OUT_MAVLINK1
  93. mavlink_status_t *status = mavlink_get_channel_status(MAVLINK_COMM_0);
  94. if ((status->flags & MAVLINK_STATUS_FLAG_OUT_MAVLINK1) && MAVLINK_MSG_ID_VKFMU_STATUS >= 256) {
  95. return;
  96. }
  97. #endif
  98. mavlink_message_t msg;
  99. uint8_t buffer[MAVLINK_MAX_PACKET_LEN];
  100. uint16_t i;
  101. mavlink_vkfmu_status_t packet_in = {
  102. 963497464,963497672,963497880,101.0,18067,18171,18275,199,10,77
  103. };
  104. mavlink_vkfmu_status_t packet1, packet2;
  105. memset(&packet1, 0, sizeof(packet1));
  106. packet1.time_boot_ms = packet_in.time_boot_ms;
  107. packet1.flight_time = packet_in.flight_time;
  108. packet1.dist_to_tar = packet_in.dist_to_tar;
  109. packet1.flight_dist = packet_in.flight_dist;
  110. packet1.ups_volt = packet_in.ups_volt;
  111. packet1.adc_volt = packet_in.adc_volt;
  112. packet1.servo_state = packet_in.servo_state;
  113. packet1.rtl_reason = packet_in.rtl_reason;
  114. packet1.loiter_reason = packet_in.loiter_reason;
  115. packet1.s_flag3 = packet_in.s_flag3;
  116. #ifdef MAVLINK_STATUS_FLAG_OUT_MAVLINK1
  117. if (status->flags & MAVLINK_STATUS_FLAG_OUT_MAVLINK1) {
  118. // cope with extensions
  119. memset(MAVLINK_MSG_ID_VKFMU_STATUS_MIN_LEN + (char *)&packet1, 0, sizeof(packet1)-MAVLINK_MSG_ID_VKFMU_STATUS_MIN_LEN);
  120. }
  121. #endif
  122. memset(&packet2, 0, sizeof(packet2));
  123. mavlink_msg_vkfmu_status_encode(system_id, component_id, &msg, &packet1);
  124. mavlink_msg_vkfmu_status_decode(&msg, &packet2);
  125. MAVLINK_ASSERT(memcmp(&packet1, &packet2, sizeof(packet1)) == 0);
  126. memset(&packet2, 0, sizeof(packet2));
  127. mavlink_msg_vkfmu_status_pack(system_id, component_id, &msg , packet1.time_boot_ms , packet1.rtl_reason , packet1.loiter_reason , packet1.s_flag3 , packet1.ups_volt , packet1.adc_volt , packet1.flight_time , packet1.dist_to_tar , packet1.servo_state , packet1.flight_dist );
  128. mavlink_msg_vkfmu_status_decode(&msg, &packet2);
  129. MAVLINK_ASSERT(memcmp(&packet1, &packet2, sizeof(packet1)) == 0);
  130. memset(&packet2, 0, sizeof(packet2));
  131. mavlink_msg_vkfmu_status_pack_chan(system_id, component_id, MAVLINK_COMM_0, &msg , packet1.time_boot_ms , packet1.rtl_reason , packet1.loiter_reason , packet1.s_flag3 , packet1.ups_volt , packet1.adc_volt , packet1.flight_time , packet1.dist_to_tar , packet1.servo_state , packet1.flight_dist );
  132. mavlink_msg_vkfmu_status_decode(&msg, &packet2);
  133. MAVLINK_ASSERT(memcmp(&packet1, &packet2, sizeof(packet1)) == 0);
  134. memset(&packet2, 0, sizeof(packet2));
  135. mavlink_msg_to_send_buffer(buffer, &msg);
  136. for (i=0; i<mavlink_msg_get_send_buffer_length(&msg); i++) {
  137. comm_send_ch(MAVLINK_COMM_0, buffer[i]);
  138. }
  139. mavlink_msg_vkfmu_status_decode(last_msg, &packet2);
  140. MAVLINK_ASSERT(memcmp(&packet1, &packet2, sizeof(packet1)) == 0);
  141. memset(&packet2, 0, sizeof(packet2));
  142. mavlink_msg_vkfmu_status_send(MAVLINK_COMM_1 , packet1.time_boot_ms , packet1.rtl_reason , packet1.loiter_reason , packet1.s_flag3 , packet1.ups_volt , packet1.adc_volt , packet1.flight_time , packet1.dist_to_tar , packet1.servo_state , packet1.flight_dist );
  143. mavlink_msg_vkfmu_status_decode(last_msg, &packet2);
  144. MAVLINK_ASSERT(memcmp(&packet1, &packet2, sizeof(packet1)) == 0);
  145. #ifdef MAVLINK_HAVE_GET_MESSAGE_INFO
  146. MAVLINK_ASSERT(mavlink_get_message_info_by_name("VKFMU_STATUS") != NULL);
  147. MAVLINK_ASSERT(mavlink_get_message_info_by_id(MAVLINK_MSG_ID_VKFMU_STATUS) != NULL);
  148. #endif
  149. }
  150. static void mavlink_test_vk_roi_target(uint8_t system_id, uint8_t component_id, mavlink_message_t *last_msg)
  151. {
  152. #ifdef MAVLINK_STATUS_FLAG_OUT_MAVLINK1
  153. mavlink_status_t *status = mavlink_get_channel_status(MAVLINK_COMM_0);
  154. if ((status->flags & MAVLINK_STATUS_FLAG_OUT_MAVLINK1) && MAVLINK_MSG_ID_VK_ROI_TARGET >= 256) {
  155. return;
  156. }
  157. #endif
  158. mavlink_message_t msg;
  159. uint8_t buffer[MAVLINK_MAX_PACKET_LEN];
  160. uint16_t i;
  161. mavlink_vk_roi_target_t packet_in = {
  162. 963497464,963497672,963497880,101.0,18067
  163. };
  164. mavlink_vk_roi_target_t packet1, packet2;
  165. memset(&packet1, 0, sizeof(packet1));
  166. packet1.time_boot_ms = packet_in.time_boot_ms;
  167. packet1.lat = packet_in.lat;
  168. packet1.lon = packet_in.lon;
  169. packet1.alt = packet_in.alt;
  170. packet1.state = packet_in.state;
  171. #ifdef MAVLINK_STATUS_FLAG_OUT_MAVLINK1
  172. if (status->flags & MAVLINK_STATUS_FLAG_OUT_MAVLINK1) {
  173. // cope with extensions
  174. memset(MAVLINK_MSG_ID_VK_ROI_TARGET_MIN_LEN + (char *)&packet1, 0, sizeof(packet1)-MAVLINK_MSG_ID_VK_ROI_TARGET_MIN_LEN);
  175. }
  176. #endif
  177. memset(&packet2, 0, sizeof(packet2));
  178. mavlink_msg_vk_roi_target_encode(system_id, component_id, &msg, &packet1);
  179. mavlink_msg_vk_roi_target_decode(&msg, &packet2);
  180. MAVLINK_ASSERT(memcmp(&packet1, &packet2, sizeof(packet1)) == 0);
  181. memset(&packet2, 0, sizeof(packet2));
  182. mavlink_msg_vk_roi_target_pack(system_id, component_id, &msg , packet1.time_boot_ms , packet1.lat , packet1.lon , packet1.alt , packet1.state );
  183. mavlink_msg_vk_roi_target_decode(&msg, &packet2);
  184. MAVLINK_ASSERT(memcmp(&packet1, &packet2, sizeof(packet1)) == 0);
  185. memset(&packet2, 0, sizeof(packet2));
  186. mavlink_msg_vk_roi_target_pack_chan(system_id, component_id, MAVLINK_COMM_0, &msg , packet1.time_boot_ms , packet1.lat , packet1.lon , packet1.alt , packet1.state );
  187. mavlink_msg_vk_roi_target_decode(&msg, &packet2);
  188. MAVLINK_ASSERT(memcmp(&packet1, &packet2, sizeof(packet1)) == 0);
  189. memset(&packet2, 0, sizeof(packet2));
  190. mavlink_msg_to_send_buffer(buffer, &msg);
  191. for (i=0; i<mavlink_msg_get_send_buffer_length(&msg); i++) {
  192. comm_send_ch(MAVLINK_COMM_0, buffer[i]);
  193. }
  194. mavlink_msg_vk_roi_target_decode(last_msg, &packet2);
  195. MAVLINK_ASSERT(memcmp(&packet1, &packet2, sizeof(packet1)) == 0);
  196. memset(&packet2, 0, sizeof(packet2));
  197. mavlink_msg_vk_roi_target_send(MAVLINK_COMM_1 , packet1.time_boot_ms , packet1.lat , packet1.lon , packet1.alt , packet1.state );
  198. mavlink_msg_vk_roi_target_decode(last_msg, &packet2);
  199. MAVLINK_ASSERT(memcmp(&packet1, &packet2, sizeof(packet1)) == 0);
  200. #ifdef MAVLINK_HAVE_GET_MESSAGE_INFO
  201. MAVLINK_ASSERT(mavlink_get_message_info_by_name("VK_ROI_TARGET") != NULL);
  202. MAVLINK_ASSERT(mavlink_get_message_info_by_id(MAVLINK_MSG_ID_VK_ROI_TARGET) != NULL);
  203. #endif
  204. }
  205. static void mavlink_test_vk_bms_status(uint8_t system_id, uint8_t component_id, mavlink_message_t *last_msg)
  206. {
  207. #ifdef MAVLINK_STATUS_FLAG_OUT_MAVLINK1
  208. mavlink_status_t *status = mavlink_get_channel_status(MAVLINK_COMM_0);
  209. if ((status->flags & MAVLINK_STATUS_FLAG_OUT_MAVLINK1) && MAVLINK_MSG_ID_VK_BMS_STATUS >= 256) {
  210. return;
  211. }
  212. #endif
  213. mavlink_message_t msg;
  214. uint8_t buffer[MAVLINK_MAX_PACKET_LEN];
  215. uint16_t i;
  216. mavlink_vk_bms_status_t packet_in = {
  217. 963497464,963497672,963497880,17859,17963,18067,{ 18171, 18172, 18173, 18174, 18175, 18176, 18177, 18178, 18179, 18180, 18181, 18182, 18183, 18184, 18185, 18186, 18187, 18188, 18189, 18190, 18191, 18192, 18193, 18194, 18195, 18196, 18197, 18198, 18199, 18200 },21291,245,56,123
  218. };
  219. mavlink_vk_bms_status_t packet1, packet2;
  220. memset(&packet1, 0, sizeof(packet1));
  221. packet1.time_boot_ms = packet_in.time_boot_ms;
  222. packet1.voltage = packet_in.voltage;
  223. packet1.err_code = packet_in.err_code;
  224. packet1.current = packet_in.current;
  225. packet1.temperature = packet_in.temperature;
  226. packet1.cell_num = packet_in.cell_num;
  227. packet1.cyc_cnt = packet_in.cyc_cnt;
  228. packet1.cap_percent = packet_in.cap_percent;
  229. packet1.bat_id = packet_in.bat_id;
  230. packet1.health = packet_in.health;
  231. mav_array_memcpy(packet1.cell_volt, packet_in.cell_volt, sizeof(uint16_t)*30);
  232. #ifdef MAVLINK_STATUS_FLAG_OUT_MAVLINK1
  233. if (status->flags & MAVLINK_STATUS_FLAG_OUT_MAVLINK1) {
  234. // cope with extensions
  235. memset(MAVLINK_MSG_ID_VK_BMS_STATUS_MIN_LEN + (char *)&packet1, 0, sizeof(packet1)-MAVLINK_MSG_ID_VK_BMS_STATUS_MIN_LEN);
  236. }
  237. #endif
  238. memset(&packet2, 0, sizeof(packet2));
  239. mavlink_msg_vk_bms_status_encode(system_id, component_id, &msg, &packet1);
  240. mavlink_msg_vk_bms_status_decode(&msg, &packet2);
  241. MAVLINK_ASSERT(memcmp(&packet1, &packet2, sizeof(packet1)) == 0);
  242. memset(&packet2, 0, sizeof(packet2));
  243. mavlink_msg_vk_bms_status_pack(system_id, component_id, &msg , packet1.time_boot_ms , packet1.voltage , packet1.current , packet1.temperature , packet1.cap_percent , packet1.bat_id , packet1.err_code , packet1.cell_num , packet1.cell_volt , packet1.cyc_cnt , packet1.health );
  244. mavlink_msg_vk_bms_status_decode(&msg, &packet2);
  245. MAVLINK_ASSERT(memcmp(&packet1, &packet2, sizeof(packet1)) == 0);
  246. memset(&packet2, 0, sizeof(packet2));
  247. mavlink_msg_vk_bms_status_pack_chan(system_id, component_id, MAVLINK_COMM_0, &msg , packet1.time_boot_ms , packet1.voltage , packet1.current , packet1.temperature , packet1.cap_percent , packet1.bat_id , packet1.err_code , packet1.cell_num , packet1.cell_volt , packet1.cyc_cnt , packet1.health );
  248. mavlink_msg_vk_bms_status_decode(&msg, &packet2);
  249. MAVLINK_ASSERT(memcmp(&packet1, &packet2, sizeof(packet1)) == 0);
  250. memset(&packet2, 0, sizeof(packet2));
  251. mavlink_msg_to_send_buffer(buffer, &msg);
  252. for (i=0; i<mavlink_msg_get_send_buffer_length(&msg); i++) {
  253. comm_send_ch(MAVLINK_COMM_0, buffer[i]);
  254. }
  255. mavlink_msg_vk_bms_status_decode(last_msg, &packet2);
  256. MAVLINK_ASSERT(memcmp(&packet1, &packet2, sizeof(packet1)) == 0);
  257. memset(&packet2, 0, sizeof(packet2));
  258. mavlink_msg_vk_bms_status_send(MAVLINK_COMM_1 , packet1.time_boot_ms , packet1.voltage , packet1.current , packet1.temperature , packet1.cap_percent , packet1.bat_id , packet1.err_code , packet1.cell_num , packet1.cell_volt , packet1.cyc_cnt , packet1.health );
  259. mavlink_msg_vk_bms_status_decode(last_msg, &packet2);
  260. MAVLINK_ASSERT(memcmp(&packet1, &packet2, sizeof(packet1)) == 0);
  261. #ifdef MAVLINK_HAVE_GET_MESSAGE_INFO
  262. MAVLINK_ASSERT(mavlink_get_message_info_by_name("VK_BMS_STATUS") != NULL);
  263. MAVLINK_ASSERT(mavlink_get_message_info_by_id(MAVLINK_MSG_ID_VK_BMS_STATUS) != NULL);
  264. #endif
  265. }
  266. static void mavlink_test_vk_formation_leader(uint8_t system_id, uint8_t component_id, mavlink_message_t *last_msg)
  267. {
  268. #ifdef MAVLINK_STATUS_FLAG_OUT_MAVLINK1
  269. mavlink_status_t *status = mavlink_get_channel_status(MAVLINK_COMM_0);
  270. if ((status->flags & MAVLINK_STATUS_FLAG_OUT_MAVLINK1) && MAVLINK_MSG_ID_VK_FORMATION_LEADER >= 256) {
  271. return;
  272. }
  273. #endif
  274. mavlink_message_t msg;
  275. uint8_t buffer[MAVLINK_MAX_PACKET_LEN];
  276. uint16_t i;
  277. mavlink_vk_formation_leader_t packet_in = {
  278. 963497464,963497672,963497880,963498088,129.0,157.0,185.0,213.0,241.0,19107,19211,19315,19419,137
  279. };
  280. mavlink_vk_formation_leader_t packet1, packet2;
  281. memset(&packet1, 0, sizeof(packet1));
  282. packet1.timestamp = packet_in.timestamp;
  283. packet1.state = packet_in.state;
  284. packet1.lat = packet_in.lat;
  285. packet1.lon = packet_in.lon;
  286. packet1.msl = packet_in.msl;
  287. packet1.ve = packet_in.ve;
  288. packet1.vn = packet_in.vn;
  289. packet1.vu = packet_in.vu;
  290. packet1.yaw = packet_in.yaw;
  291. packet1.x_dist = packet_in.x_dist;
  292. packet1.y_dist = packet_in.y_dist;
  293. packet1.z_dist = packet_in.z_dist;
  294. packet1.rect_col_num = packet_in.rect_col_num;
  295. packet1.formation_type = packet_in.formation_type;
  296. #ifdef MAVLINK_STATUS_FLAG_OUT_MAVLINK1
  297. if (status->flags & MAVLINK_STATUS_FLAG_OUT_MAVLINK1) {
  298. // cope with extensions
  299. memset(MAVLINK_MSG_ID_VK_FORMATION_LEADER_MIN_LEN + (char *)&packet1, 0, sizeof(packet1)-MAVLINK_MSG_ID_VK_FORMATION_LEADER_MIN_LEN);
  300. }
  301. #endif
  302. memset(&packet2, 0, sizeof(packet2));
  303. mavlink_msg_vk_formation_leader_encode(system_id, component_id, &msg, &packet1);
  304. mavlink_msg_vk_formation_leader_decode(&msg, &packet2);
  305. MAVLINK_ASSERT(memcmp(&packet1, &packet2, sizeof(packet1)) == 0);
  306. memset(&packet2, 0, sizeof(packet2));
  307. mavlink_msg_vk_formation_leader_pack(system_id, component_id, &msg , packet1.timestamp , packet1.state , packet1.lat , packet1.lon , packet1.msl , packet1.ve , packet1.vn , packet1.vu , packet1.yaw , packet1.formation_type , packet1.x_dist , packet1.y_dist , packet1.z_dist , packet1.rect_col_num );
  308. mavlink_msg_vk_formation_leader_decode(&msg, &packet2);
  309. MAVLINK_ASSERT(memcmp(&packet1, &packet2, sizeof(packet1)) == 0);
  310. memset(&packet2, 0, sizeof(packet2));
  311. mavlink_msg_vk_formation_leader_pack_chan(system_id, component_id, MAVLINK_COMM_0, &msg , packet1.timestamp , packet1.state , packet1.lat , packet1.lon , packet1.msl , packet1.ve , packet1.vn , packet1.vu , packet1.yaw , packet1.formation_type , packet1.x_dist , packet1.y_dist , packet1.z_dist , packet1.rect_col_num );
  312. mavlink_msg_vk_formation_leader_decode(&msg, &packet2);
  313. MAVLINK_ASSERT(memcmp(&packet1, &packet2, sizeof(packet1)) == 0);
  314. memset(&packet2, 0, sizeof(packet2));
  315. mavlink_msg_to_send_buffer(buffer, &msg);
  316. for (i=0; i<mavlink_msg_get_send_buffer_length(&msg); i++) {
  317. comm_send_ch(MAVLINK_COMM_0, buffer[i]);
  318. }
  319. mavlink_msg_vk_formation_leader_decode(last_msg, &packet2);
  320. MAVLINK_ASSERT(memcmp(&packet1, &packet2, sizeof(packet1)) == 0);
  321. memset(&packet2, 0, sizeof(packet2));
  322. mavlink_msg_vk_formation_leader_send(MAVLINK_COMM_1 , packet1.timestamp , packet1.state , packet1.lat , packet1.lon , packet1.msl , packet1.ve , packet1.vn , packet1.vu , packet1.yaw , packet1.formation_type , packet1.x_dist , packet1.y_dist , packet1.z_dist , packet1.rect_col_num );
  323. mavlink_msg_vk_formation_leader_decode(last_msg, &packet2);
  324. MAVLINK_ASSERT(memcmp(&packet1, &packet2, sizeof(packet1)) == 0);
  325. #ifdef MAVLINK_HAVE_GET_MESSAGE_INFO
  326. MAVLINK_ASSERT(mavlink_get_message_info_by_name("VK_FORMATION_LEADER") != NULL);
  327. MAVLINK_ASSERT(mavlink_get_message_info_by_id(MAVLINK_MSG_ID_VK_FORMATION_LEADER) != NULL);
  328. #endif
  329. }
  330. static void mavlink_test_vk_engine_ecu_staus(uint8_t system_id, uint8_t component_id, mavlink_message_t *last_msg)
  331. {
  332. #ifdef MAVLINK_STATUS_FLAG_OUT_MAVLINK1
  333. mavlink_status_t *status = mavlink_get_channel_status(MAVLINK_COMM_0);
  334. if ((status->flags & MAVLINK_STATUS_FLAG_OUT_MAVLINK1) && MAVLINK_MSG_ID_VK_ENGINE_ECU_STAUS >= 256) {
  335. return;
  336. }
  337. #endif
  338. mavlink_message_t msg;
  339. uint8_t buffer[MAVLINK_MAX_PACKET_LEN];
  340. uint16_t i;
  341. mavlink_vk_engine_ecu_staus_t packet_in = {
  342. 963497464,963497672,17651,17755,17859,17963,18067,18171,18275,18379,18483,18587,89,156,223,34,101,{ 168, 169, 170, 171 }
  343. };
  344. mavlink_vk_engine_ecu_staus_t packet1, packet2;
  345. memset(&packet1, 0, sizeof(packet1));
  346. packet1.timestamp = packet_in.timestamp;
  347. packet1.total_runtime = packet_in.total_runtime;
  348. packet1.spd_rpm = packet_in.spd_rpm;
  349. packet1.cylinderA_temp = packet_in.cylinderA_temp;
  350. packet1.cylinderB_temp = packet_in.cylinderB_temp;
  351. packet1.coolant_temp = packet_in.coolant_temp;
  352. packet1.fuel_remain = packet_in.fuel_remain;
  353. packet1.alarm = packet_in.alarm;
  354. packet1.runtime = packet_in.runtime;
  355. packet1.service_time = packet_in.service_time;
  356. packet1.output_volt = packet_in.output_volt;
  357. packet1.output_curr = packet_in.output_curr;
  358. packet1.thr_pos = packet_in.thr_pos;
  359. packet1.fuel_pos = packet_in.fuel_pos;
  360. packet1.fault = packet_in.fault;
  361. packet1.engine_state = packet_in.engine_state;
  362. packet1.index = packet_in.index;
  363. mav_array_memcpy(packet1.reserve, packet_in.reserve, sizeof(uint8_t)*4);
  364. #ifdef MAVLINK_STATUS_FLAG_OUT_MAVLINK1
  365. if (status->flags & MAVLINK_STATUS_FLAG_OUT_MAVLINK1) {
  366. // cope with extensions
  367. memset(MAVLINK_MSG_ID_VK_ENGINE_ECU_STAUS_MIN_LEN + (char *)&packet1, 0, sizeof(packet1)-MAVLINK_MSG_ID_VK_ENGINE_ECU_STAUS_MIN_LEN);
  368. }
  369. #endif
  370. memset(&packet2, 0, sizeof(packet2));
  371. mavlink_msg_vk_engine_ecu_staus_encode(system_id, component_id, &msg, &packet1);
  372. mavlink_msg_vk_engine_ecu_staus_decode(&msg, &packet2);
  373. MAVLINK_ASSERT(memcmp(&packet1, &packet2, sizeof(packet1)) == 0);
  374. memset(&packet2, 0, sizeof(packet2));
  375. mavlink_msg_vk_engine_ecu_staus_pack(system_id, component_id, &msg , packet1.timestamp , packet1.spd_rpm , packet1.thr_pos , packet1.fuel_pos , packet1.cylinderA_temp , packet1.cylinderB_temp , packet1.coolant_temp , packet1.fuel_remain , packet1.alarm , packet1.total_runtime , packet1.runtime , packet1.service_time , packet1.output_volt , packet1.output_curr , packet1.fault , packet1.engine_state , packet1.index , packet1.reserve );
  376. mavlink_msg_vk_engine_ecu_staus_decode(&msg, &packet2);
  377. MAVLINK_ASSERT(memcmp(&packet1, &packet2, sizeof(packet1)) == 0);
  378. memset(&packet2, 0, sizeof(packet2));
  379. mavlink_msg_vk_engine_ecu_staus_pack_chan(system_id, component_id, MAVLINK_COMM_0, &msg , packet1.timestamp , packet1.spd_rpm , packet1.thr_pos , packet1.fuel_pos , packet1.cylinderA_temp , packet1.cylinderB_temp , packet1.coolant_temp , packet1.fuel_remain , packet1.alarm , packet1.total_runtime , packet1.runtime , packet1.service_time , packet1.output_volt , packet1.output_curr , packet1.fault , packet1.engine_state , packet1.index , packet1.reserve );
  380. mavlink_msg_vk_engine_ecu_staus_decode(&msg, &packet2);
  381. MAVLINK_ASSERT(memcmp(&packet1, &packet2, sizeof(packet1)) == 0);
  382. memset(&packet2, 0, sizeof(packet2));
  383. mavlink_msg_to_send_buffer(buffer, &msg);
  384. for (i=0; i<mavlink_msg_get_send_buffer_length(&msg); i++) {
  385. comm_send_ch(MAVLINK_COMM_0, buffer[i]);
  386. }
  387. mavlink_msg_vk_engine_ecu_staus_decode(last_msg, &packet2);
  388. MAVLINK_ASSERT(memcmp(&packet1, &packet2, sizeof(packet1)) == 0);
  389. memset(&packet2, 0, sizeof(packet2));
  390. mavlink_msg_vk_engine_ecu_staus_send(MAVLINK_COMM_1 , packet1.timestamp , packet1.spd_rpm , packet1.thr_pos , packet1.fuel_pos , packet1.cylinderA_temp , packet1.cylinderB_temp , packet1.coolant_temp , packet1.fuel_remain , packet1.alarm , packet1.total_runtime , packet1.runtime , packet1.service_time , packet1.output_volt , packet1.output_curr , packet1.fault , packet1.engine_state , packet1.index , packet1.reserve );
  391. mavlink_msg_vk_engine_ecu_staus_decode(last_msg, &packet2);
  392. MAVLINK_ASSERT(memcmp(&packet1, &packet2, sizeof(packet1)) == 0);
  393. #ifdef MAVLINK_HAVE_GET_MESSAGE_INFO
  394. MAVLINK_ASSERT(mavlink_get_message_info_by_name("VK_ENGINE_ECU_STAUS") != NULL);
  395. MAVLINK_ASSERT(mavlink_get_message_info_by_id(MAVLINK_MSG_ID_VK_ENGINE_ECU_STAUS) != NULL);
  396. #endif
  397. }
  398. static void mavlink_test_vk_comp_version(uint8_t system_id, uint8_t component_id, mavlink_message_t *last_msg)
  399. {
  400. #ifdef MAVLINK_STATUS_FLAG_OUT_MAVLINK1
  401. mavlink_status_t *status = mavlink_get_channel_status(MAVLINK_COMM_0);
  402. if ((status->flags & MAVLINK_STATUS_FLAG_OUT_MAVLINK1) && MAVLINK_MSG_ID_VK_COMP_VERSION >= 256) {
  403. return;
  404. }
  405. #endif
  406. mavlink_message_t msg;
  407. uint8_t buffer[MAVLINK_MAX_PACKET_LEN];
  408. uint16_t i;
  409. mavlink_vk_comp_version_t packet_in = {
  410. 17235,{ 139, 140, 141, 142, 143, 144, 145, 146, 147, 148, 149, 150, 151, 152, 153, 154 },{ 187, 188, 189, 190, 191, 192, 193, 194, 195, 196, 197, 198, 199, 200, 201, 202 },{ 235, 236, 237, 238, 239, 240, 241, 242, 243, 244, 245, 246, 247, 248, 249, 250 },{ 27, 28, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42 },{ 75, 76, 77, 78, 79, 80, 81, 82, 83, 84, 85, 86, 87, 88, 89, 90 },{ 123, 124, 125, 126, 127, 128, 129, 130, 131, 132, 133, 134, 135, 136, 137, 138 }
  411. };
  412. mavlink_vk_comp_version_t packet1, packet2;
  413. memset(&packet1, 0, sizeof(packet1));
  414. packet1.comp_id = packet_in.comp_id;
  415. mav_array_memcpy(packet1.hw_ver, packet_in.hw_ver, sizeof(uint8_t)*16);
  416. mav_array_memcpy(packet1.fw_ver, packet_in.fw_ver, sizeof(uint8_t)*16);
  417. mav_array_memcpy(packet1.SN, packet_in.SN, sizeof(uint8_t)*16);
  418. mav_array_memcpy(packet1.manufactory, packet_in.manufactory, sizeof(uint8_t)*16);
  419. mav_array_memcpy(packet1.model, packet_in.model, sizeof(uint8_t)*16);
  420. mav_array_memcpy(packet1.priv_data, packet_in.priv_data, sizeof(uint8_t)*16);
  421. #ifdef MAVLINK_STATUS_FLAG_OUT_MAVLINK1
  422. if (status->flags & MAVLINK_STATUS_FLAG_OUT_MAVLINK1) {
  423. // cope with extensions
  424. memset(MAVLINK_MSG_ID_VK_COMP_VERSION_MIN_LEN + (char *)&packet1, 0, sizeof(packet1)-MAVLINK_MSG_ID_VK_COMP_VERSION_MIN_LEN);
  425. }
  426. #endif
  427. memset(&packet2, 0, sizeof(packet2));
  428. mavlink_msg_vk_comp_version_encode(system_id, component_id, &msg, &packet1);
  429. mavlink_msg_vk_comp_version_decode(&msg, &packet2);
  430. MAVLINK_ASSERT(memcmp(&packet1, &packet2, sizeof(packet1)) == 0);
  431. memset(&packet2, 0, sizeof(packet2));
  432. mavlink_msg_vk_comp_version_pack(system_id, component_id, &msg , packet1.comp_id , packet1.hw_ver , packet1.fw_ver , packet1.SN , packet1.manufactory , packet1.model , packet1.priv_data );
  433. mavlink_msg_vk_comp_version_decode(&msg, &packet2);
  434. MAVLINK_ASSERT(memcmp(&packet1, &packet2, sizeof(packet1)) == 0);
  435. memset(&packet2, 0, sizeof(packet2));
  436. mavlink_msg_vk_comp_version_pack_chan(system_id, component_id, MAVLINK_COMM_0, &msg , packet1.comp_id , packet1.hw_ver , packet1.fw_ver , packet1.SN , packet1.manufactory , packet1.model , packet1.priv_data );
  437. mavlink_msg_vk_comp_version_decode(&msg, &packet2);
  438. MAVLINK_ASSERT(memcmp(&packet1, &packet2, sizeof(packet1)) == 0);
  439. memset(&packet2, 0, sizeof(packet2));
  440. mavlink_msg_to_send_buffer(buffer, &msg);
  441. for (i=0; i<mavlink_msg_get_send_buffer_length(&msg); i++) {
  442. comm_send_ch(MAVLINK_COMM_0, buffer[i]);
  443. }
  444. mavlink_msg_vk_comp_version_decode(last_msg, &packet2);
  445. MAVLINK_ASSERT(memcmp(&packet1, &packet2, sizeof(packet1)) == 0);
  446. memset(&packet2, 0, sizeof(packet2));
  447. mavlink_msg_vk_comp_version_send(MAVLINK_COMM_1 , packet1.comp_id , packet1.hw_ver , packet1.fw_ver , packet1.SN , packet1.manufactory , packet1.model , packet1.priv_data );
  448. mavlink_msg_vk_comp_version_decode(last_msg, &packet2);
  449. MAVLINK_ASSERT(memcmp(&packet1, &packet2, sizeof(packet1)) == 0);
  450. #ifdef MAVLINK_HAVE_GET_MESSAGE_INFO
  451. MAVLINK_ASSERT(mavlink_get_message_info_by_name("VK_COMP_VERSION") != NULL);
  452. MAVLINK_ASSERT(mavlink_get_message_info_by_id(MAVLINK_MSG_ID_VK_COMP_VERSION) != NULL);
  453. #endif
  454. }
  455. static void mavlink_test_vk_mosaich_gps_raw(uint8_t system_id, uint8_t component_id, mavlink_message_t *last_msg)
  456. {
  457. #ifdef MAVLINK_STATUS_FLAG_OUT_MAVLINK1
  458. mavlink_status_t *status = mavlink_get_channel_status(MAVLINK_COMM_0);
  459. if ((status->flags & MAVLINK_STATUS_FLAG_OUT_MAVLINK1) && MAVLINK_MSG_ID_VK_MOSAICH_GPS_RAW >= 256) {
  460. return;
  461. }
  462. #endif
  463. mavlink_message_t msg;
  464. uint8_t buffer[MAVLINK_MAX_PACKET_LEN];
  465. uint16_t i;
  466. mavlink_vk_mosaich_gps_raw_t packet_in = {
  467. 93372036854775807ULL,963497880,963498088,129.0,157.0,185.0,213.0,241.0,269.0,19315,19419,137,204,15,82,149,216,27,94
  468. };
  469. mavlink_vk_mosaich_gps_raw_t packet1, packet2;
  470. memset(&packet1, 0, sizeof(packet1));
  471. packet1.time_usec = packet_in.time_usec;
  472. packet1.lat = packet_in.lat;
  473. packet1.lon = packet_in.lon;
  474. packet1.ellipsoid_alt = packet_in.ellipsoid_alt;
  475. packet1.ve = packet_in.ve;
  476. packet1.vn = packet_in.vn;
  477. packet1.vu = packet_in.vu;
  478. packet1.yaw = packet_in.yaw;
  479. packet1.pitch = packet_in.pitch;
  480. packet1.h_acc = packet_in.h_acc;
  481. packet1.v_acc = packet_in.v_acc;
  482. packet1.fix_type = packet_in.fix_type;
  483. packet1.psv_num = packet_in.psv_num;
  484. packet1.pvt_err = packet_in.pvt_err;
  485. packet1.pvt_mode = packet_in.pvt_mode;
  486. packet1.hsv_num = packet_in.hsv_num;
  487. packet1.att_err = packet_in.att_err;
  488. packet1.att_mode = packet_in.att_mode;
  489. packet1.reserved = packet_in.reserved;
  490. #ifdef MAVLINK_STATUS_FLAG_OUT_MAVLINK1
  491. if (status->flags & MAVLINK_STATUS_FLAG_OUT_MAVLINK1) {
  492. // cope with extensions
  493. memset(MAVLINK_MSG_ID_VK_MOSAICH_GPS_RAW_MIN_LEN + (char *)&packet1, 0, sizeof(packet1)-MAVLINK_MSG_ID_VK_MOSAICH_GPS_RAW_MIN_LEN);
  494. }
  495. #endif
  496. memset(&packet2, 0, sizeof(packet2));
  497. mavlink_msg_vk_mosaich_gps_raw_encode(system_id, component_id, &msg, &packet1);
  498. mavlink_msg_vk_mosaich_gps_raw_decode(&msg, &packet2);
  499. MAVLINK_ASSERT(memcmp(&packet1, &packet2, sizeof(packet1)) == 0);
  500. memset(&packet2, 0, sizeof(packet2));
  501. mavlink_msg_vk_mosaich_gps_raw_pack(system_id, component_id, &msg , packet1.time_usec , packet1.fix_type , packet1.psv_num , packet1.pvt_err , packet1.pvt_mode , packet1.lat , packet1.lon , packet1.ellipsoid_alt , packet1.ve , packet1.vn , packet1.vu , packet1.h_acc , packet1.v_acc , packet1.yaw , packet1.pitch , packet1.hsv_num , packet1.att_err , packet1.att_mode , packet1.reserved );
  502. mavlink_msg_vk_mosaich_gps_raw_decode(&msg, &packet2);
  503. MAVLINK_ASSERT(memcmp(&packet1, &packet2, sizeof(packet1)) == 0);
  504. memset(&packet2, 0, sizeof(packet2));
  505. mavlink_msg_vk_mosaich_gps_raw_pack_chan(system_id, component_id, MAVLINK_COMM_0, &msg , packet1.time_usec , packet1.fix_type , packet1.psv_num , packet1.pvt_err , packet1.pvt_mode , packet1.lat , packet1.lon , packet1.ellipsoid_alt , packet1.ve , packet1.vn , packet1.vu , packet1.h_acc , packet1.v_acc , packet1.yaw , packet1.pitch , packet1.hsv_num , packet1.att_err , packet1.att_mode , packet1.reserved );
  506. mavlink_msg_vk_mosaich_gps_raw_decode(&msg, &packet2);
  507. MAVLINK_ASSERT(memcmp(&packet1, &packet2, sizeof(packet1)) == 0);
  508. memset(&packet2, 0, sizeof(packet2));
  509. mavlink_msg_to_send_buffer(buffer, &msg);
  510. for (i=0; i<mavlink_msg_get_send_buffer_length(&msg); i++) {
  511. comm_send_ch(MAVLINK_COMM_0, buffer[i]);
  512. }
  513. mavlink_msg_vk_mosaich_gps_raw_decode(last_msg, &packet2);
  514. MAVLINK_ASSERT(memcmp(&packet1, &packet2, sizeof(packet1)) == 0);
  515. memset(&packet2, 0, sizeof(packet2));
  516. mavlink_msg_vk_mosaich_gps_raw_send(MAVLINK_COMM_1 , packet1.time_usec , packet1.fix_type , packet1.psv_num , packet1.pvt_err , packet1.pvt_mode , packet1.lat , packet1.lon , packet1.ellipsoid_alt , packet1.ve , packet1.vn , packet1.vu , packet1.h_acc , packet1.v_acc , packet1.yaw , packet1.pitch , packet1.hsv_num , packet1.att_err , packet1.att_mode , packet1.reserved );
  517. mavlink_msg_vk_mosaich_gps_raw_decode(last_msg, &packet2);
  518. MAVLINK_ASSERT(memcmp(&packet1, &packet2, sizeof(packet1)) == 0);
  519. #ifdef MAVLINK_HAVE_GET_MESSAGE_INFO
  520. MAVLINK_ASSERT(mavlink_get_message_info_by_name("VK_MOSAICH_GPS_RAW") != NULL);
  521. MAVLINK_ASSERT(mavlink_get_message_info_by_id(MAVLINK_MSG_ID_VK_MOSAICH_GPS_RAW) != NULL);
  522. #endif
  523. }
  524. static void mavlink_test_vk_digi_esc_status(uint8_t system_id, uint8_t component_id, mavlink_message_t *last_msg)
  525. {
  526. #ifdef MAVLINK_STATUS_FLAG_OUT_MAVLINK1
  527. mavlink_status_t *status = mavlink_get_channel_status(MAVLINK_COMM_0);
  528. if ((status->flags & MAVLINK_STATUS_FLAG_OUT_MAVLINK1) && MAVLINK_MSG_ID_VK_DIGI_ESC_STATUS >= 256) {
  529. return;
  530. }
  531. #endif
  532. mavlink_message_t msg;
  533. uint8_t buffer[MAVLINK_MAX_PACKET_LEN];
  534. uint16_t i;
  535. mavlink_vk_digi_esc_status_t packet_in = {
  536. 963497464,{ 963497672, 963497673, 963497674, 963497675 },{ 157.0, 158.0, 159.0, 160.0 },{ 269.0, 270.0, 271.0, 272.0 },{ 963500168, 963500169, 963500170, 963500171 },{ 20771, 20772, 20773, 20774 },233
  537. };
  538. mavlink_vk_digi_esc_status_t packet1, packet2;
  539. memset(&packet1, 0, sizeof(packet1));
  540. packet1.timestamp = packet_in.timestamp;
  541. packet1.index = packet_in.index;
  542. mav_array_memcpy(packet1.rpm, packet_in.rpm, sizeof(int32_t)*4);
  543. mav_array_memcpy(packet1.voltage, packet_in.voltage, sizeof(float)*4);
  544. mav_array_memcpy(packet1.current, packet_in.current, sizeof(float)*4);
  545. mav_array_memcpy(packet1.status, packet_in.status, sizeof(uint32_t)*4);
  546. mav_array_memcpy(packet1.temperature, packet_in.temperature, sizeof(int16_t)*4);
  547. #ifdef MAVLINK_STATUS_FLAG_OUT_MAVLINK1
  548. if (status->flags & MAVLINK_STATUS_FLAG_OUT_MAVLINK1) {
  549. // cope with extensions
  550. memset(MAVLINK_MSG_ID_VK_DIGI_ESC_STATUS_MIN_LEN + (char *)&packet1, 0, sizeof(packet1)-MAVLINK_MSG_ID_VK_DIGI_ESC_STATUS_MIN_LEN);
  551. }
  552. #endif
  553. memset(&packet2, 0, sizeof(packet2));
  554. mavlink_msg_vk_digi_esc_status_encode(system_id, component_id, &msg, &packet1);
  555. mavlink_msg_vk_digi_esc_status_decode(&msg, &packet2);
  556. MAVLINK_ASSERT(memcmp(&packet1, &packet2, sizeof(packet1)) == 0);
  557. memset(&packet2, 0, sizeof(packet2));
  558. mavlink_msg_vk_digi_esc_status_pack(system_id, component_id, &msg , packet1.index , packet1.timestamp , packet1.rpm , packet1.voltage , packet1.current , packet1.temperature , packet1.status );
  559. mavlink_msg_vk_digi_esc_status_decode(&msg, &packet2);
  560. MAVLINK_ASSERT(memcmp(&packet1, &packet2, sizeof(packet1)) == 0);
  561. memset(&packet2, 0, sizeof(packet2));
  562. mavlink_msg_vk_digi_esc_status_pack_chan(system_id, component_id, MAVLINK_COMM_0, &msg , packet1.index , packet1.timestamp , packet1.rpm , packet1.voltage , packet1.current , packet1.temperature , packet1.status );
  563. mavlink_msg_vk_digi_esc_status_decode(&msg, &packet2);
  564. MAVLINK_ASSERT(memcmp(&packet1, &packet2, sizeof(packet1)) == 0);
  565. memset(&packet2, 0, sizeof(packet2));
  566. mavlink_msg_to_send_buffer(buffer, &msg);
  567. for (i=0; i<mavlink_msg_get_send_buffer_length(&msg); i++) {
  568. comm_send_ch(MAVLINK_COMM_0, buffer[i]);
  569. }
  570. mavlink_msg_vk_digi_esc_status_decode(last_msg, &packet2);
  571. MAVLINK_ASSERT(memcmp(&packet1, &packet2, sizeof(packet1)) == 0);
  572. memset(&packet2, 0, sizeof(packet2));
  573. mavlink_msg_vk_digi_esc_status_send(MAVLINK_COMM_1 , packet1.index , packet1.timestamp , packet1.rpm , packet1.voltage , packet1.current , packet1.temperature , packet1.status );
  574. mavlink_msg_vk_digi_esc_status_decode(last_msg, &packet2);
  575. MAVLINK_ASSERT(memcmp(&packet1, &packet2, sizeof(packet1)) == 0);
  576. #ifdef MAVLINK_HAVE_GET_MESSAGE_INFO
  577. MAVLINK_ASSERT(mavlink_get_message_info_by_name("VK_DIGI_ESC_STATUS") != NULL);
  578. MAVLINK_ASSERT(mavlink_get_message_info_by_id(MAVLINK_MSG_ID_VK_DIGI_ESC_STATUS) != NULL);
  579. #endif
  580. }
  581. static void mavlink_test_vk_fixedwing_control_value(uint8_t system_id, uint8_t component_id, mavlink_message_t *last_msg)
  582. {
  583. #ifdef MAVLINK_STATUS_FLAG_OUT_MAVLINK1
  584. mavlink_status_t *status = mavlink_get_channel_status(MAVLINK_COMM_0);
  585. if ((status->flags & MAVLINK_STATUS_FLAG_OUT_MAVLINK1) && MAVLINK_MSG_ID_VK_FIXEDWING_CONTROL_VALUE >= 256) {
  586. return;
  587. }
  588. #endif
  589. mavlink_message_t msg;
  590. uint8_t buffer[MAVLINK_MAX_PACKET_LEN];
  591. uint16_t i;
  592. mavlink_vk_fixedwing_control_value_t packet_in = {
  593. 963497464,45.0,73.0,101.0,129.0
  594. };
  595. mavlink_vk_fixedwing_control_value_t packet1, packet2;
  596. memset(&packet1, 0, sizeof(packet1));
  597. packet1.timestamp = packet_in.timestamp;
  598. packet1.roll_value = packet_in.roll_value;
  599. packet1.pitch_value = packet_in.pitch_value;
  600. packet1.throttle_value = packet_in.throttle_value;
  601. packet1.yaw_value = packet_in.yaw_value;
  602. #ifdef MAVLINK_STATUS_FLAG_OUT_MAVLINK1
  603. if (status->flags & MAVLINK_STATUS_FLAG_OUT_MAVLINK1) {
  604. // cope with extensions
  605. memset(MAVLINK_MSG_ID_VK_FIXEDWING_CONTROL_VALUE_MIN_LEN + (char *)&packet1, 0, sizeof(packet1)-MAVLINK_MSG_ID_VK_FIXEDWING_CONTROL_VALUE_MIN_LEN);
  606. }
  607. #endif
  608. memset(&packet2, 0, sizeof(packet2));
  609. mavlink_msg_vk_fixedwing_control_value_encode(system_id, component_id, &msg, &packet1);
  610. mavlink_msg_vk_fixedwing_control_value_decode(&msg, &packet2);
  611. MAVLINK_ASSERT(memcmp(&packet1, &packet2, sizeof(packet1)) == 0);
  612. memset(&packet2, 0, sizeof(packet2));
  613. mavlink_msg_vk_fixedwing_control_value_pack(system_id, component_id, &msg , packet1.timestamp , packet1.roll_value , packet1.pitch_value , packet1.throttle_value , packet1.yaw_value );
  614. mavlink_msg_vk_fixedwing_control_value_decode(&msg, &packet2);
  615. MAVLINK_ASSERT(memcmp(&packet1, &packet2, sizeof(packet1)) == 0);
  616. memset(&packet2, 0, sizeof(packet2));
  617. mavlink_msg_vk_fixedwing_control_value_pack_chan(system_id, component_id, MAVLINK_COMM_0, &msg , packet1.timestamp , packet1.roll_value , packet1.pitch_value , packet1.throttle_value , packet1.yaw_value );
  618. mavlink_msg_vk_fixedwing_control_value_decode(&msg, &packet2);
  619. MAVLINK_ASSERT(memcmp(&packet1, &packet2, sizeof(packet1)) == 0);
  620. memset(&packet2, 0, sizeof(packet2));
  621. mavlink_msg_to_send_buffer(buffer, &msg);
  622. for (i=0; i<mavlink_msg_get_send_buffer_length(&msg); i++) {
  623. comm_send_ch(MAVLINK_COMM_0, buffer[i]);
  624. }
  625. mavlink_msg_vk_fixedwing_control_value_decode(last_msg, &packet2);
  626. MAVLINK_ASSERT(memcmp(&packet1, &packet2, sizeof(packet1)) == 0);
  627. memset(&packet2, 0, sizeof(packet2));
  628. mavlink_msg_vk_fixedwing_control_value_send(MAVLINK_COMM_1 , packet1.timestamp , packet1.roll_value , packet1.pitch_value , packet1.throttle_value , packet1.yaw_value );
  629. mavlink_msg_vk_fixedwing_control_value_decode(last_msg, &packet2);
  630. MAVLINK_ASSERT(memcmp(&packet1, &packet2, sizeof(packet1)) == 0);
  631. #ifdef MAVLINK_HAVE_GET_MESSAGE_INFO
  632. MAVLINK_ASSERT(mavlink_get_message_info_by_name("VK_FIXEDWING_CONTROL_VALUE") != NULL);
  633. MAVLINK_ASSERT(mavlink_get_message_info_by_id(MAVLINK_MSG_ID_VK_FIXEDWING_CONTROL_VALUE) != NULL);
  634. #endif
  635. }
  636. static void mavlink_test_vk_fixedwing_servo_signal(uint8_t system_id, uint8_t component_id, mavlink_message_t *last_msg)
  637. {
  638. #ifdef MAVLINK_STATUS_FLAG_OUT_MAVLINK1
  639. mavlink_status_t *status = mavlink_get_channel_status(MAVLINK_COMM_0);
  640. if ((status->flags & MAVLINK_STATUS_FLAG_OUT_MAVLINK1) && MAVLINK_MSG_ID_VK_FIXEDWING_SERVO_SIGNAL >= 256) {
  641. return;
  642. }
  643. #endif
  644. mavlink_message_t msg;
  645. uint8_t buffer[MAVLINK_MAX_PACKET_LEN];
  646. uint16_t i;
  647. mavlink_vk_fixedwing_servo_signal_t packet_in = {
  648. 963497464,{ 17443, 17444, 17445, 17446, 17447, 17448, 17449, 17450, 17451, 17452, 17453, 17454, 17455, 17456, 17457, 17458 }
  649. };
  650. mavlink_vk_fixedwing_servo_signal_t packet1, packet2;
  651. memset(&packet1, 0, sizeof(packet1));
  652. packet1.timestamp = packet_in.timestamp;
  653. mav_array_memcpy(packet1.servo_signal, packet_in.servo_signal, sizeof(uint16_t)*16);
  654. #ifdef MAVLINK_STATUS_FLAG_OUT_MAVLINK1
  655. if (status->flags & MAVLINK_STATUS_FLAG_OUT_MAVLINK1) {
  656. // cope with extensions
  657. memset(MAVLINK_MSG_ID_VK_FIXEDWING_SERVO_SIGNAL_MIN_LEN + (char *)&packet1, 0, sizeof(packet1)-MAVLINK_MSG_ID_VK_FIXEDWING_SERVO_SIGNAL_MIN_LEN);
  658. }
  659. #endif
  660. memset(&packet2, 0, sizeof(packet2));
  661. mavlink_msg_vk_fixedwing_servo_signal_encode(system_id, component_id, &msg, &packet1);
  662. mavlink_msg_vk_fixedwing_servo_signal_decode(&msg, &packet2);
  663. MAVLINK_ASSERT(memcmp(&packet1, &packet2, sizeof(packet1)) == 0);
  664. memset(&packet2, 0, sizeof(packet2));
  665. mavlink_msg_vk_fixedwing_servo_signal_pack(system_id, component_id, &msg , packet1.timestamp , packet1.servo_signal );
  666. mavlink_msg_vk_fixedwing_servo_signal_decode(&msg, &packet2);
  667. MAVLINK_ASSERT(memcmp(&packet1, &packet2, sizeof(packet1)) == 0);
  668. memset(&packet2, 0, sizeof(packet2));
  669. mavlink_msg_vk_fixedwing_servo_signal_pack_chan(system_id, component_id, MAVLINK_COMM_0, &msg , packet1.timestamp , packet1.servo_signal );
  670. mavlink_msg_vk_fixedwing_servo_signal_decode(&msg, &packet2);
  671. MAVLINK_ASSERT(memcmp(&packet1, &packet2, sizeof(packet1)) == 0);
  672. memset(&packet2, 0, sizeof(packet2));
  673. mavlink_msg_to_send_buffer(buffer, &msg);
  674. for (i=0; i<mavlink_msg_get_send_buffer_length(&msg); i++) {
  675. comm_send_ch(MAVLINK_COMM_0, buffer[i]);
  676. }
  677. mavlink_msg_vk_fixedwing_servo_signal_decode(last_msg, &packet2);
  678. MAVLINK_ASSERT(memcmp(&packet1, &packet2, sizeof(packet1)) == 0);
  679. memset(&packet2, 0, sizeof(packet2));
  680. mavlink_msg_vk_fixedwing_servo_signal_send(MAVLINK_COMM_1 , packet1.timestamp , packet1.servo_signal );
  681. mavlink_msg_vk_fixedwing_servo_signal_decode(last_msg, &packet2);
  682. MAVLINK_ASSERT(memcmp(&packet1, &packet2, sizeof(packet1)) == 0);
  683. #ifdef MAVLINK_HAVE_GET_MESSAGE_INFO
  684. MAVLINK_ASSERT(mavlink_get_message_info_by_name("VK_FIXEDWING_SERVO_SIGNAL") != NULL);
  685. MAVLINK_ASSERT(mavlink_get_message_info_by_id(MAVLINK_MSG_ID_VK_FIXEDWING_SERVO_SIGNAL) != NULL);
  686. #endif
  687. }
  688. static void mavlink_test_vk_fixedwing_rtl_circle_wp(uint8_t system_id, uint8_t component_id, mavlink_message_t *last_msg)
  689. {
  690. #ifdef MAVLINK_STATUS_FLAG_OUT_MAVLINK1
  691. mavlink_status_t *status = mavlink_get_channel_status(MAVLINK_COMM_0);
  692. if ((status->flags & MAVLINK_STATUS_FLAG_OUT_MAVLINK1) && MAVLINK_MSG_ID_VK_FIXEDWING_RTL_CIRCLE_WP >= 256) {
  693. return;
  694. }
  695. #endif
  696. mavlink_message_t msg;
  697. uint8_t buffer[MAVLINK_MAX_PACKET_LEN];
  698. uint16_t i;
  699. mavlink_vk_fixedwing_rtl_circle_wp_t packet_in = {
  700. 963497464,963497672,73.0,101.0
  701. };
  702. mavlink_vk_fixedwing_rtl_circle_wp_t packet1, packet2;
  703. memset(&packet1, 0, sizeof(packet1));
  704. packet1.latitude = packet_in.latitude;
  705. packet1.longitude = packet_in.longitude;
  706. packet1.altitude = packet_in.altitude;
  707. packet1.radius = packet_in.radius;
  708. #ifdef MAVLINK_STATUS_FLAG_OUT_MAVLINK1
  709. if (status->flags & MAVLINK_STATUS_FLAG_OUT_MAVLINK1) {
  710. // cope with extensions
  711. memset(MAVLINK_MSG_ID_VK_FIXEDWING_RTL_CIRCLE_WP_MIN_LEN + (char *)&packet1, 0, sizeof(packet1)-MAVLINK_MSG_ID_VK_FIXEDWING_RTL_CIRCLE_WP_MIN_LEN);
  712. }
  713. #endif
  714. memset(&packet2, 0, sizeof(packet2));
  715. mavlink_msg_vk_fixedwing_rtl_circle_wp_encode(system_id, component_id, &msg, &packet1);
  716. mavlink_msg_vk_fixedwing_rtl_circle_wp_decode(&msg, &packet2);
  717. MAVLINK_ASSERT(memcmp(&packet1, &packet2, sizeof(packet1)) == 0);
  718. memset(&packet2, 0, sizeof(packet2));
  719. mavlink_msg_vk_fixedwing_rtl_circle_wp_pack(system_id, component_id, &msg , packet1.latitude , packet1.longitude , packet1.altitude , packet1.radius );
  720. mavlink_msg_vk_fixedwing_rtl_circle_wp_decode(&msg, &packet2);
  721. MAVLINK_ASSERT(memcmp(&packet1, &packet2, sizeof(packet1)) == 0);
  722. memset(&packet2, 0, sizeof(packet2));
  723. mavlink_msg_vk_fixedwing_rtl_circle_wp_pack_chan(system_id, component_id, MAVLINK_COMM_0, &msg , packet1.latitude , packet1.longitude , packet1.altitude , packet1.radius );
  724. mavlink_msg_vk_fixedwing_rtl_circle_wp_decode(&msg, &packet2);
  725. MAVLINK_ASSERT(memcmp(&packet1, &packet2, sizeof(packet1)) == 0);
  726. memset(&packet2, 0, sizeof(packet2));
  727. mavlink_msg_to_send_buffer(buffer, &msg);
  728. for (i=0; i<mavlink_msg_get_send_buffer_length(&msg); i++) {
  729. comm_send_ch(MAVLINK_COMM_0, buffer[i]);
  730. }
  731. mavlink_msg_vk_fixedwing_rtl_circle_wp_decode(last_msg, &packet2);
  732. MAVLINK_ASSERT(memcmp(&packet1, &packet2, sizeof(packet1)) == 0);
  733. memset(&packet2, 0, sizeof(packet2));
  734. mavlink_msg_vk_fixedwing_rtl_circle_wp_send(MAVLINK_COMM_1 , packet1.latitude , packet1.longitude , packet1.altitude , packet1.radius );
  735. mavlink_msg_vk_fixedwing_rtl_circle_wp_decode(last_msg, &packet2);
  736. MAVLINK_ASSERT(memcmp(&packet1, &packet2, sizeof(packet1)) == 0);
  737. #ifdef MAVLINK_HAVE_GET_MESSAGE_INFO
  738. MAVLINK_ASSERT(mavlink_get_message_info_by_name("VK_FIXEDWING_RTL_CIRCLE_WP") != NULL);
  739. MAVLINK_ASSERT(mavlink_get_message_info_by_id(MAVLINK_MSG_ID_VK_FIXEDWING_RTL_CIRCLE_WP) != NULL);
  740. #endif
  741. }
  742. static void mavlink_test_vk_parachute_status(uint8_t system_id, uint8_t component_id, mavlink_message_t *last_msg)
  743. {
  744. #ifdef MAVLINK_STATUS_FLAG_OUT_MAVLINK1
  745. mavlink_status_t *status = mavlink_get_channel_status(MAVLINK_COMM_0);
  746. if ((status->flags & MAVLINK_STATUS_FLAG_OUT_MAVLINK1) && MAVLINK_MSG_ID_VK_PARACHUTE_STATUS >= 256) {
  747. return;
  748. }
  749. #endif
  750. mavlink_message_t msg;
  751. uint8_t buffer[MAVLINK_MAX_PACKET_LEN];
  752. uint16_t i;
  753. mavlink_vk_parachute_status_t packet_in = {
  754. 963497464,45.0,17651,163,230,41
  755. };
  756. mavlink_vk_parachute_status_t packet1, packet2;
  757. memset(&packet1, 0, sizeof(packet1));
  758. packet1.timestamp = packet_in.timestamp;
  759. packet1.backvolt = packet_in.backvolt;
  760. packet1.err_code = packet_in.err_code;
  761. packet1.state = packet_in.state;
  762. packet1.auto_launch = packet_in.auto_launch;
  763. packet1.uav_cmd = packet_in.uav_cmd;
  764. #ifdef MAVLINK_STATUS_FLAG_OUT_MAVLINK1
  765. if (status->flags & MAVLINK_STATUS_FLAG_OUT_MAVLINK1) {
  766. // cope with extensions
  767. memset(MAVLINK_MSG_ID_VK_PARACHUTE_STATUS_MIN_LEN + (char *)&packet1, 0, sizeof(packet1)-MAVLINK_MSG_ID_VK_PARACHUTE_STATUS_MIN_LEN);
  768. }
  769. #endif
  770. memset(&packet2, 0, sizeof(packet2));
  771. mavlink_msg_vk_parachute_status_encode(system_id, component_id, &msg, &packet1);
  772. mavlink_msg_vk_parachute_status_decode(&msg, &packet2);
  773. MAVLINK_ASSERT(memcmp(&packet1, &packet2, sizeof(packet1)) == 0);
  774. memset(&packet2, 0, sizeof(packet2));
  775. mavlink_msg_vk_parachute_status_pack(system_id, component_id, &msg , packet1.timestamp , packet1.state , packet1.auto_launch , packet1.uav_cmd , packet1.err_code , packet1.backvolt );
  776. mavlink_msg_vk_parachute_status_decode(&msg, &packet2);
  777. MAVLINK_ASSERT(memcmp(&packet1, &packet2, sizeof(packet1)) == 0);
  778. memset(&packet2, 0, sizeof(packet2));
  779. mavlink_msg_vk_parachute_status_pack_chan(system_id, component_id, MAVLINK_COMM_0, &msg , packet1.timestamp , packet1.state , packet1.auto_launch , packet1.uav_cmd , packet1.err_code , packet1.backvolt );
  780. mavlink_msg_vk_parachute_status_decode(&msg, &packet2);
  781. MAVLINK_ASSERT(memcmp(&packet1, &packet2, sizeof(packet1)) == 0);
  782. memset(&packet2, 0, sizeof(packet2));
  783. mavlink_msg_to_send_buffer(buffer, &msg);
  784. for (i=0; i<mavlink_msg_get_send_buffer_length(&msg); i++) {
  785. comm_send_ch(MAVLINK_COMM_0, buffer[i]);
  786. }
  787. mavlink_msg_vk_parachute_status_decode(last_msg, &packet2);
  788. MAVLINK_ASSERT(memcmp(&packet1, &packet2, sizeof(packet1)) == 0);
  789. memset(&packet2, 0, sizeof(packet2));
  790. mavlink_msg_vk_parachute_status_send(MAVLINK_COMM_1 , packet1.timestamp , packet1.state , packet1.auto_launch , packet1.uav_cmd , packet1.err_code , packet1.backvolt );
  791. mavlink_msg_vk_parachute_status_decode(last_msg, &packet2);
  792. MAVLINK_ASSERT(memcmp(&packet1, &packet2, sizeof(packet1)) == 0);
  793. #ifdef MAVLINK_HAVE_GET_MESSAGE_INFO
  794. MAVLINK_ASSERT(mavlink_get_message_info_by_name("VK_PARACHUTE_STATUS") != NULL);
  795. MAVLINK_ASSERT(mavlink_get_message_info_by_id(MAVLINK_MSG_ID_VK_PARACHUTE_STATUS) != NULL);
  796. #endif
  797. }
  798. static void mavlink_test_vk_weigher_state(uint8_t system_id, uint8_t component_id, mavlink_message_t *last_msg)
  799. {
  800. #ifdef MAVLINK_STATUS_FLAG_OUT_MAVLINK1
  801. mavlink_status_t *status = mavlink_get_channel_status(MAVLINK_COMM_0);
  802. if ((status->flags & MAVLINK_STATUS_FLAG_OUT_MAVLINK1) && MAVLINK_MSG_ID_VK_WEIGHER_STATE >= 256) {
  803. return;
  804. }
  805. #endif
  806. mavlink_message_t msg;
  807. uint8_t buffer[MAVLINK_MAX_PACKET_LEN];
  808. uint16_t i;
  809. mavlink_vk_weigher_state_t packet_in = {
  810. 963497464,963497672,17651,163,230
  811. };
  812. mavlink_vk_weigher_state_t packet1, packet2;
  813. memset(&packet1, 0, sizeof(packet1));
  814. packet1.timestamp = packet_in.timestamp;
  815. packet1.weight = packet_in.weight;
  816. packet1.weight_d = packet_in.weight_d;
  817. packet1.work_state = packet_in.work_state;
  818. packet1.err_code = packet_in.err_code;
  819. #ifdef MAVLINK_STATUS_FLAG_OUT_MAVLINK1
  820. if (status->flags & MAVLINK_STATUS_FLAG_OUT_MAVLINK1) {
  821. // cope with extensions
  822. memset(MAVLINK_MSG_ID_VK_WEIGHER_STATE_MIN_LEN + (char *)&packet1, 0, sizeof(packet1)-MAVLINK_MSG_ID_VK_WEIGHER_STATE_MIN_LEN);
  823. }
  824. #endif
  825. memset(&packet2, 0, sizeof(packet2));
  826. mavlink_msg_vk_weigher_state_encode(system_id, component_id, &msg, &packet1);
  827. mavlink_msg_vk_weigher_state_decode(&msg, &packet2);
  828. MAVLINK_ASSERT(memcmp(&packet1, &packet2, sizeof(packet1)) == 0);
  829. memset(&packet2, 0, sizeof(packet2));
  830. mavlink_msg_vk_weigher_state_pack(system_id, component_id, &msg , packet1.timestamp , packet1.weight , packet1.weight_d , packet1.work_state , packet1.err_code );
  831. mavlink_msg_vk_weigher_state_decode(&msg, &packet2);
  832. MAVLINK_ASSERT(memcmp(&packet1, &packet2, sizeof(packet1)) == 0);
  833. memset(&packet2, 0, sizeof(packet2));
  834. mavlink_msg_vk_weigher_state_pack_chan(system_id, component_id, MAVLINK_COMM_0, &msg , packet1.timestamp , packet1.weight , packet1.weight_d , packet1.work_state , packet1.err_code );
  835. mavlink_msg_vk_weigher_state_decode(&msg, &packet2);
  836. MAVLINK_ASSERT(memcmp(&packet1, &packet2, sizeof(packet1)) == 0);
  837. memset(&packet2, 0, sizeof(packet2));
  838. mavlink_msg_to_send_buffer(buffer, &msg);
  839. for (i=0; i<mavlink_msg_get_send_buffer_length(&msg); i++) {
  840. comm_send_ch(MAVLINK_COMM_0, buffer[i]);
  841. }
  842. mavlink_msg_vk_weigher_state_decode(last_msg, &packet2);
  843. MAVLINK_ASSERT(memcmp(&packet1, &packet2, sizeof(packet1)) == 0);
  844. memset(&packet2, 0, sizeof(packet2));
  845. mavlink_msg_vk_weigher_state_send(MAVLINK_COMM_1 , packet1.timestamp , packet1.weight , packet1.weight_d , packet1.work_state , packet1.err_code );
  846. mavlink_msg_vk_weigher_state_decode(last_msg, &packet2);
  847. MAVLINK_ASSERT(memcmp(&packet1, &packet2, sizeof(packet1)) == 0);
  848. #ifdef MAVLINK_HAVE_GET_MESSAGE_INFO
  849. MAVLINK_ASSERT(mavlink_get_message_info_by_name("VK_WEIGHER_STATE") != NULL);
  850. MAVLINK_ASSERT(mavlink_get_message_info_by_id(MAVLINK_MSG_ID_VK_WEIGHER_STATE) != NULL);
  851. #endif
  852. }
  853. static void mavlink_test_vk_payload_data_relay(uint8_t system_id, uint8_t component_id, mavlink_message_t *last_msg)
  854. {
  855. #ifdef MAVLINK_STATUS_FLAG_OUT_MAVLINK1
  856. mavlink_status_t *status = mavlink_get_channel_status(MAVLINK_COMM_0);
  857. if ((status->flags & MAVLINK_STATUS_FLAG_OUT_MAVLINK1) && MAVLINK_MSG_ID_VK_PAYLOAD_DATA_RELAY >= 256) {
  858. return;
  859. }
  860. #endif
  861. mavlink_message_t msg;
  862. uint8_t buffer[MAVLINK_MAX_PACKET_LEN];
  863. uint16_t i;
  864. mavlink_vk_payload_data_relay_t packet_in = {
  865. 17235,139,206,{ 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45, 46, 47, 48, 49, 50, 51, 52, 53, 54, 55, 56, 57, 58, 59, 60, 61, 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 81, 82, 83, 84, 85, 86, 87, 88, 89, 90, 91, 92, 93, 94, 95, 96, 97, 98, 99, 100, 101, 102, 103, 104, 105, 106, 107, 108, 109, 110, 111, 112, 113, 114, 115, 116, 117, 118, 119, 120, 121, 122, 123, 124, 125, 126, 127, 128, 129, 130, 131, 132, 133, 134, 135, 136, 137, 138, 139, 140, 141, 142, 143, 144 }
  866. };
  867. mavlink_vk_payload_data_relay_t packet1, packet2;
  868. memset(&packet1, 0, sizeof(packet1));
  869. packet1.payload_addr = packet_in.payload_addr;
  870. packet1.reserve = packet_in.reserve;
  871. packet1.data_len = packet_in.data_len;
  872. mav_array_memcpy(packet1.data, packet_in.data, sizeof(uint8_t)*128);
  873. #ifdef MAVLINK_STATUS_FLAG_OUT_MAVLINK1
  874. if (status->flags & MAVLINK_STATUS_FLAG_OUT_MAVLINK1) {
  875. // cope with extensions
  876. memset(MAVLINK_MSG_ID_VK_PAYLOAD_DATA_RELAY_MIN_LEN + (char *)&packet1, 0, sizeof(packet1)-MAVLINK_MSG_ID_VK_PAYLOAD_DATA_RELAY_MIN_LEN);
  877. }
  878. #endif
  879. memset(&packet2, 0, sizeof(packet2));
  880. mavlink_msg_vk_payload_data_relay_encode(system_id, component_id, &msg, &packet1);
  881. mavlink_msg_vk_payload_data_relay_decode(&msg, &packet2);
  882. MAVLINK_ASSERT(memcmp(&packet1, &packet2, sizeof(packet1)) == 0);
  883. memset(&packet2, 0, sizeof(packet2));
  884. mavlink_msg_vk_payload_data_relay_pack(system_id, component_id, &msg , packet1.payload_addr , packet1.reserve , packet1.data_len , packet1.data );
  885. mavlink_msg_vk_payload_data_relay_decode(&msg, &packet2);
  886. MAVLINK_ASSERT(memcmp(&packet1, &packet2, sizeof(packet1)) == 0);
  887. memset(&packet2, 0, sizeof(packet2));
  888. mavlink_msg_vk_payload_data_relay_pack_chan(system_id, component_id, MAVLINK_COMM_0, &msg , packet1.payload_addr , packet1.reserve , packet1.data_len , packet1.data );
  889. mavlink_msg_vk_payload_data_relay_decode(&msg, &packet2);
  890. MAVLINK_ASSERT(memcmp(&packet1, &packet2, sizeof(packet1)) == 0);
  891. memset(&packet2, 0, sizeof(packet2));
  892. mavlink_msg_to_send_buffer(buffer, &msg);
  893. for (i=0; i<mavlink_msg_get_send_buffer_length(&msg); i++) {
  894. comm_send_ch(MAVLINK_COMM_0, buffer[i]);
  895. }
  896. mavlink_msg_vk_payload_data_relay_decode(last_msg, &packet2);
  897. MAVLINK_ASSERT(memcmp(&packet1, &packet2, sizeof(packet1)) == 0);
  898. memset(&packet2, 0, sizeof(packet2));
  899. mavlink_msg_vk_payload_data_relay_send(MAVLINK_COMM_1 , packet1.payload_addr , packet1.reserve , packet1.data_len , packet1.data );
  900. mavlink_msg_vk_payload_data_relay_decode(last_msg, &packet2);
  901. MAVLINK_ASSERT(memcmp(&packet1, &packet2, sizeof(packet1)) == 0);
  902. #ifdef MAVLINK_HAVE_GET_MESSAGE_INFO
  903. MAVLINK_ASSERT(mavlink_get_message_info_by_name("VK_PAYLOAD_DATA_RELAY") != NULL);
  904. MAVLINK_ASSERT(mavlink_get_message_info_by_id(MAVLINK_MSG_ID_VK_PAYLOAD_DATA_RELAY) != NULL);
  905. #endif
  906. }
  907. static void mavlink_test_vk_fw_update_begin(uint8_t system_id, uint8_t component_id, mavlink_message_t *last_msg)
  908. {
  909. #ifdef MAVLINK_STATUS_FLAG_OUT_MAVLINK1
  910. mavlink_status_t *status = mavlink_get_channel_status(MAVLINK_COMM_0);
  911. if ((status->flags & MAVLINK_STATUS_FLAG_OUT_MAVLINK1) && MAVLINK_MSG_ID_VK_FW_UPDATE_BEGIN >= 256) {
  912. return;
  913. }
  914. #endif
  915. mavlink_message_t msg;
  916. uint8_t buffer[MAVLINK_MAX_PACKET_LEN];
  917. uint16_t i;
  918. mavlink_vk_fw_update_begin_t packet_in = {
  919. 963497464,17,84
  920. };
  921. mavlink_vk_fw_update_begin_t packet1, packet2;
  922. memset(&packet1, 0, sizeof(packet1));
  923. packet1.file_size = packet_in.file_size;
  924. packet1.target_system = packet_in.target_system;
  925. packet1.target_comp = packet_in.target_comp;
  926. #ifdef MAVLINK_STATUS_FLAG_OUT_MAVLINK1
  927. if (status->flags & MAVLINK_STATUS_FLAG_OUT_MAVLINK1) {
  928. // cope with extensions
  929. memset(MAVLINK_MSG_ID_VK_FW_UPDATE_BEGIN_MIN_LEN + (char *)&packet1, 0, sizeof(packet1)-MAVLINK_MSG_ID_VK_FW_UPDATE_BEGIN_MIN_LEN);
  930. }
  931. #endif
  932. memset(&packet2, 0, sizeof(packet2));
  933. mavlink_msg_vk_fw_update_begin_encode(system_id, component_id, &msg, &packet1);
  934. mavlink_msg_vk_fw_update_begin_decode(&msg, &packet2);
  935. MAVLINK_ASSERT(memcmp(&packet1, &packet2, sizeof(packet1)) == 0);
  936. memset(&packet2, 0, sizeof(packet2));
  937. mavlink_msg_vk_fw_update_begin_pack(system_id, component_id, &msg , packet1.target_system , packet1.target_comp , packet1.file_size );
  938. mavlink_msg_vk_fw_update_begin_decode(&msg, &packet2);
  939. MAVLINK_ASSERT(memcmp(&packet1, &packet2, sizeof(packet1)) == 0);
  940. memset(&packet2, 0, sizeof(packet2));
  941. mavlink_msg_vk_fw_update_begin_pack_chan(system_id, component_id, MAVLINK_COMM_0, &msg , packet1.target_system , packet1.target_comp , packet1.file_size );
  942. mavlink_msg_vk_fw_update_begin_decode(&msg, &packet2);
  943. MAVLINK_ASSERT(memcmp(&packet1, &packet2, sizeof(packet1)) == 0);
  944. memset(&packet2, 0, sizeof(packet2));
  945. mavlink_msg_to_send_buffer(buffer, &msg);
  946. for (i=0; i<mavlink_msg_get_send_buffer_length(&msg); i++) {
  947. comm_send_ch(MAVLINK_COMM_0, buffer[i]);
  948. }
  949. mavlink_msg_vk_fw_update_begin_decode(last_msg, &packet2);
  950. MAVLINK_ASSERT(memcmp(&packet1, &packet2, sizeof(packet1)) == 0);
  951. memset(&packet2, 0, sizeof(packet2));
  952. mavlink_msg_vk_fw_update_begin_send(MAVLINK_COMM_1 , packet1.target_system , packet1.target_comp , packet1.file_size );
  953. mavlink_msg_vk_fw_update_begin_decode(last_msg, &packet2);
  954. MAVLINK_ASSERT(memcmp(&packet1, &packet2, sizeof(packet1)) == 0);
  955. #ifdef MAVLINK_HAVE_GET_MESSAGE_INFO
  956. MAVLINK_ASSERT(mavlink_get_message_info_by_name("VK_FW_UPDATE_BEGIN") != NULL);
  957. MAVLINK_ASSERT(mavlink_get_message_info_by_id(MAVLINK_MSG_ID_VK_FW_UPDATE_BEGIN) != NULL);
  958. #endif
  959. }
  960. static void mavlink_test_vk_fw_update_ack(uint8_t system_id, uint8_t component_id, mavlink_message_t *last_msg)
  961. {
  962. #ifdef MAVLINK_STATUS_FLAG_OUT_MAVLINK1
  963. mavlink_status_t *status = mavlink_get_channel_status(MAVLINK_COMM_0);
  964. if ((status->flags & MAVLINK_STATUS_FLAG_OUT_MAVLINK1) && MAVLINK_MSG_ID_VK_FW_UPDATE_ACK >= 256) {
  965. return;
  966. }
  967. #endif
  968. mavlink_message_t msg;
  969. uint8_t buffer[MAVLINK_MAX_PACKET_LEN];
  970. uint16_t i;
  971. mavlink_vk_fw_update_ack_t packet_in = {
  972. 5
  973. };
  974. mavlink_vk_fw_update_ack_t packet1, packet2;
  975. memset(&packet1, 0, sizeof(packet1));
  976. packet1.result = packet_in.result;
  977. #ifdef MAVLINK_STATUS_FLAG_OUT_MAVLINK1
  978. if (status->flags & MAVLINK_STATUS_FLAG_OUT_MAVLINK1) {
  979. // cope with extensions
  980. memset(MAVLINK_MSG_ID_VK_FW_UPDATE_ACK_MIN_LEN + (char *)&packet1, 0, sizeof(packet1)-MAVLINK_MSG_ID_VK_FW_UPDATE_ACK_MIN_LEN);
  981. }
  982. #endif
  983. memset(&packet2, 0, sizeof(packet2));
  984. mavlink_msg_vk_fw_update_ack_encode(system_id, component_id, &msg, &packet1);
  985. mavlink_msg_vk_fw_update_ack_decode(&msg, &packet2);
  986. MAVLINK_ASSERT(memcmp(&packet1, &packet2, sizeof(packet1)) == 0);
  987. memset(&packet2, 0, sizeof(packet2));
  988. mavlink_msg_vk_fw_update_ack_pack(system_id, component_id, &msg , packet1.result );
  989. mavlink_msg_vk_fw_update_ack_decode(&msg, &packet2);
  990. MAVLINK_ASSERT(memcmp(&packet1, &packet2, sizeof(packet1)) == 0);
  991. memset(&packet2, 0, sizeof(packet2));
  992. mavlink_msg_vk_fw_update_ack_pack_chan(system_id, component_id, MAVLINK_COMM_0, &msg , packet1.result );
  993. mavlink_msg_vk_fw_update_ack_decode(&msg, &packet2);
  994. MAVLINK_ASSERT(memcmp(&packet1, &packet2, sizeof(packet1)) == 0);
  995. memset(&packet2, 0, sizeof(packet2));
  996. mavlink_msg_to_send_buffer(buffer, &msg);
  997. for (i=0; i<mavlink_msg_get_send_buffer_length(&msg); i++) {
  998. comm_send_ch(MAVLINK_COMM_0, buffer[i]);
  999. }
  1000. mavlink_msg_vk_fw_update_ack_decode(last_msg, &packet2);
  1001. MAVLINK_ASSERT(memcmp(&packet1, &packet2, sizeof(packet1)) == 0);
  1002. memset(&packet2, 0, sizeof(packet2));
  1003. mavlink_msg_vk_fw_update_ack_send(MAVLINK_COMM_1 , packet1.result );
  1004. mavlink_msg_vk_fw_update_ack_decode(last_msg, &packet2);
  1005. MAVLINK_ASSERT(memcmp(&packet1, &packet2, sizeof(packet1)) == 0);
  1006. #ifdef MAVLINK_HAVE_GET_MESSAGE_INFO
  1007. MAVLINK_ASSERT(mavlink_get_message_info_by_name("VK_FW_UPDATE_ACK") != NULL);
  1008. MAVLINK_ASSERT(mavlink_get_message_info_by_id(MAVLINK_MSG_ID_VK_FW_UPDATE_ACK) != NULL);
  1009. #endif
  1010. }
  1011. static void mavlink_test_vk_fw_update_data_request(uint8_t system_id, uint8_t component_id, mavlink_message_t *last_msg)
  1012. {
  1013. #ifdef MAVLINK_STATUS_FLAG_OUT_MAVLINK1
  1014. mavlink_status_t *status = mavlink_get_channel_status(MAVLINK_COMM_0);
  1015. if ((status->flags & MAVLINK_STATUS_FLAG_OUT_MAVLINK1) && MAVLINK_MSG_ID_VK_FW_UPDATE_DATA_REQUEST >= 256) {
  1016. return;
  1017. }
  1018. #endif
  1019. mavlink_message_t msg;
  1020. uint8_t buffer[MAVLINK_MAX_PACKET_LEN];
  1021. uint16_t i;
  1022. mavlink_vk_fw_update_data_request_t packet_in = {
  1023. 963497464,963497672
  1024. };
  1025. mavlink_vk_fw_update_data_request_t packet1, packet2;
  1026. memset(&packet1, 0, sizeof(packet1));
  1027. packet1.offset = packet_in.offset;
  1028. packet1.count = packet_in.count;
  1029. #ifdef MAVLINK_STATUS_FLAG_OUT_MAVLINK1
  1030. if (status->flags & MAVLINK_STATUS_FLAG_OUT_MAVLINK1) {
  1031. // cope with extensions
  1032. memset(MAVLINK_MSG_ID_VK_FW_UPDATE_DATA_REQUEST_MIN_LEN + (char *)&packet1, 0, sizeof(packet1)-MAVLINK_MSG_ID_VK_FW_UPDATE_DATA_REQUEST_MIN_LEN);
  1033. }
  1034. #endif
  1035. memset(&packet2, 0, sizeof(packet2));
  1036. mavlink_msg_vk_fw_update_data_request_encode(system_id, component_id, &msg, &packet1);
  1037. mavlink_msg_vk_fw_update_data_request_decode(&msg, &packet2);
  1038. MAVLINK_ASSERT(memcmp(&packet1, &packet2, sizeof(packet1)) == 0);
  1039. memset(&packet2, 0, sizeof(packet2));
  1040. mavlink_msg_vk_fw_update_data_request_pack(system_id, component_id, &msg , packet1.offset , packet1.count );
  1041. mavlink_msg_vk_fw_update_data_request_decode(&msg, &packet2);
  1042. MAVLINK_ASSERT(memcmp(&packet1, &packet2, sizeof(packet1)) == 0);
  1043. memset(&packet2, 0, sizeof(packet2));
  1044. mavlink_msg_vk_fw_update_data_request_pack_chan(system_id, component_id, MAVLINK_COMM_0, &msg , packet1.offset , packet1.count );
  1045. mavlink_msg_vk_fw_update_data_request_decode(&msg, &packet2);
  1046. MAVLINK_ASSERT(memcmp(&packet1, &packet2, sizeof(packet1)) == 0);
  1047. memset(&packet2, 0, sizeof(packet2));
  1048. mavlink_msg_to_send_buffer(buffer, &msg);
  1049. for (i=0; i<mavlink_msg_get_send_buffer_length(&msg); i++) {
  1050. comm_send_ch(MAVLINK_COMM_0, buffer[i]);
  1051. }
  1052. mavlink_msg_vk_fw_update_data_request_decode(last_msg, &packet2);
  1053. MAVLINK_ASSERT(memcmp(&packet1, &packet2, sizeof(packet1)) == 0);
  1054. memset(&packet2, 0, sizeof(packet2));
  1055. mavlink_msg_vk_fw_update_data_request_send(MAVLINK_COMM_1 , packet1.offset , packet1.count );
  1056. mavlink_msg_vk_fw_update_data_request_decode(last_msg, &packet2);
  1057. MAVLINK_ASSERT(memcmp(&packet1, &packet2, sizeof(packet1)) == 0);
  1058. #ifdef MAVLINK_HAVE_GET_MESSAGE_INFO
  1059. MAVLINK_ASSERT(mavlink_get_message_info_by_name("VK_FW_UPDATE_DATA_REQUEST") != NULL);
  1060. MAVLINK_ASSERT(mavlink_get_message_info_by_id(MAVLINK_MSG_ID_VK_FW_UPDATE_DATA_REQUEST) != NULL);
  1061. #endif
  1062. }
  1063. static void mavlink_test_vk_fw_update_data(uint8_t system_id, uint8_t component_id, mavlink_message_t *last_msg)
  1064. {
  1065. #ifdef MAVLINK_STATUS_FLAG_OUT_MAVLINK1
  1066. mavlink_status_t *status = mavlink_get_channel_status(MAVLINK_COMM_0);
  1067. if ((status->flags & MAVLINK_STATUS_FLAG_OUT_MAVLINK1) && MAVLINK_MSG_ID_VK_FW_UPDATE_DATA >= 256) {
  1068. return;
  1069. }
  1070. #endif
  1071. mavlink_message_t msg;
  1072. uint8_t buffer[MAVLINK_MAX_PACKET_LEN];
  1073. uint16_t i;
  1074. mavlink_vk_fw_update_data_t packet_in = {
  1075. 963497464,17,{ 84, 85, 86, 87, 88, 89, 90, 91, 92, 93, 94, 95, 96, 97, 98, 99, 100, 101, 102, 103, 104, 105, 106, 107, 108, 109, 110, 111, 112, 113, 114, 115, 116, 117, 118, 119, 120, 121, 122, 123, 124, 125, 126, 127, 128, 129, 130, 131, 132, 133, 134, 135, 136, 137, 138, 139, 140, 141, 142, 143, 144, 145, 146, 147, 148, 149, 150, 151, 152, 153, 154, 155, 156, 157, 158, 159, 160, 161, 162, 163, 164, 165, 166, 167, 168, 169, 170, 171, 172, 173, 174, 175, 176, 177, 178, 179, 180, 181, 182, 183, 184, 185, 186, 187, 188, 189, 190, 191, 192, 193, 194, 195, 196, 197, 198, 199, 200, 201, 202, 203, 204, 205, 206, 207, 208, 209, 210, 211 }
  1076. };
  1077. mavlink_vk_fw_update_data_t packet1, packet2;
  1078. memset(&packet1, 0, sizeof(packet1));
  1079. packet1.offset = packet_in.offset;
  1080. packet1.count = packet_in.count;
  1081. mav_array_memcpy(packet1.data, packet_in.data, sizeof(uint8_t)*128);
  1082. #ifdef MAVLINK_STATUS_FLAG_OUT_MAVLINK1
  1083. if (status->flags & MAVLINK_STATUS_FLAG_OUT_MAVLINK1) {
  1084. // cope with extensions
  1085. memset(MAVLINK_MSG_ID_VK_FW_UPDATE_DATA_MIN_LEN + (char *)&packet1, 0, sizeof(packet1)-MAVLINK_MSG_ID_VK_FW_UPDATE_DATA_MIN_LEN);
  1086. }
  1087. #endif
  1088. memset(&packet2, 0, sizeof(packet2));
  1089. mavlink_msg_vk_fw_update_data_encode(system_id, component_id, &msg, &packet1);
  1090. mavlink_msg_vk_fw_update_data_decode(&msg, &packet2);
  1091. MAVLINK_ASSERT(memcmp(&packet1, &packet2, sizeof(packet1)) == 0);
  1092. memset(&packet2, 0, sizeof(packet2));
  1093. mavlink_msg_vk_fw_update_data_pack(system_id, component_id, &msg , packet1.offset , packet1.count , packet1.data );
  1094. mavlink_msg_vk_fw_update_data_decode(&msg, &packet2);
  1095. MAVLINK_ASSERT(memcmp(&packet1, &packet2, sizeof(packet1)) == 0);
  1096. memset(&packet2, 0, sizeof(packet2));
  1097. mavlink_msg_vk_fw_update_data_pack_chan(system_id, component_id, MAVLINK_COMM_0, &msg , packet1.offset , packet1.count , packet1.data );
  1098. mavlink_msg_vk_fw_update_data_decode(&msg, &packet2);
  1099. MAVLINK_ASSERT(memcmp(&packet1, &packet2, sizeof(packet1)) == 0);
  1100. memset(&packet2, 0, sizeof(packet2));
  1101. mavlink_msg_to_send_buffer(buffer, &msg);
  1102. for (i=0; i<mavlink_msg_get_send_buffer_length(&msg); i++) {
  1103. comm_send_ch(MAVLINK_COMM_0, buffer[i]);
  1104. }
  1105. mavlink_msg_vk_fw_update_data_decode(last_msg, &packet2);
  1106. MAVLINK_ASSERT(memcmp(&packet1, &packet2, sizeof(packet1)) == 0);
  1107. memset(&packet2, 0, sizeof(packet2));
  1108. mavlink_msg_vk_fw_update_data_send(MAVLINK_COMM_1 , packet1.offset , packet1.count , packet1.data );
  1109. mavlink_msg_vk_fw_update_data_decode(last_msg, &packet2);
  1110. MAVLINK_ASSERT(memcmp(&packet1, &packet2, sizeof(packet1)) == 0);
  1111. #ifdef MAVLINK_HAVE_GET_MESSAGE_INFO
  1112. MAVLINK_ASSERT(mavlink_get_message_info_by_name("VK_FW_UPDATE_DATA") != NULL);
  1113. MAVLINK_ASSERT(mavlink_get_message_info_by_id(MAVLINK_MSG_ID_VK_FW_UPDATE_DATA) != NULL);
  1114. #endif
  1115. }
  1116. static void mavlink_test_vk_update_terminate(uint8_t system_id, uint8_t component_id, mavlink_message_t *last_msg)
  1117. {
  1118. #ifdef MAVLINK_STATUS_FLAG_OUT_MAVLINK1
  1119. mavlink_status_t *status = mavlink_get_channel_status(MAVLINK_COMM_0);
  1120. if ((status->flags & MAVLINK_STATUS_FLAG_OUT_MAVLINK1) && MAVLINK_MSG_ID_VK_UPDATE_TERMINATE >= 256) {
  1121. return;
  1122. }
  1123. #endif
  1124. mavlink_message_t msg;
  1125. uint8_t buffer[MAVLINK_MAX_PACKET_LEN];
  1126. uint16_t i;
  1127. mavlink_vk_update_terminate_t packet_in = {
  1128. 5,72
  1129. };
  1130. mavlink_vk_update_terminate_t packet1, packet2;
  1131. memset(&packet1, 0, sizeof(packet1));
  1132. packet1.target_system = packet_in.target_system;
  1133. packet1.target_comp = packet_in.target_comp;
  1134. #ifdef MAVLINK_STATUS_FLAG_OUT_MAVLINK1
  1135. if (status->flags & MAVLINK_STATUS_FLAG_OUT_MAVLINK1) {
  1136. // cope with extensions
  1137. memset(MAVLINK_MSG_ID_VK_UPDATE_TERMINATE_MIN_LEN + (char *)&packet1, 0, sizeof(packet1)-MAVLINK_MSG_ID_VK_UPDATE_TERMINATE_MIN_LEN);
  1138. }
  1139. #endif
  1140. memset(&packet2, 0, sizeof(packet2));
  1141. mavlink_msg_vk_update_terminate_encode(system_id, component_id, &msg, &packet1);
  1142. mavlink_msg_vk_update_terminate_decode(&msg, &packet2);
  1143. MAVLINK_ASSERT(memcmp(&packet1, &packet2, sizeof(packet1)) == 0);
  1144. memset(&packet2, 0, sizeof(packet2));
  1145. mavlink_msg_vk_update_terminate_pack(system_id, component_id, &msg , packet1.target_system , packet1.target_comp );
  1146. mavlink_msg_vk_update_terminate_decode(&msg, &packet2);
  1147. MAVLINK_ASSERT(memcmp(&packet1, &packet2, sizeof(packet1)) == 0);
  1148. memset(&packet2, 0, sizeof(packet2));
  1149. mavlink_msg_vk_update_terminate_pack_chan(system_id, component_id, MAVLINK_COMM_0, &msg , packet1.target_system , packet1.target_comp );
  1150. mavlink_msg_vk_update_terminate_decode(&msg, &packet2);
  1151. MAVLINK_ASSERT(memcmp(&packet1, &packet2, sizeof(packet1)) == 0);
  1152. memset(&packet2, 0, sizeof(packet2));
  1153. mavlink_msg_to_send_buffer(buffer, &msg);
  1154. for (i=0; i<mavlink_msg_get_send_buffer_length(&msg); i++) {
  1155. comm_send_ch(MAVLINK_COMM_0, buffer[i]);
  1156. }
  1157. mavlink_msg_vk_update_terminate_decode(last_msg, &packet2);
  1158. MAVLINK_ASSERT(memcmp(&packet1, &packet2, sizeof(packet1)) == 0);
  1159. memset(&packet2, 0, sizeof(packet2));
  1160. mavlink_msg_vk_update_terminate_send(MAVLINK_COMM_1 , packet1.target_system , packet1.target_comp );
  1161. mavlink_msg_vk_update_terminate_decode(last_msg, &packet2);
  1162. MAVLINK_ASSERT(memcmp(&packet1, &packet2, sizeof(packet1)) == 0);
  1163. #ifdef MAVLINK_HAVE_GET_MESSAGE_INFO
  1164. MAVLINK_ASSERT(mavlink_get_message_info_by_name("VK_UPDATE_TERMINATE") != NULL);
  1165. MAVLINK_ASSERT(mavlink_get_message_info_by_id(MAVLINK_MSG_ID_VK_UPDATE_TERMINATE) != NULL);
  1166. #endif
  1167. }
  1168. static void mavlink_test_qingxie_bms(uint8_t system_id, uint8_t component_id, mavlink_message_t *last_msg)
  1169. {
  1170. #ifdef MAVLINK_STATUS_FLAG_OUT_MAVLINK1
  1171. mavlink_status_t *status = mavlink_get_channel_status(MAVLINK_COMM_0);
  1172. if ((status->flags & MAVLINK_STATUS_FLAG_OUT_MAVLINK1) && MAVLINK_MSG_ID_QINGXIE_BMS >= 256) {
  1173. return;
  1174. }
  1175. #endif
  1176. mavlink_message_t msg;
  1177. uint8_t buffer[MAVLINK_MAX_PACKET_LEN];
  1178. uint16_t i;
  1179. mavlink_qingxie_bms_t packet_in = {
  1180. 17235,17339,17443,17547,17651,17755,17859,17963,18067,18171,18275,199,10,18483,18587,18691,223,34,101,168,19003,19107,19211
  1181. };
  1182. mavlink_qingxie_bms_t packet1, packet2;
  1183. memset(&packet1, 0, sizeof(packet1));
  1184. packet1.bat_voltage = packet_in.bat_voltage;
  1185. packet1.servo_current = packet_in.servo_current;
  1186. packet1.stack_voltage = packet_in.stack_voltage;
  1187. packet1.servo_voltage = packet_in.servo_voltage;
  1188. packet1.bat_refuel_current = packet_in.bat_refuel_current;
  1189. packet1.gas_tank_pressure = packet_in.gas_tank_pressure;
  1190. packet1.pipe_pressure = packet_in.pipe_pressure;
  1191. packet1.pcb_temp = packet_in.pcb_temp;
  1192. packet1.stack_temp = packet_in.stack_temp;
  1193. packet1.work_status = packet_in.work_status;
  1194. packet1.falt_status = packet_in.falt_status;
  1195. packet1.self_check = packet_in.self_check;
  1196. packet1.Id = packet_in.Id;
  1197. packet1.gass_mass = packet_in.gass_mass;
  1198. packet1.gass_percent = packet_in.gass_percent;
  1199. packet1.runtime_remain = packet_in.runtime_remain;
  1200. packet1.fan_percent = packet_in.fan_percent;
  1201. packet1.fan_rpm = packet_in.fan_rpm;
  1202. packet1.sys_run_state = packet_in.sys_run_state;
  1203. packet1.sys_fault_state = packet_in.sys_fault_state;
  1204. packet1.sys_fault_code = packet_in.sys_fault_code;
  1205. packet1.lipo_current = packet_in.lipo_current;
  1206. packet1.total_runtime = packet_in.total_runtime;
  1207. #ifdef MAVLINK_STATUS_FLAG_OUT_MAVLINK1
  1208. if (status->flags & MAVLINK_STATUS_FLAG_OUT_MAVLINK1) {
  1209. // cope with extensions
  1210. memset(MAVLINK_MSG_ID_QINGXIE_BMS_MIN_LEN + (char *)&packet1, 0, sizeof(packet1)-MAVLINK_MSG_ID_QINGXIE_BMS_MIN_LEN);
  1211. }
  1212. #endif
  1213. memset(&packet2, 0, sizeof(packet2));
  1214. mavlink_msg_qingxie_bms_encode(system_id, component_id, &msg, &packet1);
  1215. mavlink_msg_qingxie_bms_decode(&msg, &packet2);
  1216. MAVLINK_ASSERT(memcmp(&packet1, &packet2, sizeof(packet1)) == 0);
  1217. memset(&packet2, 0, sizeof(packet2));
  1218. mavlink_msg_qingxie_bms_pack(system_id, component_id, &msg , packet1.bat_voltage , packet1.servo_current , packet1.stack_voltage , packet1.servo_voltage , packet1.bat_refuel_current , packet1.gas_tank_pressure , packet1.pipe_pressure , packet1.pcb_temp , packet1.stack_temp , packet1.work_status , packet1.falt_status , packet1.self_check , packet1.Id , packet1.gass_mass , packet1.gass_percent , packet1.runtime_remain , packet1.fan_percent , packet1.fan_rpm , packet1.sys_run_state , packet1.sys_fault_state , packet1.sys_fault_code , packet1.lipo_current , packet1.total_runtime );
  1219. mavlink_msg_qingxie_bms_decode(&msg, &packet2);
  1220. MAVLINK_ASSERT(memcmp(&packet1, &packet2, sizeof(packet1)) == 0);
  1221. memset(&packet2, 0, sizeof(packet2));
  1222. mavlink_msg_qingxie_bms_pack_chan(system_id, component_id, MAVLINK_COMM_0, &msg , packet1.bat_voltage , packet1.servo_current , packet1.stack_voltage , packet1.servo_voltage , packet1.bat_refuel_current , packet1.gas_tank_pressure , packet1.pipe_pressure , packet1.pcb_temp , packet1.stack_temp , packet1.work_status , packet1.falt_status , packet1.self_check , packet1.Id , packet1.gass_mass , packet1.gass_percent , packet1.runtime_remain , packet1.fan_percent , packet1.fan_rpm , packet1.sys_run_state , packet1.sys_fault_state , packet1.sys_fault_code , packet1.lipo_current , packet1.total_runtime );
  1223. mavlink_msg_qingxie_bms_decode(&msg, &packet2);
  1224. MAVLINK_ASSERT(memcmp(&packet1, &packet2, sizeof(packet1)) == 0);
  1225. memset(&packet2, 0, sizeof(packet2));
  1226. mavlink_msg_to_send_buffer(buffer, &msg);
  1227. for (i=0; i<mavlink_msg_get_send_buffer_length(&msg); i++) {
  1228. comm_send_ch(MAVLINK_COMM_0, buffer[i]);
  1229. }
  1230. mavlink_msg_qingxie_bms_decode(last_msg, &packet2);
  1231. MAVLINK_ASSERT(memcmp(&packet1, &packet2, sizeof(packet1)) == 0);
  1232. memset(&packet2, 0, sizeof(packet2));
  1233. mavlink_msg_qingxie_bms_send(MAVLINK_COMM_1 , packet1.bat_voltage , packet1.servo_current , packet1.stack_voltage , packet1.servo_voltage , packet1.bat_refuel_current , packet1.gas_tank_pressure , packet1.pipe_pressure , packet1.pcb_temp , packet1.stack_temp , packet1.work_status , packet1.falt_status , packet1.self_check , packet1.Id , packet1.gass_mass , packet1.gass_percent , packet1.runtime_remain , packet1.fan_percent , packet1.fan_rpm , packet1.sys_run_state , packet1.sys_fault_state , packet1.sys_fault_code , packet1.lipo_current , packet1.total_runtime );
  1234. mavlink_msg_qingxie_bms_decode(last_msg, &packet2);
  1235. MAVLINK_ASSERT(memcmp(&packet1, &packet2, sizeof(packet1)) == 0);
  1236. #ifdef MAVLINK_HAVE_GET_MESSAGE_INFO
  1237. MAVLINK_ASSERT(mavlink_get_message_info_by_name("QINGXIE_BMS") != NULL);
  1238. MAVLINK_ASSERT(mavlink_get_message_info_by_id(MAVLINK_MSG_ID_QINGXIE_BMS) != NULL);
  1239. #endif
  1240. }
  1241. static void mavlink_test_VKFly(uint8_t system_id, uint8_t component_id, mavlink_message_t *last_msg)
  1242. {
  1243. mavlink_test_vkins_status(system_id, component_id, last_msg);
  1244. mavlink_test_vkfmu_status(system_id, component_id, last_msg);
  1245. mavlink_test_vk_roi_target(system_id, component_id, last_msg);
  1246. mavlink_test_vk_bms_status(system_id, component_id, last_msg);
  1247. mavlink_test_vk_formation_leader(system_id, component_id, last_msg);
  1248. mavlink_test_vk_engine_ecu_staus(system_id, component_id, last_msg);
  1249. mavlink_test_vk_comp_version(system_id, component_id, last_msg);
  1250. mavlink_test_vk_mosaich_gps_raw(system_id, component_id, last_msg);
  1251. mavlink_test_vk_digi_esc_status(system_id, component_id, last_msg);
  1252. mavlink_test_vk_fixedwing_control_value(system_id, component_id, last_msg);
  1253. mavlink_test_vk_fixedwing_servo_signal(system_id, component_id, last_msg);
  1254. mavlink_test_vk_fixedwing_rtl_circle_wp(system_id, component_id, last_msg);
  1255. mavlink_test_vk_parachute_status(system_id, component_id, last_msg);
  1256. mavlink_test_vk_weigher_state(system_id, component_id, last_msg);
  1257. mavlink_test_vk_payload_data_relay(system_id, component_id, last_msg);
  1258. mavlink_test_vk_fw_update_begin(system_id, component_id, last_msg);
  1259. mavlink_test_vk_fw_update_ack(system_id, component_id, last_msg);
  1260. mavlink_test_vk_fw_update_data_request(system_id, component_id, last_msg);
  1261. mavlink_test_vk_fw_update_data(system_id, component_id, last_msg);
  1262. mavlink_test_vk_update_terminate(system_id, component_id, last_msg);
  1263. mavlink_test_qingxie_bms(system_id, component_id, last_msg);
  1264. }
  1265. #ifdef __cplusplus
  1266. }
  1267. #endif // __cplusplus
  1268. #endif // VKFLY_TESTSUITE_H