From 3ef75526094f91db4c6b8b06d2d805d835c438b0 Mon Sep 17 00:00:00 2001 From: gdisirio Date: Sat, 27 Sep 2014 08:10:38 +0000 Subject: git-svn-id: svn://svn.code.sf.net/p/chibios/svn/trunk@7323 35acf78f-673a-0410-8e92-d51de3d6d3f4 --- .../boards/NONSTANDARD_STM32F4_BARTHESS1/board.h | 2 +- .../boards/NONSTANDARD_STM32F4_BARTHESS2/board.h | 2 +- os/hal/boards/OLIMEX_STM32_E407/board.h | 2 +- os/hal/boards/OLIMEX_STM32_H407/board.h | 2 +- os/hal/boards/OLIMEX_STM32_P407/board.h | 2 +- os/hal/boards/ST_NUCLEO_F401RE/board.h | 2 +- os/hal/boards/ST_STM32F429I_DISCOVERY/board.h | 2 +- os/hal/boards/ST_STM32F4_DISCOVERY/board.h | 2 +- os/hal/ports/STM32/STM32F4xx/hal_lld.h | 80 ++++++++++++++++------ os/hal/ports/STM32/STM32F4xx/stm32_rcc.h | 2 +- 10 files changed, 69 insertions(+), 29 deletions(-) (limited to 'os/hal') diff --git a/os/hal/boards/NONSTANDARD_STM32F4_BARTHESS1/board.h b/os/hal/boards/NONSTANDARD_STM32F4_BARTHESS1/board.h index 06c130efb..e1ce6ccd2 100644 --- a/os/hal/boards/NONSTANDARD_STM32F4_BARTHESS1/board.h +++ b/os/hal/boards/NONSTANDARD_STM32F4_BARTHESS1/board.h @@ -43,7 +43,7 @@ /* * MCU type as defined in the ST header. */ -#define STM32F40_41xxx +#define STM32F407xx /* * IO pins assignments. diff --git a/os/hal/boards/NONSTANDARD_STM32F4_BARTHESS2/board.h b/os/hal/boards/NONSTANDARD_STM32F4_BARTHESS2/board.h index e022ca986..dd5cb4b19 100644 --- a/os/hal/boards/NONSTANDARD_STM32F4_BARTHESS2/board.h +++ b/os/hal/boards/NONSTANDARD_STM32F4_BARTHESS2/board.h @@ -46,7 +46,7 @@ /* * MCU type, supported types are defined in ./os/hal/platforms/hal_lld.h. */ -#define STM32F40_41xxx +#define STM32F407xx /* * IO pins assignments. diff --git a/os/hal/boards/OLIMEX_STM32_E407/board.h b/os/hal/boards/OLIMEX_STM32_E407/board.h index 0ccfa8744..1942b9975 100644 --- a/os/hal/boards/OLIMEX_STM32_E407/board.h +++ b/os/hal/boards/OLIMEX_STM32_E407/board.h @@ -53,7 +53,7 @@ /* * MCU type as defined in the ST header. */ -#define STM32F40_41xxx +#define STM32F407xx /* * IO pins assignments. diff --git a/os/hal/boards/OLIMEX_STM32_H407/board.h b/os/hal/boards/OLIMEX_STM32_H407/board.h index dac44dc76..e2c022694 100644 --- a/os/hal/boards/OLIMEX_STM32_H407/board.h +++ b/os/hal/boards/OLIMEX_STM32_H407/board.h @@ -53,7 +53,7 @@ /* * MCU type as defined in the ST header. */ -#define STM32F40_41xxx +#define STM32F407xx /* * IO pins assignments. diff --git a/os/hal/boards/OLIMEX_STM32_P407/board.h b/os/hal/boards/OLIMEX_STM32_P407/board.h index d15ae2ef5..75ae02569 100644 --- a/os/hal/boards/OLIMEX_STM32_P407/board.h +++ b/os/hal/boards/OLIMEX_STM32_P407/board.h @@ -51,7 +51,7 @@ /* * MCU type as defined in the ST header. */ -#define STM32F40_41xxx +#define STM32F407xx /* * IO pins assignments. diff --git a/os/hal/boards/ST_NUCLEO_F401RE/board.h b/os/hal/boards/ST_NUCLEO_F401RE/board.h index 829995c42..9d41a25b7 100644 --- a/os/hal/boards/ST_NUCLEO_F401RE/board.h +++ b/os/hal/boards/ST_NUCLEO_F401RE/board.h @@ -50,7 +50,7 @@ /* * MCU type as defined in the ST header. */ -#define STM32F401xx +#define STM32F401xE /* * IO pins assignments. diff --git a/os/hal/boards/ST_STM32F429I_DISCOVERY/board.h b/os/hal/boards/ST_STM32F429I_DISCOVERY/board.h index ecea64321..ef0aab7a7 100644 --- a/os/hal/boards/ST_STM32F429I_DISCOVERY/board.h +++ b/os/hal/boards/ST_STM32F429I_DISCOVERY/board.h @@ -49,7 +49,7 @@ /* * MCU type as defined in the ST header. */ -#define STM32F429_439xx +#define STM32F429xx /* * IO pins assignments. diff --git a/os/hal/boards/ST_STM32F4_DISCOVERY/board.h b/os/hal/boards/ST_STM32F4_DISCOVERY/board.h index eedacce87..68162194f 100644 --- a/os/hal/boards/ST_STM32F4_DISCOVERY/board.h +++ b/os/hal/boards/ST_STM32F4_DISCOVERY/board.h @@ -49,7 +49,7 @@ /* * MCU type as defined in the ST header. */ -#define STM32F40_41xxx +#define STM32F407xx /* * IO pins assignments. diff --git a/os/hal/ports/STM32/STM32F4xx/hal_lld.h b/os/hal/ports/STM32/STM32F4xx/hal_lld.h index b4ac037e1..58f4fc35b 100644 --- a/os/hal/ports/STM32/STM32F4xx/hal_lld.h +++ b/os/hal/ports/STM32/STM32F4xx/hal_lld.h @@ -26,11 +26,12 @@ * - STM32_VDD (as hundredths of Volt). * . * One of the following macros must also be defined: - * - STM32F2XX for High-performance STM32 F-2 devices. - * - STM32F401xx for High-performance STM32 F-4 devices. - * - STM32F40_41xxx for High-performance STM32 F-4 devices. - * - STM32F427_437xx for High-performance STM32 F-4 devices. - * - STM32F429_439xx for High-performance STM32 F-4 devices. + * - STM32F405xx, STM32F415xx, STM32F407xx, STM32F417xx for + * High-performance STM32 F-2 devices. + * - STM32F427xx, STM32F437xx, STM32F429xx, STM32F439xx for + * High-performance STM32 F-4 devices. + * - STM32F401xC, STM32F401xE for High-performance STM32 F-4 devices. + * - STM32F411xE for High-performance STM32 F-4 devices. * . * * @addtogroup HAL @@ -40,8 +41,6 @@ #ifndef _HAL_LLD_H_ #define _HAL_LLD_H_ -#include "stm32_registry.h" - /*===========================================================================*/ /* Driver constants. */ /*===========================================================================*/ @@ -55,17 +54,49 @@ * @name Platform identification macros * @{ */ -#if defined(STM32F429_439xx) || defined(__DOXYGEN__) -#define PLATFORM_NAME "STM32F429/F439 High Performance with DSP and FPU" +#if defined(STM32F439xx) || defined(__DOXYGEN__) +#define PLATFORM_NAME "STM32F439 High Performance with DSP and FPU" +#define STM32F429_439xx -#elif defined(STM32F427_437xx) -#define PLATFORM_NAME "STM32F427/F437 High Performance with DSP and FPU" +#elif defined(STM32F429xx) +#define PLATFORM_NAME "STM32F429 High Performance with DSP and FPU" +#define STM32F429_439xx -#elif defined(STM32F40_41xxx) -#define PLATFORM_NAME "STM32F407/F417 High Performance with DSP and FPU" +#elif defined(STM32F437xx) +#define PLATFORM_NAME "STM32F437 High Performance with DSP and FPU" +#define STM32F427_437xx -#elif defined(STM32F401xx) -#define PLATFORM_NAME "STM32F401 High Performance with DSP and FPU" +#elif defined(STM32F427xx) +#define PLATFORM_NAME "STM32F427 High Performance with DSP and FPU" +#define STM32F427_437xx + +#elif defined(STM32F405xx) +#define PLATFORM_NAME "STM32F405 High Performance with DSP and FPU" +#define STM32F40_41xxx + +#elif defined(STM32F415xx) +#define PLATFORM_NAME "STM32F415 High Performance with DSP and FPU" +#define STM32F40_41xxx + +#elif defined(STM32F407xx) +#define PLATFORM_NAME "STM32F407 High Performance with DSP and FPU" +#define STM32F40_41xxx + +#elif defined(STM32F417xx) +#define PLATFORM_NAME "STM32F417 High Performance with DSP and FPU" +#define STM32F40_41xxx + +#elif defined(STM32F401xC) +#define PLATFORM_NAME "STM32F401xC High Performance with DSP and FPU" +#define STM32F401xx + +#elif defined(STM32F401xE) +#define PLATFORM_NAME "STM32F401xE High Performance with DSP and FPU" +#define STM32F401xx + +#elif defined(STM32F411xE) +#define PLATFORM_NAME "STM32F411xE High Performance with DSP and FPU" +#define STM32F411xx #elif defined(STM32F2XX) #define PLATFORM_NAME "STM32F2xx High Performance" @@ -90,7 +121,8 @@ * @name Absolute Maximum Ratings * @{ */ -#if defined(STM32F427_437xx) || defined(STM32F429_439xx) || \ +#if defined(STM32F427xx) || defined(STM32F437xx) || \ + defined(STM32F429xx) || defined(STM32F439xx) || \ defined(__DOXYGEN__) /** * @brief Absolute maximum system clock. @@ -176,7 +208,7 @@ * @brief Maximum SPI/I2S clock frequency. */ #define STM32_SPII2S_MAX 45000000 -#endif /* STM32F40_41xxx */ +#endif #if defined(STM32F40_41xxx) || defined(__DOXYGEN__) #define STM32_SYSCLK_MAX 168000000 @@ -196,7 +228,7 @@ #define STM32_PCLK1_MAX 42000000 #define STM32_PCLK2_MAX 84000000 #define STM32_SPII2S_MAX 42000000 -#endif /* STM32F40_41xxx */ +#endif #if defined(STM32F401xx) || defined(__DOXYGEN__) #define STM32_SYSCLK_MAX 84000000 @@ -216,7 +248,11 @@ #define STM32_PCLK1_MAX 42000000 #define STM32_PCLK2_MAX 84000000 #define STM32_SPII2S_MAX 42000000 -#endif /* STM32F40_41xxx */ +#endif + +#if defined(STM32F411xx) +#error "missing Absolute Maximum Ratings for STM32F411xx" +#endif #if defined(STM32F2XX) #define STM32_SYSCLK_MAX 120000000 @@ -236,7 +272,7 @@ #define STM32_PCLK1_MAX 30000000 #define STM32_PCLK2_MAX 60000000 #define STM32_SPII2S_MAX 30000000 -#endif /* defined(STM32F2XX) */ +#endif /** @} */ /** @@ -764,6 +800,9 @@ #error "invalid VDD voltage specified" #endif +#elif defined(STM32F411xx) +#error "missing WS settings for STM32F411xx" + #else /* STM32F2XX */ #if (STM32_VDD >= 270) && (STM32_VDD <= 360) #define STM32_0WS_THRESHOLD 30000000 @@ -1378,6 +1417,7 @@ /* Various helpers.*/ #include "nvic.h" +#include "stm32_registry.h" #include "stm32_isr.h" #include "stm32_dma.h" #include "stm32_rcc.h" diff --git a/os/hal/ports/STM32/STM32F4xx/stm32_rcc.h b/os/hal/ports/STM32/STM32F4xx/stm32_rcc.h index fa9fe14bd..431b9ce24 100644 --- a/os/hal/ports/STM32/STM32F4xx/stm32_rcc.h +++ b/os/hal/ports/STM32/STM32F4xx/stm32_rcc.h @@ -663,7 +663,7 @@ * * @api */ -#define rccResetOTG_HS() rccResetAHB1(RCC_AHB1RSTR_OTGHSRST) +#define rccResetOTG_HS() rccResetAHB1(RCC_AHB1RSTR_OTGHRST) /** * @brief Enables the OTG_HS peripheral clock. -- cgit v1.2.3