encoder.cpp 4.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174
  1. #include "stm32g0xx_hal.h"
  2. #include "encoder.h"
  3. TIM_HandleTypeDef htim1;
  4. #define TEST_BUF_LEN 256
  5. uint32_t test_index;
  6. uint32_t test_buf[TEST_BUF_LEN];
  7. #define RESOLUTION 1024
  8. uint8_t direction;
  9. uint32_t forw_cnt;
  10. uint32_t back_cnt;
  11. uint32_t forw_turns;
  12. uint32_t back_turns;
  13. //
  14. void init_encoder(void)
  15. {
  16. TIM_Encoder_InitTypeDef sConfig = {0};
  17. TIM_MasterConfigTypeDef sMasterConfig = {0};
  18. __HAL_RCC_TIM1_CLK_ENABLE();
  19. init_gpio_encoder();
  20. htim1.Instance = TIM1;
  21. htim1.Init.Prescaler = 0;
  22. htim1.Init.CounterMode = TIM_COUNTERMODE_UP;
  23. htim1.Init.Period = 65535;
  24. htim1.Init.ClockDivision = TIM_CLOCKDIVISION_DIV1;
  25. htim1.Init.RepetitionCounter = 0;
  26. htim1.Init.AutoReloadPreload = TIM_AUTORELOAD_PRELOAD_DISABLE; //TIM_AUTORELOAD_PRELOAD_ENABLE;
  27. sConfig.EncoderMode = TIM_ENCODERMODE_TI1; //TIM_ENCODERMODE_TI12;
  28. sConfig.IC1Polarity = TIM_ICPOLARITY_RISING;
  29. sConfig.IC1Selection = TIM_ICSELECTION_DIRECTTI;
  30. sConfig.IC1Prescaler = TIM_ICPSC_DIV1;
  31. sConfig.IC1Filter = 0;
  32. sConfig.IC2Polarity = TIM_ICPOLARITY_RISING;
  33. sConfig.IC2Selection = TIM_ICSELECTION_DIRECTTI;
  34. sConfig.IC2Prescaler = TIM_ICPSC_DIV1;
  35. sConfig.IC2Filter = 0;
  36. HAL_TIM_Encoder_Init(&htim1, &sConfig);
  37. sMasterConfig.MasterOutputTrigger = TIM_TRGO_RESET;
  38. sMasterConfig.MasterOutputTrigger2 = TIM_TRGO2_RESET;
  39. sMasterConfig.MasterSlaveMode = TIM_MASTERSLAVEMODE_DISABLE;
  40. HAL_TIMEx_MasterConfigSynchronization(&htim1, &sMasterConfig);
  41. //HAL_NVIC_SetPriority(TIM1_BRK_UP_TRG_COM_IRQn, 6, 0);
  42. //HAL_NVIC_EnableIRQ(TIM1_BRK_UP_TRG_COM_IRQn);
  43. //__HAL_TIM_ENABLE_IT(&htim1, TIM_IT_UPDATE);
  44. HAL_NVIC_SetPriority(TIM1_CC_IRQn, 6, 0);
  45. HAL_NVIC_EnableIRQ(TIM1_CC_IRQn);
  46. //HAL_TIM_Encoder_Start(&htim1, TIM_CHANNEL_ALL);
  47. //HAL_TIM_Encoder_Start_IT(&htim1, TIM_CHANNEL_ALL);
  48. HAL_TIM_Encoder_Start_IT(&htim1, TIM_CHANNEL_1);
  49. }
  50. //
  51. void init_gpio_encoder(void)
  52. {
  53. GPIO_InitTypeDef GPIO_InitStruct = {0};
  54. __HAL_RCC_GPIOA_CLK_ENABLE();
  55. __HAL_RCC_GPIOB_CLK_ENABLE();
  56. GPIO_InitStruct.Pin = GPIO_PIN_8;
  57. GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
  58. GPIO_InitStruct.Pull = GPIO_NOPULL;
  59. GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_LOW;
  60. GPIO_InitStruct.Alternate = GPIO_AF2_TIM1;
  61. HAL_GPIO_Init(GPIOA, &GPIO_InitStruct);
  62. GPIO_InitStruct.Pin = GPIO_PIN_3;
  63. GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
  64. GPIO_InitStruct.Pull = GPIO_NOPULL;
  65. GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_LOW;
  66. GPIO_InitStruct.Alternate = GPIO_AF1_TIM1;
  67. HAL_GPIO_Init(GPIOB, &GPIO_InitStruct);
  68. #if 0
  69. GPIO_InitStruct.Pin = GPIO_PIN_0;
  70. GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
  71. GPIO_InitStruct.Pull = GPIO_PULLUP;
  72. GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_VERY_HIGH;
  73. GPIO_InitStruct.Alternate = GPIO_AF1_TIM1; //GPIO_AF2_TIM1;
  74. HAL_GPIO_Init(GPIOB, &GPIO_InitStruct);
  75. GPIO_InitStruct.Pin = GPIO_PIN_3;
  76. GPIO_InitStruct.Alternate = GPIO_AF1_TIM1;
  77. HAL_GPIO_Init(GPIOB, &GPIO_InitStruct);
  78. #endif
  79. }
  80. void HAL_TIM_PeriodElapsedCallback(TIM_HandleTypeDef *htim)
  81. {
  82. static uint32_t cnt = 0;
  83. cnt++;
  84. }
  85. void HAL_TIM_IC_CaptureCallback(TIM_HandleTypeDef *htim)
  86. {
  87. if (htim->Instance->CR1 & TIM_CR1_DIR) {
  88. direction = 1;
  89. back_cnt++;
  90. if (back_cnt >= RESOLUTION) {
  91. back_cnt = 0;
  92. back_turns++;
  93. }
  94. }
  95. else {
  96. direction = 0;
  97. forw_cnt++;
  98. if (forw_cnt >= RESOLUTION) {
  99. forw_cnt = 0;
  100. forw_turns++;
  101. }
  102. }
  103. #if 0
  104. //test_buf[test_index++] = (uint16_t)TIM1->CNT;
  105. test_buf[test_index++] = (uint16_t)TIM1->CCR1;
  106. if (test_index == TEST_BUF_LEN)
  107. test_index = 0;
  108. #endif
  109. }
  110. extern "C" {
  111. void TIM1_BRK_UP_TRG_COM_IRQHandler(void)
  112. {
  113. HAL_TIM_IRQHandler(&htim1);
  114. #if 0
  115. if (TIM_GetITStatus(TIM1, TIM_IT_Update) != RESET)
  116. {
  117. TIM_ClearITPendingBit(TIM1, TIM_IT_Update);
  118. //encDir = (TIM1->CR1 & TIM_CR1_DIR ? true : false);
  119. #if 0
  120. if (!encInit)
  121. return;
  122. xSemaphoreGiveFromISR(semphEncoder, &xHigherPriorityTaskWoken);
  123. #endif
  124. }
  125. #endif
  126. //HAL_TIM_IRQHandler(&htim1);
  127. }
  128. void TIM1_CC_IRQHandler(void)
  129. {
  130. HAL_TIM_IRQHandler(&htim1);
  131. }
  132. }