1
0

board.c 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899
  1. /*
  2. * Copyright (c) 2006-2022, RT-Thread Development Team
  3. *
  4. * SPDX-License-Identifier: Apache-2.0
  5. *
  6. * Change Logs:
  7. * Date Author Notes
  8. * 2020-08-20 Abbcc first version
  9. */
  10. #include "board.h"
  11. void apm32_usart_init(void)
  12. {
  13. GPIO_Config_T GPIO_ConfigStruct;
  14. #ifdef BSP_USING_UART1
  15. RCM_EnableAHB1PeriphClock(RCM_AHB1_PERIPH_GPIOA);
  16. RCM_EnableAPB2PeriphClock(RCM_APB2_PERIPH_USART1);
  17. GPIO_ConfigStruct.mode = GPIO_MODE_AF;
  18. GPIO_ConfigStruct.pin = GPIO_PIN_9;
  19. GPIO_ConfigStruct.otype = GPIO_OTYPE_PP;
  20. GPIO_ConfigStruct.speed = GPIO_SPEED_50MHz;
  21. GPIO_Config(GPIOA, &GPIO_ConfigStruct);
  22. GPIO_ConfigPinAF(GPIOA, GPIO_PIN_SOURCE_9, GPIO_AF_USART1);
  23. GPIO_ConfigStruct.mode = GPIO_MODE_AF;
  24. GPIO_ConfigStruct.pin = GPIO_PIN_10;
  25. GPIO_ConfigStruct.pupd = GPIO_PUPD_UP;
  26. GPIO_ConfigStruct.speed = GPIO_SPEED_50MHz;
  27. GPIO_Config(GPIOA, &GPIO_ConfigStruct);
  28. GPIO_ConfigPinAF(GPIOA, GPIO_PIN_SOURCE_10, GPIO_AF_USART1);
  29. #endif
  30. #ifdef BSP_USING_UART2
  31. RCM_EnableAHB1PeriphClock(RCM_AHB1_PERIPH_GPIOA);
  32. RCM_EnableAPB1PeriphClock(RCM_APB1_PERIPH_USART2);
  33. GPIO_ConfigStruct.mode = GPIO_MODE_AF;
  34. GPIO_ConfigStruct.pin = GPIO_PIN_2;
  35. GPIO_ConfigStruct.otype = GPIO_OTYPE_PP;
  36. GPIO_ConfigStruct.speed = GPIO_SPEED_50MHz;
  37. GPIO_Config(GPIOA, &GPIO_ConfigStruct);
  38. GPIO_ConfigPinAF(GPIOA, GPIO_PIN_SOURCE_2, GPIO_AF_USART2);
  39. GPIO_ConfigStruct.mode = GPIO_MODE_AF;
  40. GPIO_ConfigStruct.pin = GPIO_PIN_3;
  41. GPIO_ConfigStruct.pupd = GPIO_PUPD_UP;
  42. GPIO_ConfigStruct.speed = GPIO_SPEED_50MHz;
  43. GPIO_Config(GPIOA, &GPIO_ConfigStruct);
  44. GPIO_ConfigPinAF(GPIOA, GPIO_PIN_SOURCE_3, GPIO_AF_USART2);
  45. #endif
  46. }
  47. void apm32_msp_can_init(void *Instance)
  48. {
  49. #if defined(BSP_USING_CAN1) || defined(BSP_USING_CAN2)
  50. GPIO_Config_T GPIO_InitStructure;
  51. CAN_T *CANx = (CAN_T *)Instance;
  52. if (CAN1 == CANx)
  53. {
  54. RCM_EnableAPB1PeriphClock(RCM_APB1_PERIPH_CAN1);
  55. RCM_EnableAHB1PeriphClock(RCM_AHB1_PERIPH_GPIOB);
  56. /* PB8: CAN1_RX, PB9: CAN1_TX */
  57. GPIO_InitStructure.pin = GPIO_PIN_8 | GPIO_PIN_9;
  58. GPIO_InitStructure.mode = GPIO_MODE_AF;
  59. GPIO_InitStructure.otype = GPIO_OTYPE_PP;
  60. GPIO_InitStructure.speed = GPIO_SPEED_100MHz;
  61. GPIO_InitStructure.pupd = GPIO_PUPD_UP;
  62. GPIO_Config(GPIOB, &GPIO_InitStructure);
  63. GPIO_ConfigPinAF(GPIOB, GPIO_PIN_SOURCE_8, GPIO_AF_CAN1);
  64. GPIO_ConfigPinAF(GPIOB, GPIO_PIN_SOURCE_9, GPIO_AF_CAN1);
  65. }
  66. else if (CAN2 == CANx)
  67. {
  68. /* When using the CAN2 peripheral, the CAN1 clock must be turned on */
  69. RCM_EnableAPB1PeriphClock(RCM_APB1_PERIPH_CAN1);
  70. RCM_EnableAPB1PeriphClock(RCM_APB1_PERIPH_CAN2);
  71. RCM_EnableAHB1PeriphClock(RCM_AHB1_PERIPH_GPIOB);
  72. /* PB12: CAN2_RX, PB13: CAN2_TX */
  73. GPIO_InitStructure.pin = GPIO_PIN_12 | GPIO_PIN_13;
  74. GPIO_InitStructure.mode = GPIO_MODE_AF;
  75. GPIO_InitStructure.otype = GPIO_OTYPE_PP;
  76. GPIO_InitStructure.speed = GPIO_SPEED_100MHz;
  77. GPIO_InitStructure.pupd = GPIO_PUPD_UP;
  78. GPIO_Config(GPIOB, &GPIO_InitStructure);
  79. GPIO_ConfigPinAF(GPIOB, GPIO_PIN_SOURCE_12, GPIO_AF_CAN2);
  80. GPIO_ConfigPinAF(GPIOB, GPIO_PIN_SOURCE_13, GPIO_AF_CAN2);
  81. }
  82. #endif
  83. }