modbus_params.c 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398
  1. #include "at32f403a_407.h"
  2. #include "modbus_params.h"
  3. #include "settings_api.h"
  4. #include "io.h"
  5. #include "uptime.h"
  6. #include "rtc.h"
  7. #include "input.h"
  8. #include "output.h"
  9. #include "log.h"
  10. #include <string.h>
  11. mb_param_t mb_param[MB_PARAM_MAX];
  12. uint32_t rtc_sinhro;
  13. void get_time(uint8_t* buf, uint8_t size);
  14. void get_din_mode(uint8_t* buf, uint8_t size);
  15. void get_log_entries_number(uint8_t* buf, uint8_t size);
  16. void get_archive_entries_number(uint8_t* buf, uint8_t size);
  17. //
  18. void mb_init_params(void)
  19. {
  20. uint16_t index = 0;
  21. uint16_t addr = 0;
  22. mb_param[index].reg = 0x0100;
  23. mb_param[index].size = 1;
  24. mb_param[index].param = (uint8_t*)&input_state_bit; // Текущее состояние входа
  25. mb_param[index].set = NULL;
  26. mb_param[index].get = NULL;
  27. mb_param[index].check_handler = mb_check_dummy;
  28. index++;
  29. // Счетчики импульсов. Регистры 0x0102 - 0x0111
  30. addr = 0x0102;
  31. for (int i = 0; i < DI_NUMBER; i++)
  32. {
  33. mb_param[index].reg = addr;
  34. mb_param[index].size = 2;
  35. mb_param[index].param = (uint8_t*)&input_cnt[i]; // Счетчик ипульсов
  36. mb_param[index].set = NULL;
  37. mb_param[index].get = NULL;
  38. mb_param[index].check_handler = mb_check_dummy;
  39. addr += 2;
  40. index++;
  41. }
  42. // Режим работы входов
  43. mb_param[index].reg = 0x0120;
  44. mb_param[index].size = 1;
  45. mb_param[index].param = (uint8_t*)&settings.di_mode_bits;
  46. mb_param[index].set = mb_set_din_mode;
  47. mb_param[index].get = NULL;
  48. mb_param[index].check_handler = mb_check_dummy;
  49. index++;
  50. // Нормальное состояние входов
  51. mb_param[index].reg = 0x0122;
  52. mb_param[index].size = 1;
  53. mb_param[index].param = (uint8_t*)&settings.di_norm_state_bits;
  54. mb_param[index].set = NULL;
  55. mb_param[index].get = NULL;
  56. mb_param[index].check_handler = mb_check_dummy;
  57. index++;
  58. // Счетчики импульсов. Регистры 0x0102 - 0x0111
  59. addr = 0x0124;
  60. for (int i = 0; i < DI_NUMBER; i++)
  61. {
  62. mb_param[index].reg = addr;
  63. mb_param[index].size = 1;
  64. mb_param[index].param = (uint8_t*)&settings.di_debounce[i]; // Счетчик ипульсов
  65. mb_param[index].set = NULL;
  66. mb_param[index].get = NULL;
  67. mb_param[index].check_handler = mb_check_dummy;
  68. addr++;
  69. index++;
  70. }
  71. // Текущее состояние выходов
  72. mb_param[index].reg = 0x0200;
  73. mb_param[index].size = 1;
  74. mb_param[index].param = (uint8_t*)&output_state_bit;
  75. mb_param[index].set = mb_set_do;
  76. mb_param[index].get = NULL;
  77. mb_param[index].check_handler = mb_check_dummy;
  78. index++;
  79. // Режим работы выходов
  80. mb_param[index].reg = 0x0202;
  81. mb_param[index].size = 1;
  82. mb_param[index].param = (uint8_t*)&output_mode_bit;
  83. mb_param[index].set = mb_set_do_mode;
  84. mb_param[index].get = NULL;
  85. mb_param[index].check_handler = mb_check_dummy;
  86. index++;
  87. // Состояние выходов в безопасном режиме
  88. mb_param[index].reg = 0x0203;
  89. mb_param[index].size = 1;
  90. mb_param[index].param = (uint8_t*)&settings.do_save_bits;
  91. mb_param[index].set = mb_set_do;
  92. mb_param[index].get = NULL;
  93. mb_param[index].check_handler = mb_check_dummy;
  94. index++;
  95. // Заполнение PWM. Регистры 0x0210 - 0x0217
  96. addr = 0x0210;
  97. for (int i = 0; i < DO_NUMBER; i++)
  98. {
  99. mb_param[index].reg = addr;
  100. mb_param[index].size = 1;
  101. mb_param[index].param = (uint8_t*)&output_pwm[i]; // Счетчик ипульсов
  102. mb_param[index].set = mb_set_do;
  103. mb_param[index].get = NULL;
  104. mb_param[index].check_handler = mb_check_dummy;
  105. addr++;
  106. index++;
  107. }
  108. // Заполнение PWM в безопасном режиме. Регистры 0x0220 - 0x0227
  109. addr = 0x0220;
  110. for (int i = 0; i < DO_NUMBER; i++)
  111. {
  112. mb_param[index].reg = addr;
  113. mb_param[index].size = 1;
  114. mb_param[index].param = (uint8_t*)&output_pwm_save[i]; // Счетчик ипульсов
  115. mb_param[index].set = mb_set_do;
  116. mb_param[index].get = NULL;
  117. mb_param[index].check_handler = mb_check_dummy;
  118. addr++;
  119. index++;
  120. }
  121. // Период PWM. Регистры 0x0220 - 0x0227
  122. addr = 0x0230;
  123. for (int i = 0; i < DO_NUMBER; i++)
  124. {
  125. mb_param[index].reg = addr;
  126. mb_param[index].size = 1;
  127. mb_param[index].param = (uint8_t*)&output_pwm_period[i]; // Счетчик ипульсов
  128. mb_param[index].set = mb_set_do;
  129. mb_param[index].get = NULL;
  130. mb_param[index].check_handler = mb_check_dummy;
  131. addr++;
  132. index++;
  133. }
  134. // Период PWM. Регистры 0x0220 - 0x0227
  135. addr = 0x0240;
  136. for (int i = 0; i < DO_NUMBER; i++)
  137. {
  138. mb_param[index].reg = addr;
  139. mb_param[index].size = 1;
  140. mb_param[index].param = (uint8_t*)&output_pwm_period_save[i]; // Счетчик ипульсов
  141. mb_param[index].set = mb_set_do;
  142. mb_param[index].get = NULL;
  143. mb_param[index].check_handler = mb_check_dummy;
  144. addr++;
  145. index++;
  146. }
  147. // Журналы/рахивы
  148. // Емкость журнала (максимальная)
  149. mb_param[index].reg = 0x0900;
  150. mb_param[index].size = 1;
  151. mb_param[index].param = (uint8_t*)&log_entries_capacity; //
  152. mb_param[index].set = NULL;
  153. mb_param[index].get = NULL;
  154. mb_param[index].check_handler = mb_check_dummy;
  155. index++;
  156. // Текущее количество записей в журнале
  157. mb_param[index].reg = 0x0901;
  158. mb_param[index].size = 1;
  159. mb_param[index].param = NULL; //
  160. mb_param[index].set = NULL;
  161. mb_param[index].get = get_log_entries_number;
  162. mb_param[index].check_handler = mb_check_dummy;
  163. index++;
  164. // Емкость архива (максимальная)
  165. mb_param[index].reg = 0x0902;
  166. mb_param[index].size = 1;
  167. mb_param[index].param = (uint8_t*)&archive_entries_capacity; //
  168. mb_param[index].set = NULL;
  169. mb_param[index].get = NULL;
  170. mb_param[index].check_handler = mb_check_dummy;
  171. index++;
  172. // Текущее количество записей в архиве
  173. mb_param[index].reg = 0x0903;
  174. mb_param[index].size = 1;
  175. mb_param[index].param = NULL; //
  176. mb_param[index].set = NULL;
  177. mb_param[index].get = get_archive_entries_number;
  178. mb_param[index].check_handler = mb_check_dummy;
  179. index++;
  180. /*
  181. // Емкость архива (максимальная)
  182. mb_param[index].reg = 0x0901;
  183. mb_param[index].size = 1;
  184. mb_param[index].param = (uint8_t*)&log_entries_capacity; //
  185. mb_param[index].set = NULL;
  186. mb_param[index].get = NULL;
  187. mb_param[index].check_handler = mb_check_dummy;
  188. index++;
  189. */
  190. }
  191. // Возвращает размер параметра в регистрах
  192. bool mb_find_param(uint16_t reg, uint16_t *index, uint16_t *size)
  193. {
  194. for (uint16_t i = 0; i < MB_PARAM_MAX; i++)
  195. {
  196. if (mb_param[i].reg == reg)
  197. {
  198. *index = i;
  199. *size = mb_param[i].size;
  200. return true;
  201. }
  202. }
  203. return false;
  204. }
  205. //
  206. mb_delay_action_t mb_set_param(uint8_t *buf, uint16_t index)
  207. {
  208. uint8_t *ptr = mb_param[index].param;
  209. // Если параметр только для чтения
  210. if (mb_param[index].check_handler == NULL)
  211. return MB_NO_ACTION;
  212. for (uint16_t i = 0; i < 2*mb_param[index].size; i++)
  213. {
  214. *ptr = buf[2*mb_param[index].size - 1 - i];
  215. ptr++;
  216. }
  217. /*
  218. if (mb_param[index].check_handler != NULL)
  219. mb_param[index].check_handler();
  220. */
  221. mb_param[index].check_handler();
  222. if (mb_param[index].set != NULL)
  223. return mb_param[index].set();
  224. else
  225. return MB_NO_ACTION;
  226. /*
  227. if (mb_param[index].f_activity)
  228. return mb_param[index].set_handler();
  229. else
  230. return MB_NO_ACTION;
  231. */
  232. }
  233. //
  234. void mb_get_param(uint8_t *buf, uint16_t index)
  235. {
  236. uint8_t *ptr;
  237. if (mb_param[index].get != NULL) {
  238. mb_param[index].get(buf, mb_param[index].size);
  239. return;
  240. }
  241. ptr = mb_param[index].param + 2*mb_param[index].size - 1;
  242. for (uint16_t i = 0; i < 2*mb_param[index].size; i++)
  243. {
  244. *buf = *ptr;
  245. buf++;
  246. ptr--;
  247. }
  248. }
  249. // -------------------------------------------------------------------------- //
  250. // Чтение параметров
  251. // -------------------------------------------------------------------------- //
  252. void get_time(uint8_t* buf, uint8_t size)
  253. {
  254. uint32_t rtc_unix = RTC_GetUnixTime();
  255. uint8_t *ptr = (uint8_t*)&rtc_unix + 2*size - 1;
  256. for (uint16_t i = 0; i < 2*size; i++)
  257. {
  258. *buf = *ptr;
  259. buf++;
  260. ptr--;
  261. }
  262. }
  263. //
  264. void get_din_mode(uint8_t* buf, uint8_t size)
  265. {
  266. }
  267. //
  268. void get_log_entries_number(uint8_t* buf, uint8_t size)
  269. {
  270. uint16_t capacity = log_capacity();
  271. SWAP_16(buf, capacity);
  272. }
  273. //
  274. void get_archive_entries_number(uint8_t* buf, uint8_t size)
  275. {
  276. uint16_t capacity = log_arch_capacity();
  277. SWAP_16(buf, capacity);
  278. }
  279. // -------------------------------------------------------------------------- //
  280. // Установка параметров
  281. // -------------------------------------------------------------------------- //
  282. //
  283. mb_delay_action_t mb_set_din_mode(void)
  284. {
  285. in_set();
  286. return MB_NO_ACTION;
  287. }
  288. //
  289. mb_delay_action_t mb_set_do(void)
  290. {
  291. //do_set();
  292. do_set_common();
  293. return MB_NO_ACTION;
  294. }
  295. //
  296. mb_delay_action_t mb_set_do_mode(void)
  297. {
  298. do_set_mode();
  299. return MB_NO_ACTION;
  300. }
  301. //
  302. mb_delay_action_t mb_set_time(void)
  303. {
  304. TM_RTC_SetDataTimeUnix(rtc_sinhro);
  305. return MB_NO_ACTION;
  306. }
  307. // -------------------------------------------------------------------------- //
  308. // Проверка параметров //
  309. // -------------------------------------------------------------------------- //
  310. //
  311. void mb_check_dummy(void)
  312. {
  313. }