modbus_params.c 5.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252
  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. // Возвращает размер параметра в регистрах
  86. bool mb_find_param(uint16_t reg, uint16_t *index, uint16_t *size)
  87. {
  88. for (uint16_t i = 0; i < MB_PARAM_MAX; i++)
  89. {
  90. if (mb_param[i].reg == reg)
  91. {
  92. *index = i;
  93. *size = mb_param[i].size;
  94. return true;
  95. }
  96. }
  97. return false;
  98. }
  99. //
  100. mb_delay_action_t mb_set_param(uint8_t *buf, uint16_t index)
  101. {
  102. uint8_t *ptr = mb_param[index].param;
  103. // Если параметр только для чтения
  104. if (mb_param[index].check_handler == NULL)
  105. return MB_NO_ACTION;
  106. for (uint16_t i = 0; i < 2*mb_param[index].size; i++)
  107. {
  108. *ptr = buf[2*mb_param[index].size - 1 - i];
  109. ptr++;
  110. }
  111. /*
  112. if (mb_param[index].check_handler != NULL)
  113. mb_param[index].check_handler();
  114. */
  115. mb_param[index].check_handler();
  116. if (mb_param[index].set != NULL)
  117. return mb_param[index].set();
  118. else
  119. return MB_NO_ACTION;
  120. /*
  121. if (mb_param[index].f_activity)
  122. return mb_param[index].set_handler();
  123. else
  124. return MB_NO_ACTION;
  125. */
  126. }
  127. //
  128. void mb_get_param(uint8_t *buf, uint16_t index)
  129. {
  130. uint8_t *ptr;
  131. if (mb_param[index].get != NULL) {
  132. mb_param[index].get(buf, mb_param[index].size);
  133. return;
  134. }
  135. ptr = mb_param[index].param + 2*mb_param[index].size - 1;
  136. for (uint16_t i = 0; i < 2*mb_param[index].size; i++)
  137. {
  138. *buf = *ptr;
  139. buf++;
  140. ptr--;
  141. }
  142. }
  143. // -------------------------------------------------------------------------- //
  144. // Чтение параметров
  145. // -------------------------------------------------------------------------- //
  146. void get_time(uint8_t* buf, uint8_t size)
  147. {
  148. uint32_t rtc_unix = RTC_GetUnixTime();
  149. uint8_t *ptr = (uint8_t*)&rtc_unix + 2*size - 1;
  150. for (uint16_t i = 0; i < 2*size; i++)
  151. {
  152. *buf = *ptr;
  153. buf++;
  154. ptr--;
  155. }
  156. }
  157. //
  158. void get_din_mode(uint8_t* buf, uint8_t size)
  159. {
  160. }
  161. // -------------------------------------------------------------------------- //
  162. // Установка параметров
  163. // -------------------------------------------------------------------------- //
  164. //
  165. mb_delay_action_t mb_set_din_mode(void)
  166. {
  167. in_set();
  168. return MB_NO_ACTION;
  169. }
  170. //
  171. mb_delay_action_t mb_set_do(void)
  172. {
  173. do_set();
  174. return MB_NO_ACTION;
  175. }
  176. //
  177. mb_delay_action_t mb_set_do_mode(void)
  178. {
  179. do_set_mode();
  180. return MB_NO_ACTION;
  181. }
  182. //
  183. mb_delay_action_t mb_set_time(void)
  184. {
  185. TM_RTC_SetDataTimeUnix(rtc_sinhro);
  186. return MB_NO_ACTION;
  187. }
  188. // -------------------------------------------------------------------------- //
  189. // Проверка параметров //
  190. // -------------------------------------------------------------------------- //
  191. //
  192. void mb_check_dummy(void)
  193. {
  194. }