modbus_ai_params.c 6.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219
  1. #include "at32f403a_407.h"
  2. #include "modbus_ai_params.h"
  3. #include "settings_api.h"
  4. #include "modbus_params.h"
  5. #include "analog_input.h"
  6. extern mb_param_t mb_param[];
  7. #if defined (MAI_12)
  8. //
  9. uint16_t mb_init_ai_params(uint16_t i)
  10. {
  11. uint16_t index = i;
  12. uint16_t addr = 0;
  13. // Статус входов (вкл./выкл.)
  14. mb_param[index].reg = 0x0300;
  15. mb_param[index].size = 1;
  16. mb_param[index].param = (uint8_t*)&settings.ai_state_bits;
  17. mb_param[index].set = mb_set_ai_state;
  18. mb_param[index].get = NULL;
  19. mb_param[index].check_handler = mb_check_dummy;
  20. index++;
  21. // Режим работы входов
  22. mb_param[index].reg = 0x0301;
  23. mb_param[index].size = 1;
  24. mb_param[index].param = (uint8_t*)&settings.ai_mode_bits;
  25. mb_param[index].set = mb_set_ai_mode;
  26. mb_param[index].get = NULL;
  27. mb_param[index].check_handler = mb_check_dummy;
  28. index++;
  29. // Флаги аварий аналоговых входов. Определяется аппаратно.
  30. mb_param[index].reg = 0x0302;
  31. mb_param[index].size = 1;
  32. mb_param[index].param = (uint8_t*)&ai_alarm;
  33. mb_param[index].set = NULL;
  34. mb_param[index].get = NULL;
  35. mb_param[index].check_handler = mb_check_dummy;
  36. index++;
  37. //
  38. mb_param[index].reg = 0x0303;
  39. mb_param[index].size = 1;
  40. mb_param[index].param = (uint8_t*)&settings.ext_sens_power;
  41. mb_param[index].set = mb_set_ext_sens_power;
  42. mb_param[index].get = NULL;
  43. mb_param[index].check_handler = mb_check_dummy;
  44. index++;
  45. // Коэффициенты усиления. Регистры 0x0310 - 0x031В.
  46. addr = 0x0310;
  47. for (int i = 0; i < AI_COMMON_NUMBER; i++)
  48. {
  49. mb_param[index].reg = addr;
  50. mb_param[index].size = 1;
  51. mb_param[index].param = (uint8_t*)&ai_gain[i];
  52. mb_param[index].set = mb_set_ai_gain;
  53. mb_param[index].get = NULL;
  54. mb_param[index].check_handler = mb_check_dummy;
  55. addr += 1;
  56. index++;
  57. }
  58. // ---------------------------------------------------------------------- //
  59. // Коэффициенты K
  60. addr = 0x0320;
  61. for (int i = 0; i < AI_COMMON_NUMBER; i++)
  62. {
  63. mb_param[index].reg = addr;
  64. mb_param[index].size = 2;
  65. mb_param[index].param = (uint8_t*)&settings.ai[i].k_factor;
  66. mb_param[index].set = NULL;
  67. mb_param[index].get = NULL;
  68. mb_param[index].check_handler = mb_check_dummy;
  69. addr += 2;
  70. index++;
  71. }
  72. // ---------------------------------------------------------------------- //
  73. // Коэффициенты B
  74. addr = 0x0340;
  75. for (int i = 0; i < AI_COMMON_NUMBER; i++)
  76. {
  77. mb_param[index].reg = addr;
  78. mb_param[index].size = 2;
  79. mb_param[index].param = (uint8_t*)&settings.ai[i].b_factor;
  80. mb_param[index].set = NULL;
  81. mb_param[index].get = NULL;
  82. mb_param[index].check_handler = mb_check_dummy;
  83. addr += 2;
  84. index++;
  85. }
  86. // ---------------------------------------------------------------------- //
  87. // Сырые данные каналов ADC
  88. addr = 0x0360;
  89. for (int i = 0; i < AI_COMMON_NUMBER; i++)
  90. {
  91. mb_param[index].reg = addr + i;
  92. mb_param[index].size = 1;
  93. mb_param[index].param = (uint8_t*)&adc_com_raw_data[i];
  94. mb_param[index].set = NULL;
  95. mb_param[index].get = NULL;
  96. mb_param[index].check_handler = mb_check_dummy;
  97. index++;
  98. }
  99. addr = 0x036C;
  100. // V_ISO_CL, V_ISO, CRNT_LIM_U_BFR_R, CRNT_LIM_U_ABFR_R
  101. for (int i = 0; i < AI_ADD_NUMBER; i++)
  102. {
  103. mb_param[index].reg = addr + i;
  104. mb_param[index].size = 1;
  105. mb_param[index].param = (uint8_t*)&adc_add_raw_data[i];
  106. mb_param[index].set = NULL;
  107. mb_param[index].get = NULL;
  108. mb_param[index].check_handler = mb_check_dummy;
  109. index++;
  110. }
  111. // ---------------------------------------------------------------------- //
  112. // Фильтрованные данные с учетом коэф-ов К, B
  113. addr = 0x0380;
  114. for (int i = 0; i < AI_COMMON_NUMBER; i++)
  115. {
  116. mb_param[index].reg = addr;
  117. mb_param[index].size = 2;
  118. mb_param[index].param = (uint8_t*)&adc_com_data[i];
  119. mb_param[index].set = NULL;
  120. mb_param[index].get = NULL;
  121. mb_param[index].check_handler = mb_check_dummy;
  122. addr += 2;
  123. index++;
  124. }
  125. // ---------------------------------------------------------------------- //
  126. // Фильтрованные значения 12-и основных каналов. Вывод для отладки.
  127. addr = 0x03A0;
  128. for (int i = 0; i < AI_COMMON_NUMBER; i++)
  129. {
  130. mb_param[index].reg = addr + i;
  131. mb_param[index].size = 1;
  132. mb_param[index].param = (uint8_t*)&adc_com_fil_data[i];
  133. mb_param[index].set = NULL;
  134. mb_param[index].get = NULL;
  135. mb_param[index].check_handler = mb_check_dummy;
  136. index++;
  137. }
  138. // ---------------------------------------------------------------------- //
  139. return index;
  140. }
  141. // -------------------------------------------------------------------------- //
  142. // Установка параметров
  143. // -------------------------------------------------------------------------- //
  144. //
  145. mb_delay_action_t mb_set_ai_state(void)
  146. {
  147. ai_set();
  148. return MB_NO_ACTION;
  149. }
  150. // При изменении режима измерения нужно проверить флаг аварий.
  151. // Если флаг установлен, то канал нельзя перевести в режим измерения тока.
  152. mb_delay_action_t mb_set_ai_mode(void)
  153. {
  154. for (uint8_t i = 0; i < AI_COMMON_NUMBER; i++)
  155. {
  156. if (!ai_alarm_f[i].alarm_flag)
  157. settings.ai[i].mode = (uint8_t)((settings.ai_mode_bits >> i) & 1);
  158. else if (((uint8_t)(settings.ai_mode_bits >> i) & 1) == 0)
  159. settings.ai[i].mode = (uint8_t)((settings.ai_mode_bits >> i) & 1);
  160. }
  161. ai_set_meas_mode();
  162. return MB_SAVE_SETTINGS;
  163. }
  164. //
  165. mb_delay_action_t mb_set_ai_gain(void)
  166. {
  167. for (uint8_t i = 0; i < AI_COMMON_NUMBER; i++)
  168. {
  169. settings.ai[i].gain_factor = ai_gain[i];
  170. }
  171. return MB_NO_ACTION;
  172. }
  173. //
  174. mb_delay_action_t mb_set_ext_sens_power(void)
  175. {
  176. if (!ai_cur_lim.alarm_flag)
  177. ai_ext_sens_power(settings.ext_sens_power);
  178. return MB_SAVE_SETTINGS;
  179. }
  180. #endif