modbus_params.c 8.3 KB

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