You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

188 lines
7.4 KiB

2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
  1. #include <stddef.h>
  2. #include <stdio.h>
  3. #include "board.h"
  4. #include "sdk\components\subcanmodule\zcancmder_subboard_initer.hpp"
  5. /*******************************************************************************
  6. * PROJECT_INCLUDE *
  7. *******************************************************************************/
  8. #include "sdk/components/step_motor_ctrl_module/step_motor_ctrl_module.hpp"
  9. #include "sdk\components\mini_servo_motor\feite_servo_motor.hpp"
  10. #include "sdk\components\mini_servo_motor\mini_servo_motor_ctrl_module.hpp"
  11. #include "sdk\components\modbus\modbus_client.hpp"
  12. #include "sdk\components\pipette_module\pipette_ctrl_module_v2.hpp"
  13. #include "sdk\components\sensors\m3078\m3078_code_scaner.hpp"
  14. #include "sdk\components\tmc\ic\ztmc4361A.hpp"
  15. #include "sdk\components\tmc\ic\ztmc5130.hpp"
  16. //
  17. #include "sdk\components\hardware\uart\zuart_dma_receiver.hpp"
  18. #include "temperature_sensor.hpp"
  19. #define TAG "main"
  20. using namespace iflytop;
  21. using namespace std;
  22. static ZCancmderSubboardIniter initer;
  23. extern void umain();
  24. extern "C" {
  25. void StartDefaultTask(void const* argument) { umain(); }
  26. class UARTSender : public ZIUartSender {
  27. UART_HandleTypeDef* m_huart;
  28. public:
  29. void init(UART_HandleTypeDef* huart) { m_huart = huart; }
  30. virtual void send(const uint8_t* data, size_t len) { HAL_UART_Transmit(m_huart, (uint8_t*)data, len, 1000); }
  31. };
  32. extern DMA_HandleTypeDef hdma_usart3_rx;
  33. extern DMA_HandleTypeDef hdma_usart3_tx;
  34. }
  35. /*******************************************************************************
  36. * GET_DEVICE_ID *
  37. *******************************************************************************/
  38. static int32_t getDeviceId() {
  39. static bool init = false;
  40. static ZGPIO ID0;
  41. static ZGPIO ID1;
  42. static ZGPIO ID2;
  43. static ZGPIO ID3;
  44. static ZGPIO ID4;
  45. if (!init) {
  46. ID0.initAsInput(ID0_IO, ZGPIO::kMode_nopull, ZGPIO::kIRQ_noIrq, true);
  47. ID1.initAsInput(ID1_IO, ZGPIO::kMode_nopull, ZGPIO::kIRQ_noIrq, true);
  48. ID2.initAsInput(ID2_IO, ZGPIO::kMode_nopull, ZGPIO::kIRQ_noIrq, true);
  49. ID3.initAsInput(ID3_IO, ZGPIO::kMode_nopull, ZGPIO::kIRQ_noIrq, true);
  50. ID4.initAsInput(ID4_IO, ZGPIO::kMode_nopull, ZGPIO::kIRQ_noIrq, true);
  51. init = true;
  52. }
  53. uint8_t id = ID0.getState() * 1 + ID1.getState() * 2 + ID2.getState() * 4 + ID3.getState() * 8 + ID4.getState() * 16;
  54. return id;
  55. }
  56. /*******************************************************************************
  57. * INIT_SUBMODULE *
  58. *******************************************************************************/
  59. void nvs_init_cb() {}
  60. TemperatureSensor m_temperature_sensor[8];
  61. static void initsubmodule() {
  62. osDelay(1000);
  63. {
  64. m_temperature_sensor[0].initialize(&hadc1, ADC_CHANNEL_10);
  65. m_temperature_sensor[1].initialize(&hadc1, ADC_CHANNEL_11);
  66. m_temperature_sensor[2].initialize(&hadc1, ADC_CHANNEL_12);
  67. m_temperature_sensor[3].initialize(&hadc1, ADC_CHANNEL_13);
  68. m_temperature_sensor[4].initialize(&hadc1, ADC_CHANNEL_14);
  69. }
  70. {
  71. /*******************************************************************************
  72. * ȴMODBUS CLIEN ʼ *
  73. *******************************************************************************/
  74. static ZUARTDmaReceiver dmaUartReceiver;
  75. static ZUARTDmaReceiver::hardware_config_t cfg = {
  76. .huart = &PC_MODBUS_UART,
  77. .dma_rx = &PC_MODBUS_UART_DMA_HANDLER,
  78. .rxbuffersize = PC_MODBUS_UART_RX_BUF_SIZE,
  79. .rxovertime_ms = 1,
  80. };
  81. dmaUartReceiver.initialize(&cfg);
  82. static UARTSender uartSender;
  83. uartSender.init(&PC_MODBUS_UART);
  84. ModulebusClient::Inst()->init(
  85. &dmaUartReceiver, &uartSender, 1, //
  86. [](uint16_t regadd, uint16_t& val) {
  87. int32_t sendval = 0;
  88. if (regadd == 0) {
  89. m_temperature_sensor[0].getTemperature(sendval);
  90. val = sendval;
  91. } else if (regadd == 1) {
  92. m_temperature_sensor[1].getTemperature(sendval);
  93. val = sendval;
  94. } else if (regadd == 2) {
  95. m_temperature_sensor[2].getTemperature(sendval);
  96. val = sendval;
  97. } else if (regadd == 3) {
  98. m_temperature_sensor[3].getTemperature(sendval);
  99. val = sendval;
  100. } else if (regadd == 4) {
  101. m_temperature_sensor[4].getTemperature(sendval);
  102. val = sendval;
  103. }
  104. }, //
  105. [](uint16_t regadd, uint16_t val) {});
  106. }
  107. {
  108. // 115200
  109. /*******************************************************************************
  110. * Թñж *
  111. *******************************************************************************/
  112. static FeiTeServoMotor feiteservomotor_bus; // ���ض�������
  113. // ���ض�������
  114. ZASSERT(huart3.Init.BaudRate == 115200);
  115. feiteservomotor_bus.initialize(&huart3, &hdma_usart3_rx, &hdma_usart3_tx);
  116. {
  117. static MiniRobotCtrlModule mini_servo;
  118. static MiniRobotCtrlModule::flash_config_t cfg = {0};
  119. cfg.default_torque = 330;
  120. mini_servo.initialize(initer.get_module_id(1), &feiteservomotor_bus, 1, &cfg);
  121. initer.register_module(&mini_servo);
  122. }
  123. {
  124. static MiniRobotCtrlModule mini_servo;
  125. static MiniRobotCtrlModule::flash_config_t cfg = {0};
  126. cfg.default_torque = 330;
  127. mini_servo.initialize(initer.get_module_id(2), &feiteservomotor_bus, 2, &cfg);
  128. initer.register_module(&mini_servo);
  129. }
  130. {
  131. static MiniRobotCtrlModule mini_servo;
  132. static MiniRobotCtrlModule::flash_config_t cfg = {0};
  133. cfg.default_torque = 330;
  134. mini_servo.initialize(initer.get_module_id(3), &feiteservomotor_bus, 3, &cfg);
  135. initer.register_module(&mini_servo);
  136. }
  137. {
  138. static MiniRobotCtrlModule mini_servo;
  139. static MiniRobotCtrlModule::flash_config_t cfg = {0};
  140. cfg.default_torque = 330;
  141. mini_servo.initialize(initer.get_module_id(4), &feiteservomotor_bus, 4, &cfg);
  142. initer.register_module(&mini_servo);
  143. }
  144. {
  145. static MiniRobotCtrlModule mini_servo;
  146. static MiniRobotCtrlModule::flash_config_t cfg = {0};
  147. cfg.default_torque = 330;
  148. mini_servo.initialize(initer.get_module_id(5), &feiteservomotor_bus, 5, &cfg);
  149. initer.register_module(&mini_servo);
  150. }
  151. }
  152. }
  153. /*******************************************************************************
  154. * MAIN *
  155. *******************************************************************************/
  156. void umain() {
  157. ZCancmderSubboardIniter::cfg_t cfg = //
  158. {
  159. .deviceId = getDeviceId(),
  160. .input_gpio = {},
  161. .output_gpio = {},
  162. .temperature_sensor =
  163. {
  164. &m_temperature_sensor[0],
  165. &m_temperature_sensor[1],
  166. &m_temperature_sensor[2],
  167. &m_temperature_sensor[3],
  168. &m_temperature_sensor[4],
  169. },
  170. };
  171. initer.init(&cfg);
  172. initsubmodule();
  173. initer.loop();
  174. }