modbus_ai_params.c 4.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165
  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. extern mb_param_t mb_param[];
  7. #if defined (MAI_12)
  8. //
  9. uint16_t mb_init_ai_params(uint16_t i)
  10. {
  11. uint16_t index = i;
  12. uint16_t addr = 0;
  13. // Статус входов (вкл./выкл.)
  14. mb_param[index].reg = 0x0300;
  15. mb_param[index].size = 1;
  16. mb_param[index].param = (uint8_t*)&settings.ai_state_bits;
  17. mb_param[index].set = mb_set_ai_state;
  18. mb_param[index].get = NULL;
  19. mb_param[index].check_handler = mb_check_dummy;
  20. index++;
  21. // Режим работы входов
  22. mb_param[index].reg = 0x0301;
  23. mb_param[index].size = 1;
  24. mb_param[index].param = (uint8_t*)&settings.ai_mode_bits;
  25. mb_param[index].set = mb_set_ai_mode;
  26. mb_param[index].get = NULL;
  27. mb_param[index].check_handler = mb_check_dummy;
  28. index++;
  29. // Флаги аварий аналоговых входов
  30. mb_param[index].reg = 0x0302;
  31. mb_param[index].size = 1;
  32. mb_param[index].param = (uint8_t*)&ai_alarm;
  33. mb_param[index].set = NULL;
  34. mb_param[index].get = NULL;
  35. mb_param[index].check_handler = mb_check_dummy;
  36. index++;
  37. //
  38. mb_param[index].reg = 0x0303;
  39. mb_param[index].size = 1;
  40. mb_param[index].param = (uint8_t*)&settings.ext_sens_power;
  41. mb_param[index].set = mb_set_ext_sens_power;
  42. mb_param[index].get = NULL;
  43. mb_param[index].check_handler = mb_check_dummy;
  44. index++;
  45. // Коэффициенты усиления. Регистры 0x0310 - 0x031В.
  46. addr = 0x0310;
  47. for (int i = 0; i < AI_COMMON_NUMBER; i++)
  48. {
  49. mb_param[index].reg = addr;
  50. mb_param[index].size = 1;
  51. mb_param[index].param = (uint8_t*)&ai_gain[i];
  52. mb_param[index].set = mb_set_ai_gain;
  53. mb_param[index].get = NULL;
  54. mb_param[index].check_handler = mb_check_dummy;
  55. addr += 1;
  56. index++;
  57. }
  58. // ---------------------------------------------------------------------- //
  59. // Сырые данные каналов ADC
  60. addr = 0x0320;
  61. for (int i = 0; i < AI_COMMON_NUMBER; i++)
  62. {
  63. mb_param[index].reg = addr + i;
  64. mb_param[index].size = 1;
  65. mb_param[index].param = (uint8_t*)&adc_com_raw_data[i];
  66. mb_param[index].set = NULL;
  67. mb_param[index].get = NULL;
  68. mb_param[index].check_handler = mb_check_dummy;
  69. index++;
  70. }
  71. addr = 0x032C;
  72. // V_ISO_CL, V_ISO, CRNT_LIM_U_BFR_R, CRNT_LIM_U_ABFR_R
  73. for (int i = 0; i < AI_ADD_NUMBER; i++)
  74. {
  75. mb_param[index].reg = addr + i;
  76. mb_param[index].size = 1;
  77. mb_param[index].param = (uint8_t*)&adc_add_raw_data[i];
  78. mb_param[index].set = NULL;
  79. mb_param[index].get = NULL;
  80. mb_param[index].check_handler = mb_check_dummy;
  81. index++;
  82. }
  83. // ---------------------------------------------------------------------- //
  84. // Фильтрованные значения 12-и основных каналов
  85. addr = 0x0330;
  86. for (int i = 0; i < AI_COMMON_NUMBER; i++)
  87. {
  88. mb_param[index].reg = addr + i;
  89. mb_param[index].size = 1;
  90. mb_param[index].param = (uint8_t*)&adc_com_fil_data[i];
  91. mb_param[index].set = NULL;
  92. mb_param[index].get = NULL;
  93. mb_param[index].check_handler = mb_check_dummy;
  94. index++;
  95. }
  96. // ---------------------------------------------------------------------- //
  97. return index;
  98. }
  99. // -------------------------------------------------------------------------- //
  100. // Установка параметров
  101. // -------------------------------------------------------------------------- //
  102. //
  103. mb_delay_action_t mb_set_ai_state(void)
  104. {
  105. ai_set();
  106. return MB_NO_ACTION;
  107. }
  108. //
  109. mb_delay_action_t mb_set_ai_mode(void)
  110. {
  111. for (uint8_t i = 0; i < AI_COMMON_NUMBER; i++) {
  112. settings.ai[i].mode = (uint8_t)((settings.ai_mode_bits >> i) & 1);
  113. }
  114. ai_set_meas_mode();
  115. return MB_SAVE_SETTINGS;
  116. }
  117. //
  118. mb_delay_action_t mb_set_ai_gain(void)
  119. {
  120. for (uint8_t i = 0; i < AI_COMMON_NUMBER; i++)
  121. {
  122. settings.ai[i].gain_factor = ai_gain[i];
  123. }
  124. return MB_NO_ACTION;
  125. }
  126. //
  127. mb_delay_action_t mb_set_ext_sens_power(void)
  128. {
  129. ai_ext_sens_power(settings.ext_sens_power);
  130. //sh_ai_connect(0x80);
  131. return MB_SAVE_SETTINGS;
  132. }
  133. #endif