modbus_ai_params.c 8.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285
  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. #include "preset_ai.h"
  7. extern mb_param_t mb_param[];
  8. #if defined (MAI_12)
  9. //
  10. uint16_t mb_init_ai_params(uint16_t i)
  11. {
  12. uint16_t index = i;
  13. uint16_t addr = 0;
  14. // Статус входов (вкл./выкл.)
  15. mb_param[index].reg = 0x0300;
  16. mb_param[index].size = 1;
  17. mb_param[index].param = (uint8_t*)&settings.ai_state_bits;
  18. mb_param[index].set = mb_set_ai_state;
  19. mb_param[index].get = NULL;
  20. mb_param[index].check_handler = mb_check_dummy;
  21. index++;
  22. // Режим работы входов
  23. mb_param[index].reg = 0x0301;
  24. mb_param[index].size = 1;
  25. mb_param[index].param = (uint8_t*)&settings.ai_mode_bits;
  26. mb_param[index].set = mb_set_ai_mode;
  27. mb_param[index].get = NULL;
  28. mb_param[index].check_handler = mb_check_dummy;
  29. index++;
  30. // Флаги аварий аналоговых входов. Определяется аппаратно.
  31. mb_param[index].reg = 0x0302;
  32. mb_param[index].size = 1;
  33. mb_param[index].param = (uint8_t*)&ai_alarm;
  34. mb_param[index].set = NULL;
  35. mb_param[index].get = NULL;
  36. mb_param[index].check_handler = mb_check_dummy;
  37. index++;
  38. //
  39. mb_param[index].reg = 0x0303;
  40. mb_param[index].size = 1;
  41. mb_param[index].param = (uint8_t*)&settings.ext_sens_power;
  42. mb_param[index].set = mb_set_ext_sens_power;
  43. mb_param[index].get = NULL;
  44. mb_param[index].check_handler = mb_check_dummy;
  45. index++;
  46. // Коэффициенты усиления. Регистры 0x0310 - 0x031В.
  47. addr = 0x0310;
  48. for (int i = 0; i < AI_COMMON_NUMBER; i++)
  49. {
  50. mb_param[index].reg = addr;
  51. mb_param[index].size = 1;
  52. mb_param[index].param = (uint8_t*)&ai_gain[i];
  53. mb_param[index].set = mb_set_ai_gain;
  54. mb_param[index].get = NULL;
  55. mb_param[index].check_handler = mb_check_dummy;
  56. addr += 1;
  57. index++;
  58. }
  59. // ---------------------------------------------------------------------- //
  60. // Коэффициенты K
  61. addr = 0x0320;
  62. for (int i = 0; i < AI_COMMON_NUMBER; i++)
  63. {
  64. mb_param[index].reg = addr;
  65. mb_param[index].size = 2;
  66. mb_param[index].param = (uint8_t*)&settings.ai[i].k_factor;
  67. mb_param[index].set = NULL;
  68. mb_param[index].get = NULL;
  69. mb_param[index].check_handler = mb_check_dummy;
  70. addr += 2;
  71. index++;
  72. }
  73. // ---------------------------------------------------------------------- //
  74. // Коэффициенты B
  75. addr = 0x0340;
  76. for (int i = 0; i < AI_COMMON_NUMBER; i++)
  77. {
  78. mb_param[index].reg = addr;
  79. mb_param[index].size = 2;
  80. mb_param[index].param = (uint8_t*)&settings.ai[i].b_factor;
  81. mb_param[index].set = NULL;
  82. mb_param[index].get = NULL;
  83. mb_param[index].check_handler = mb_check_dummy;
  84. addr += 2;
  85. index++;
  86. }
  87. // ---------------------------------------------------------------------- //
  88. // Сырые данные каналов ADC
  89. addr = 0x0360;
  90. for (int i = 0; i < AI_COMMON_NUMBER; i++)
  91. {
  92. mb_param[index].reg = addr + i;
  93. mb_param[index].size = 1;
  94. mb_param[index].param = (uint8_t*)&adc_com_raw_data[i];
  95. mb_param[index].set = NULL;
  96. mb_param[index].get = NULL;
  97. mb_param[index].check_handler = mb_check_dummy;
  98. index++;
  99. }
  100. addr = 0x036C;
  101. // V_ISO_CL, V_ISO, CRNT_LIM_U_BFR_R, CRNT_LIM_U_ABFR_R
  102. for (int i = 0; i < AI_ADD_NUMBER; i++)
  103. {
  104. mb_param[index].reg = addr + i;
  105. mb_param[index].size = 1;
  106. mb_param[index].param = (uint8_t*)&adc_add_raw_data[i];
  107. mb_param[index].set = NULL;
  108. mb_param[index].get = NULL;
  109. mb_param[index].check_handler = mb_check_dummy;
  110. index++;
  111. }
  112. // ---------------------------------------------------------------------- //
  113. // Фильтрованные данные с учетом коэф-ов К, B
  114. addr = 0x0380;
  115. for (int i = 0; i < AI_COMMON_NUMBER; i++)
  116. {
  117. mb_param[index].reg = addr;
  118. mb_param[index].size = 2;
  119. mb_param[index].param = (uint8_t*)&adc_com_data[i];
  120. mb_param[index].set = NULL;
  121. mb_param[index].get = NULL;
  122. mb_param[index].check_handler = mb_check_dummy;
  123. addr += 2;
  124. index++;
  125. }
  126. // ---------------------------------------------------------------------- //
  127. // Фильтрованные значения 12-и основных каналов. Вывод для отладки.
  128. addr = 0x03A0;
  129. for (int i = 0; i < AI_COMMON_NUMBER; i++)
  130. {
  131. mb_param[index].reg = addr + i;
  132. mb_param[index].size = 1;
  133. mb_param[index].param = (uint8_t*)&adc_com_fil_data[i];
  134. mb_param[index].set = NULL;
  135. mb_param[index].get = NULL;
  136. mb_param[index].check_handler = mb_check_dummy;
  137. index++;
  138. }
  139. // ---------------------------------------------------------------------- //
  140. // Статус уставок (вкл./выкл.)
  141. mb_param[index].reg = 0x03B0;
  142. mb_param[index].size = 1;
  143. mb_param[index].param = (uint8_t*)&settings.preset_state_bits;
  144. mb_param[index].set = mb_set_preset_state;
  145. mb_param[index].get = NULL;
  146. mb_param[index].check_handler = mb_check_dummy;
  147. index++;
  148. // Нижнее значение уставки
  149. addr = 0x03BA;
  150. for (int i = 0; i < AI_COMMON_NUMBER; i++)
  151. {
  152. mb_param[index].reg = addr;
  153. mb_param[index].size = 2;
  154. mb_param[index].param = (uint8_t*)&settings.preset[i].min;
  155. mb_param[index].set = NULL;
  156. mb_param[index].get = NULL;
  157. mb_param[index].check_handler = mb_check_dummy;
  158. addr += 2;
  159. index++;
  160. }
  161. // Верхнее значение уставки
  162. addr = 0x03D2;
  163. for (int i = 0; i < AI_COMMON_NUMBER; i++)
  164. {
  165. mb_param[index].reg = addr;
  166. mb_param[index].size = 2;
  167. mb_param[index].param = (uint8_t*)&settings.preset[i].max;
  168. mb_param[index].set = NULL;
  169. mb_param[index].get = NULL;
  170. mb_param[index].check_handler = mb_check_dummy;
  171. addr += 2;
  172. index++;
  173. }
  174. // Значение гистерезиса
  175. addr = 0x03EA;
  176. for (int i = 0; i < AI_COMMON_NUMBER; i++)
  177. {
  178. mb_param[index].reg = addr;
  179. mb_param[index].size = 2;
  180. mb_param[index].param = (uint8_t*)&settings.preset[i].hyst;
  181. mb_param[index].set = NULL;
  182. mb_param[index].get = NULL;
  183. mb_param[index].check_handler = mb_check_dummy;
  184. addr += 2;
  185. index++;
  186. }
  187. return index;
  188. }
  189. // -------------------------------------------------------------------------- //
  190. // Установка параметров
  191. // -------------------------------------------------------------------------- //
  192. //
  193. mb_delay_action_t mb_set_ai_state(void)
  194. {
  195. ai_set();
  196. return MB_SAVE_SETTINGS;;
  197. }
  198. // При изменении режима измерения нужно проверить флаг аварий.
  199. // Если флаг установлен, то канал нельзя перевести в режим измерения тока.
  200. mb_delay_action_t mb_set_ai_mode(void)
  201. {
  202. for (uint8_t i = 0; i < AI_COMMON_NUMBER; i++)
  203. {
  204. if (!ai_alarm_f[i].alarm_flag)
  205. settings.ai[i].mode = (uint8_t)((settings.ai_mode_bits >> i) & 1);
  206. else if (((uint8_t)(settings.ai_mode_bits >> i) & 1) == 0)
  207. settings.ai[i].mode = (uint8_t)((settings.ai_mode_bits >> i) & 1);
  208. }
  209. ai_set_meas_mode();
  210. return MB_SAVE_SETTINGS;
  211. }
  212. //
  213. mb_delay_action_t mb_set_ai_gain(void)
  214. {
  215. for (uint8_t i = 0; i < AI_COMMON_NUMBER; i++)
  216. {
  217. settings.ai[i].gain_factor = ai_gain[i];
  218. }
  219. return MB_NO_ACTION;
  220. }
  221. //
  222. mb_delay_action_t mb_set_ext_sens_power(void)
  223. {
  224. if (!ai_cur_lim.alarm_flag)
  225. ai_ext_sens_power(settings.ext_sens_power);
  226. return MB_SAVE_SETTINGS;
  227. }
  228. // Статус уставок (вкл./выкл.)
  229. mb_delay_action_t mb_set_preset_state(void)
  230. {
  231. preset_set_state();
  232. return MB_SAVE_SETTINGS;
  233. }
  234. #endif