nv_storage.c 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112
  1. #include "app/nv_storage.h"
  2. #include "bsp/fmc_flash.h"
  3. #include "libs/crc16.h"
  4. #include "foc/motor/motor_param.h"
  5. #include "foc/foc_config.h"
  6. static motor_params_t m_params;
  7. static foc_params_t foc_params;
  8. motor_params_t *nv_get_motor_params(void) {
  9. return &m_params;
  10. }
  11. foc_params_t *nv_get_foc_params(void) {
  12. return &foc_params;
  13. }
  14. void nv_save_hall_table(s32 *hall_table) {
  15. memcpy((char *)m_params.hall_table, (char *)hall_table, sizeof(m_params.hall_table));
  16. nv_save_motor_params();
  17. }
  18. void nv_save_hall_offset(s16 offset) {
  19. m_params.hall_offset = offset;
  20. nv_save_motor_params();
  21. }
  22. static void nv_default_motor_params(void) {
  23. m_params.poles = MOTOR_POLES;
  24. m_params.r = MOTOR_R;
  25. m_params.ld = MOTOR_Ld;
  26. m_params.lq = MOTOR_Lq;
  27. m_params.encoder_offset = -50;
  28. m_params.est_pll_band = 200;
  29. m_params.pos_lock_pll_band = 200;
  30. m_params.flux_linkage = 0.0f;
  31. m_params.hall_offset = 0;
  32. }
  33. static void nv_default_foc_params(void) {
  34. foc_params.s_maxvDC = 16;
  35. foc_params.s_maxiDC = 10;
  36. foc_params.s_maxIdq = 20;
  37. foc_params.s_minIdq = -20;
  38. foc_params.s_maxRPM = 8200;
  39. foc_params.s_maxTorque = 15;
  40. foc_params.s_maxBrkCurrent = 2.0f;
  41. foc_params.n_currentBand = 500;
  42. foc_params.n_modulation = 1.0f;
  43. foc_params.n_PhaseFilterCeof = 0.2f;
  44. foc_params.spd_kp = 0.001f;
  45. foc_params.spd_ki = 0.01;
  46. foc_params.trq_kp = 0.001f;
  47. foc_params.trq_ki = 0.01;
  48. foc_params.fw_kp = 0.1f;
  49. foc_params.fw_ki = 0.01;
  50. foc_params.fw_baseSpd = 5000;
  51. }
  52. void nv_save_motor_params(void) {
  53. u16 crc = crc16_get((u8 *)&m_params, sizeof(m_params) - 2);
  54. m_params.crc16 = crc;
  55. fmc_write_data(motorParam_idx_0, (u8 *)&m_params, sizeof(m_params));
  56. fmc_write_data(motorParam_idx_1, (u8 *)&m_params, sizeof(m_params));
  57. }
  58. void nv_read_motor_params(void) {
  59. fmc_read_data(motorParam_idx_0, (u8 *)&m_params, sizeof(m_params));
  60. u16 crc0 = crc16_get((u8 *)&m_params, sizeof(m_params) - 2);
  61. if (crc0 != m_params.crc16) {
  62. fmc_read_data(motorParam_idx_1, (u8 *)&m_params, sizeof(m_params));
  63. crc0 = crc16_get((u8 *)&m_params, sizeof(m_params) - 2);
  64. if (crc0 != m_params.crc16) {
  65. nv_default_motor_params();
  66. nv_save_motor_params();
  67. return;
  68. }
  69. fmc_write_data(motorParam_idx_0, (u8 *)&m_params, sizeof(m_params));
  70. }else {
  71. fmc_write_data(motorParam_idx_1, (u8 *)&m_params, sizeof(m_params));
  72. }
  73. }
  74. void nv_save_foc_params(void) {
  75. u16 crc = crc16_get((u8 *)&foc_params, sizeof(foc_params) - 2);
  76. foc_params.crc16 = crc;
  77. fmc_write_data(focParam_idx_0, (u8 *)&foc_params, sizeof(foc_params));
  78. fmc_write_data(focParam_idx_1, (u8 *)&foc_params, sizeof(foc_params));
  79. }
  80. void nv_read_foc_params(void) {
  81. fmc_read_data(focParam_idx_0, (u8 *)&foc_params, sizeof(foc_params));
  82. u16 crc0 = crc16_get((u8 *)&foc_params, sizeof(foc_params) - 2);
  83. if (crc0 != foc_params.crc16) {
  84. fmc_read_data(focParam_idx_1, (u8 *)&foc_params, sizeof(foc_params));
  85. crc0 = crc16_get((u8 *)&foc_params, sizeof(foc_params) - 2);
  86. if (crc0 != foc_params.crc16) {
  87. nv_default_foc_params();
  88. nv_save_foc_params();
  89. return;
  90. }
  91. fmc_write_data(focParam_idx_0, (u8 *)&foc_params, sizeof(foc_params));
  92. }else {
  93. fmc_write_data(focParam_idx_1, (u8 *)&foc_params, sizeof(foc_params));
  94. }
  95. }
  96. void nv_storage_init(void) {
  97. nv_read_motor_params();
  98. nv_read_foc_params();
  99. }