modbus_ai_params.c 9.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345
  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*)&settings.ai_voltage_mode_bits;
  34. mb_param[index].set = mb_set_ai_voltage_mode;
  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.ai_current_mode_bits;
  42. mb_param[index].set = mb_set_ai_current_mode;
  43. mb_param[index].get = NULL;
  44. mb_param[index].check_handler = mb_check_dummy;
  45. index++;
  46. // Флаги аварий аналоговых входов. Определяется аппаратно.
  47. mb_param[index].reg = 0x0304;
  48. mb_param[index].size = 1;
  49. mb_param[index].param = (uint8_t*)&ai_alarm;
  50. mb_param[index].set = NULL;
  51. mb_param[index].get = NULL;
  52. mb_param[index].check_handler = mb_check_dummy;
  53. index++;
  54. //
  55. mb_param[index].reg = 0x0305;
  56. mb_param[index].size = 1;
  57. mb_param[index].param = (uint8_t*)&settings.ext_sens_power;
  58. mb_param[index].set = mb_set_ext_sens_power;
  59. mb_param[index].get = NULL;
  60. mb_param[index].check_handler = mb_check_dummy;
  61. index++;
  62. // Коэффициенты усиления. Регистры 0x0310 - 0x031В.
  63. addr = 0x0310;
  64. for (int i = 0; i < AI_COMMON_NUMBER; i++)
  65. {
  66. mb_param[index].reg = addr;
  67. mb_param[index].size = 1;
  68. mb_param[index].param = (uint8_t*)&ai_gain[i];
  69. mb_param[index].set = mb_set_ai_gain;
  70. mb_param[index].get = NULL;
  71. mb_param[index].check_handler = mb_check_dummy;
  72. addr += 1;
  73. index++;
  74. }
  75. // ---------------------------------------------------------------------- //
  76. // Коэффициенты K
  77. addr = 0x0320;
  78. for (int i = 0; i < AI_COMMON_NUMBER; i++)
  79. {
  80. mb_param[index].reg = addr;
  81. mb_param[index].size = 2;
  82. mb_param[index].param = (uint8_t*)&settings.ai[i].k_factor;
  83. mb_param[index].set = NULL;
  84. mb_param[index].get = NULL;
  85. mb_param[index].check_handler = mb_check_dummy;
  86. addr += 2;
  87. index++;
  88. }
  89. // ---------------------------------------------------------------------- //
  90. // Коэффициенты B
  91. addr = 0x0340;
  92. for (int i = 0; i < AI_COMMON_NUMBER; i++)
  93. {
  94. mb_param[index].reg = addr;
  95. mb_param[index].size = 2;
  96. mb_param[index].param = (uint8_t*)&settings.ai[i].b_factor;
  97. mb_param[index].set = NULL;
  98. mb_param[index].get = NULL;
  99. mb_param[index].check_handler = mb_check_dummy;
  100. addr += 2;
  101. index++;
  102. }
  103. // ---------------------------------------------------------------------- //
  104. // Сырые данные каналов ADC
  105. addr = 0x0360;
  106. for (int i = 0; i < AI_COMMON_NUMBER; i++)
  107. {
  108. mb_param[index].reg = addr + i;
  109. mb_param[index].size = 1;
  110. mb_param[index].param = (uint8_t*)&adc_com_raw_data[i];
  111. mb_param[index].set = NULL;
  112. mb_param[index].get = NULL;
  113. mb_param[index].check_handler = mb_check_dummy;
  114. index++;
  115. }
  116. addr = 0x036C;
  117. //CRNT_LIM_U_BFR_R, CRNT_LIM_U_ABFR_R
  118. for (int i = 0; i < AI_ADD_NUMBER; i++)
  119. {
  120. mb_param[index].reg = addr + i;
  121. mb_param[index].size = 1;
  122. mb_param[index].param = (uint8_t*)&adc_add_raw_data[i];
  123. mb_param[index].set = NULL;
  124. mb_param[index].get = NULL;
  125. mb_param[index].check_handler = mb_check_dummy;
  126. index++;
  127. }
  128. // ---------------------------------------------------------------------- //
  129. // Фильтрованные данные с учетом коэф-ов К, B
  130. addr = 0x0380;
  131. for (int i = 0; i < AI_COMMON_NUMBER; i++)
  132. {
  133. mb_param[index].reg = addr;
  134. mb_param[index].size = 2;
  135. mb_param[index].param = (uint8_t*)&adc_com_data[i];
  136. mb_param[index].set = NULL;
  137. mb_param[index].get = NULL;
  138. mb_param[index].check_handler = mb_check_dummy;
  139. addr += 2;
  140. index++;
  141. }
  142. // ---------------------------------------------------------------------- //
  143. // Фильтрованные значения 12-и основных каналов. Вывод для отладки.
  144. addr = 0x03A0;
  145. for (int i = 0; i < AI_COMMON_NUMBER; i++)
  146. {
  147. mb_param[index].reg = addr + i;
  148. mb_param[index].size = 1;
  149. mb_param[index].param = (uint8_t*)&adc_com_fil_data[i];
  150. mb_param[index].set = NULL;
  151. mb_param[index].get = NULL;
  152. mb_param[index].check_handler = mb_check_dummy;
  153. index++;
  154. }
  155. // ---------------------------------------------------------------------- //
  156. // Статус уставок (вкл./выкл.)
  157. mb_param[index].reg = 0x03B0;
  158. mb_param[index].size = 1;
  159. mb_param[index].param = (uint8_t*)&settings.preset_state_bits;
  160. mb_param[index].set = mb_set_preset_state;
  161. mb_param[index].get = NULL;
  162. mb_param[index].check_handler = mb_check_dummy;
  163. index++;
  164. // Нижнее значение уставки
  165. addr = 0x03BA;
  166. for (int i = 0; i < AI_COMMON_NUMBER; i++)
  167. {
  168. mb_param[index].reg = addr;
  169. mb_param[index].size = 2;
  170. mb_param[index].param = (uint8_t*)&settings.preset[i].min;
  171. mb_param[index].set = NULL;
  172. mb_param[index].get = NULL;
  173. mb_param[index].check_handler = mb_check_dummy;
  174. addr += 2;
  175. index++;
  176. }
  177. // Верхнее значение уставки
  178. addr = 0x03D2;
  179. for (int i = 0; i < AI_COMMON_NUMBER; i++)
  180. {
  181. mb_param[index].reg = addr;
  182. mb_param[index].size = 2;
  183. mb_param[index].param = (uint8_t*)&settings.preset[i].max;
  184. mb_param[index].set = NULL;
  185. mb_param[index].get = NULL;
  186. mb_param[index].check_handler = mb_check_dummy;
  187. addr += 2;
  188. index++;
  189. }
  190. // Значение гистерезиса
  191. addr = 0x03EA;
  192. for (int i = 0; i < AI_COMMON_NUMBER; i++)
  193. {
  194. mb_param[index].reg = addr;
  195. mb_param[index].size = 2;
  196. mb_param[index].param = (uint8_t*)&settings.preset[i].hyst;
  197. mb_param[index].set = NULL;
  198. mb_param[index].get = NULL;
  199. mb_param[index].check_handler = mb_check_dummy;
  200. addr += 2;
  201. index++;
  202. }
  203. // Набор калибровочных коэффициентов "K"
  204. /*
  205. addr = 0x0410;
  206. for (int i = 0; i < AI_COMMON_NUMBER; i++)
  207. {
  208. mb_param[index].reg = addr;
  209. mb_param[index].size = 2;
  210. mb_param[index].param = (uint8_t*)&settings.preset[i].hyst;
  211. mb_param[index].set = NULL;
  212. mb_param[index].get = NULL;
  213. mb_param[index].check_handler = mb_check_dummy;
  214. addr += 2;
  215. index++;
  216. }
  217. */
  218. return index;
  219. }
  220. // -------------------------------------------------------------------------- //
  221. // Установка параметров
  222. // -------------------------------------------------------------------------- //
  223. //
  224. mb_delay_action_t mb_set_ai_state(void)
  225. {
  226. ai_set();
  227. return MB_SAVE_SETTINGS;;
  228. }
  229. // При изменении режима измерения нужно проверить флаг аварий.
  230. // Если флаг установлен, то канал нельзя перевести в режим измерения тока.
  231. mb_delay_action_t mb_set_ai_mode(void)
  232. {
  233. for (uint8_t i = 0; i < AI_COMMON_NUMBER; i++)
  234. {
  235. if (!ai_alarm_f[i].alarm_flag)
  236. settings.ai[i].mode = (uint8_t)((settings.ai_mode_bits >> i) & 1);
  237. else if (((uint8_t)(settings.ai_mode_bits >> i) & 1) == 0)
  238. settings.ai[i].mode = (uint8_t)((settings.ai_mode_bits >> i) & 1);
  239. }
  240. ai_set_meas_mode();
  241. return MB_SAVE_SETTINGS;
  242. }
  243. // Диапазон измерения напряжения.
  244. mb_delay_action_t mb_set_ai_voltage_mode(void)
  245. {
  246. for (uint8_t i = 0; i < AI_COMMON_NUMBER; i++)
  247. {
  248. settings.ai[i].voltage_mode = (uint8_t)((settings.ai_voltage_mode_bits >> i) & 1);
  249. }
  250. return MB_SAVE_SETTINGS;
  251. }
  252. // Диапазон зимерения тока.
  253. mb_delay_action_t mb_set_ai_current_mode(void)
  254. {
  255. for (uint8_t i = 0; i < AI_COMMON_NUMBER; i++)
  256. {
  257. settings.ai[i].current_mode = (uint8_t)((settings.ai_current_mode_bits >> i) & 1);
  258. }
  259. return MB_SAVE_SETTINGS;
  260. }
  261. //
  262. mb_delay_action_t mb_set_ai_gain(void)
  263. {
  264. for (uint8_t i = 0; i < AI_COMMON_NUMBER; i++)
  265. {
  266. settings.ai[i].gain_factor = ai_gain[i];
  267. }
  268. return MB_NO_ACTION;
  269. }
  270. //
  271. mb_delay_action_t mb_set_ext_sens_power(void)
  272. {
  273. if (!ai_cur_lim.alarm_flag)
  274. ai_ext_sens_power(settings.ext_sens_power);
  275. return MB_SAVE_SETTINGS;
  276. }
  277. // Статус уставок (вкл./выкл.)
  278. mb_delay_action_t mb_set_preset_state(void)
  279. {
  280. preset_set_state();
  281. return MB_SAVE_SETTINGS;
  282. }
  283. #endif