testsuite.h 75 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433
  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
  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. #ifdef MAVLINK_STATUS_FLAG_OUT_MAVLINK1
  1198. if (status->flags & MAVLINK_STATUS_FLAG_OUT_MAVLINK1) {
  1199. // cope with extensions
  1200. memset(MAVLINK_MSG_ID_QINGXIE_BMS_MIN_LEN + (char *)&packet1, 0, sizeof(packet1)-MAVLINK_MSG_ID_QINGXIE_BMS_MIN_LEN);
  1201. }
  1202. #endif
  1203. memset(&packet2, 0, sizeof(packet2));
  1204. mavlink_msg_qingxie_bms_encode(system_id, component_id, &msg, &packet1);
  1205. mavlink_msg_qingxie_bms_decode(&msg, &packet2);
  1206. MAVLINK_ASSERT(memcmp(&packet1, &packet2, sizeof(packet1)) == 0);
  1207. memset(&packet2, 0, sizeof(packet2));
  1208. 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 );
  1209. mavlink_msg_qingxie_bms_decode(&msg, &packet2);
  1210. MAVLINK_ASSERT(memcmp(&packet1, &packet2, sizeof(packet1)) == 0);
  1211. memset(&packet2, 0, sizeof(packet2));
  1212. 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 );
  1213. mavlink_msg_qingxie_bms_decode(&msg, &packet2);
  1214. MAVLINK_ASSERT(memcmp(&packet1, &packet2, sizeof(packet1)) == 0);
  1215. memset(&packet2, 0, sizeof(packet2));
  1216. mavlink_msg_to_send_buffer(buffer, &msg);
  1217. for (i=0; i<mavlink_msg_get_send_buffer_length(&msg); i++) {
  1218. comm_send_ch(MAVLINK_COMM_0, buffer[i]);
  1219. }
  1220. mavlink_msg_qingxie_bms_decode(last_msg, &packet2);
  1221. MAVLINK_ASSERT(memcmp(&packet1, &packet2, sizeof(packet1)) == 0);
  1222. memset(&packet2, 0, sizeof(packet2));
  1223. 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 );
  1224. mavlink_msg_qingxie_bms_decode(last_msg, &packet2);
  1225. MAVLINK_ASSERT(memcmp(&packet1, &packet2, sizeof(packet1)) == 0);
  1226. #ifdef MAVLINK_HAVE_GET_MESSAGE_INFO
  1227. MAVLINK_ASSERT(mavlink_get_message_info_by_name("QINGXIE_BMS") != NULL);
  1228. MAVLINK_ASSERT(mavlink_get_message_info_by_id(MAVLINK_MSG_ID_QINGXIE_BMS) != NULL);
  1229. #endif
  1230. }
  1231. static void mavlink_test_VKFly(uint8_t system_id, uint8_t component_id, mavlink_message_t *last_msg)
  1232. {
  1233. mavlink_test_vkins_status(system_id, component_id, last_msg);
  1234. mavlink_test_vkfmu_status(system_id, component_id, last_msg);
  1235. mavlink_test_vk_roi_target(system_id, component_id, last_msg);
  1236. mavlink_test_vk_bms_status(system_id, component_id, last_msg);
  1237. mavlink_test_vk_formation_leader(system_id, component_id, last_msg);
  1238. mavlink_test_vk_engine_ecu_staus(system_id, component_id, last_msg);
  1239. mavlink_test_vk_comp_version(system_id, component_id, last_msg);
  1240. mavlink_test_vk_mosaich_gps_raw(system_id, component_id, last_msg);
  1241. mavlink_test_vk_digi_esc_status(system_id, component_id, last_msg);
  1242. mavlink_test_vk_fixedwing_control_value(system_id, component_id, last_msg);
  1243. mavlink_test_vk_fixedwing_servo_signal(system_id, component_id, last_msg);
  1244. mavlink_test_vk_fixedwing_rtl_circle_wp(system_id, component_id, last_msg);
  1245. mavlink_test_vk_parachute_status(system_id, component_id, last_msg);
  1246. mavlink_test_vk_weigher_state(system_id, component_id, last_msg);
  1247. mavlink_test_vk_payload_data_relay(system_id, component_id, last_msg);
  1248. mavlink_test_vk_fw_update_begin(system_id, component_id, last_msg);
  1249. mavlink_test_vk_fw_update_ack(system_id, component_id, last_msg);
  1250. mavlink_test_vk_fw_update_data_request(system_id, component_id, last_msg);
  1251. mavlink_test_vk_fw_update_data(system_id, component_id, last_msg);
  1252. mavlink_test_vk_update_terminate(system_id, component_id, last_msg);
  1253. mavlink_test_qingxie_bms(system_id, component_id, last_msg);
  1254. }
  1255. #ifdef __cplusplus
  1256. }
  1257. #endif // __cplusplus
  1258. #endif // VKFLY_TESTSUITE_H