modbus_ai_params.c 6.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261
  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. mb_param[index].reg = 0x0300;
  14. mb_param[index].size = 1;
  15. mb_param[index].param = (uint8_t*)&settings.ai_state_bits;
  16. mb_param[index].set = mb_set_ai_state;
  17. mb_param[index].get = NULL;
  18. mb_param[index].check_handler = mb_check_dummy;
  19. index++;
  20. mb_param[index].reg = 0x0301;
  21. mb_param[index].size = 1;
  22. mb_param[index].param = (uint8_t*)&settings.ai_mode_bits;
  23. mb_param[index].set = mb_set_ai_mode;
  24. mb_param[index].get = NULL;
  25. mb_param[index].check_handler = mb_check_dummy;
  26. index++;
  27. // Коэффициенты усиления. Регистры 0x0302 - 0x030В
  28. addr = 0x0302;
  29. for (int i = 0; i < AI_COMMON_NUMBER; i++)
  30. {
  31. mb_param[index].reg = addr;
  32. mb_param[index].size = 1;
  33. mb_param[index].param = (uint8_t*)&ai_gain[i];
  34. mb_param[index].set = NULL;
  35. mb_param[index].get = NULL;
  36. mb_param[index].check_handler = mb_check_dummy;
  37. addr += 1;
  38. index++;
  39. }
  40. #if 0
  41. mb_param[index].reg = 0x0301;
  42. mb_param[index].size = 1;
  43. mb_param[index].param = (uint8_t*)&ai_alarm;
  44. mb_param[index].set = NULL;
  45. mb_param[index].get = NULL;
  46. mb_param[index].check_handler = mb_check_dummy;
  47. index++;
  48. // Сырые данные каналов ADC
  49. mb_param[index].reg = 0x0302;
  50. mb_param[index].size = 1;
  51. mb_param[index].param = (uint8_t*)&adc_raw_data[AN_INP_1];
  52. mb_param[index].set = NULL;
  53. mb_param[index].get = NULL;
  54. mb_param[index].check_handler = mb_check_dummy;
  55. index++;
  56. mb_param[index].reg = 0x0303;
  57. mb_param[index].size = 1;
  58. mb_param[index].param = (uint8_t*)&adc_raw_data[AN_INP_2];
  59. mb_param[index].set = NULL;
  60. mb_param[index].get = NULL;
  61. mb_param[index].check_handler = mb_check_dummy;
  62. index++;
  63. mb_param[index].reg = 0x0304;
  64. mb_param[index].size = 1;
  65. mb_param[index].param = (uint8_t*)&adc_raw_data[AN_INP_3];
  66. mb_param[index].set = NULL;
  67. mb_param[index].get = NULL;
  68. mb_param[index].check_handler = mb_check_dummy;
  69. index++;
  70. mb_param[index].reg = 0x0305;
  71. mb_param[index].size = 1;
  72. mb_param[index].param = (uint8_t*)&adc_raw_data[AN_INP_4];
  73. mb_param[index].set = NULL;
  74. mb_param[index].get = NULL;
  75. mb_param[index].check_handler = mb_check_dummy;
  76. index++;
  77. mb_param[index].reg = 0x0306;
  78. mb_param[index].size = 1;
  79. mb_param[index].param = (uint8_t*)&adc_raw_data[AN_INP_5];
  80. mb_param[index].set = NULL;
  81. mb_param[index].get = NULL;
  82. mb_param[index].check_handler = mb_check_dummy;
  83. index++;
  84. mb_param[index].reg = 0x0307;
  85. mb_param[index].size = 1;
  86. mb_param[index].param = (uint8_t*)&adc_raw_data[AN_INP_6];
  87. mb_param[index].set = NULL;
  88. mb_param[index].get = NULL;
  89. mb_param[index].check_handler = mb_check_dummy;
  90. index++;
  91. mb_param[index].reg = 0x0308;
  92. mb_param[index].size = 1;
  93. mb_param[index].param = (uint8_t*)&adc_raw_data[AN_INP_7];
  94. mb_param[index].set = NULL;
  95. mb_param[index].get = NULL;
  96. mb_param[index].check_handler = mb_check_dummy;
  97. index++;
  98. mb_param[index].reg = 0x0309;
  99. mb_param[index].size = 1;
  100. mb_param[index].param = (uint8_t*)&adc_raw_data[AN_INP_8];
  101. mb_param[index].set = NULL;
  102. mb_param[index].get = NULL;
  103. mb_param[index].check_handler = mb_check_dummy;
  104. index++;
  105. mb_param[index].reg = 0x030A;
  106. mb_param[index].size = 1;
  107. mb_param[index].param = (uint8_t*)&adc_raw_data[AN_INP_9];
  108. mb_param[index].set = NULL;
  109. mb_param[index].get = NULL;
  110. mb_param[index].check_handler = mb_check_dummy;
  111. index++;
  112. mb_param[index].reg = 0x030B;
  113. mb_param[index].size = 1;
  114. mb_param[index].param = (uint8_t*)&adc_raw_data[AN_INP_10];
  115. mb_param[index].set = NULL;
  116. mb_param[index].get = NULL;
  117. mb_param[index].check_handler = mb_check_dummy;
  118. index++;
  119. mb_param[index].reg = 0x030C;
  120. mb_param[index].size = 1;
  121. mb_param[index].param = (uint8_t*)&adc_raw_data[AN_INP_11];
  122. mb_param[index].set = NULL;
  123. mb_param[index].get = NULL;
  124. mb_param[index].check_handler = mb_check_dummy;
  125. index++;
  126. mb_param[index].reg = 0x030D;
  127. mb_param[index].size = 1;
  128. mb_param[index].param = (uint8_t*)&adc_raw_data[AN_INP_12];
  129. mb_param[index].set = NULL;
  130. mb_param[index].get = NULL;
  131. mb_param[index].check_handler = mb_check_dummy;
  132. index++;
  133. mb_param[index].reg = 0x030E;
  134. mb_param[index].size = 1;
  135. mb_param[index].param = (uint8_t*)&adc_raw_data[V_ISO_CL];
  136. mb_param[index].set = NULL;
  137. mb_param[index].get = NULL;
  138. mb_param[index].check_handler = mb_check_dummy;
  139. index++;
  140. mb_param[index].reg = 0x030F;
  141. mb_param[index].size = 1;
  142. mb_param[index].param = (uint8_t*)&adc_raw_data[V_ISO];
  143. mb_param[index].set = NULL;
  144. mb_param[index].get = NULL;
  145. mb_param[index].check_handler = mb_check_dummy;
  146. index++;
  147. mb_param[index].reg = 0x0310;
  148. mb_param[index].size = 1;
  149. mb_param[index].param = (uint8_t*)&adc_raw_data[CRNT_LIM_U_BFR_R];
  150. mb_param[index].set = NULL;
  151. mb_param[index].get = NULL;
  152. mb_param[index].check_handler = mb_check_dummy;
  153. index++;
  154. mb_param[index].reg = 0x0311;
  155. mb_param[index].size = 1;
  156. mb_param[index].param = (uint8_t*)&adc_raw_data[CRNT_LIM_U_ABFR_R];
  157. mb_param[index].set = NULL;
  158. mb_param[index].get = NULL;
  159. mb_param[index].check_handler = mb_check_dummy;
  160. index++;
  161. mb_param[index].reg = 0x0320;
  162. mb_param[index].size = 1;
  163. mb_param[index].param = (uint8_t*)&settings.ext_sens_power;
  164. mb_param[index].set = mb_set_ext_sens_power;
  165. mb_param[index].get = NULL;
  166. mb_param[index].check_handler = mb_check_dummy;
  167. index++;
  168. #endif
  169. return index;
  170. }
  171. // -------------------------------------------------------------------------- //
  172. // Установка параметров
  173. // -------------------------------------------------------------------------- //
  174. //
  175. mb_delay_action_t mb_set_ai_state(void)
  176. {
  177. ai_set();
  178. return MB_NO_ACTION;
  179. }
  180. //
  181. mb_delay_action_t mb_set_ai_mode(void)
  182. {
  183. ai_set_meas_mode();
  184. return MB_SAVE_SETTINGS;
  185. }
  186. //
  187. mb_delay_action_t mb_set_ai_gain(void)
  188. {
  189. for (uint8_t i = 0; i < AI_COMMON_NUMBER/2; i++)
  190. {
  191. settings.ai[i].gain_factor = ai_gain[i];
  192. settings.ai[i + 8].gain_factor = ai_gain[i + 6];
  193. }
  194. return MB_NO_ACTION;
  195. }
  196. //
  197. mb_delay_action_t mb_set_ext_sens_power(void)
  198. {
  199. ai_ext_sens_power(settings.ext_sens_power);
  200. //sh_ai_connect(0x80);
  201. return MB_SAVE_SETTINGS;
  202. }
  203. #endif