hi

Dependents:   hello_enc_test

Fork of Nucleo_Hello_Encoder by David Lowe

Committer:
gregeric
Date:
Sun Oct 04 11:58:58 2015 +0000
Revision:
1:cd7b42c99ff8
Parent:
0:ee5cb967aa17
Child:
2:8349e61b6152
Added more targets, use HAL macros to read counter value & direction.

Who changed what in which revision?

UserRevisionLine numberNew contents of line
gregeric 0:ee5cb967aa17 1 #include "mbed.h"
gregeric 0:ee5cb967aa17 2 /*
gregeric 0:ee5cb967aa17 3 * HAL_TIM_Encoder_MspInit()
gregeric 0:ee5cb967aa17 4 * Overrides the __weak function stub in stm32f4xx_hal_tim.h
gregeric 0:ee5cb967aa17 5 *
gregeric 0:ee5cb967aa17 6 * Edit the below for your preferred pin wiring & pullup/down
gregeric 0:ee5cb967aa17 7 * I have encoder common at 3V3, using GPIO_PULLDOWN on inputs.
gregeric 0:ee5cb967aa17 8 * Encoder A&B outputs connected directly to GPIOs.
gregeric 0:ee5cb967aa17 9 *
gregeric 1:cd7b42c99ff8 10 * www.st.com/st-web-ui/static/active/en/resource/technical/document/datasheet/DM00102166.pdf
gregeric 1:cd7b42c99ff8 11 * www.st.com/st-web-ui/static/active/en/resource/technical/document/datasheet/DM00141306.pdf
gregeric 1:cd7b42c99ff8 12 *
gregeric 1:cd7b42c99ff8 13 * TIM1_CH1: AF1 @ PA_8, PE_9
gregeric 1:cd7b42c99ff8 14 * TIM1_CH2: AF1 @ PA_9, PE_11
gregeric 1:cd7b42c99ff8 15 *
gregeric 1:cd7b42c99ff8 16 * TIM2_CH1: AF1 @ PA_0, PA_5, PA_15, PB_8* *F446 only
gregeric 1:cd7b42c99ff8 17 * TIM2_CH2: AF1 @ PA_1, PB_3, PB_9* *F446 only
gregeric 1:cd7b42c99ff8 18 *
gregeric 1:cd7b42c99ff8 19 * TIM3_CH1: AF2 @ PA_6, PB_4, PC_6
gregeric 1:cd7b42c99ff8 20 * TIM3_CH2: AF2 @ PA_7, PB_5, PC_7
gregeric 1:cd7b42c99ff8 21 *
gregeric 1:cd7b42c99ff8 22 * TIM4_CH1: AF2 @ PB_6, PD_12
gregeric 1:cd7b42c99ff8 23 * TIM4_CH2: AF2 @ PB_7, PD_13
gregeric 1:cd7b42c99ff8 24 *
gregeric 1:cd7b42c99ff8 25 * TIM5_CH1: AF2 @ PA_0* *TIM5 used by mbed system ticker so unavailable
gregeric 1:cd7b42c99ff8 26 * TIM5_CH2: AF2 @ PA_1*
gregeric 1:cd7b42c99ff8 27 *
gregeric 0:ee5cb967aa17 28 */
gregeric 0:ee5cb967aa17 29
gregeric 0:ee5cb967aa17 30 #ifdef TARGET_STM32F4
gregeric 0:ee5cb967aa17 31 void HAL_TIM_Encoder_MspInit(TIM_HandleTypeDef *htim)
gregeric 0:ee5cb967aa17 32 {
gregeric 0:ee5cb967aa17 33 GPIO_InitTypeDef GPIO_InitStruct;
gregeric 0:ee5cb967aa17 34
gregeric 1:cd7b42c99ff8 35 if (htim->Instance == TIM1) { //PA8 PA9 = Nucleo D7 D8
gregeric 0:ee5cb967aa17 36 __TIM1_CLK_ENABLE();
gregeric 0:ee5cb967aa17 37 __GPIOA_CLK_ENABLE();
gregeric 0:ee5cb967aa17 38 GPIO_InitStruct.Pin = GPIO_PIN_8 | GPIO_PIN_9;
gregeric 0:ee5cb967aa17 39 GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
gregeric 0:ee5cb967aa17 40 GPIO_InitStruct.Pull = GPIO_PULLDOWN;
gregeric 0:ee5cb967aa17 41 GPIO_InitStruct.Speed = GPIO_SPEED_HIGH;
gregeric 0:ee5cb967aa17 42 GPIO_InitStruct.Alternate = GPIO_AF1_TIM1;
gregeric 0:ee5cb967aa17 43 HAL_GPIO_Init(GPIOA, &GPIO_InitStruct);
gregeric 0:ee5cb967aa17 44 }
gregeric 1:cd7b42c99ff8 45 else if (htim->Instance == TIM2) { //PA0 PA1 = Nucleo A0 A1
gregeric 0:ee5cb967aa17 46 __TIM2_CLK_ENABLE();
gregeric 0:ee5cb967aa17 47 __GPIOA_CLK_ENABLE();
gregeric 0:ee5cb967aa17 48 GPIO_InitStruct.Pin = GPIO_PIN_0 | GPIO_PIN_1;
gregeric 0:ee5cb967aa17 49 GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
gregeric 0:ee5cb967aa17 50 GPIO_InitStruct.Pull = GPIO_PULLDOWN;
gregeric 0:ee5cb967aa17 51 GPIO_InitStruct.Speed = GPIO_SPEED_HIGH;
gregeric 0:ee5cb967aa17 52 GPIO_InitStruct.Alternate = GPIO_AF1_TIM2;
gregeric 0:ee5cb967aa17 53 HAL_GPIO_Init(GPIOA, &GPIO_InitStruct);
gregeric 0:ee5cb967aa17 54 }
gregeric 1:cd7b42c99ff8 55 else if (htim->Instance == TIM3) { //PB4 PB5 = Nucleo D5 D4
gregeric 0:ee5cb967aa17 56 __TIM3_CLK_ENABLE();
gregeric 0:ee5cb967aa17 57 __GPIOB_CLK_ENABLE();
gregeric 0:ee5cb967aa17 58 GPIO_InitStruct.Pin = GPIO_PIN_4 | GPIO_PIN_5;
gregeric 0:ee5cb967aa17 59 GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
gregeric 0:ee5cb967aa17 60 GPIO_InitStruct.Pull = GPIO_PULLDOWN;
gregeric 0:ee5cb967aa17 61 GPIO_InitStruct.Speed = GPIO_SPEED_HIGH;
gregeric 0:ee5cb967aa17 62 GPIO_InitStruct.Alternate = GPIO_AF2_TIM3;
gregeric 0:ee5cb967aa17 63 HAL_GPIO_Init(GPIOB, &GPIO_InitStruct);
gregeric 0:ee5cb967aa17 64 }
gregeric 0:ee5cb967aa17 65 else if (htim->Instance == TIM4) { // PB6 PB7 = Nucleo D10 MORPHO_PB7
gregeric 0:ee5cb967aa17 66 __TIM4_CLK_ENABLE();
gregeric 0:ee5cb967aa17 67 __GPIOB_CLK_ENABLE();
gregeric 0:ee5cb967aa17 68 GPIO_InitStruct.Pin = GPIO_PIN_6 | GPIO_PIN_7;
gregeric 0:ee5cb967aa17 69 GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
gregeric 0:ee5cb967aa17 70 GPIO_InitStruct.Pull = GPIO_PULLDOWN;
gregeric 0:ee5cb967aa17 71 GPIO_InitStruct.Speed = GPIO_SPEED_HIGH;
gregeric 0:ee5cb967aa17 72 GPIO_InitStruct.Alternate = GPIO_AF2_TIM4;
gregeric 0:ee5cb967aa17 73 HAL_GPIO_Init(GPIOB, &GPIO_InitStruct);
gregeric 0:ee5cb967aa17 74 }
gregeric 0:ee5cb967aa17 75 }
gregeric 0:ee5cb967aa17 76 #endif