modbus_ao_params.c 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131
  1. #include "at32f403a_407.h"
  2. #include "modbus_ao_params.h"
  3. #include "settings_api.h"
  4. #include "modbus_params.h"
  5. #include "analog_output.h"
  6. #if defined (MAO_4)
  7. extern mb_param_t mb_param[];
  8. //
  9. uint16_t mb_init_ao_params(uint16_t i)
  10. {
  11. uint16_t index = i;
  12. uint16_t addr = 0;
  13. // Статус выходов (вкл./выкл.)
  14. mb_param[index].reg = 0x0400;
  15. mb_param[index].size = 1;
  16. mb_param[index].param = (uint8_t*)&settings.ao_state_bits;
  17. mb_param[index].set = mb_set_ao_state;
  18. mb_param[index].get = NULL;
  19. mb_param[index].check_handler = mb_check_dummy;
  20. index++;
  21. // Статус выходов в безопасном режиме (вкл./выкл.)
  22. mb_param[index].reg = 0x0401;
  23. mb_param[index].size = 1;
  24. mb_param[index].param = (uint8_t*)&settings.ao_state_save_bits;
  25. mb_param[index].set = mb_set_ao_state_save;
  26. mb_param[index].get = NULL;
  27. mb_param[index].check_handler = mb_check_dummy;
  28. index++;
  29. // Режим работы выходов
  30. mb_param[index].reg = 0x0402;
  31. mb_param[index].size = 1;
  32. mb_param[index].param = (uint8_t*)&settings.ao_mode_bits;
  33. mb_param[index].set = mb_set_ao_mode;
  34. mb_param[index].get = NULL;
  35. mb_param[index].check_handler = mb_check_dummy;
  36. index++;
  37. // Режим работы выходов
  38. mb_param[index].reg = 0x0403;
  39. mb_param[index].size = 1;
  40. mb_param[index].param = (uint8_t*)&settings.ao_mode_save_bits;
  41. mb_param[index].set = mb_set_ao_mode_save;
  42. mb_param[index].get = NULL;
  43. mb_param[index].check_handler = mb_check_dummy;
  44. index++;
  45. // ---------------------------------------------------------------------- //
  46. // Значения выходов. Регистры 0x0410 - 0x0413.
  47. addr = 0x0410;
  48. for (int i = 0; i < AO_NUMBER; i++)
  49. {
  50. mb_param[index].reg = addr;
  51. mb_param[index].size = 1;
  52. mb_param[index].param = (uint8_t*)&settings.ao[i].value;
  53. mb_param[index].set = NULL;
  54. mb_param[index].get = NULL;
  55. mb_param[index].check_handler = mb_check_dummy;
  56. addr += 1;
  57. index++;
  58. }
  59. // Значения выходов в безопасном режиме. Регистры 0x0420 - 0x0423.
  60. addr = 0x0420;
  61. for (int i = 0; i < AO_NUMBER; i++)
  62. {
  63. mb_param[index].reg = addr;
  64. mb_param[index].size = 1;
  65. mb_param[index].param = (uint8_t*)&settings.ao_save[i].value;
  66. mb_param[index].set = NULL;
  67. mb_param[index].get = NULL;
  68. mb_param[index].check_handler = mb_check_dummy;
  69. addr += 1;
  70. index++;
  71. }
  72. return index;
  73. }
  74. // -------------------------------------------------------------------------- //
  75. // Установка параметров
  76. // -------------------------------------------------------------------------- //
  77. //
  78. mb_delay_action_t mb_set_ao_state(void)
  79. {
  80. ao_set();
  81. return MB_NO_ACTION;
  82. }
  83. //
  84. mb_delay_action_t mb_set_ao_state_save(void)
  85. {
  86. ao_set_save();
  87. return MB_NO_ACTION;
  88. }
  89. //
  90. mb_delay_action_t mb_set_ao_mode(void)
  91. {
  92. ao_set_mode();
  93. return MB_SAVE_SETTINGS;
  94. }
  95. //
  96. mb_delay_action_t mb_set_ao_mode_save(void)
  97. {
  98. ao_set_mode_save();
  99. return MB_SAVE_SETTINGS;
  100. }
  101. #endif