Brandon Modon Encoder_Nucleo_16_bits
EncoderMspInitL4.cpp@0:ebd170807e11, 2016-05-22 (annotated)
- Committer:
- kkoichy
- Date:
- Sun May 22 19:59:18 2016 +0000
- Revision:
- 0:ebd170807e11
V1.0 :; - Objet Encoder_Nucleo_16_bits created, allowing 32bits encoder counting operation, based on a software 32bits counter, using a 16bits TIM with interrupt.; Based on the work of David Lowe
Who changed what in which revision?
User | Revision | Line number | New contents of line |
---|---|---|---|
kkoichy | 0:ebd170807e11 | 1 | #include "mbed.h" |
kkoichy | 0:ebd170807e11 | 2 | /* |
kkoichy | 0:ebd170807e11 | 3 | * HAL_TIM_Encoder_MspInit() |
kkoichy | 0:ebd170807e11 | 4 | * Overrides the __weak function stub in stm32f4xx_hal_tim.h |
kkoichy | 0:ebd170807e11 | 5 | * |
kkoichy | 0:ebd170807e11 | 6 | * Edit the below for your preferred pin wiring & pullup/down |
kkoichy | 0:ebd170807e11 | 7 | * I have encoder common at 3V3, using GPIO_PULLDOWN on inputs. |
kkoichy | 0:ebd170807e11 | 8 | * Encoder A&B outputs connected directly to GPIOs. |
kkoichy | 0:ebd170807e11 | 9 | * |
kkoichy | 0:ebd170807e11 | 10 | * http://www.st.com/st-web-ui/static/active/en/resource/technical/document/datasheet/DM00108832.pdf |
kkoichy | 0:ebd170807e11 | 11 | * Table 15 has GPIOx AFx pinouts |
kkoichy | 0:ebd170807e11 | 12 | * |
kkoichy | 0:ebd170807e11 | 13 | * TIM1_CH1: AF1 @ PA8, PE9 |
kkoichy | 0:ebd170807e11 | 14 | * TIM1_CH2: AF1 @ PA9, PE11 |
kkoichy | 0:ebd170807e11 | 15 | * |
kkoichy | 0:ebd170807e11 | 16 | * TIM2_CH1: AF1 @ PA0, PA5, PA15 |
kkoichy | 0:ebd170807e11 | 17 | * TIM2_CH2: AF1 @ PA1, PB3 |
kkoichy | 0:ebd170807e11 | 18 | * |
kkoichy | 0:ebd170807e11 | 19 | * TIM3_CH1: AF2 @ PA6, PB4, PC6, PE3 |
kkoichy | 0:ebd170807e11 | 20 | * TIM3_CH2: AF2 @ PA7, PB5, PC7, PE4 |
kkoichy | 0:ebd170807e11 | 21 | * |
kkoichy | 0:ebd170807e11 | 22 | * TIM4_CH1: AF2 @ PB6, PD12 |
kkoichy | 0:ebd170807e11 | 23 | * TIM4_CH2: AF2 @ PB7, PD13 |
kkoichy | 0:ebd170807e11 | 24 | * |
kkoichy | 0:ebd170807e11 | 25 | * TIM5_CH1: AF2 @ PA0, PF6 |
kkoichy | 0:ebd170807e11 | 26 | * TIM5_CH2: AF2 @ PA1, PF7 |
kkoichy | 0:ebd170807e11 | 27 | * |
kkoichy | 0:ebd170807e11 | 28 | */ |
kkoichy | 0:ebd170807e11 | 29 | |
kkoichy | 0:ebd170807e11 | 30 | #ifdef TARGET_STM32L4 |
kkoichy | 0:ebd170807e11 | 31 | void HAL_TIM_Encoder_MspInit(TIM_HandleTypeDef *htim) |
kkoichy | 0:ebd170807e11 | 32 | { |
kkoichy | 0:ebd170807e11 | 33 | GPIO_InitTypeDef GPIO_InitStruct; |
kkoichy | 0:ebd170807e11 | 34 | |
kkoichy | 0:ebd170807e11 | 35 | if (htim->Instance == TIM1) { //PA8 PA9 = Nucleo D7 D8 |
kkoichy | 0:ebd170807e11 | 36 | __TIM1_CLK_ENABLE(); |
kkoichy | 0:ebd170807e11 | 37 | __GPIOA_CLK_ENABLE(); |
kkoichy | 0:ebd170807e11 | 38 | GPIO_InitStruct.Pin = GPIO_PIN_8 | GPIO_PIN_9; |
kkoichy | 0:ebd170807e11 | 39 | GPIO_InitStruct.Mode = GPIO_MODE_AF_PP; |
kkoichy | 0:ebd170807e11 | 40 | GPIO_InitStruct.Pull = GPIO_PULLDOWN; |
kkoichy | 0:ebd170807e11 | 41 | GPIO_InitStruct.Speed = GPIO_SPEED_HIGH; |
kkoichy | 0:ebd170807e11 | 42 | GPIO_InitStruct.Alternate = GPIO_AF1_TIM1; |
kkoichy | 0:ebd170807e11 | 43 | HAL_GPIO_Init(GPIOA, &GPIO_InitStruct); |
kkoichy | 0:ebd170807e11 | 44 | } |
kkoichy | 0:ebd170807e11 | 45 | else if (htim->Instance == TIM2) { //PA0 PA1 = Nucleo A0 A1 |
kkoichy | 0:ebd170807e11 | 46 | __TIM2_CLK_ENABLE(); |
kkoichy | 0:ebd170807e11 | 47 | __GPIOA_CLK_ENABLE(); |
kkoichy | 0:ebd170807e11 | 48 | GPIO_InitStruct.Pin = GPIO_PIN_0 | GPIO_PIN_1; |
kkoichy | 0:ebd170807e11 | 49 | GPIO_InitStruct.Mode = GPIO_MODE_AF_PP; |
kkoichy | 0:ebd170807e11 | 50 | GPIO_InitStruct.Pull = GPIO_PULLDOWN; |
kkoichy | 0:ebd170807e11 | 51 | GPIO_InitStruct.Speed = GPIO_SPEED_HIGH; |
kkoichy | 0:ebd170807e11 | 52 | GPIO_InitStruct.Alternate = GPIO_AF1_TIM2; |
kkoichy | 0:ebd170807e11 | 53 | HAL_GPIO_Init(GPIOA, &GPIO_InitStruct); |
kkoichy | 0:ebd170807e11 | 54 | } |
kkoichy | 0:ebd170807e11 | 55 | else if (htim->Instance == TIM3) { //PB4 PB5 = Nucleo D5 D4 |
kkoichy | 0:ebd170807e11 | 56 | __TIM3_CLK_ENABLE(); |
kkoichy | 0:ebd170807e11 | 57 | __GPIOB_CLK_ENABLE(); |
kkoichy | 0:ebd170807e11 | 58 | GPIO_InitStruct.Pin = GPIO_PIN_4 | GPIO_PIN_5; |
kkoichy | 0:ebd170807e11 | 59 | GPIO_InitStruct.Mode = GPIO_MODE_AF_PP; |
kkoichy | 0:ebd170807e11 | 60 | GPIO_InitStruct.Pull = GPIO_PULLDOWN; |
kkoichy | 0:ebd170807e11 | 61 | GPIO_InitStruct.Speed = GPIO_SPEED_HIGH; |
kkoichy | 0:ebd170807e11 | 62 | GPIO_InitStruct.Alternate = GPIO_AF2_TIM3; |
kkoichy | 0:ebd170807e11 | 63 | HAL_GPIO_Init(GPIOB, &GPIO_InitStruct); |
kkoichy | 0:ebd170807e11 | 64 | } |
kkoichy | 0:ebd170807e11 | 65 | else if (htim->Instance == TIM4) { // PB6 PB7 = Nucleo D10 MORPHO_PB7 |
kkoichy | 0:ebd170807e11 | 66 | __TIM4_CLK_ENABLE(); |
kkoichy | 0:ebd170807e11 | 67 | __GPIOB_CLK_ENABLE(); |
kkoichy | 0:ebd170807e11 | 68 | GPIO_InitStruct.Pin = GPIO_PIN_6 | GPIO_PIN_7; |
kkoichy | 0:ebd170807e11 | 69 | GPIO_InitStruct.Mode = GPIO_MODE_AF_PP; |
kkoichy | 0:ebd170807e11 | 70 | GPIO_InitStruct.Pull = GPIO_PULLDOWN; |
kkoichy | 0:ebd170807e11 | 71 | GPIO_InitStruct.Speed = GPIO_SPEED_HIGH; |
kkoichy | 0:ebd170807e11 | 72 | GPIO_InitStruct.Alternate = GPIO_AF2_TIM4; |
kkoichy | 0:ebd170807e11 | 73 | HAL_GPIO_Init(GPIOB, &GPIO_InitStruct); |
kkoichy | 0:ebd170807e11 | 74 | } |
kkoichy | 0:ebd170807e11 | 75 | else if (htim->Instance == TIM5) { // here for completeness, mbed sytem timer uses this |
kkoichy | 0:ebd170807e11 | 76 | __TIM5_CLK_ENABLE(); |
kkoichy | 0:ebd170807e11 | 77 | __GPIOA_CLK_ENABLE(); |
kkoichy | 0:ebd170807e11 | 78 | GPIO_InitStruct.Pin = GPIO_PIN_0 | GPIO_PIN_1; |
kkoichy | 0:ebd170807e11 | 79 | GPIO_InitStruct.Mode = GPIO_MODE_AF_PP; |
kkoichy | 0:ebd170807e11 | 80 | GPIO_InitStruct.Pull = GPIO_PULLDOWN; |
kkoichy | 0:ebd170807e11 | 81 | GPIO_InitStruct.Speed = GPIO_SPEED_HIGH; |
kkoichy | 0:ebd170807e11 | 82 | GPIO_InitStruct.Alternate = GPIO_AF2_TIM5; |
kkoichy | 0:ebd170807e11 | 83 | HAL_GPIO_Init(GPIOA, &GPIO_InitStruct); |
kkoichy | 0:ebd170807e11 | 84 | } |
kkoichy | 0:ebd170807e11 | 85 | } |
kkoichy | 0:ebd170807e11 | 86 | #endif |