soft_flash.c 27 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847
  1. #include "soft_flash.h"
  2. #include "auto_pilot.h"
  3. #include "bsp_V8M_flash.h"
  4. #include "control_rate.h"
  5. #include "control_throttle.h"
  6. #include "data_save.h"
  7. #include "gcs_vklink_v30.h"
  8. #include "geomatry.h"
  9. #include "my_math.h"
  10. #include "params.h"
  11. #include "pilot_navigation.h"
  12. #include "soft_delay.h"
  13. #include "soft_gs.h"
  14. #include "soft_motor_output.h"
  15. #include "soft_port_uart4.h"
  16. #include "soft_rc_input.h"
  17. #include "soft_time.h"
  18. #include "ver_config.h"
  19. #include "bsp_V8M_YY_pwm.h"
  20. #include "hard_system.h"
  21. #include <string.h>
  22. #ifdef GD25Q16_FLASH
  23. #include "hard_flash_gd25q16.h"
  24. #else
  25. #include "hard_flash_at45db.h"
  26. #endif
  27. /**
  28. * @brief flash 接口初始化
  29. *
  30. */
  31. void flash_at45db_initial(void) { flash_at45db_init(); }
  32. /**
  33. * @brief 检查 flash 是否挂载
  34. *
  35. * @return true 已挂载
  36. * @return false 不存在
  37. */
  38. bool flash_isexist(void)
  39. {
  40. if (AT45DB_Check() == 0)
  41. return false;
  42. else
  43. return true;
  44. }
  45. /**
  46. * @brief 检查 flash 是否正在忙
  47. *
  48. * @return true 正在忙
  49. * @return false 可用
  50. */
  51. bool flash_isbusy(void)
  52. {
  53. if (AT45DB_IS_BUSY() == 0)
  54. return true;
  55. else
  56. return false;
  57. }
  58. /**
  59. * @brief flash 读取指定地址的 n bytes 数据
  60. *
  61. * @param add 要读取的地址
  62. * @param pdata 读出数据存放的 buffer 指针
  63. * @param len 读取的字节数
  64. */
  65. void flash_read_bytes(unsigned int add, unsigned char *pdata,
  66. unsigned short len)
  67. {
  68. AT45DB_Read_Bytes(add, pdata, len);
  69. }
  70. /**
  71. * @brief flash 指定地址写入 n bytes 的数据
  72. *
  73. * @param add 要写入的地址
  74. * @param pdata 指向待写入的数据的指针
  75. * @param len 待写入的字节数
  76. */
  77. void flash_write_bytes(unsigned int add, unsigned char *pdata,
  78. unsigned short len)
  79. {
  80. AT45DB_Write_Bytes(add, pdata, len);
  81. }
  82. /**
  83. * @brief flash 读取一个 int16 数据
  84. *
  85. * @param add 读取的地址
  86. * @return short 读取的数据
  87. */
  88. short flash_read_int16(unsigned int add) { return AT45DB_Read_int16(add); }
  89. /**
  90. * @brief flash 写入一个 int16 数据
  91. *
  92. * @param add 写入的地址
  93. * @param wvalue 待写入的数据
  94. */
  95. void flash_write_int16(unsigned int add, short wvalue)
  96. {
  97. AT45DB_Write_int16(add, wvalue);
  98. }
  99. void flash_read_page(uint16_t Page_Add, uint8_t *pdata)
  100. {
  101. AT45DB_ReadPage(Page_Add, pdata);
  102. }
  103. void flash_write_page(uint16_t page, uint8_t *Data)
  104. {
  105. AT45DB_WritePage(page, Data);
  106. }
  107. void flash_write_bytes_ononepage(uint16_t page, uint8_t *pdata, uint16_t len)
  108. {
  109. AT45DB_WriteBytes_OnOnePage(page, pdata, len);
  110. }
  111. // @brief 装载默认的 PID 参数
  112. void load_default_pidinf(void)
  113. {
  114. unsigned char i = 0;
  115. pidinf._pid_flag = (int16_t)0xA12A;
  116. pidinf._Roll_Angle_P = 450;
  117. pidinf._Roll_Gyro_P = 60;
  118. pidinf._Roll_Gyro_I = 5;
  119. pidinf._Roll_Gyro_D = 5;
  120. pidinf._Roll_Gyro_Imax = 150;
  121. pidinf._Pitch_Angle_P = 450;
  122. pidinf._Pitch_Gyro_P = 60;
  123. pidinf._Pitch_Gyro_I = 5;
  124. pidinf._Pitch_Gyro_D = 5;
  125. pidinf._Pitch_Gyro_Imax = 150;
  126. pidinf._Yaw_Angle_P = 450;
  127. pidinf._Yaw_Gyro_P = 350;
  128. pidinf._Yaw_Gyro_I = 10;
  129. pidinf._Yaw_Gyro_D = 0;
  130. pidinf._Yaw_Gyro_Imax = 150;
  131. pidinf._AltHold_Dist_P = 60;
  132. pidinf._AltHold_Speed_P = 350;
  133. pidinf._AltHold_Acc_P = 25;
  134. pidinf._AltHold_Acc_I = 15;
  135. pidinf._AltHold_Acc_Imax = 200;
  136. pidinf._Loiter_Dist_P = 70;
  137. pidinf._Loiter_Speed_P = 120;
  138. pidinf._Loiter_Acc_P = 40;
  139. pidinf._Loiter_Acc_I = 20;
  140. pidinf._Loiter_Brake_Gyro = 20;
  141. for (i = 0; i < RC_CALIB_CH_NUM; i++)
  142. {
  143. pidinf._rc_cal_offset[i] = 1500; // 初始中立值 1500
  144. pidinf._rc_cal_factor_up[i] = 1000; // 初始补偿因数1000 /1000 = 1
  145. pidinf._rc_cal_factor_down[i] = 1000; // 初始补偿因数1000 /1000 = 1
  146. }
  147. }
  148. // @brief flash 读取 pid 参数信息
  149. void flash_read_pidinf(void)
  150. {
  151. unsigned char i = 0;
  152. // unsigned int testi[2] = {0};
  153. // testi[0] = 0x12345678;
  154. // testi[1] = 0x12345678;
  155. // flash_write_bytes(pidinf_addr, (uint8_t*)&testi, sizeof(testi));
  156. flash_read_bytes(pidinf_addr, (uint8_t *)&pidinf, sizeof(pidinf));
  157. if (pidinf._pid_flag != (int16_t)0xA12A)
  158. { // 配置表是否有效?
  159. load_default_pidinf(); // 装载默认的配置,并写入Flash
  160. flash_write_bytes(pidinf_addr, (uint8_t *)&pidinf, sizeof(pidinf));
  161. }
  162. pid_v_roll.angle_p = pidinf._Roll_Angle_P / 100.0f; // 1.2
  163. pid_v_roll.gyro_p = pidinf._Roll_Gyro_P / 100.0f; // 4.5
  164. pid_v_roll.gyro_i = 0.05f;
  165. pid_v_roll.gyro_d = pidinf._Roll_Gyro_D / 100.0f; // 0.06
  166. pid_v_roll.gyro_imax = 150.0f;
  167. pid_v_pitch.angle_p = pidinf._Pitch_Angle_P / 100.0f;
  168. pid_v_pitch.gyro_p = pidinf._Pitch_Gyro_P / 100.0f;
  169. pid_v_pitch.gyro_i = 0.05f;
  170. pid_v_pitch.gyro_d = pidinf._Pitch_Gyro_D / 100.0f;
  171. pid_v_pitch.gyro_imax = 150.0f;
  172. pid_v_yaw.angle_p = pidinf._Yaw_Angle_P / 100.0f;
  173. pid_v_yaw.gyro_p = pidinf._Yaw_Gyro_P / 100.0f;
  174. pid_v_yaw.gyro_i = 0.10f;
  175. pid_v_yaw.gyro_d = pidinf._Yaw_Gyro_D / 100.0f;
  176. pid_v_yaw.gyro_imax = 150.0f;
  177. pid_v_alt.dist_p = pidinf._AltHold_Dist_P / 100.0f;
  178. pid_v_alt.speed_p = pidinf._AltHold_Speed_P / 100.0f;
  179. pid_v_alt.acc_p = pidinf._AltHold_Acc_P / 100.0f;
  180. pid_v_alt.acc_i = pidinf._AltHold_Acc_I / 100.0f;
  181. pid_v_alt.brake_gyro = pidinf._AltHold_Acc_Imax / 10.0f;
  182. pid_v_pos.dist_p = pidinf._Loiter_Dist_P / 100.0f;
  183. pid_v_pos.speed_p = pidinf._Loiter_Speed_P / 100.0f;
  184. pid_v_pos.acc_p = pidinf._Loiter_Acc_P / 100.0f;
  185. pid_v_pos.acc_i = pidinf._Loiter_Acc_I / 100.0f;
  186. pidinf._Loiter_Brake_Gyro =
  187. constrain_int16(pidinf._Loiter_Brake_Gyro, 10, 50);
  188. pid_v_pos.brake_gyro = pidinf._Loiter_Brake_Gyro / 10.0f;
  189. // 如果中立位值超过范围,视为错误,恢复默认值
  190. if (((pidinf._rc_cal_offset[RC_ROLL] > 1800) ||
  191. (pidinf._rc_cal_offset[RC_ROLL] < 1200)) ||
  192. ((pidinf._rc_cal_offset[RC_PITCH] > 1800) ||
  193. (pidinf._rc_cal_offset[RC_PITCH] < 1200)) ||
  194. ((pidinf._rc_cal_offset[RC_THR] > 1800) ||
  195. (pidinf._rc_cal_offset[RC_THR] < 1200)) ||
  196. ((pidinf._rc_cal_offset[RC_YAW] > 1800) ||
  197. (pidinf._rc_cal_offset[RC_YAW] < 1200)))
  198. {
  199. for (i = 0; i < RC_CALIB_CH_NUM; i++)
  200. {
  201. rc_cal_offset[i] = 1500;
  202. rc_cal_factor_up[i] = 1000;
  203. rc_cal_factor_down[i] = 1000;
  204. }
  205. }
  206. else
  207. {
  208. for (i = 0; i < RC_CALIB_CH_NUM; i++)
  209. {
  210. rc_cal_offset[i] = pidinf._rc_cal_offset[i];
  211. rc_cal_factor_up[i] = pidinf._rc_cal_factor_up[i];
  212. rc_cal_factor_down[i] = pidinf._rc_cal_factor_down[i];
  213. }
  214. }
  215. }
  216. // @brief flash 写入 pid 信息发
  217. void flash_write_pidinf(void)
  218. {
  219. unsigned char i = 0;
  220. pidinf._pid_flag = (int16_t)0xA12A; // 数据有效标志
  221. //================数据赋值部分=============
  222. pid_v_roll.angle_p = pidinf._Roll_Angle_P / 100.0f;
  223. pid_v_roll.gyro_p = pidinf._Roll_Gyro_P / 100.0f;
  224. pid_v_roll.gyro_i = 0.05f;
  225. pid_v_roll.gyro_d = pidinf._Roll_Gyro_D / 100.0f;
  226. pid_v_roll.gyro_imax = 150.0f;
  227. pid_v_pitch.angle_p = pidinf._Pitch_Angle_P / 100.0f;
  228. pid_v_pitch.gyro_p = pidinf._Pitch_Gyro_P / 100.0f;
  229. pid_v_pitch.gyro_i = 0.05f;
  230. pid_v_pitch.gyro_d = pidinf._Pitch_Gyro_D / 100.0f;
  231. pid_v_pitch.gyro_imax = 150.0f;
  232. pid_v_yaw.angle_p = pidinf._Yaw_Angle_P / 100.0f;
  233. pid_v_yaw.gyro_p = pidinf._Yaw_Gyro_P / 100.0f;
  234. pid_v_yaw.gyro_i = 0.10f;
  235. pid_v_yaw.gyro_d = pidinf._Yaw_Gyro_D / 100.0f;
  236. pid_v_yaw.gyro_imax = 150.0f;
  237. pid_v_alt.dist_p = pidinf._AltHold_Dist_P / 100.0f;
  238. pid_v_alt.speed_p = pidinf._AltHold_Speed_P / 100.0f;
  239. pid_v_alt.acc_p = pidinf._AltHold_Acc_P / 100.0f;
  240. pid_v_alt.acc_i = pidinf._AltHold_Acc_I / 100.0f;
  241. pid_v_alt.brake_gyro = pidinf._AltHold_Acc_Imax / 10.0f;
  242. pid_v_pos.dist_p = pidinf._Loiter_Dist_P / 100.0f;
  243. pid_v_pos.speed_p = pidinf._Loiter_Speed_P / 100.0f;
  244. pid_v_pos.acc_p = pidinf._Loiter_Acc_P / 100.0f;
  245. pid_v_pos.acc_i = pidinf._Loiter_Acc_I / 100.0f;
  246. pidinf._Loiter_Brake_Gyro =
  247. constrain_int16(pidinf._Loiter_Brake_Gyro, 10, 50);
  248. pid_v_pos.brake_gyro = pidinf._Loiter_Brake_Gyro / 10.0f;
  249. //====================================================
  250. for (i = 0; i < RC_CALIB_CH_NUM; i++)
  251. {
  252. pidinf._rc_cal_offset[i] = rc_cal_offset[i];
  253. pidinf._rc_cal_factor_up[i] = rc_cal_factor_up[i];
  254. pidinf._rc_cal_factor_down[i] = rc_cal_factor_down[i];
  255. }
  256. if (thr_lock_status == LOCKED)
  257. {
  258. flash_write_bytes(pidinf_addr, (uint8_t *)&pidinf, sizeof(pidinf));
  259. }
  260. else
  261. {
  262. return;
  263. }
  264. }
  265. // @brief 装载默认的版本信息
  266. void load_default_verinf(void)
  267. {
  268. verinf._ver_flag = (int16_t)0xA11A;
  269. memcpy(verinf._ap_name, NM_VER, sizeof(verinf._ap_name));
  270. verinf._serial_id = 001;
  271. verinf._sysid = 0;
  272. }
  273. // @brief flash 读取版本信息
  274. void flash_read_verinf(void)
  275. {
  276. flash_read_bytes(verinf_addr, (uint8_t *)&verinf, sizeof(verinf));
  277. if (verinf._ver_flag != (int16_t)0xA11A)
  278. { // 配置表是否有效?
  279. load_default_verinf(); // 装载默认的配置,并写入Flash
  280. flash_write_bytes(verinf_addr, (uint8_t *)&verinf, sizeof(verinf));
  281. }
  282. memcpy(ver_par.ap_name, verinf._ap_name, sizeof(verinf._ap_name));
  283. ver_par.serial_id = verinf._serial_id;
  284. ver_par.hardware_id = HW_VER;
  285. ver_par.firmware_id = FW_VER;
  286. }
  287. // @brief flash 写入版本信息
  288. void flash_write_verinf(void)
  289. {
  290. verinf._ver_flag = (int16_t)0xA11A; // 数据有效标志
  291. //==================数据赋值部分===============
  292. memcpy(ver_par.ap_name, verinf._ap_name, sizeof(verinf._ap_name));
  293. ver_par.serial_id = verinf._serial_id;
  294. ver_par.hardware_id = HW_VER;
  295. ver_par.firmware_id = FW_VER;
  296. //==============================================
  297. flash_write_bytes(verinf_addr, (uint8_t *)&verinf, sizeof(verinf));
  298. }
  299. // @brief 装载默认的机型配置信息
  300. void load_default_confinf(void)
  301. {
  302. confinf._conf_flag = (int16_t)0xA14A;
  303. confinf._jixing = 42; // 默认机型为4旋翼X型
  304. confinf._lowvolt_flag = 2; // 默认一级电压保护返航
  305. confinf._lowvolt_value = 111; // 11.1V
  306. confinf._lowvolt_flag2 = 3;
  307. confinf._lowvolt_value2 = 0;
  308. confinf._lostlink_time = 0; // 默认不开启,失去联系 返航 单位s
  309. confinf._circle_radius = 12; // 默认盘旋半径12m
  310. confinf._takeoff_alt = 5; // 默认起飞高度5m
  311. confinf._rth_alt = 10; // 默认返航高度10m
  312. confinf._mag_offset = 0; // 默认磁偏角补偿0
  313. confinf._enable_infrared = 10; // 默认雷达灵敏度10
  314. confinf._idle_speed_level = 2; // 默认怠速2档 1150
  315. confinf._port4_af_function = 0; // 默认串口 4 复用功能透传
  316. confinf._rc_fail_loiter_time = 10; // 默认遥控器失控后的悬停时间 10s
  317. }
  318. // @brief flash 读取机型配置信息
  319. void flash_read_confinf(void)
  320. {
  321. flash_read_bytes(confinf_addr, (uint8_t *)&confinf, sizeof(confinf));
  322. if (confinf._conf_flag != (int16_t)0xA14A)
  323. { // 配置表是否有效?
  324. load_default_confinf(); // 装载默认的配置,并写入Flash
  325. flash_write_bytes(confinf_addr, (uint8_t *)&confinf, sizeof(confinf));
  326. }
  327. conf_par.jixing = confinf._jixing;
  328. conf_par.lowvolt_flag = confinf._lowvolt_flag;
  329. conf_par.lowvolt_value = confinf._lowvolt_value;
  330. conf_par.lostlink_time = confinf._lostlink_time;
  331. conf_par.circle_radius = confinf._circle_radius * 100;
  332. // 环绕半径不小于500cm
  333. if (conf_par.circle_radius < 500)
  334. {
  335. conf_par.circle_radius = 500;
  336. }
  337. conf_par.rth_alt_cm = confinf._rth_alt * 100;
  338. conf_par.takeoff_alt_cm = confinf._takeoff_alt * 100;
  339. conf_par.mag_offset = confinf._mag_offset;
  340. conf_par.enable_infrared = confinf._enable_infrared;
  341. // 根据怠速级别设置怠速数值
  342. if (confinf._idle_speed_level >= 1 && confinf._idle_speed_level <= 5)
  343. conf_par.idle_speed = 1050 + (confinf._idle_speed_level - 1) * 50;
  344. else
  345. {
  346. conf_par.idle_speed = 1100;
  347. confinf._idle_speed_level = 2;
  348. }
  349. conf_par.port4_af_function = confinf._port4_af_function;
  350. // conf_par.dpgs_direction = confinf._dgps_direction;
  351. conf_par.lowvolt_flag2 = confinf._lowvolt_flag2;
  352. conf_par.lowvolt_value2 = confinf._lowvolt_value2;
  353. conf_par.rc_fail_loiter_time = confinf._rc_fail_loiter_time;
  354. }
  355. // @brief flash 写入机型配置信息
  356. void flash_write_confinf(void)
  357. {
  358. confinf._conf_flag = (int16_t)0xA14A; // 数据有效标志
  359. //===============数据赋值部分=======================
  360. conf_par.jixing = confinf._jixing;
  361. conf_par.lowvolt_flag = confinf._lowvolt_flag;
  362. conf_par.lowvolt_value = confinf._lowvolt_value;
  363. conf_par.lostlink_time = confinf._lostlink_time;
  364. conf_par.circle_radius = confinf._circle_radius * 100;
  365. // 环绕半径不小于500cm
  366. if (conf_par.circle_radius < 500)
  367. {
  368. conf_par.circle_radius = 500;
  369. }
  370. conf_par.rth_alt_cm = confinf._rth_alt * 100;
  371. conf_par.takeoff_alt_cm = confinf._takeoff_alt * 100;
  372. conf_par.mag_offset = confinf._mag_offset;
  373. conf_par.enable_infrared = confinf._enable_infrared;
  374. // 根据怠速级别设置怠速数值
  375. if (confinf._idle_speed_level >= 1 && confinf._idle_speed_level <= 5)
  376. conf_par.idle_speed = 1050 + (confinf._idle_speed_level - 1) * 50;
  377. else
  378. {
  379. conf_par.idle_speed = 1100;
  380. confinf._idle_speed_level = 2;
  381. }
  382. // conf_par.center_compensation_x = confinf._center_compensation_x;
  383. // conf_par.center_compensation_y = confinf._center_compensation_y;
  384. // conf_par.center_compensation_z = confinf._center_compensation_z;
  385. conf_par.port4_af_function = confinf._port4_af_function;
  386. // conf_par.dpgs_direction = confinf._dgps_direction;
  387. //====================================================
  388. conf_par.lowvolt_flag2 = confinf._lowvolt_flag2;
  389. conf_par.lowvolt_value2 = confinf._lowvolt_value2;
  390. conf_par.rc_fail_loiter_time = confinf._rc_fail_loiter_time;
  391. flash_write_bytes(confinf_addr, (uint8_t *)&confinf, sizeof(confinf));
  392. }
  393. // @brief flash 写入自定义禁飞区信息
  394. // @param custom_no_fly_zone_total_num 自定义禁飞区总条数
  395. // @param current_no_fly_zone_num 要写入的禁飞区是第几条
  396. // @param current_no_fly_zone_vertex_num 要写入的禁飞区的顶点个数
  397. // @param *pdata 要写入的禁飞区顶点的坐标信息指针
  398. void flash_write_custom_no_fly_zone(uint8_t custom_no_fly_zone_total_num,
  399. uint8_t current_no_fly_zone_num,
  400. uint8_t current_no_fly_zone_vertex_num,
  401. Coords3dint *pdata)
  402. {
  403. static uint8_t write_buffer[SIZE_OF_ONE_NO_FLY_ZONE] = {0};
  404. uint16_t no_fly_zone_useable_flag = (uint16_t)0xACCA;
  405. uint16_t index = 0;
  406. uint32_t write_addr =
  407. NO_FLY_ZONE_ADDR + (current_no_fly_zone_num)*SIZE_OF_ONE_NO_FLY_ZONE;
  408. short2buf(&write_buffer[index], (short *)&no_fly_zone_useable_flag);
  409. index += sizeof(uint16_t);
  410. write_buffer[index++] = custom_no_fly_zone_total_num;
  411. write_buffer[index++] = current_no_fly_zone_vertex_num;
  412. if (current_no_fly_zone_vertex_num <= 8)
  413. {
  414. memcpy(&write_buffer[index], pdata,
  415. current_no_fly_zone_vertex_num * sizeof(Coords3dint));
  416. flash_write_bytes(write_addr, write_buffer, sizeof(write_buffer));
  417. }
  418. }
  419. // @brief flash 读取禁飞区信息
  420. // @param read_no_fly_zone_num 要读取的禁飞区的序号 0 开始数
  421. // @param *custom_no_fly_zone_total_num 读出来的禁飞区总个数
  422. // @param *current_no_fly_zone_vertex_num 读出来的当前禁飞区顶点个数
  423. // @param *pdata 读出来的顶点数据存放地址指针
  424. static bool flash_read_custom_no_fly_zone(
  425. uint8_t read_no_fly_zone_num, uint8_t *custom_no_fly_zone_total_num,
  426. uint8_t *current_no_fly_zone_vertex_num, Coords3dint *pdata)
  427. {
  428. uint32_t read_addr =
  429. NO_FLY_ZONE_ADDR + (read_no_fly_zone_num)*SIZE_OF_ONE_NO_FLY_ZONE;
  430. uint16_t useableFlag;
  431. // 预备存储读取出来的总条数,顶点数
  432. uint8_t totalNum, currentVertexNum;
  433. flash_read_bytes(read_addr, (uint8_t *)&useableFlag, sizeof(useableFlag));
  434. flash_read_bytes(read_addr + sizeof(useableFlag), &totalNum,
  435. sizeof(totalNum));
  436. flash_read_bytes(read_addr + sizeof(useableFlag) + sizeof(totalNum),
  437. &currentVertexNum, sizeof(currentVertexNum));
  438. // 如果存储有效
  439. if (useableFlag == 0xACCA && totalNum <= 5 && currentVertexNum <= 8)
  440. {
  441. // 如果是在读第一个位置存储的禁飞区,则更新一下自定义禁飞区的总条数
  442. if (read_no_fly_zone_num == 0)
  443. {
  444. *custom_no_fly_zone_total_num = totalNum;
  445. }
  446. // 更新一下自定义禁飞区的定点个数
  447. *current_no_fly_zone_vertex_num = currentVertexNum;
  448. // 读出顶点的坐标数据
  449. flash_read_bytes(read_addr + sizeof(useableFlag) + sizeof(totalNum) +
  450. sizeof(currentVertexNum),
  451. (uint8_t *)pdata,
  452. currentVertexNum * sizeof(Coords3dint));
  453. return true;
  454. }
  455. else
  456. {
  457. useableFlag = 0x0000;
  458. flash_write_bytes(read_addr, (uint8_t *)&useableFlag,
  459. sizeof(useableFlag));
  460. return false;
  461. }
  462. }
  463. /**
  464. * @brief 装载默认的 par 参数
  465. */
  466. void load_default_parinf(void)
  467. {
  468. parinf._par_flag = (int16_t)0xAAEE; // 数据有效标志
  469. parinf._par_maxangle = 25; // 最大角度 30 deg
  470. parinf._par_maxhspeed = 80; // GPS 推杆最大水平速度 dm/s
  471. parinf._par_maxupspeed = 40; // GPS 推杆最大上升速度 dm/s
  472. parinf._par_maxdownspeed = 30; // GPS 推杆最大下降速度 dm/s
  473. parinf._par_hover_throttle = 1400; // 默认悬停油门
  474. parinf._par_alt_fs_rth = 2000; // 高度限制,1级保护。返航
  475. parinf._par_alt_fs_land = 2500; // 高度限制,2级保护。迫降
  476. parinf._par_maxyawrate = 30; // 最大自动转航向角速度
  477. parinf._par_volt_offset[0] = 0; // 底板电压采集有压降, 0.3v
  478. parinf._par_volt_offset[1] = 0;
  479. parinf._par_volt_offset[2] = 0;
  480. parinf._par_volt_offset_b[0] = 0; // 底板电压采集有压降, 0.3v
  481. parinf._par_volt_offset_b[1] = 0;
  482. parinf._par_volt_offset_b[2] = 0;
  483. parinf._fllow_dist = 10;
  484. // 自动模式最大爬升速率 dm/s
  485. parinf._par_max_climb_rate_automode = 20;
  486. // 自动模式最大下降目标速率 dm/s
  487. parinf._par_max_approach_rate_automode = 15;
  488. // 自动模式降落最小目标垂直速率 dm/s
  489. parinf._par_min_landing_rate_automode = 4;
  490. // 自动模式巡航最大水平速率 dm/s
  491. parinf._par_max_rth_horizontal_speed = 80;
  492. // 电压校准系数
  493. parinf._par_volt_kp[0] = 1000;
  494. parinf._par_volt_kp[1] = 1000;
  495. parinf._par_volt_kp[2] = 1000;
  496. // 最大水平加加速度
  497. parinf._max_hor_jet = 15;
  498. parinf._bms_low_capacity_percentage = 30;
  499. parinf._motor_failsafe_action = 0;
  500. }
  501. /**
  502. * @brief 从 flash 读取 par 参数
  503. */
  504. void flash_read_parinf(void)
  505. {
  506. flash_read_bytes(parinf_addr, (uint8_t *)&parinf, sizeof(parinf));
  507. if (parinf._par_flag != (int16_t)0xAAEE)
  508. { // 配置表是否有效?
  509. load_default_parinf(); // 装载默认的配置,并写入Flash
  510. flash_write_bytes(parinf_addr, (uint8_t *)&parinf, sizeof(parinf));
  511. }
  512. //=============数据赋值部分================
  513. if (params_get_value(ParamNum_APMaxTilteAngleDeg) < 15)
  514. {
  515. params_set_value(ParamNum_APMaxTilteAngleDeg, 15);
  516. }
  517. else if (params_get_value(ParamNum_APMaxTilteAngleDeg) > 45)
  518. {
  519. params_set_value(ParamNum_APMaxTilteAngleDeg, 45);
  520. }
  521. if (parinf._par_maxhspeed < 30)
  522. {
  523. parinf._par_maxhspeed = 30;
  524. }
  525. else if (parinf._par_maxhspeed > 150)
  526. {
  527. parinf._par_maxhspeed = 150;
  528. }
  529. // 对跟随距离做限制
  530. if (parinf._fllow_dist < 3)
  531. {
  532. parinf._fllow_dist = 3;
  533. }
  534. else if (parinf._fllow_dist > 100)
  535. {
  536. parinf._fllow_dist = 100;
  537. }
  538. // 最大自动目标爬升速率在 1~5 m/s
  539. if (parinf._par_max_climb_rate_automode < 10)
  540. {
  541. parinf._par_max_climb_rate_automode = 10;
  542. }
  543. else if (parinf._par_max_climb_rate_automode > 50)
  544. {
  545. parinf._par_max_climb_rate_automode = 50;
  546. }
  547. // 最大自动目标下降速率在 1~5 m/s
  548. if (parinf._par_max_approach_rate_automode < 10)
  549. {
  550. parinf._par_max_approach_rate_automode = 10;
  551. }
  552. else if (parinf._par_max_approach_rate_automode > 50)
  553. {
  554. parinf._par_max_approach_rate_automode = 50;
  555. }
  556. // 最小目标降落速度在 0.2 ~ 0.5 m/s
  557. if (parinf._par_min_landing_rate_automode < 2)
  558. {
  559. parinf._par_min_landing_rate_automode = 2;
  560. }
  561. else if (parinf._par_min_landing_rate_automode > 5)
  562. {
  563. parinf._par_min_landing_rate_automode = 5;
  564. }
  565. // 最大目标航线水平速度在 10~20 m/s
  566. if (parinf._par_max_rth_horizontal_speed < 20 ||
  567. parinf._par_max_rth_horizontal_speed > 300)
  568. {
  569. parinf._par_max_rth_horizontal_speed = 80;
  570. }
  571. if (parinf._max_hor_jet < 4 || parinf._max_hor_jet > 50)
  572. {
  573. parinf._max_hor_jet = 50;
  574. }
  575. //=========================================
  576. }
  577. /**************************实现函数********************************************
  578. *函数原型: void flash_write_jfqinf(void)
  579. *功  能: 将当前的拍照参数设置保存到Flash,永久保存
  580. *******************************************************************************/
  581. void flash_write_parinf(void)
  582. {
  583. parinf._par_flag = (int16_t)0xAAEE; // 数据有效标志
  584. //=============数据赋值部分================
  585. if (params_get_value(ParamNum_APMaxTilteAngleDeg) < 15)
  586. {
  587. params_set_value(ParamNum_APMaxTilteAngleDeg, 15);
  588. }
  589. else if (params_get_value(ParamNum_APMaxTilteAngleDeg) > 45)
  590. {
  591. params_set_value(ParamNum_APMaxTilteAngleDeg, 45);
  592. }
  593. if (parinf._par_maxhspeed < 30)
  594. {
  595. parinf._par_maxhspeed = 30;
  596. }
  597. else if (parinf._par_maxhspeed > 150)
  598. {
  599. parinf._par_maxhspeed = 150;
  600. }
  601. // 对跟随距离做限制
  602. if (parinf._fllow_dist < 3)
  603. {
  604. parinf._fllow_dist = 3;
  605. }
  606. else if (parinf._fllow_dist > 100)
  607. {
  608. parinf._fllow_dist = 100;
  609. }
  610. // 最大自动目标爬升速率在 1~5 m/s
  611. if (parinf._par_max_climb_rate_automode < 10)
  612. {
  613. parinf._par_max_climb_rate_automode = 10;
  614. }
  615. else if (parinf._par_max_climb_rate_automode > 50)
  616. {
  617. parinf._par_max_climb_rate_automode = 50;
  618. }
  619. // 最大自动目标下降速率在 1~5 m/s
  620. if (parinf._par_max_approach_rate_automode < 10)
  621. {
  622. parinf._par_max_approach_rate_automode = 10;
  623. }
  624. else if (parinf._par_max_approach_rate_automode > 50)
  625. {
  626. parinf._par_max_approach_rate_automode = 50;
  627. }
  628. // 最小目标降落速度在 0.2 ~ 0.5 m/s
  629. if (parinf._par_min_landing_rate_automode < 2)
  630. {
  631. parinf._par_min_landing_rate_automode = 2;
  632. }
  633. else if (parinf._par_min_landing_rate_automode > 5)
  634. {
  635. parinf._par_min_landing_rate_automode = 5;
  636. }
  637. // 最大目标航线水平速度在 10~20 m/s
  638. if (parinf._par_max_rth_horizontal_speed < 20 ||
  639. parinf._par_max_rth_horizontal_speed > 300)
  640. {
  641. parinf._par_max_rth_horizontal_speed = 80;
  642. }
  643. if (parinf._max_hor_jet < 4 || parinf._max_hor_jet > 50)
  644. {
  645. parinf._max_hor_jet = 50;
  646. }
  647. flash_write_bytes(parinf_addr, (uint8_t *)&parinf, sizeof(parinf));
  648. }
  649. /**************************实现函数********************************************
  650. *函数原型: void initial_parameters(void)
  651. *功  能: 初始化四轴的数据参数。
  652. 读取PID参数,以便在四轴控制中进行运算
  653. *******************************************************************************/
  654. void initial_parameters(void)
  655. {
  656. // 读取PID参数
  657. flash_read_pidinf();
  658. // 读取飞控版本信息
  659. flash_read_verinf();
  660. // 读取机型配置信息
  661. flash_read_confinf();
  662. // 读取备用参数信息
  663. flash_read_parinf();
  664. }
  665. /* 需要记录参数的标志位 */
  666. bool write_pid_information = false, write_conf_information = false,
  667. write_cam_information = false, write_ver_information = false,
  668. write_breakpoint_information = false,
  669. write_par_information = false, write_pos_information = false,
  670. write_postotal_information = false, write_iap_flag = false,
  671. write_rcfactor_flag = false, write_custom_noflyzone = false;
  672. /**
  673. * @brief 参数写入 flash
  674. *
  675. */
  676. void write_par_to_flash(void)
  677. {
  678. if (thr_lock_status != LOCKED)
  679. {
  680. if (write_pid_information == true) // 写PID参数信息
  681. {
  682. // FLASH忙则先返回。
  683. flash_write_pidinf();
  684. }
  685. return;
  686. }
  687. if (write_pid_information == true) // 写PID参数信息
  688. {
  689. // FLASH忙则先返回。
  690. if (flash_isbusy())
  691. return;
  692. flash_write_pidinf();
  693. write_pid_information = false;
  694. }
  695. else if (write_ver_information == true) // 写版本信息
  696. {
  697. // FLASH忙则先返回。
  698. if (flash_isbusy())
  699. return;
  700. flash_write_verinf();
  701. write_ver_information = false;
  702. }
  703. else if (write_conf_information == true) // 写机型配置信息
  704. {
  705. // FLASH忙则先返回。
  706. if (flash_isbusy())
  707. return;
  708. flash_write_confinf();
  709. write_conf_information = false;
  710. }
  711. else if (write_par_information == true) // 写备用参数信息
  712. {
  713. // FLASH忙则先返回。
  714. if (flash_isbusy())
  715. return;
  716. flash_write_parinf();
  717. write_par_information = false;
  718. }
  719. else if (write_rcfactor_flag == true) // 写遥控器校准系数信息
  720. {
  721. // 计算遥控器补偿的系数
  722. calc_rcfactor_calibration();
  723. // 写入flash
  724. flash_write_pidinf();
  725. delay_ms(200);
  726. write_rcfactor_flag = false;
  727. pilot_mode = PILOT_NORMAL;
  728. }
  729. else if (write_iap_flag == true) // 写IAP升级信息
  730. {
  731. switch (ver_par.hardware_id)
  732. {
  733. case HW_V8M_YY:
  734. V8M_record_iap_flag();
  735. break;
  736. default:
  737. return;
  738. }
  739. write_iap_flag = false;
  740. // 升级前失能电平芯片输出,PWM脉宽给0
  741. PWM_IS_DISABLE();
  742. for (uint8_t i = 1; i <= params_get_value(ParamNum_APType) / 10; i++)
  743. {
  744. set_motor_pwm(i, 0);
  745. }
  746. delay_ms(200);
  747. // 软件复位
  748. sys_reset();
  749. }
  750. }
  751. //------------------End of File----------------------------