Important changes to repositories hosted on mbed.com
Mbed hosted mercurial repositories are deprecated and are due to be permanently deleted in July 2026.
To keep a copy of this software download the repository Zip archive or clone locally using Mercurial.
It is also possible to export all your personal repositories from the account settings page.
Fork of Encoder_Nucleo_16_bits by
Revision 7:cd502aeab71a, committed 2017-02-21
- Comitter:
- Brand101
- Date:
- Tue Feb 21 15:33:10 2017 +0000
- Parent:
- 6:11dea4c204ba
- Commit message:
- 45465446
Changed in this revision
--- a/EncoderMspInitF0.cpp Fri Oct 14 13:38:48 2016 +0000
+++ /dev/null Thu Jan 01 00:00:00 1970 +0000
@@ -1,37 +0,0 @@
-#include "mbed.h"
-/*
- * HAL_TIM_Encoder_MspInit()
- * Overrides the __weak function stub in stm32f0xx_hal_tim.h
- *
- * Edit the below for your preferred pin wiring & pullup/down
- * I have encoder common at 3V3, using GPIO_PULLDOWN on inputs.
- * Encoder A&B outputs connected directly to GPIOs.
- *
- * http://www.st.com/st-web-ui/static/active/en/resource/technical/document/datasheet/DM00088500.pdf
- * Table 11 has GPIO alternate function pinout mappings.
- *
- * TIM1_CH1: AF2 @ PA_8 - TIM1 used as system ticker under mbed, so unavailable
- * TIM1_CH2: AF2 @ PA_9
- *
- * TIM3_CH1: AF1 @ PA_6, PB_4; AF0 @ PC_6* *only for F030xC devices
- * TIM3_CH2: AF1 @ PA_7, PB_5; AF0 @ PC_7*
- *
- */
-
-#ifdef TARGET_STM32F0
-void HAL_TIM_Encoder_MspInit(TIM_HandleTypeDef *htim)
-{
- GPIO_InitTypeDef GPIO_InitStruct;
-
- if (htim->Instance == TIM3) { //PB_4 PB_5 = Nucleo D5 D4
- __TIM3_CLK_ENABLE();
- __GPIOB_CLK_ENABLE();
- GPIO_InitStruct.Pin = GPIO_PIN_4 | GPIO_PIN_5;
- GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
- GPIO_InitStruct.Pull = GPIO_PULLDOWN;
- GPIO_InitStruct.Speed = GPIO_SPEED_HIGH;
- GPIO_InitStruct.Alternate = GPIO_AF1_TIM3;
- HAL_GPIO_Init(GPIOB, &GPIO_InitStruct);
- }
-}
-#endif
\ No newline at end of file
--- a/EncoderMspInitF1.cpp Fri Oct 14 13:38:48 2016 +0000
+++ /dev/null Thu Jan 01 00:00:00 1970 +0000
@@ -1,74 +0,0 @@
-#include "mbed.h"
-/*
- * HAL_TIM_Encoder_MspInit()
- * Overrides the __weak function stub in stm32f1xx_hal_tim.h
- *
- * Edit the below for your preferred pin wiring & pullup/down
- * I have encoder common at 3V3, using GPIO_PULLDOWN on inputs.
- * Encoder A&B outputs connected directly to GPIOs.
- *
- * http://www.st.com/st-web-ui/static/active/en/resource/technical/document/datasheet/CD00161566.pdf
- * Table 5 has GPIO alternate function pinout mappings.
- *
- * TIM1_CH1: default PA_8, remap PE_9
- * TIM1_CH2: default PA_9, remap PE_11
- *
- * TIM2_CH1: default PA_0
- * TIM2_CH2: default PA_1, remap PB_3
- *
- * TIM3_CH1: default PA_6, remap PB_4, PC_6
- * TIM3_CH2: default PA_7, remap PB_5, PC_7
- *
- * TIM4_CH1: default PB_6, remap PD_12
- * TIM4_CH2: default PB_7, remap PD_13
- *
- * NB one of these timers will be the employed by mbed as systick, unavailable as encoder.
- */
-
-#ifdef TARGET_STM32F1
-void HAL_TIM_Encoder_MspInit(TIM_HandleTypeDef *htim)
-{
- GPIO_InitTypeDef GPIO_InitStruct;
-
- if (htim->Instance == TIM1) { //PA8 PA9 = Nucleo D7 D8
- __TIM1_CLK_ENABLE();
- __GPIOA_CLK_ENABLE();
- GPIO_InitStruct.Pin = GPIO_PIN_8 | GPIO_PIN_9;
- GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
- GPIO_InitStruct.Pull = GPIO_PULLDOWN;
- GPIO_InitStruct.Speed = GPIO_SPEED_HIGH;
-// GPIO_InitStruct.Alternate = GPIO_AF1_TIM1;
- HAL_GPIO_Init(GPIOA, &GPIO_InitStruct);
- }
- else if (htim->Instance == TIM2) { //PA0 PA1 = Nucleo A0 A1
- __TIM2_CLK_ENABLE();
- __GPIOA_CLK_ENABLE();
- GPIO_InitStruct.Pin = GPIO_PIN_0 | GPIO_PIN_1;
- GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
- GPIO_InitStruct.Pull = GPIO_PULLDOWN;
- GPIO_InitStruct.Speed = GPIO_SPEED_HIGH;
-// GPIO_InitStruct.Alternate = GPIO_AF1_TIM2;
- HAL_GPIO_Init(GPIOA, &GPIO_InitStruct);
- }
- else if (htim->Instance == TIM3) { //PA6 PA7 = Nucleo D12 D11
- __TIM3_CLK_ENABLE();
- __GPIOA_CLK_ENABLE();
- GPIO_InitStruct.Pin = GPIO_PIN_6 | GPIO_PIN_7;
- GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
- GPIO_InitStruct.Pull = GPIO_PULLDOWN;
- GPIO_InitStruct.Speed = GPIO_SPEED_HIGH;
-// GPIO_InitStruct.Alternate = GPIO_AF2_TIM3;
- HAL_GPIO_Init(GPIOA, &GPIO_InitStruct);
- }
- else if (htim->Instance == TIM4) { // PB6 PB7 = Nucleo D10 MORPHO PB7
- __TIM4_CLK_ENABLE();
- __GPIOB_CLK_ENABLE();
- GPIO_InitStruct.Pin = GPIO_PIN_6 | GPIO_PIN_7;
- GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
- GPIO_InitStruct.Pull = GPIO_PULLDOWN;
- GPIO_InitStruct.Speed = GPIO_SPEED_HIGH;
-// GPIO_InitStruct.Alternate = GPIO_AF2_TIM4;
- HAL_GPIO_Init(GPIOB, &GPIO_InitStruct);
- }
-}
-#endif
\ No newline at end of file
--- a/EncoderMspInitF3.cpp Fri Oct 14 13:38:48 2016 +0000
+++ /dev/null Thu Jan 01 00:00:00 1970 +0000
@@ -1,82 +0,0 @@
-#include "mbed.h"
-/*
- * HAL_TIM_Encoder_MspInit()
- * Overrides the __weak function stub in stm32f3xx_hal_tim.h
- *
- * Edit the below for your preferred pin wiring & pullup/down
- * I have encoder common at 3V3, using GPIO_PULLDOWN on inputs.
- * Encoder A&B outputs connected directly to GPIOs.
- *
- * http://www.st.com/st-web-ui/static/active/en/resource/technical/document/datasheet/DM00093333.pdf
- * http://www.st.com/st-web-ui/static/active/en/resource/technical/document/datasheet/DM00097745.pdf
- * http://www.st.com/st-web-ui/static/active/en/resource/technical/document/datasheet/DM00133117.pdf
- * Table 14 has GPIO alternate function pinout mappings.
- *
- * TIM1_CH1: AF2 @ PC_0, PE_9; AF6 @ PA_8
- * TIM1_CH2: AF2 @ PC_1, PE_11; AF6 @ PA_9
- *
- * (TIM2_CH1: AF1 @ PA_0, PA_5, PA_15; AF2 @ PD_3) TIM2 is the mbed system ticker, so unavailable as encoder.
- * (TIM2_CH2: AF1 @ PA_1, PB_3; AF2 @ PD_4)
- *
- * TIM3_CH1: AF2 @ PA_6, PB_4, PC_6, PE_2 not for F302R8, OK @ F334R8
- * TIM3_CH2: AF2 @ PA_4, PA_7, PB_5, PC_7, PE_3
- *
- * TIM4_CH1: AF2 @ PB_6, PD_12; AF10 @ PA_11 not for both F302R8 & F334R8
- * TIM4_CH2: AF2 @ PB_7, PD_13; AF10 @ PA_12
- *
- */
-
-#ifdef TARGET_STM32F3
-
-void HAL_TIM_Encoder_MspInit(TIM_HandleTypeDef *htim)
-{
- GPIO_InitTypeDef GPIO_InitStruct;
-
- if (htim->Instance == TIM1) { //PA8 PA9 = Nucleo D7 D8
- __TIM1_CLK_ENABLE();
- __GPIOA_CLK_ENABLE();
- GPIO_InitStruct.Pin = GPIO_PIN_8 | GPIO_PIN_9;
- GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
- GPIO_InitStruct.Pull = GPIO_PULLDOWN;
- GPIO_InitStruct.Speed = GPIO_SPEED_HIGH;
- GPIO_InitStruct.Alternate = GPIO_AF6_TIM1;
- HAL_GPIO_Init(GPIOA, &GPIO_InitStruct);
- }
-#if 0 //TIM2 is the mbed system ticker
- else if (htim->Instance == TIM2) { //PA0 PA1 = Nucleo A0 A1
- __TIM2_CLK_ENABLE();
- __GPIOA_CLK_ENABLE();
- GPIO_InitStruct.Pin = GPIO_PIN_0 | GPIO_PIN_1;
- GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
- GPIO_InitStruct.Pull = GPIO_PULLDOWN;
- GPIO_InitStruct.Speed = GPIO_SPEED_HIGH;
- GPIO_InitStruct.Alternate = GPIO_AF1_TIM2;
- HAL_GPIO_Init(GPIOA, &GPIO_InitStruct);
- }
-#endif
-#if defined TARGET_STM32F334R8
- else if (htim->Instance == TIM3) { //PB4 PB5 = Nucleo D5 D4
- __TIM3_CLK_ENABLE();
- __GPIOB_CLK_ENABLE();
- GPIO_InitStruct.Pin = GPIO_PIN_4 | GPIO_PIN_5;
- GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
- GPIO_InitStruct.Pull = GPIO_PULLDOWN;
- GPIO_InitStruct.Speed = GPIO_SPEED_HIGH;
- GPIO_InitStruct.Alternate = GPIO_AF2_TIM3;
- HAL_GPIO_Init(GPIOB, &GPIO_InitStruct);
- }
-#endif
-#if 0
- else if (htim->Instance == TIM4) { // PB6 PB7 = Nucleo D10 MORPHO_PB7
- __TIM4_CLK_ENABLE();
- __GPIOB_CLK_ENABLE();
- GPIO_InitStruct.Pin = GPIO_PIN_6 | GPIO_PIN_7;
- GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
- GPIO_InitStruct.Pull = GPIO_PULLDOWN;
- GPIO_InitStruct.Speed = GPIO_SPEED_HIGH;
- GPIO_InitStruct.Alternate = GPIO_AF2_TIM4;
- HAL_GPIO_Init(GPIOB, &GPIO_InitStruct);
- }
-#endif
-}
-#endif
\ No newline at end of file
--- a/EncoderMspInitF4.cpp Fri Oct 14 13:38:48 2016 +0000
+++ b/EncoderMspInitF4.cpp Tue Feb 21 15:33:10 2017 +0000
@@ -52,10 +52,10 @@
GPIO_InitStruct.Alternate = GPIO_AF1_TIM2;
HAL_GPIO_Init(GPIOA, &GPIO_InitStruct);
}
- else if (htim->Instance == TIM3) { //PB4 PB5 = Nucleo D5 D4
+ else if (htim->Instance == TIM3) { //PA6 PA7 = Nucleo D12 D11 //MY MODIF
__TIM3_CLK_ENABLE();
__GPIOB_CLK_ENABLE();
- GPIO_InitStruct.Pin = GPIO_PIN_4 | GPIO_PIN_5;
+ GPIO_InitStruct.Pin = GPIO_PIN_6 | GPIO_PIN_7; //MY MODIF
GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
GPIO_InitStruct.Pull = GPIO_PULLDOWN;
GPIO_InitStruct.Speed = GPIO_SPEED_HIGH;
--- a/EncoderMspInitL0.cpp Fri Oct 14 13:38:48 2016 +0000
+++ /dev/null Thu Jan 01 00:00:00 1970 +0000
@@ -1,28 +0,0 @@
-#include "mbed.h"
-/*
- * HAL_TIM_Encoder_MspInit()
- * Overrides the __weak function stub in stm32f4xx_hal_tim.h
- *
- * Edit the below for your preferred pin wiring & pullup/down
- * I have encoder common at 3V3, using GPIO_PULLDOWN on inputs.
- * Encoder A&B outputs connected directly to GPIOs.
- *
- */
-
-#ifdef TARGET_STM32L0
-void HAL_TIM_Encoder_MspInit(TIM_HandleTypeDef *htim)
-{
- GPIO_InitTypeDef GPIO_InitStruct;
-
- if (htim->Instance == TIM2) { //PA0 PA1 = Nucleo A0 A1
- __TIM2_CLK_ENABLE();
- __GPIOA_CLK_ENABLE();
- GPIO_InitStruct.Pin = GPIO_PIN_0 | GPIO_PIN_1;
- GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
- GPIO_InitStruct.Pull = GPIO_PULLDOWN;
- GPIO_InitStruct.Speed = GPIO_SPEED_HIGH;
- GPIO_InitStruct.Alternate = GPIO_AF1_TIM2;
- HAL_GPIO_Init(GPIOA, &GPIO_InitStruct);
- }
-}
-#endif
\ No newline at end of file
--- a/EncoderMspInitL1.cpp Fri Oct 14 13:38:48 2016 +0000
+++ /dev/null Thu Jan 01 00:00:00 1970 +0000
@@ -1,63 +0,0 @@
-#include "mbed.h"
-/*
- * HAL_TIM_Encoder_MspInit()
- * Overrides the __weak function stub in stm32l4xx_hal_tim.h
- *
- * Edit the below for your preferred pin wiring & pullup/down
- * I have encoder common at 3V3, using GPIO_PULLDOWN on inputs.
- * Encoder A&B outputs connected directly to GPIOs.
- *
- * http://www.st.com/st-web-ui/static/active/en/resource/technical/document/datasheet/DM00098321.pdf
- * Table 9 has GPIO alternate function pinout mappings.
- *
- * TIM2_CH1: AF1 @ PA_0, PA_5, PA_15, PE_9
- * TIM2_CH2: AF1 @ PA_1, PB_3, PE_10
- *
- * TIM3_CH1: AF2 @ PA_6, PB_4, PC_6, PE_3
- * TIM3_CH2: AF2 @ PA_7, PB_5, PC_7, PE_4
- *
- * TIM4_CH1: AF2 @ PB_6, PD_12
- * TIM4_CH2: AF2 @ PB_7, PD_13
- *
- * TIM5_CH1: AF2 @ PA_0* *TIM5 used by mbed system ticker so unavailable
- * TIM5_CH2: AF2 @ PA_1*
- *
- */
-
-#ifdef TARGET_STM32L1
-void HAL_TIM_Encoder_MspInit(TIM_HandleTypeDef *htim)
-{
- GPIO_InitTypeDef GPIO_InitStruct;
-
- if (htim->Instance == TIM2) { //PA0 PA1 = Nucleo A0 A1
- __TIM2_CLK_ENABLE();
- __GPIOA_CLK_ENABLE();
- GPIO_InitStruct.Pin = GPIO_PIN_0 | GPIO_PIN_1;
- GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
- GPIO_InitStruct.Pull = GPIO_PULLDOWN;
- GPIO_InitStruct.Speed = GPIO_SPEED_HIGH;
- GPIO_InitStruct.Alternate = GPIO_AF1_TIM2;
- HAL_GPIO_Init(GPIOA, &GPIO_InitStruct);
- }
- else if (htim->Instance == TIM3) { //PB4 PB5 = Nucleo D5 D4
- __TIM3_CLK_ENABLE();
- __GPIOB_CLK_ENABLE();
- GPIO_InitStruct.Pin = GPIO_PIN_4 | GPIO_PIN_5;
- GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
- GPIO_InitStruct.Pull = GPIO_PULLDOWN;
- GPIO_InitStruct.Speed = GPIO_SPEED_HIGH;
- GPIO_InitStruct.Alternate = GPIO_AF2_TIM3;
- HAL_GPIO_Init(GPIOB, &GPIO_InitStruct);
- }
- else if (htim->Instance == TIM4) { // PB6 PB7 = Nucleo D10 MORPHO_PB7
- __TIM4_CLK_ENABLE();
- __GPIOB_CLK_ENABLE();
- GPIO_InitStruct.Pin = GPIO_PIN_6 | GPIO_PIN_7;
- GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
- GPIO_InitStruct.Pull = GPIO_PULLDOWN;
- GPIO_InitStruct.Speed = GPIO_SPEED_HIGH;
- GPIO_InitStruct.Alternate = GPIO_AF2_TIM4;
- HAL_GPIO_Init(GPIOB, &GPIO_InitStruct);
- }
-}
-#endif
\ No newline at end of file
--- a/EncoderMspInitL4.cpp Fri Oct 14 13:38:48 2016 +0000
+++ /dev/null Thu Jan 01 00:00:00 1970 +0000
@@ -1,86 +0,0 @@
-#include "mbed.h"
-/*
- * HAL_TIM_Encoder_MspInit()
- * Overrides the __weak function stub in stm32f4xx_hal_tim.h
- *
- * Edit the below for your preferred pin wiring & pullup/down
- * I have encoder common at 3V3, using GPIO_PULLDOWN on inputs.
- * Encoder A&B outputs connected directly to GPIOs.
- *
- * http://www.st.com/st-web-ui/static/active/en/resource/technical/document/datasheet/DM00108832.pdf
- * Table 15 has GPIOx AFx pinouts
- *
- * TIM1_CH1: AF1 @ PA8, PE9
- * TIM1_CH2: AF1 @ PA9, PE11
- *
- * TIM2_CH1: AF1 @ PA0, PA5, PA15
- * TIM2_CH2: AF1 @ PA1, PB3
- *
- * TIM3_CH1: AF2 @ PA6, PB4, PC6, PE3
- * TIM3_CH2: AF2 @ PA7, PB5, PC7, PE4
- *
- * TIM4_CH1: AF2 @ PB6, PD12
- * TIM4_CH2: AF2 @ PB7, PD13
- *
- * TIM5_CH1: AF2 @ PA0, PF6
- * TIM5_CH2: AF2 @ PA1, PF7
- *
- */
-
-#ifdef TARGET_STM32L4
-void HAL_TIM_Encoder_MspInit(TIM_HandleTypeDef *htim)
-{
- GPIO_InitTypeDef GPIO_InitStruct;
-
- if (htim->Instance == TIM1) { //PA8 PA9 = Nucleo D7 D8
- __TIM1_CLK_ENABLE();
- __GPIOA_CLK_ENABLE();
- GPIO_InitStruct.Pin = GPIO_PIN_8 | GPIO_PIN_9;
- GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
- GPIO_InitStruct.Pull = GPIO_PULLDOWN;
- GPIO_InitStruct.Speed = GPIO_SPEED_HIGH;
- GPIO_InitStruct.Alternate = GPIO_AF1_TIM1;
- HAL_GPIO_Init(GPIOA, &GPIO_InitStruct);
- }
- else if (htim->Instance == TIM2) { //PA0 PA1 = Nucleo A0 A1
- __TIM2_CLK_ENABLE();
- __GPIOA_CLK_ENABLE();
- GPIO_InitStruct.Pin = GPIO_PIN_0 | GPIO_PIN_1;
- GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
- GPIO_InitStruct.Pull = GPIO_PULLDOWN;
- GPIO_InitStruct.Speed = GPIO_SPEED_HIGH;
- GPIO_InitStruct.Alternate = GPIO_AF1_TIM2;
- HAL_GPIO_Init(GPIOA, &GPIO_InitStruct);
- }
- else if (htim->Instance == TIM3) { //PB4 PB5 = Nucleo D5 D4
- __TIM3_CLK_ENABLE();
- __GPIOB_CLK_ENABLE();
- GPIO_InitStruct.Pin = GPIO_PIN_4 | GPIO_PIN_5;
- GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
- GPIO_InitStruct.Pull = GPIO_PULLDOWN;
- GPIO_InitStruct.Speed = GPIO_SPEED_HIGH;
- GPIO_InitStruct.Alternate = GPIO_AF2_TIM3;
- HAL_GPIO_Init(GPIOB, &GPIO_InitStruct);
- }
- else if (htim->Instance == TIM4) { // PB6 PB7 = Nucleo D10 MORPHO_PB7
- __TIM4_CLK_ENABLE();
- __GPIOB_CLK_ENABLE();
- GPIO_InitStruct.Pin = GPIO_PIN_6 | GPIO_PIN_7;
- GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
- GPIO_InitStruct.Pull = GPIO_PULLDOWN;
- GPIO_InitStruct.Speed = GPIO_SPEED_HIGH;
- GPIO_InitStruct.Alternate = GPIO_AF2_TIM4;
- HAL_GPIO_Init(GPIOB, &GPIO_InitStruct);
- }
- else if (htim->Instance == TIM5) { // here for completeness, mbed sytem timer uses this
- __TIM5_CLK_ENABLE();
- __GPIOA_CLK_ENABLE();
- GPIO_InitStruct.Pin = GPIO_PIN_0 | GPIO_PIN_1;
- GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
- GPIO_InitStruct.Pull = GPIO_PULLDOWN;
- GPIO_InitStruct.Speed = GPIO_SPEED_HIGH;
- GPIO_InitStruct.Alternate = GPIO_AF2_TIM5;
- HAL_GPIO_Init(GPIOA, &GPIO_InitStruct);
- }
-}
-#endif
\ No newline at end of file
