misc.c 4.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169
  1. #include "misc.h"
  2. #include "FreeRTOS.h"
  3. #include "task.h"
  4. #include "mux.h"
  5. #include "mb.h"
  6. #include "mbport.h"
  7. #include "at32f403a_407_board.h"
  8. #include <stdio.h>
  9. char recv_buf[1024] = {0};
  10. // TIM1, 8, 9, 10, 11 тактируются от 120 МГц
  11. // TIM2, 3, 4, 5, 6, 7, 12, 13, 14 тактируются от 240 МГц
  12. void nop(uint32_t cnt);
  13. void modbus_tim_init(void)
  14. {
  15. crm_clocks_freq_type crm_clocks_freq_struct = {0};
  16. crm_periph_clock_enable(CRM_TMR7_PERIPH_CLOCK, TRUE);
  17. crm_clocks_freq_get(&crm_clocks_freq_struct);
  18. tmr_base_init(TMR7, 1, 5999);
  19. tmr_cnt_dir_set(TMR7, TMR_COUNT_UP);
  20. tmr_flag_clear(TMR7, TMR_OVF_FLAG);
  21. nvic_priority_group_config(NVIC_PRIORITY_GROUP_4);
  22. nvic_irq_enable(TMR7_GLOBAL_IRQn, 5, 0);
  23. tmr_counter_enable(TMR7, TRUE);
  24. tmr_interrupt_enable(TMR7, TMR_OVF_INT, TRUE);
  25. }
  26. //
  27. void modbus_init(void)
  28. {
  29. const UCHAR ucSlaveID[] = {0xAA, 0xBB, 0xCC};
  30. uint32_t baud = 115200;
  31. eMBParity par = MB_PAR_NONE;
  32. UCHAR mb_addr = 1;
  33. unsigned int stop_bits = 1;
  34. #if 1
  35. eMBInit(MB_RTU, mb_addr, 4, baud, par, stop_bits);
  36. eMBSetSlaveID(0x34, TRUE, ucSlaveID, 3);
  37. eMBEnable();
  38. #endif
  39. }
  40. //
  41. void test_modbus_port_init(void)
  42. {
  43. gpio_init_type gpio_init_struct;
  44. crm_periph_clock_enable(CRM_USART3_PERIPH_CLOCK, TRUE);
  45. crm_periph_clock_enable(CRM_GPIOD_PERIPH_CLOCK, TRUE);
  46. crm_periph_clock_enable(CRM_IOMUX_PERIPH_CLOCK, TRUE);
  47. gpio_pin_remap_config(USART3_GMUX_0011, TRUE);
  48. gpio_default_para_init(&gpio_init_struct);
  49. // configure the uart tx pin
  50. gpio_init_struct.gpio_drive_strength = GPIO_DRIVE_STRENGTH_STRONGER;
  51. gpio_init_struct.gpio_out_type = GPIO_OUTPUT_PUSH_PULL;
  52. gpio_init_struct.gpio_mode = GPIO_MODE_MUX;
  53. gpio_init_struct.gpio_pins = GPIO_PINS_8;
  54. gpio_init_struct.gpio_pull = GPIO_PULL_NONE;
  55. gpio_init(GPIOD, &gpio_init_struct);
  56. // configure the uart rx pin
  57. gpio_init_struct.gpio_mode = GPIO_MODE_INPUT;
  58. gpio_init_struct.gpio_pins = GPIO_PINS_9;
  59. gpio_init_struct.gpio_pull = GPIO_PULL_UP;
  60. gpio_init(GPIOD, &gpio_init_struct);
  61. // configure the uart rx pin
  62. gpio_init_struct.gpio_drive_strength = GPIO_DRIVE_STRENGTH_STRONGER;
  63. gpio_init_struct.gpio_out_type = GPIO_OUTPUT_PUSH_PULL;
  64. gpio_init_struct.gpio_mode = GPIO_MODE_OUTPUT;
  65. gpio_init_struct.gpio_pins = GPIO_PINS_10;
  66. gpio_init_struct.gpio_pull = GPIO_PULL_UP;
  67. gpio_init(GPIOD, &gpio_init_struct);
  68. MB_RX_ENABLE;
  69. // configure uart param
  70. usart_init(USART3, 115200, USART_DATA_8BITS, USART_STOP_1_BIT);
  71. usart_parity_selection_config(USART3, USART_PARITY_NONE);
  72. usart_flag_clear(USART3, USART_RDBF_FLAG);
  73. usart_interrupt_enable(USART3, USART_RDBF_INT, TRUE);
  74. usart_receiver_enable(USART3, TRUE);
  75. usart_transmitter_enable(USART3, TRUE);
  76. usart_enable(USART3, TRUE);
  77. nvic_priority_group_config(NVIC_PRIORITY_GROUP_4);
  78. nvic_irq_enable(USART3_IRQn, 5, 0);
  79. }
  80. void nop(uint32_t cnt)
  81. {
  82. for (uint32_t i = 0; i < cnt; i++)
  83. __NOP();
  84. }
  85. // PA_2 (pin_25)
  86. void mb_test_gpio_init(void)
  87. {
  88. gpio_init_type gpio_init_struct;
  89. crm_periph_clock_enable(CRM_GPIOA_PERIPH_CLOCK, TRUE);
  90. gpio_default_para_init(&gpio_init_struct);
  91. // configure the uart tx pin
  92. gpio_init_struct.gpio_drive_strength = GPIO_DRIVE_STRENGTH_STRONGER;
  93. gpio_init_struct.gpio_out_type = GPIO_OUTPUT_PUSH_PULL;
  94. gpio_init_struct.gpio_mode = GPIO_MODE_OUTPUT;
  95. gpio_init_struct.gpio_pins = GPIO_PINS_2;
  96. gpio_init_struct.gpio_pull = GPIO_PULL_NONE;
  97. gpio_init(GPIOA, &gpio_init_struct);
  98. }
  99. #if 0
  100. void USART3_IRQHandler(void)
  101. {
  102. char rx_byte;
  103. static int counter = 0;
  104. if (usart_flag_get(USART3, USART_RDBF_FLAG) != RESET) {
  105. rx_byte = USART3->dt;
  106. PRINT_UART->dt = ((uint16_t)rx_byte & 0x01FF);
  107. recv_buf[counter++] = rx_byte;
  108. if (counter == 1024)
  109. counter = 0;
  110. MB_TX_ENABLE;
  111. nop(10000);
  112. while(usart_flag_get(USART3, USART_TDBE_FLAG) == RESET);
  113. USART3->dt = ((uint16_t)(rx_byte + 1) & 0x01FF);
  114. while(usart_flag_get(USART3, USART_TDC_FLAG) == RESET);
  115. MB_RX_ENABLE;
  116. }
  117. }
  118. #endif
  119. #if 0
  120. //
  121. void TMR7_GLOBAL_IRQHandler(void)
  122. {
  123. if(tmr_flag_get(TMR7, TMR_OVF_FLAG) != RESET)
  124. {
  125. tmr_flag_clear(TMR7, TMR_OVF_FLAG);
  126. mux_led_test_toggle();
  127. }
  128. }
  129. #endif