diff options
Diffstat (limited to 'stm/lib')
36 files changed, 5860 insertions, 382 deletions
| diff --git a/stm/lib/stm32f4xx.h b/stm/lib/stm32f4xx.h index 082a18e72..eca261691 100644 --- a/stm/lib/stm32f4xx.h +++ b/stm/lib/stm32f4xx.h @@ -2,8 +2,8 @@    ******************************************************************************
    * @file    stm32f4xx.h
    * @author  MCD Application Team
 -  * @version V1.1.0
 -  * @date    11-January-2013
 +  * @version V1.3.0
 +  * @date    08-November-2013
    * @brief   CMSIS Cortex-M4 Device Peripheral Access Layer Header File. 
    *          This file contains all the peripheral register's definitions, bits 
    *          definitions and memory mapping for STM32F4xx devices.            
 @@ -65,17 +65,39 @@     application 
    */
 -#if !defined (STM32F4XX) && !defined (STM32F40XX) && !defined (STM32F427X)
 -  /* #define STM32F40XX */   /*!< STM32F40xx/41xx Devices */
 -  /* #define STM32F427X */   /*!< STM32F427x/437x Devices*/
 +#if !defined (STM32F40_41xxx) && !defined (STM32F427_437xx) && !defined (STM32F429_439xx) && !defined (STM32F401xx)
 +  /* #define STM32F40_41xxx */   /*!< STM32F405RG, STM32F405VG, STM32F405ZG, STM32F415RG, STM32F415VG, STM32F415ZG,  
 +                                     STM32F407VG, STM32F407VE, STM32F407ZG, STM32F407ZE, STM32F407IG, STM32F407IE, 
 +                                     STM32F417VG, STM32F417VE, STM32F417ZG, STM32F417ZE, STM32F417IG and STM32F417IE Devices */
 +
 +  /* #define STM32F427_437xx */   /*!< STM32F427VG, STM32F427VI, STM32F427ZG, STM32F427ZI, STM32F427IG, STM32F427II,  
 +                                       STM32F437VG, STM32F437VI, STM32F437ZG, STM32F437ZI, STM32F437IG, STM32F437II Devices */
 +                                    
 +  /* #define STM32F429_439xx */   /*!< STM32F429VG, STM32F429VI, STM32F429ZG, STM32F429ZI, STM32F429BG, STM32F429BI,  
 +                                       STM32F429NG, STM32F439NI, STM32F429IG, STM32F429II, STM32F439VG, STM32F439VI, 
 +                                       STM32F439ZG, STM32F439ZI, STM32F439BG, STM32F439BI, STM32F439NG, STM32F439NI,
 +                                       STM32F439IG and STM32F439II Devices */
 +                                    
 +  /* #define STM32F401xx */     /*!< STM32F401CB, STM32F401CC,  STM32F401RB, STM32F401RC, STM32F401VB, STM32F401VC  
 +                                     STM32F401CD, STM32F401RD, STM32F401VD, STM32F401CExx, STM32F401RE, STM32F401VE Devices */  
 +  
  #endif
 +/* Old STM32F40XX definition, maintained for legacy purpose */
 +#ifdef STM32F40XX
 +  #define STM32F40_41xxx
 +#endif /* STM32F40XX */
 +
 +/* Old STM32F427X definition, maintained for legacy purpose */
 +#ifdef STM32F427X
 +  #define STM32F427_437xx
 +#endif /* STM32F427X */
  /*  Tip: To avoid modifying this file each time you need to switch between these
          devices, you can define the device in your toolchain compiler preprocessor.
    */
 -#if !defined (STM32F4XX) && !defined (STM32F40XX) && !defined (STM32F427X)
 +#if !defined (STM32F40_41xxx) && !defined (STM32F427_437xx) && !defined (STM32F429_439xx) && !defined (STM32F401xx)
   #error "Please select first the target STM32F4xx device used in your application (in stm32f4xx.h file)"
  #endif
 @@ -98,6 +120,7 @@  #if !defined  (HSE_VALUE) 
    #define HSE_VALUE    ((uint32_t)25000000) /*!< Value of the External oscillator in Hz */
 +  
  #endif /* HSE_VALUE */
  /**
 @@ -105,7 +128,7 @@     Timeout value 
     */
  #if !defined  (HSE_STARTUP_TIMEOUT) 
 -  #define HSE_STARTUP_TIMEOUT    ((uint16_t)0x0500)   /*!< Time out for HSE start up */
 +  #define HSE_STARTUP_TIMEOUT    ((uint16_t)0x05000)   /*!< Time out for HSE start up */
  #endif /* HSE_STARTUP_TIMEOUT */   
  #if !defined  (HSI_VALUE)   
 @@ -113,10 +136,10 @@  #endif /* HSI_VALUE */   
  /**
 - * @brief STM32F4XX Standard Peripherals Library version number V1.1.0
 + * @brief STM32F4XX Standard Peripherals Library version number V1.3.0
     */
  #define __STM32F4XX_STDPERIPH_VERSION_MAIN   (0x01) /*!< [31:24] main version */                                  
 -#define __STM32F4XX_STDPERIPH_VERSION_SUB1   (0x01) /*!< [23:16] sub1 version */
 +#define __STM32F4XX_STDPERIPH_VERSION_SUB1   (0x03) /*!< [23:16] sub1 version */
  #define __STM32F4XX_STDPERIPH_VERSION_SUB2   (0x00) /*!< [15:8]  sub2 version */
  #define __STM32F4XX_STDPERIPH_VERSION_RC     (0x00) /*!< [7:0]  release candidate */ 
  #define __STM32F4XX_STDPERIPH_VERSION        ((__STM32F4XX_STDPERIPH_VERSION_MAIN << 24)\
 @@ -176,6 +199,8 @@ typedef enum IRQn    DMA1_Stream5_IRQn           = 16,     /*!< DMA1 Stream 5 global Interrupt                                    */
    DMA1_Stream6_IRQn           = 17,     /*!< DMA1 Stream 6 global Interrupt                                    */
    ADC_IRQn                    = 18,     /*!< ADC1, ADC2 and ADC3 global Interrupts                             */
 +
 +#if defined (STM32F40_41xxx)
    CAN1_TX_IRQn                = 19,     /*!< CAN1 TX Interrupt                                                 */
    CAN1_RX0_IRQn               = 20,     /*!< CAN1 RX0 Interrupt                                                */
    CAN1_RX1_IRQn               = 21,     /*!< CAN1 RX1 Interrupt                                                */
 @@ -238,20 +263,197 @@ typedef enum IRQn    DCMI_IRQn                   = 78,     /*!< DCMI global interrupt                                             */
    CRYP_IRQn                   = 79,     /*!< CRYP crypto global interrupt                                      */
    HASH_RNG_IRQn               = 80,     /*!< Hash and Rng global interrupt                                     */
 -
 -#ifdef STM32F40XX
    FPU_IRQn                    = 81      /*!< FPU global interrupt                                              */
 -#endif /* STM32F40XX */
 +#endif /* STM32F40_41xxx */
 -#ifdef STM32F427X 
 +#if defined (STM32F427_437xx)
 +  CAN1_TX_IRQn                = 19,     /*!< CAN1 TX Interrupt                                                 */
 +  CAN1_RX0_IRQn               = 20,     /*!< CAN1 RX0 Interrupt                                                */
 +  CAN1_RX1_IRQn               = 21,     /*!< CAN1 RX1 Interrupt                                                */
 +  CAN1_SCE_IRQn               = 22,     /*!< CAN1 SCE Interrupt                                                */
 +  EXTI9_5_IRQn                = 23,     /*!< External Line[9:5] Interrupts                                     */
 +  TIM1_BRK_TIM9_IRQn          = 24,     /*!< TIM1 Break interrupt and TIM9 global interrupt                    */
 +  TIM1_UP_TIM10_IRQn          = 25,     /*!< TIM1 Update Interrupt and TIM10 global interrupt                  */
 +  TIM1_TRG_COM_TIM11_IRQn     = 26,     /*!< TIM1 Trigger and Commutation Interrupt and TIM11 global interrupt */
 +  TIM1_CC_IRQn                = 27,     /*!< TIM1 Capture Compare Interrupt                                    */
 +  TIM2_IRQn                   = 28,     /*!< TIM2 global Interrupt                                             */
 +  TIM3_IRQn                   = 29,     /*!< TIM3 global Interrupt                                             */
 +  TIM4_IRQn                   = 30,     /*!< TIM4 global Interrupt                                             */
 +  I2C1_EV_IRQn                = 31,     /*!< I2C1 Event Interrupt                                              */
 +  I2C1_ER_IRQn                = 32,     /*!< I2C1 Error Interrupt                                              */
 +  I2C2_EV_IRQn                = 33,     /*!< I2C2 Event Interrupt                                              */
 +  I2C2_ER_IRQn                = 34,     /*!< I2C2 Error Interrupt                                              */  
 +  SPI1_IRQn                   = 35,     /*!< SPI1 global Interrupt                                             */
 +  SPI2_IRQn                   = 36,     /*!< SPI2 global Interrupt                                             */
 +  USART1_IRQn                 = 37,     /*!< USART1 global Interrupt                                           */
 +  USART2_IRQn                 = 38,     /*!< USART2 global Interrupt                                           */
 +  USART3_IRQn                 = 39,     /*!< USART3 global Interrupt                                           */
 +  EXTI15_10_IRQn              = 40,     /*!< External Line[15:10] Interrupts                                   */
 +  RTC_Alarm_IRQn              = 41,     /*!< RTC Alarm (A and B) through EXTI Line Interrupt                   */
 +  OTG_FS_WKUP_IRQn            = 42,     /*!< USB OTG FS Wakeup through EXTI line interrupt                     */    
 +  TIM8_BRK_TIM12_IRQn         = 43,     /*!< TIM8 Break Interrupt and TIM12 global interrupt                   */
 +  TIM8_UP_TIM13_IRQn          = 44,     /*!< TIM8 Update Interrupt and TIM13 global interrupt                  */
 +  TIM8_TRG_COM_TIM14_IRQn     = 45,     /*!< TIM8 Trigger and Commutation Interrupt and TIM14 global interrupt */
 +  TIM8_CC_IRQn                = 46,     /*!< TIM8 Capture Compare Interrupt                                    */
 +  DMA1_Stream7_IRQn           = 47,     /*!< DMA1 Stream7 Interrupt                                            */
 +  FMC_IRQn                    = 48,     /*!< FMC global Interrupt                                              */
 +  SDIO_IRQn                   = 49,     /*!< SDIO global Interrupt                                             */
 +  TIM5_IRQn                   = 50,     /*!< TIM5 global Interrupt                                             */
 +  SPI3_IRQn                   = 51,     /*!< SPI3 global Interrupt                                             */
 +  UART4_IRQn                  = 52,     /*!< UART4 global Interrupt                                            */
 +  UART5_IRQn                  = 53,     /*!< UART5 global Interrupt                                            */
 +  TIM6_DAC_IRQn               = 54,     /*!< TIM6 global and DAC1&2 underrun error  interrupts                 */
 +  TIM7_IRQn                   = 55,     /*!< TIM7 global interrupt                                             */
 +  DMA2_Stream0_IRQn           = 56,     /*!< DMA2 Stream 0 global Interrupt                                    */
 +  DMA2_Stream1_IRQn           = 57,     /*!< DMA2 Stream 1 global Interrupt                                    */
 +  DMA2_Stream2_IRQn           = 58,     /*!< DMA2 Stream 2 global Interrupt                                    */
 +  DMA2_Stream3_IRQn           = 59,     /*!< DMA2 Stream 3 global Interrupt                                    */
 +  DMA2_Stream4_IRQn           = 60,     /*!< DMA2 Stream 4 global Interrupt                                    */
 +  ETH_IRQn                    = 61,     /*!< Ethernet global Interrupt                                         */
 +  ETH_WKUP_IRQn               = 62,     /*!< Ethernet Wakeup through EXTI line Interrupt                       */
 +  CAN2_TX_IRQn                = 63,     /*!< CAN2 TX Interrupt                                                 */
 +  CAN2_RX0_IRQn               = 64,     /*!< CAN2 RX0 Interrupt                                                */
 +  CAN2_RX1_IRQn               = 65,     /*!< CAN2 RX1 Interrupt                                                */
 +  CAN2_SCE_IRQn               = 66,     /*!< CAN2 SCE Interrupt                                                */
 +  OTG_FS_IRQn                 = 67,     /*!< USB OTG FS global Interrupt                                       */
 +  DMA2_Stream5_IRQn           = 68,     /*!< DMA2 Stream 5 global interrupt                                    */
 +  DMA2_Stream6_IRQn           = 69,     /*!< DMA2 Stream 6 global interrupt                                    */
 +  DMA2_Stream7_IRQn           = 70,     /*!< DMA2 Stream 7 global interrupt                                    */
 +  USART6_IRQn                 = 71,     /*!< USART6 global interrupt                                           */
 +  I2C3_EV_IRQn                = 72,     /*!< I2C3 event interrupt                                              */
 +  I2C3_ER_IRQn                = 73,     /*!< I2C3 error interrupt                                              */
 +  OTG_HS_EP1_OUT_IRQn         = 74,     /*!< USB OTG HS End Point 1 Out global interrupt                       */
 +  OTG_HS_EP1_IN_IRQn          = 75,     /*!< USB OTG HS End Point 1 In global interrupt                        */
 +  OTG_HS_WKUP_IRQn            = 76,     /*!< USB OTG HS Wakeup through EXTI interrupt                          */
 +  OTG_HS_IRQn                 = 77,     /*!< USB OTG HS global interrupt                                       */
 +  DCMI_IRQn                   = 78,     /*!< DCMI global interrupt                                             */
 +  CRYP_IRQn                   = 79,     /*!< CRYP crypto global interrupt                                      */
 +  HASH_RNG_IRQn               = 80,     /*!< Hash and Rng global interrupt                                     */
    FPU_IRQn                    = 81,     /*!< FPU global interrupt                                              */
    UART7_IRQn                  = 82,     /*!< UART7 global interrupt                                            */
    UART8_IRQn                  = 83,     /*!< UART8 global interrupt                                            */
    SPI4_IRQn                   = 84,     /*!< SPI4 global Interrupt                                             */
    SPI5_IRQn                   = 85,     /*!< SPI5 global Interrupt                                             */
 -  SPI6_IRQn                   = 86      /*!< SPI6 global Interrupt                                             */
 -#endif /* STM32F427X */
 - 
 +  SPI6_IRQn                   = 86,     /*!< SPI6 global Interrupt                                             */
 +  SAI1_IRQn                   = 87,     /*!< SAI1 global Interrupt                                             */
 +  DMA2D_IRQn                  = 90      /*!< DMA2D global Interrupt                                            */   
 +#endif /* STM32F427_437xx */
 +    
 +#if defined (STM32F429_439xx)
 +  CAN1_TX_IRQn                = 19,     /*!< CAN1 TX Interrupt                                                 */
 +  CAN1_RX0_IRQn               = 20,     /*!< CAN1 RX0 Interrupt                                                */
 +  CAN1_RX1_IRQn               = 21,     /*!< CAN1 RX1 Interrupt                                                */
 +  CAN1_SCE_IRQn               = 22,     /*!< CAN1 SCE Interrupt                                                */
 +  EXTI9_5_IRQn                = 23,     /*!< External Line[9:5] Interrupts                                     */
 +  TIM1_BRK_TIM9_IRQn          = 24,     /*!< TIM1 Break interrupt and TIM9 global interrupt                    */
 +  TIM1_UP_TIM10_IRQn          = 25,     /*!< TIM1 Update Interrupt and TIM10 global interrupt                  */
 +  TIM1_TRG_COM_TIM11_IRQn     = 26,     /*!< TIM1 Trigger and Commutation Interrupt and TIM11 global interrupt */
 +  TIM1_CC_IRQn                = 27,     /*!< TIM1 Capture Compare Interrupt                                    */
 +  TIM2_IRQn                   = 28,     /*!< TIM2 global Interrupt                                             */
 +  TIM3_IRQn                   = 29,     /*!< TIM3 global Interrupt                                             */
 +  TIM4_IRQn                   = 30,     /*!< TIM4 global Interrupt                                             */
 +  I2C1_EV_IRQn                = 31,     /*!< I2C1 Event Interrupt                                              */
 +  I2C1_ER_IRQn                = 32,     /*!< I2C1 Error Interrupt                                              */
 +  I2C2_EV_IRQn                = 33,     /*!< I2C2 Event Interrupt                                              */
 +  I2C2_ER_IRQn                = 34,     /*!< I2C2 Error Interrupt                                              */  
 +  SPI1_IRQn                   = 35,     /*!< SPI1 global Interrupt                                             */
 +  SPI2_IRQn                   = 36,     /*!< SPI2 global Interrupt                                             */
 +  USART1_IRQn                 = 37,     /*!< USART1 global Interrupt                                           */
 +  USART2_IRQn                 = 38,     /*!< USART2 global Interrupt                                           */
 +  USART3_IRQn                 = 39,     /*!< USART3 global Interrupt                                           */
 +  EXTI15_10_IRQn              = 40,     /*!< External Line[15:10] Interrupts                                   */
 +  RTC_Alarm_IRQn              = 41,     /*!< RTC Alarm (A and B) through EXTI Line Interrupt                   */
 +  OTG_FS_WKUP_IRQn            = 42,     /*!< USB OTG FS Wakeup through EXTI line interrupt                     */    
 +  TIM8_BRK_TIM12_IRQn         = 43,     /*!< TIM8 Break Interrupt and TIM12 global interrupt                   */
 +  TIM8_UP_TIM13_IRQn          = 44,     /*!< TIM8 Update Interrupt and TIM13 global interrupt                  */
 +  TIM8_TRG_COM_TIM14_IRQn     = 45,     /*!< TIM8 Trigger and Commutation Interrupt and TIM14 global interrupt */
 +  TIM8_CC_IRQn                = 46,     /*!< TIM8 Capture Compare Interrupt                                    */
 +  DMA1_Stream7_IRQn           = 47,     /*!< DMA1 Stream7 Interrupt                                            */
 +  FMC_IRQn                    = 48,     /*!< FMC global Interrupt                                              */
 +  SDIO_IRQn                   = 49,     /*!< SDIO global Interrupt                                             */
 +  TIM5_IRQn                   = 50,     /*!< TIM5 global Interrupt                                             */
 +  SPI3_IRQn                   = 51,     /*!< SPI3 global Interrupt                                             */
 +  UART4_IRQn                  = 52,     /*!< UART4 global Interrupt                                            */
 +  UART5_IRQn                  = 53,     /*!< UART5 global Interrupt                                            */
 +  TIM6_DAC_IRQn               = 54,     /*!< TIM6 global and DAC1&2 underrun error  interrupts                 */
 +  TIM7_IRQn                   = 55,     /*!< TIM7 global interrupt                                             */
 +  DMA2_Stream0_IRQn           = 56,     /*!< DMA2 Stream 0 global Interrupt                                    */
 +  DMA2_Stream1_IRQn           = 57,     /*!< DMA2 Stream 1 global Interrupt                                    */
 +  DMA2_Stream2_IRQn           = 58,     /*!< DMA2 Stream 2 global Interrupt                                    */
 +  DMA2_Stream3_IRQn           = 59,     /*!< DMA2 Stream 3 global Interrupt                                    */
 +  DMA2_Stream4_IRQn           = 60,     /*!< DMA2 Stream 4 global Interrupt                                    */
 +  ETH_IRQn                    = 61,     /*!< Ethernet global Interrupt                                         */
 +  ETH_WKUP_IRQn               = 62,     /*!< Ethernet Wakeup through EXTI line Interrupt                       */
 +  CAN2_TX_IRQn                = 63,     /*!< CAN2 TX Interrupt                                                 */
 +  CAN2_RX0_IRQn               = 64,     /*!< CAN2 RX0 Interrupt                                                */
 +  CAN2_RX1_IRQn               = 65,     /*!< CAN2 RX1 Interrupt                                                */
 +  CAN2_SCE_IRQn               = 66,     /*!< CAN2 SCE Interrupt                                                */
 +  OTG_FS_IRQn                 = 67,     /*!< USB OTG FS global Interrupt                                       */
 +  DMA2_Stream5_IRQn           = 68,     /*!< DMA2 Stream 5 global interrupt                                    */
 +  DMA2_Stream6_IRQn           = 69,     /*!< DMA2 Stream 6 global interrupt                                    */
 +  DMA2_Stream7_IRQn           = 70,     /*!< DMA2 Stream 7 global interrupt                                    */
 +  USART6_IRQn                 = 71,     /*!< USART6 global interrupt                                           */
 +  I2C3_EV_IRQn                = 72,     /*!< I2C3 event interrupt                                              */
 +  I2C3_ER_IRQn                = 73,     /*!< I2C3 error interrupt                                              */
 +  OTG_HS_EP1_OUT_IRQn         = 74,     /*!< USB OTG HS End Point 1 Out global interrupt                       */
 +  OTG_HS_EP1_IN_IRQn          = 75,     /*!< USB OTG HS End Point 1 In global interrupt                        */
 +  OTG_HS_WKUP_IRQn            = 76,     /*!< USB OTG HS Wakeup through EXTI interrupt                          */
 +  OTG_HS_IRQn                 = 77,     /*!< USB OTG HS global interrupt                                       */
 +  DCMI_IRQn                   = 78,     /*!< DCMI global interrupt                                             */
 +  CRYP_IRQn                   = 79,     /*!< CRYP crypto global interrupt                                      */
 +  HASH_RNG_IRQn               = 80,     /*!< Hash and Rng global interrupt                                     */
 +  FPU_IRQn                    = 81,     /*!< FPU global interrupt                                              */
 +  UART7_IRQn                  = 82,     /*!< UART7 global interrupt                                            */
 +  UART8_IRQn                  = 83,     /*!< UART8 global interrupt                                            */
 +  SPI4_IRQn                   = 84,     /*!< SPI4 global Interrupt                                             */
 +  SPI5_IRQn                   = 85,     /*!< SPI5 global Interrupt                                             */
 +  SPI6_IRQn                   = 86,     /*!< SPI6 global Interrupt                                             */
 +  SAI1_IRQn                   = 87,     /*!< SAI1 global Interrupt                                             */
 +  LTDC_IRQn                   = 88,     /*!< LTDC global Interrupt                                             */
 +  LTDC_ER_IRQn                = 89,     /*!< LTDC Error global Interrupt                                       */
 +  DMA2D_IRQn                  = 90      /*!< DMA2D global Interrupt                                            */   
 +#endif /* STM32F429_439xx */
 +   
 +#if defined (STM32F401xx)
 +  EXTI9_5_IRQn                = 23,     /*!< External Line[9:5] Interrupts                                     */
 +  TIM1_BRK_TIM9_IRQn          = 24,     /*!< TIM1 Break interrupt and TIM9 global interrupt                    */
 +  TIM1_UP_TIM10_IRQn          = 25,     /*!< TIM1 Update Interrupt and TIM10 global interrupt                  */
 +  TIM1_TRG_COM_TIM11_IRQn     = 26,     /*!< TIM1 Trigger and Commutation Interrupt and TIM11 global interrupt */
 +  TIM1_CC_IRQn                = 27,     /*!< TIM1 Capture Compare Interrupt                                    */
 +  TIM2_IRQn                   = 28,     /*!< TIM2 global Interrupt                                             */
 +  TIM3_IRQn                   = 29,     /*!< TIM3 global Interrupt                                             */
 +  TIM4_IRQn                   = 30,     /*!< TIM4 global Interrupt                                             */
 +  I2C1_EV_IRQn                = 31,     /*!< I2C1 Event Interrupt                                              */
 +  I2C1_ER_IRQn                = 32,     /*!< I2C1 Error Interrupt                                              */
 +  I2C2_EV_IRQn                = 33,     /*!< I2C2 Event Interrupt                                              */
 +  I2C2_ER_IRQn                = 34,     /*!< I2C2 Error Interrupt                                              */  
 +  SPI1_IRQn                   = 35,     /*!< SPI1 global Interrupt                                             */
 +  SPI2_IRQn                   = 36,     /*!< SPI2 global Interrupt                                             */
 +  USART1_IRQn                 = 37,     /*!< USART1 global Interrupt                                           */
 +  USART2_IRQn                 = 38,     /*!< USART2 global Interrupt                                           */
 +  EXTI15_10_IRQn              = 40,     /*!< External Line[15:10] Interrupts                                   */
 +  RTC_Alarm_IRQn              = 41,     /*!< RTC Alarm (A and B) through EXTI Line Interrupt                   */
 +  OTG_FS_WKUP_IRQn            = 42,     /*!< USB OTG FS Wakeup through EXTI line interrupt                     */  
 +  DMA1_Stream7_IRQn           = 47,     /*!< DMA1 Stream7 Interrupt                                            */
 +  SDIO_IRQn                   = 49,     /*!< SDIO global Interrupt                                             */
 +  TIM5_IRQn                   = 50,     /*!< TIM5 global Interrupt                                             */
 +  SPI3_IRQn                   = 51,     /*!< SPI3 global Interrupt                                             */
 +  DMA2_Stream0_IRQn           = 56,     /*!< DMA2 Stream 0 global Interrupt                                    */
 +  DMA2_Stream1_IRQn           = 57,     /*!< DMA2 Stream 1 global Interrupt                                    */
 +  DMA2_Stream2_IRQn           = 58,     /*!< DMA2 Stream 2 global Interrupt                                    */
 +  DMA2_Stream3_IRQn           = 59,     /*!< DMA2 Stream 3 global Interrupt                                    */
 +  DMA2_Stream4_IRQn           = 60,     /*!< DMA2 Stream 4 global Interrupt                                    */
 +  OTG_FS_IRQn                 = 67,     /*!< USB OTG FS global Interrupt                                       */
 +  DMA2_Stream5_IRQn           = 68,     /*!< DMA2 Stream 5 global interrupt                                    */
 +  DMA2_Stream6_IRQn           = 69,     /*!< DMA2 Stream 6 global interrupt                                    */
 +  DMA2_Stream7_IRQn           = 70,     /*!< DMA2 Stream 7 global interrupt                                    */
 +  USART6_IRQn                 = 71,     /*!< USART6 global interrupt                                           */
 +  I2C3_EV_IRQn                = 72,     /*!< I2C3 event interrupt                                              */
 +  I2C3_ER_IRQn                = 73,     /*!< I2C3 error interrupt                                              */
 +  FPU_IRQn                    = 81,      /*!< FPU global interrupt                                             */
 +  SPI4_IRQn                   = 84       /*!< SPI4 global Interrupt                                            */
 +#endif /* STM32F401xx */
 +
  } IRQn_Type;
  /**
 @@ -501,6 +703,37 @@ typedef struct    __IO uint32_t LIFCR;  /*!< DMA low interrupt flag clear register,  Address offset: 0x08 */
    __IO uint32_t HIFCR;  /*!< DMA high interrupt flag clear register, Address offset: 0x0C */
  } DMA_TypeDef;
 + 
 +/** 
 +  * @brief DMA2D Controller
 +  */
 +
 +typedef struct
 +{
 +  __IO uint32_t CR;            /*!< DMA2D Control Register,                         Address offset: 0x00 */
 +  __IO uint32_t ISR;           /*!< DMA2D Interrupt Status Register,                Address offset: 0x04 */
 +  __IO uint32_t IFCR;          /*!< DMA2D Interrupt Flag Clear Register,            Address offset: 0x08 */
 +  __IO uint32_t FGMAR;         /*!< DMA2D Foreground Memory Address Register,       Address offset: 0x0C */
 +  __IO uint32_t FGOR;          /*!< DMA2D Foreground Offset Register,               Address offset: 0x10 */
 +  __IO uint32_t BGMAR;         /*!< DMA2D Background Memory Address Register,       Address offset: 0x14 */
 +  __IO uint32_t BGOR;          /*!< DMA2D Background Offset Register,               Address offset: 0x18 */
 +  __IO uint32_t FGPFCCR;       /*!< DMA2D Foreground PFC Control Register,          Address offset: 0x1C */
 +  __IO uint32_t FGCOLR;        /*!< DMA2D Foreground Color Register,                Address offset: 0x20 */
 +  __IO uint32_t BGPFCCR;       /*!< DMA2D Background PFC Control Register,          Address offset: 0x24 */
 +  __IO uint32_t BGCOLR;        /*!< DMA2D Background Color Register,                Address offset: 0x28 */
 +  __IO uint32_t FGCMAR;        /*!< DMA2D Foreground CLUT Memory Address Register,  Address offset: 0x2C */
 +  __IO uint32_t BGCMAR;        /*!< DMA2D Background CLUT Memory Address Register,  Address offset: 0x30 */
 +  __IO uint32_t OPFCCR;        /*!< DMA2D Output PFC Control Register,              Address offset: 0x34 */
 +  __IO uint32_t OCOLR;         /*!< DMA2D Output Color Register,                    Address offset: 0x38 */
 +  __IO uint32_t OMAR;          /*!< DMA2D Output Memory Address Register,           Address offset: 0x3C */
 +  __IO uint32_t OOR;           /*!< DMA2D Output Offset Register,                   Address offset: 0x40 */
 +  __IO uint32_t NLR;           /*!< DMA2D Number of Line Register,                  Address offset: 0x44 */
 +  __IO uint32_t LWR;           /*!< DMA2D Line Watermark Register,                  Address offset: 0x48 */
 +  __IO uint32_t AMTCR;         /*!< DMA2D AHB Master Timer Configuration Register,  Address offset: 0x4C */
 +  uint32_t      RESERVED[236]; /*!< Reserved, 0x50-0x3FF */
 +  __IO uint32_t FGCLUT[256];   /*!< DMA2D Foreground CLUT,                          Address offset:400-7FF */
 +  __IO uint32_t BGCLUT[256];   /*!< DMA2D Background CLUT,                          Address offset:800-BFF */
 +} DMA2D_TypeDef;
  /** 
    * @brief Ethernet MAC
 @@ -605,6 +838,7 @@ typedef struct    __IO uint32_t OPTCR1;   /*!< FLASH option control register 1, Address offset: 0x18 */
  } FLASH_TypeDef;
 +#if defined (STM32F40_41xxx)
  /** 
    * @brief Flexible Static Memory Controller
    */
 @@ -663,6 +897,81 @@ typedef struct    __IO uint32_t PATT4;      /*!< PC Card  Attribute memory space timing register 4, Address offset: 0xAC */
    __IO uint32_t PIO4;       /*!< PC Card  I/O space timing register 4,              Address offset: 0xB0 */
  } FSMC_Bank4_TypeDef; 
 +#endif /* STM32F40_41xxx */
 +
 +#if defined (STM32F427_437xx) || defined (STM32F429_439xx)
 +/** 
 +  * @brief Flexible Memory Controller
 +  */
 +
 +typedef struct
 +{
 +  __IO uint32_t BTCR[8];    /*!< NOR/PSRAM chip-select control register(BCR) and chip-select timing register(BTR), Address offset: 0x00-1C */   
 +} FMC_Bank1_TypeDef; 
 +
 +/** 
 +  * @brief Flexible Memory Controller Bank1E
 +  */
 +  
 +typedef struct
 +{
 +  __IO uint32_t BWTR[7];    /*!< NOR/PSRAM write timing registers, Address offset: 0x104-0x11C */
 +} FMC_Bank1E_TypeDef;
 +
 +/** 
 +  * @brief Flexible Memory Controller Bank2
 +  */
 +  
 +typedef struct
 +{
 +  __IO uint32_t PCR2;       /*!< NAND Flash control register 2,                       Address offset: 0x60 */
 +  __IO uint32_t SR2;        /*!< NAND Flash FIFO status and interrupt register 2,     Address offset: 0x64 */
 +  __IO uint32_t PMEM2;      /*!< NAND Flash Common memory space timing register 2,    Address offset: 0x68 */
 +  __IO uint32_t PATT2;      /*!< NAND Flash Attribute memory space timing register 2, Address offset: 0x6C */
 +  uint32_t      RESERVED0;  /*!< Reserved, 0x70                                                            */
 +  __IO uint32_t ECCR2;      /*!< NAND Flash ECC result registers 2,                   Address offset: 0x74 */
 +} FMC_Bank2_TypeDef;
 +
 +/** 
 +  * @brief Flexible Memory Controller Bank3
 +  */
 +  
 +typedef struct
 +{
 +  __IO uint32_t PCR3;       /*!< NAND Flash control register 3,                       Address offset: 0x80 */
 +  __IO uint32_t SR3;        /*!< NAND Flash FIFO status and interrupt register 3,     Address offset: 0x84 */
 +  __IO uint32_t PMEM3;      /*!< NAND Flash Common memory space timing register 3,    Address offset: 0x88 */
 +  __IO uint32_t PATT3;      /*!< NAND Flash Attribute memory space timing register 3, Address offset: 0x8C */
 +  uint32_t      RESERVED0;  /*!< Reserved, 0x90                                                            */
 +  __IO uint32_t ECCR3;      /*!< NAND Flash ECC result registers 3,                   Address offset: 0x94 */
 +} FMC_Bank3_TypeDef;
 +
 +/** 
 +  * @brief Flexible Memory Controller Bank4
 +  */
 +  
 +typedef struct
 +{
 +  __IO uint32_t PCR4;       /*!< PC Card  control register 4,                       Address offset: 0xA0 */
 +  __IO uint32_t SR4;        /*!< PC Card  FIFO status and interrupt register 4,     Address offset: 0xA4 */
 +  __IO uint32_t PMEM4;      /*!< PC Card  Common memory space timing register 4,    Address offset: 0xA8 */
 +  __IO uint32_t PATT4;      /*!< PC Card  Attribute memory space timing register 4, Address offset: 0xAC */
 +  __IO uint32_t PIO4;       /*!< PC Card  I/O space timing register 4,              Address offset: 0xB0 */
 +} FMC_Bank4_TypeDef; 
 +
 +/** 
 +  * @brief Flexible Memory Controller Bank5_6
 +  */
 +  
 +typedef struct
 +{
 +  __IO uint32_t SDCR[2];        /*!< SDRAM Control registers ,      Address offset: 0x140-0x144  */
 +  __IO uint32_t SDTR[2];        /*!< SDRAM Timing registers ,       Address offset: 0x148-0x14C  */
 +  __IO uint32_t SDCMR;       /*!< SDRAM Command Mode register,    Address offset: 0x150  */
 +  __IO uint32_t SDRTR;       /*!< SDRAM Refresh Timer register,   Address offset: 0x154  */
 +  __IO uint32_t SDSR;        /*!< SDRAM Status register,          Address offset: 0x158  */
 +} FMC_Bank5_6_TypeDef; 
 +#endif /* STM32F427_437xx ||  STM32F429_439xx */
  /** 
    * @brief General Purpose I/O
 @@ -736,6 +1045,54 @@ typedef struct  } IWDG_TypeDef;
  /** 
 +  * @brief LCD-TFT Display Controller
 +  */
 +  
 +typedef struct
 +{
 +  uint32_t      RESERVED0[2];  /*!< Reserved, 0x00-0x04 */
 +  __IO uint32_t SSCR;          /*!< LTDC Synchronization Size Configuration Register,    Address offset: 0x08 */
 +  __IO uint32_t BPCR;          /*!< LTDC Back Porch Configuration Register,              Address offset: 0x0C */
 +  __IO uint32_t AWCR;          /*!< LTDC Active Width Configuration Register,            Address offset: 0x10 */
 +  __IO uint32_t TWCR;          /*!< LTDC Total Width Configuration Register,             Address offset: 0x14 */
 +  __IO uint32_t GCR;           /*!< LTDC Global Control Register,                        Address offset: 0x18 */
 +  uint32_t      RESERVED1[2];  /*!< Reserved, 0x1C-0x20 */
 +  __IO uint32_t SRCR;          /*!< LTDC Shadow Reload Configuration Register,           Address offset: 0x24 */
 +  uint32_t      RESERVED2[1];  /*!< Reserved, 0x28 */
 +  __IO uint32_t BCCR;          /*!< LTDC Background Color Configuration Register,        Address offset: 0x2C */
 +  uint32_t      RESERVED3[1];  /*!< Reserved, 0x30 */
 +  __IO uint32_t IER;           /*!< LTDC Interrupt Enable Register,                      Address offset: 0x34 */
 +  __IO uint32_t ISR;           /*!< LTDC Interrupt Status Register,                      Address offset: 0x38 */
 +  __IO uint32_t ICR;           /*!< LTDC Interrupt Clear Register,                       Address offset: 0x3C */
 +  __IO uint32_t LIPCR;         /*!< LTDC Line Interrupt Position Configuration Register, Address offset: 0x40 */
 +  __IO uint32_t CPSR;          /*!< LTDC Current Position Status Register,               Address offset: 0x44 */
 +  __IO uint32_t CDSR;         /*!< LTDC Current Display Status Register,                       Address offset: 0x48 */
 +} LTDC_TypeDef;  
 +
 +/** 
 +  * @brief LCD-TFT Display layer x Controller
 +  */
 +  
 +typedef struct
 +{  
 +  __IO uint32_t CR;            /*!< LTDC Layerx Control Register                                  Address offset: 0x84 */
 +  __IO uint32_t WHPCR;         /*!< LTDC Layerx Window Horizontal Position Configuration Register Address offset: 0x88 */
 +  __IO uint32_t WVPCR;         /*!< LTDC Layerx Window Vertical Position Configuration Register   Address offset: 0x8C */
 +  __IO uint32_t CKCR;          /*!< LTDC Layerx Color Keying Configuration Register               Address offset: 0x90 */
 +  __IO uint32_t PFCR;          /*!< LTDC Layerx Pixel Format Configuration Register               Address offset: 0x94 */
 +  __IO uint32_t CACR;          /*!< LTDC Layerx Constant Alpha Configuration Register             Address offset: 0x98 */
 +  __IO uint32_t DCCR;          /*!< LTDC Layerx Default Color Configuration Register              Address offset: 0x9C */
 +  __IO uint32_t BFCR;          /*!< LTDC Layerx Blending Factors Configuration Register           Address offset: 0xA0 */
 +  uint32_t      RESERVED0[2];  /*!< Reserved */
 +  __IO uint32_t CFBAR;         /*!< LTDC Layerx Color Frame Buffer Address Register               Address offset: 0xAC */
 +  __IO uint32_t CFBLR;         /*!< LTDC Layerx Color Frame Buffer Length Register                Address offset: 0xB0 */
 +  __IO uint32_t CFBLNR;        /*!< LTDC Layerx ColorFrame Buffer Line Number Register            Address offset: 0xB4 */
 +  uint32_t      RESERVED1[3];  /*!< Reserved */
 +  __IO uint32_t CLUTWR;         /*!< LTDC Layerx CLUT Write Register                               Address offset: 0x144 */
 +
 +} LTDC_Layer_TypeDef;
 +
 +/** 
    * @brief Power Control
    */
 @@ -781,11 +1138,8 @@ typedef struct    uint32_t      RESERVED6[2];  /*!< Reserved, 0x78-0x7C                                                               */
    __IO uint32_t SSCGR;         /*!< RCC spread spectrum clock generation register,               Address offset: 0x80 */
    __IO uint32_t PLLI2SCFGR;    /*!< RCC PLLI2S configuration register,                           Address offset: 0x84 */
 -
 -#ifdef STM32F427X  
 -  uint32_t      RESERVED7;     /*!< Reserved, 0x88                                                                    */
 +  __IO uint32_t PLLSAICFGR;    /*!< RCC PLLSAI configuration register,                           Address offset: 0x88 */
    __IO uint32_t DCKCFGR;       /*!< RCC Dedicated Clocks configuration register,                 Address offset: 0x8C */
 -#endif /* STM32F427X */
  } RCC_TypeDef;
 @@ -837,6 +1191,28 @@ typedef struct    __IO uint32_t BKP19R;  /*!< RTC backup register 19,                                   Address offset: 0x9C */
  } RTC_TypeDef;
 +
 +/** 
 +  * @brief Serial Audio Interface
 +  */
 +  
 +typedef struct
 +{
 +  __IO uint32_t GCR;      /*!< SAI global configuration register,        Address offset: 0x00 */
 +} SAI_TypeDef;
 +
 +typedef struct
 +{
 +  __IO uint32_t CR1;      /*!< SAI block x configuration register 1,     Address offset: 0x04 */
 +  __IO uint32_t CR2;      /*!< SAI block x configuration register 2,     Address offset: 0x08 */
 +  __IO uint32_t FRCR;     /*!< SAI block x frame configuration register, Address offset: 0x0C */
 +  __IO uint32_t SLOTR;    /*!< SAI block x slot register,                Address offset: 0x10 */
 +  __IO uint32_t IMR;      /*!< SAI block x interrupt mask register,      Address offset: 0x14 */
 +  __IO uint32_t SR;       /*!< SAI block x status register,              Address offset: 0x18 */
 +  __IO uint32_t CLRFR;    /*!< SAI block x clear flag register,          Address offset: 0x1C */
 +  __IO uint32_t DR;       /*!< SAI block x data register,                Address offset: 0x20 */
 +} SAI_Block_TypeDef;
 +
  /** 
    * @brief SD host Interface
    */
 @@ -1062,12 +1438,19 @@ typedef struct  #define SRAM3_BASE            ((uint32_t)0x20020000) /*!< SRAM3(64 KB) base address in the alias region                              */
  #define PERIPH_BASE           ((uint32_t)0x40000000) /*!< Peripheral base address in the alias region                                */
  #define BKPSRAM_BASE          ((uint32_t)0x40024000) /*!< Backup SRAM(4 KB) base address in the alias region                         */
 +
 +#if defined (STM32F40_41xxx)
  #define FSMC_R_BASE           ((uint32_t)0xA0000000) /*!< FSMC registers base address                                                */
 +#endif /* STM32F40_41xxx */
 +
 +#if defined (STM32F427_437xx) || defined (STM32F429_439xx)
 +#define FMC_R_BASE            ((uint32_t)0xA0000000) /*!< FMC registers base address                                                 */
 +#endif /* STM32F427_437xx ||  STM32F429_439xx */
  #define CCMDATARAM_BB_BASE    ((uint32_t)0x12000000) /*!< CCM(core coupled memory) data RAM(64 KB) base address in the bit-band region  */
  #define SRAM1_BB_BASE         ((uint32_t)0x22000000) /*!< SRAM1(112 KB) base address in the bit-band region                             */
  #define SRAM2_BB_BASE         ((uint32_t)0x2201C000) /*!< SRAM2(16 KB) base address in the bit-band region                              */
 -#define SRAM3_BB_BASE         ((uint32_t)0x22020000) /*!< SRAM3(64 KB) base address in the bit-band region                              */
 +#define SRAM3_BB_BASE         ((uint32_t)0x22400000) /*!< SRAM3(64 KB) base address in the bit-band region                              */
  #define PERIPH_BB_BASE        ((uint32_t)0x42000000) /*!< Peripheral base address in the bit-band region                                */
  #define BKPSRAM_BB_BASE       ((uint32_t)0x42024000) /*!< Backup SRAM(4 KB) base address in the bit-band region                         */
 @@ -1075,6 +1458,7 @@ typedef struct  #define SRAM_BASE             SRAM1_BASE
  #define SRAM_BB_BASE          SRAM1_BB_BASE
 +
  /*!< Peripheral memory map */
  #define APB1PERIPH_BASE       PERIPH_BASE
  #define APB2PERIPH_BASE       (PERIPH_BASE + 0x00010000)
 @@ -1131,6 +1515,12 @@ typedef struct  #define TIM11_BASE            (APB2PERIPH_BASE + 0x4800)
  #define SPI5_BASE             (APB2PERIPH_BASE + 0x5000)
  #define SPI6_BASE             (APB2PERIPH_BASE + 0x5400)
 +#define SAI1_BASE             (APB2PERIPH_BASE + 0x5800)
 +#define SAI1_Block_A_BASE     (SAI1_BASE + 0x004)
 +#define SAI1_Block_B_BASE     (SAI1_BASE + 0x024)
 +#define LTDC_BASE             (APB2PERIPH_BASE + 0x6800)
 +#define LTDC_Layer1_BASE      (LTDC_BASE + 0x84)
 +#define LTDC_Layer2_BASE      (LTDC_BASE + 0x104) 
  /*!< AHB1 peripherals */
  #define GPIOA_BASE            (AHB1PERIPH_BASE + 0x0000)
 @@ -1142,7 +1532,8 @@ typedef struct  #define GPIOG_BASE            (AHB1PERIPH_BASE + 0x1800)
  #define GPIOH_BASE            (AHB1PERIPH_BASE + 0x1C00)
  #define GPIOI_BASE            (AHB1PERIPH_BASE + 0x2000)
 -
 +#define GPIOJ_BASE            (AHB1PERIPH_BASE + 0x2400)
 +#define GPIOK_BASE            (AHB1PERIPH_BASE + 0x2800)
  #define CRC_BASE              (AHB1PERIPH_BASE + 0x3000)
  #define RCC_BASE              (AHB1PERIPH_BASE + 0x3800)
  #define FLASH_R_BASE          (AHB1PERIPH_BASE + 0x3C00)
 @@ -1169,6 +1560,7 @@ typedef struct  #define ETH_MMC_BASE          (ETH_BASE + 0x0100)
  #define ETH_PTP_BASE          (ETH_BASE + 0x0700)
  #define ETH_DMA_BASE          (ETH_BASE + 0x1000)
 +#define DMA2D_BASE            (AHB1PERIPH_BASE + 0xB000)
  /*!< AHB2 peripherals */
  #define DCMI_BASE             (AHB2PERIPH_BASE + 0x50000)
 @@ -1177,12 +1569,24 @@ typedef struct  #define HASH_DIGEST_BASE      (AHB2PERIPH_BASE + 0x60710)
  #define RNG_BASE              (AHB2PERIPH_BASE + 0x60800)
 +#if defined (STM32F40_41xxx)
  /*!< FSMC Bankx registers base address */
  #define FSMC_Bank1_R_BASE     (FSMC_R_BASE + 0x0000)
  #define FSMC_Bank1E_R_BASE    (FSMC_R_BASE + 0x0104)
  #define FSMC_Bank2_R_BASE     (FSMC_R_BASE + 0x0060)
  #define FSMC_Bank3_R_BASE     (FSMC_R_BASE + 0x0080)
  #define FSMC_Bank4_R_BASE     (FSMC_R_BASE + 0x00A0)
 +#endif /* STM32F40_41xxx */
 +
 +#if defined (STM32F427_437xx) || defined (STM32F429_439xx)
 +/*!< FMC Bankx registers base address */
 +#define FMC_Bank1_R_BASE      (FMC_R_BASE + 0x0000)
 +#define FMC_Bank1E_R_BASE     (FMC_R_BASE + 0x0104)
 +#define FMC_Bank2_R_BASE      (FMC_R_BASE + 0x0060)
 +#define FMC_Bank3_R_BASE      (FMC_R_BASE + 0x0080)
 +#define FMC_Bank4_R_BASE      (FMC_R_BASE + 0x00A0)
 +#define FMC_Bank5_6_R_BASE    (FMC_R_BASE + 0x0140)
 +#endif /* STM32F427_437xx ||  STM32F429_439xx */
  /* Debug MCU registers base address */
  #define DBGMCU_BASE           ((uint32_t )0xE0042000)
 @@ -1241,7 +1645,12 @@ typedef struct  #define TIM11               ((TIM_TypeDef *) TIM11_BASE)
  #define SPI5                ((SPI_TypeDef *) SPI5_BASE)
  #define SPI6                ((SPI_TypeDef *) SPI6_BASE)
 -
 +#define SAI1                ((SAI_TypeDef *) SAI1_BASE)
 +#define SAI1_Block_A        ((SAI_Block_TypeDef *)SAI1_Block_A_BASE)
 +#define SAI1_Block_B        ((SAI_Block_TypeDef *)SAI1_Block_B_BASE)
 +#define LTDC                ((LTDC_TypeDef *)LTDC_BASE)
 +#define LTDC_Layer1         ((LTDC_Layer_TypeDef *)LTDC_Layer1_BASE)
 +#define LTDC_Layer2         ((LTDC_Layer_TypeDef *)LTDC_Layer2_BASE)
  #define GPIOA               ((GPIO_TypeDef *) GPIOA_BASE)
  #define GPIOB               ((GPIO_TypeDef *) GPIOB_BASE)
  #define GPIOC               ((GPIO_TypeDef *) GPIOC_BASE)
 @@ -1251,7 +1660,8 @@ typedef struct  #define GPIOG               ((GPIO_TypeDef *) GPIOG_BASE)
  #define GPIOH               ((GPIO_TypeDef *) GPIOH_BASE)
  #define GPIOI               ((GPIO_TypeDef *) GPIOI_BASE)
 -
 +#define GPIOJ               ((GPIO_TypeDef *) GPIOJ_BASE)
 +#define GPIOK               ((GPIO_TypeDef *) GPIOK_BASE)
  #define CRC                 ((CRC_TypeDef *) CRC_BASE)
  #define RCC                 ((RCC_TypeDef *) RCC_BASE)
  #define FLASH               ((FLASH_TypeDef *) FLASH_R_BASE)
 @@ -1274,16 +1684,30 @@ typedef struct  #define DMA2_Stream6        ((DMA_Stream_TypeDef *) DMA2_Stream6_BASE)
  #define DMA2_Stream7        ((DMA_Stream_TypeDef *) DMA2_Stream7_BASE)
  #define ETH                 ((ETH_TypeDef *) ETH_BASE)  
 +#define DMA2D               ((DMA2D_TypeDef *)DMA2D_BASE)
  #define DCMI                ((DCMI_TypeDef *) DCMI_BASE)
  #define CRYP                ((CRYP_TypeDef *) CRYP_BASE)
  #define HASH                ((HASH_TypeDef *) HASH_BASE)
  #define HASH_DIGEST         ((HASH_DIGEST_TypeDef *) HASH_DIGEST_BASE)
  #define RNG                 ((RNG_TypeDef *) RNG_BASE)
 +
 +#if defined (STM32F40_41xxx)
  #define FSMC_Bank1          ((FSMC_Bank1_TypeDef *) FSMC_Bank1_R_BASE)
  #define FSMC_Bank1E         ((FSMC_Bank1E_TypeDef *) FSMC_Bank1E_R_BASE)
  #define FSMC_Bank2          ((FSMC_Bank2_TypeDef *) FSMC_Bank2_R_BASE)
  #define FSMC_Bank3          ((FSMC_Bank3_TypeDef *) FSMC_Bank3_R_BASE)
 -#define FSMC_Bank4          ((FSMC_Bank4_TypeDef *) FSMC_Bank4_R_BASE)                                                                     
 +#define FSMC_Bank4          ((FSMC_Bank4_TypeDef *) FSMC_Bank4_R_BASE)
 +#endif /* STM32F40_41xxx */
 +
 +#if defined (STM32F427_437xx) || defined (STM32F429_439xx)
 +#define FMC_Bank1           ((FMC_Bank1_TypeDef *) FMC_Bank1_R_BASE)
 +#define FMC_Bank1E          ((FMC_Bank1E_TypeDef *) FMC_Bank1E_R_BASE)
 +#define FMC_Bank2           ((FMC_Bank2_TypeDef *) FMC_Bank2_R_BASE)
 +#define FMC_Bank3           ((FMC_Bank3_TypeDef *) FMC_Bank3_R_BASE)
 +#define FMC_Bank4           ((FMC_Bank4_TypeDef *) FMC_Bank4_R_BASE)
 +#define FMC_Bank5_6         ((FMC_Bank5_6_TypeDef *) FMC_Bank5_6_R_BASE)
 +#endif /* STM32F427_437xx ||  STM32F429_439xx */
 +
  #define DBGMCU              ((DBGMCU_TypeDef *) DBGMCU_BASE)
  /**
 @@ -1308,12 +1732,12 @@ typedef struct  /*                                                                            */
  /******************************************************************************/
  /********************  Bit definition for ADC_SR register  ********************/
 -#define  ADC_SR_AWD                          ((uint8_t)0x01)               /*!<Analog watchdog flag */
 -#define  ADC_SR_EOC                          ((uint8_t)0x02)               /*!<End of conversion */
 +#define  ADC_SR_AWD                          ((uint8_t)0x01)               /*!<Analog watchdog flag               */
 +#define  ADC_SR_EOC                          ((uint8_t)0x02)               /*!<End of conversion                  */
  #define  ADC_SR_JEOC                         ((uint8_t)0x04)               /*!<Injected channel end of conversion */
 -#define  ADC_SR_JSTRT                        ((uint8_t)0x08)               /*!<Injected channel Start flag */
 -#define  ADC_SR_STRT                         ((uint8_t)0x10)               /*!<Regular channel Start flag */
 -#define  ADC_SR_OVR                          ((uint8_t)0x20)               /*!<Overrun flag */
 +#define  ADC_SR_JSTRT                        ((uint8_t)0x08)               /*!<Injected channel Start flag        */
 +#define  ADC_SR_STRT                         ((uint8_t)0x10)               /*!<Regular channel Start flag         */
 +#define  ADC_SR_OVR                          ((uint8_t)0x20)               /*!<Overrun flag                       */
  /*******************  Bit definition for ADC_CR1 register  ********************/
  #define  ADC_CR1_AWDCH                       ((uint32_t)0x0000001F)        /*!<AWDCH[4:0] bits (Analog watchdog channel select bits) */
 @@ -1322,32 +1746,32 @@ typedef struct  #define  ADC_CR1_AWDCH_2                     ((uint32_t)0x00000004)        /*!<Bit 2 */
  #define  ADC_CR1_AWDCH_3                     ((uint32_t)0x00000008)        /*!<Bit 3 */
  #define  ADC_CR1_AWDCH_4                     ((uint32_t)0x00000010)        /*!<Bit 4 */
 -#define  ADC_CR1_EOCIE                       ((uint32_t)0x00000020)        /*!<Interrupt enable for EOC */
 -#define  ADC_CR1_AWDIE                       ((uint32_t)0x00000040)        /*!<AAnalog Watchdog interrupt enable */
 -#define  ADC_CR1_JEOCIE                      ((uint32_t)0x00000080)        /*!<Interrupt enable for injected channels */
 -#define  ADC_CR1_SCAN                        ((uint32_t)0x00000100)        /*!<Scan mode */
 -#define  ADC_CR1_AWDSGL                      ((uint32_t)0x00000200)        /*!<Enable the watchdog on a single channel in scan mode */
 -#define  ADC_CR1_JAUTO                       ((uint32_t)0x00000400)        /*!<Automatic injected group conversion */
 -#define  ADC_CR1_DISCEN                      ((uint32_t)0x00000800)        /*!<Discontinuous mode on regular channels */
 -#define  ADC_CR1_JDISCEN                     ((uint32_t)0x00001000)        /*!<Discontinuous mode on injected channels */
 -#define  ADC_CR1_DISCNUM                     ((uint32_t)0x0000E000)        /*!<DISCNUM[2:0] bits (Discontinuous mode channel count) */
 +#define  ADC_CR1_EOCIE                       ((uint32_t)0x00000020)        /*!<Interrupt enable for EOC                              */
 +#define  ADC_CR1_AWDIE                       ((uint32_t)0x00000040)        /*!<AAnalog Watchdog interrupt enable                     */
 +#define  ADC_CR1_JEOCIE                      ((uint32_t)0x00000080)        /*!<Interrupt enable for injected channels                */
 +#define  ADC_CR1_SCAN                        ((uint32_t)0x00000100)        /*!<Scan mode                                             */
 +#define  ADC_CR1_AWDSGL                      ((uint32_t)0x00000200)        /*!<Enable the watchdog on a single channel in scan mode  */
 +#define  ADC_CR1_JAUTO                       ((uint32_t)0x00000400)        /*!<Automatic injected group conversion                   */
 +#define  ADC_CR1_DISCEN                      ((uint32_t)0x00000800)        /*!<Discontinuous mode on regular channels                */
 +#define  ADC_CR1_JDISCEN                     ((uint32_t)0x00001000)        /*!<Discontinuous mode on injected channels               */
 +#define  ADC_CR1_DISCNUM                     ((uint32_t)0x0000E000)        /*!<DISCNUM[2:0] bits (Discontinuous mode channel count)  */
  #define  ADC_CR1_DISCNUM_0                   ((uint32_t)0x00002000)        /*!<Bit 0 */
  #define  ADC_CR1_DISCNUM_1                   ((uint32_t)0x00004000)        /*!<Bit 1 */
  #define  ADC_CR1_DISCNUM_2                   ((uint32_t)0x00008000)        /*!<Bit 2 */
 -#define  ADC_CR1_JAWDEN                      ((uint32_t)0x00400000)        /*!<Analog watchdog enable on injected channels */
 -#define  ADC_CR1_AWDEN                       ((uint32_t)0x00800000)        /*!<Analog watchdog enable on regular channels */
 -#define  ADC_CR1_RES                         ((uint32_t)0x03000000)        /*!<RES[2:0] bits (Resolution) */
 +#define  ADC_CR1_JAWDEN                      ((uint32_t)0x00400000)        /*!<Analog watchdog enable on injected channels           */
 +#define  ADC_CR1_AWDEN                       ((uint32_t)0x00800000)        /*!<Analog watchdog enable on regular channels            */
 +#define  ADC_CR1_RES                         ((uint32_t)0x03000000)        /*!<RES[2:0] bits (Resolution)                            */
  #define  ADC_CR1_RES_0                       ((uint32_t)0x01000000)        /*!<Bit 0 */
  #define  ADC_CR1_RES_1                       ((uint32_t)0x02000000)        /*!<Bit 1 */
 -#define  ADC_CR1_OVRIE                       ((uint32_t)0x04000000)         /*!<overrun interrupt enable */
 +#define  ADC_CR1_OVRIE                       ((uint32_t)0x04000000)         /*!<overrun interrupt enable                              */
  /*******************  Bit definition for ADC_CR2 register  ********************/
 -#define  ADC_CR2_ADON                        ((uint32_t)0x00000001)        /*!<A/D Converter ON / OFF */
 -#define  ADC_CR2_CONT                        ((uint32_t)0x00000002)        /*!<Continuous Conversion */
 -#define  ADC_CR2_DMA                         ((uint32_t)0x00000100)        /*!<Direct Memory access mode */
 +#define  ADC_CR2_ADON                        ((uint32_t)0x00000001)        /*!<A/D Converter ON / OFF             */
 +#define  ADC_CR2_CONT                        ((uint32_t)0x00000002)        /*!<Continuous Conversion              */
 +#define  ADC_CR2_DMA                         ((uint32_t)0x00000100)        /*!<Direct Memory access mode          */
  #define  ADC_CR2_DDS                         ((uint32_t)0x00000200)        /*!<DMA disable selection (Single ADC) */
 -#define  ADC_CR2_EOCS                        ((uint32_t)0x00000400)        /*!<End of conversion selection */
 -#define  ADC_CR2_ALIGN                       ((uint32_t)0x00000800)        /*!<Data Alignment */
 +#define  ADC_CR2_EOCS                        ((uint32_t)0x00000400)        /*!<End of conversion selection        */
 +#define  ADC_CR2_ALIGN                       ((uint32_t)0x00000800)        /*!<Data Alignment                     */
  #define  ADC_CR2_JEXTSEL                     ((uint32_t)0x000F0000)        /*!<JEXTSEL[3:0] bits (External event select for injected group) */
  #define  ADC_CR2_JEXTSEL_0                   ((uint32_t)0x00010000)        /*!<Bit 0 */
  #define  ADC_CR2_JEXTSEL_1                   ((uint32_t)0x00020000)        /*!<Bit 1 */
 @@ -3292,6 +3716,155 @@ typedef struct  #define DMA_HIFCR_CDMEIF4                    ((uint32_t)0x00000004)
  #define DMA_HIFCR_CFEIF4                     ((uint32_t)0x00000001)
 +/******************************************************************************/
 +/*                                                                            */
 +/*                         AHB Master DMA2D Controller (DMA2D)                */
 +/*                                                                            */
 +/******************************************************************************/
 +
 +/********************  Bit definition for DMA2D_CR register  ******************/
 +
 +#define DMA2D_CR_START                     ((uint32_t)0x00000001)               /*!< Start transfer */
 +#define DMA2D_CR_SUSP                      ((uint32_t)0x00000002)               /*!< Suspend transfer */
 +#define DMA2D_CR_ABORT                     ((uint32_t)0x00000004)               /*!< Abort transfer */
 +#define DMA2D_CR_TEIE                      ((uint32_t)0x00000100)               /*!< Transfer Error Interrupt Enable */
 +#define DMA2D_CR_TCIE                      ((uint32_t)0x00000200)               /*!< Transfer Complete Interrupt Enable */
 +#define DMA2D_CR_TWIE                      ((uint32_t)0x00000400)               /*!< Transfer Watermark Interrupt Enable */
 +#define DMA2D_CR_CAEIE                     ((uint32_t)0x00000800)               /*!< CLUT Access Error Interrupt Enable */
 +#define DMA2D_CR_CTCIE                     ((uint32_t)0x00001000)               /*!< CLUT Transfer Complete Interrupt Enable */
 +#define DMA2D_CR_CEIE                      ((uint32_t)0x00002000)               /*!< Configuration Error Interrupt Enable */
 +#define DMA2D_CR_MODE                      ((uint32_t)0x00030000)               /*!< DMA2D Mode */
 +
 +/********************  Bit definition for DMA2D_ISR register  *****************/
 +
 +#define DMA2D_ISR_TEIF                     ((uint32_t)0x00000001)               /*!< Transfer Error Interrupt Flag */
 +#define DMA2D_ISR_TCIF                     ((uint32_t)0x00000002)               /*!< Transfer Complete Interrupt Flag */
 +#define DMA2D_ISR_TWIF                     ((uint32_t)0x00000004)               /*!< Transfer Watermark Interrupt Flag */
 +#define DMA2D_ISR_CAEIF                    ((uint32_t)0x00000008)               /*!< CLUT Access Error Interrupt Flag */
 +#define DMA2D_ISR_CTCIF                    ((uint32_t)0x00000010)               /*!< CLUT Transfer Complete Interrupt Flag */
 +#define DMA2D_ISR_CEIF                     ((uint32_t)0x00000020)               /*!< Configuration Error Interrupt Flag */
 +
 +/********************  Bit definition for DMA2D_IFSR register  ****************/
 +
 +#define DMA2D_IFSR_CTEIF                   ((uint32_t)0x00000001)               /*!< Clears Transfer Error Interrupt Flag */
 +#define DMA2D_IFSR_CTCIF                   ((uint32_t)0x00000002)               /*!< Clears Transfer Complete Interrupt Flag */
 +#define DMA2D_IFSR_CTWIF                   ((uint32_t)0x00000004)               /*!< Clears Transfer Watermark Interrupt Flag */
 +#define DMA2D_IFSR_CCAEIF                  ((uint32_t)0x00000008)               /*!< Clears CLUT Access Error Interrupt Flag */
 +#define DMA2D_IFSR_CCTCIF                  ((uint32_t)0x00000010)               /*!< Clears CLUT Transfer Complete Interrupt Flag */
 +#define DMA2D_IFSR_CCEIF                   ((uint32_t)0x00000020)               /*!< Clears Configuration Error Interrupt Flag */
 +
 +/********************  Bit definition for DMA2D_FGMAR register  ***************/
 +
 +#define DMA2D_FGMAR_MA                     ((uint32_t)0xFFFFFFFF)               /*!< Memory Address */
 +
 +/********************  Bit definition for DMA2D_FGOR register  ****************/
 +
 +#define DMA2D_FGOR_LO                      ((uint32_t)0x00003FFF)               /*!< Line Offset */
 +
 +/********************  Bit definition for DMA2D_BGMAR register  ***************/
 +
 +#define DMA2D_BGMAR_MA                     ((uint32_t)0xFFFFFFFF)               /*!< Memory Address */
 +
 +/********************  Bit definition for DMA2D_BGOR register  ****************/
 +
 +#define DMA2D_BGOR_LO                      ((uint32_t)0x00003FFF)               /*!< Line Offset */
 +
 +/********************  Bit definition for DMA2D_FGPFCCR register  *************/
 +
 +#define DMA2D_FGPFCCR_CM                   ((uint32_t)0x0000000F)               /*!< Color mode */
 +#define DMA2D_FGPFCCR_CCM                  ((uint32_t)0x00000010)               /*!< CLUT Color mode */
 +#define DMA2D_FGPFCCR_START                ((uint32_t)0x00000020)               /*!< Start */
 +#define DMA2D_FGPFCCR_CS                   ((uint32_t)0x0000FF00)               /*!< CLUT size */
 +#define DMA2D_FGPFCCR_AM                   ((uint32_t)0x00030000)               /*!< Alpha mode */
 +#define DMA2D_FGPFCCR_ALPHA                ((uint32_t)0xFF000000)               /*!< Alpha value */
 +
 +/********************  Bit definition for DMA2D_FGCOLR register  **************/
 +
 +#define DMA2D_FGCOLR_BLUE                  ((uint32_t)0x000000FF)               /*!< Blue Value */
 +#define DMA2D_FGCOLR_GREEN                 ((uint32_t)0x0000FF00)               /*!< Green Value */
 +#define DMA2D_FGCOLR_RED                   ((uint32_t)0x00FF0000)               /*!< Red Value */   
 +
 +/********************  Bit definition for DMA2D_BGPFCCR register  *************/
 +
 +#define DMA2D_BGPFCCR_CM                   ((uint32_t)0x0000000F)               /*!< Color mode */
 +#define DMA2D_BGPFCCR_CCM                  ((uint32_t)0x00000010)               /*!< CLUT Color mode */
 +#define DMA2D_BGPFCCR_START                ((uint32_t)0x00000020)               /*!< Start */
 +#define DMA2D_BGPFCCR_CS                   ((uint32_t)0x0000FF00)               /*!< CLUT size */
 +#define DMA2D_BGPFCCR_AM                   ((uint32_t)0x00030000)               /*!< Alpha Mode */
 +#define DMA2D_BGPFCCR_ALPHA                ((uint32_t)0xFF000000)               /*!< Alpha value */
 +
 +/********************  Bit definition for DMA2D_BGCOLR register  **************/
 +
 +#define DMA2D_BGCOLR_BLUE                  ((uint32_t)0x000000FF)               /*!< Blue Value */
 +#define DMA2D_BGCOLR_GREEN                 ((uint32_t)0x0000FF00)               /*!< Green Value */
 +#define DMA2D_BGCOLR_RED                   ((uint32_t)0x00FF0000)               /*!< Red Value */
 +
 +/********************  Bit definition for DMA2D_FGCMAR register  **************/
 +
 +#define DMA2D_FGCMAR_MA                    ((uint32_t)0xFFFFFFFF)               /*!< Memory Address */
 +
 +/********************  Bit definition for DMA2D_BGCMAR register  **************/
 +
 +#define DMA2D_BGCMAR_MA                    ((uint32_t)0xFFFFFFFF)               /*!< Memory Address */
 +
 +/********************  Bit definition for DMA2D_OPFCCR register  **************/
 +
 +#define DMA2D_OPFCCR_CM                    ((uint32_t)0x00000007)               /*!< Color mode */
 +
 +/********************  Bit definition for DMA2D_OCOLR register  ***************/
 +
 +/*!<Mode_ARGB8888/RGB888 */
 +
 +#define DMA2D_OCOLR_BLUE_1                 ((uint32_t)0x000000FF)               /*!< BLUE Value */
 +#define DMA2D_OCOLR_GREEN_1                ((uint32_t)0x0000FF00)               /*!< GREEN Value  */
 +#define DMA2D_OCOLR_RED_1                  ((uint32_t)0x00FF0000)               /*!< Red Value */
 +#define DMA2D_OCOLR_ALPHA_1                ((uint32_t)0xFF000000)               /*!< Alpha Channel Value */
 +
 +/*!<Mode_RGB565 */
 +#define DMA2D_OCOLR_BLUE_2                 ((uint32_t)0x0000001F)               /*!< BLUE Value */
 +#define DMA2D_OCOLR_GREEN_2                ((uint32_t)0x000007E0)               /*!< GREEN Value  */
 +#define DMA2D_OCOLR_RED_2                  ((uint32_t)0x0000F800)               /*!< Red Value */
 +
 +/*!<Mode_ARGB1555 */
 +#define DMA2D_OCOLR_BLUE_3                 ((uint32_t)0x0000001F)               /*!< BLUE Value */
 +#define DMA2D_OCOLR_GREEN_3                ((uint32_t)0x000003E0)               /*!< GREEN Value  */
 +#define DMA2D_OCOLR_RED_3                  ((uint32_t)0x00007C00)               /*!< Red Value */
 +#define DMA2D_OCOLR_ALPHA_3                ((uint32_t)0x00008000)               /*!< Alpha Channel Value */
 +
 +/*!<Mode_ARGB4444 */
 +#define DMA2D_OCOLR_BLUE_4                 ((uint32_t)0x0000000F)               /*!< BLUE Value */
 +#define DMA2D_OCOLR_GREEN_4                ((uint32_t)0x000000F0)               /*!< GREEN Value  */
 +#define DMA2D_OCOLR_RED_4                  ((uint32_t)0x00000F00)               /*!< Red Value */
 +#define DMA2D_OCOLR_ALPHA_4                ((uint32_t)0x0000F000)               /*!< Alpha Channel Value */
 +
 +/********************  Bit definition for DMA2D_OMAR register  ****************/
 +
 +#define DMA2D_OMAR_MA                      ((uint32_t)0xFFFFFFFF)               /*!< Memory Address */
 +
 +/********************  Bit definition for DMA2D_OOR register  *****************/
 +
 +#define DMA2D_OOR_LO                       ((uint32_t)0x00003FFF)               /*!< Line Offset */
 +
 +/********************  Bit definition for DMA2D_NLR register  *****************/
 +
 +#define DMA2D_NLR_NL                       ((uint32_t)0x0000FFFF)               /*!< Number of Lines */
 +#define DMA2D_NLR_PL                       ((uint32_t)0x3FFF0000)               /*!< Pixel per Lines */
 +
 +/********************  Bit definition for DMA2D_LWR register  *****************/
 +
 +#define DMA2D_LWR_LW                       ((uint32_t)0x0000FFFF)               /*!< Line Watermark */
 +
 +/********************  Bit definition for DMA2D_AMTCR register  ***************/
 +
 +#define DMA2D_AMTCR_EN                     ((uint32_t)0x00000001)               /*!< Enable */
 +#define DMA2D_AMTCR_DT                     ((uint32_t)0x0000FF00)               /*!< Dead Time */
 +
 +
 +
 +/********************  Bit definition for DMA2D_FGCLUT register  **************/
 +                                                                     
 +/********************  Bit definition for DMA2D_BGCLUT register  **************/
 +
  /******************************************************************************/
  /*                                                                            */
 @@ -3445,6 +4018,14 @@ typedef struct  #define FLASH_ACR_LATENCY_5WS                ((uint32_t)0x00000005)
  #define FLASH_ACR_LATENCY_6WS                ((uint32_t)0x00000006)
  #define FLASH_ACR_LATENCY_7WS                ((uint32_t)0x00000007)
 +#define FLASH_ACR_LATENCY_8WS                ((uint32_t)0x00000008)
 +#define FLASH_ACR_LATENCY_9WS                ((uint32_t)0x00000009)
 +#define FLASH_ACR_LATENCY_10WS               ((uint32_t)0x0000000A)
 +#define FLASH_ACR_LATENCY_11WS               ((uint32_t)0x0000000B)
 +#define FLASH_ACR_LATENCY_12WS               ((uint32_t)0x0000000C)
 +#define FLASH_ACR_LATENCY_13WS               ((uint32_t)0x0000000D)
 +#define FLASH_ACR_LATENCY_14WS               ((uint32_t)0x0000000E)
 +#define FLASH_ACR_LATENCY_15WS               ((uint32_t)0x0000000F)
  #define FLASH_ACR_PRFTEN                     ((uint32_t)0x00000100)
  #define FLASH_ACR_ICEN                       ((uint32_t)0x00000200)
 @@ -3488,6 +4069,8 @@ typedef struct  #define FLASH_OPTCR_BOR_LEV_0               ((uint32_t)0x00000004)
  #define FLASH_OPTCR_BOR_LEV_1               ((uint32_t)0x00000008)
  #define FLASH_OPTCR_BOR_LEV                 ((uint32_t)0x0000000C)
 +#define FLASH_OPTCR_BFB2                    ((uint32_t)0x00000010)
 +
  #define FLASH_OPTCR_WDG_SW                  ((uint32_t)0x00000020)
  #define FLASH_OPTCR_nRST_STOP               ((uint32_t)0x00000040)
  #define FLASH_OPTCR_nRST_STDBY              ((uint32_t)0x00000080)
 @@ -3513,6 +4096,9 @@ typedef struct  #define FLASH_OPTCR_nWRP_9                  ((uint32_t)0x02000000)
  #define FLASH_OPTCR_nWRP_10                 ((uint32_t)0x04000000)
  #define FLASH_OPTCR_nWRP_11                 ((uint32_t)0x08000000)
 +
 +#define FLASH_OPTCR_DB1M                    ((uint32_t)0x40000000) 
 +#define FLASH_OPTCR_SPRMOD                  ((uint32_t)0x80000000) 
  /******************  Bits definition for FLASH_OPTCR1 register  ***************/
  #define FLASH_OPTCR1_nWRP                    ((uint32_t)0x0FFF0000)
 @@ -3529,7 +4115,7 @@ typedef struct  #define FLASH_OPTCR1_nWRP_10                 ((uint32_t)0x04000000)
  #define FLASH_OPTCR1_nWRP_11                 ((uint32_t)0x08000000)
 -
 +#if defined (STM32F40_41xxx)
  /******************************************************************************/
  /*                                                                            */
  /*                       Flexible Static Memory Controller                    */
 @@ -4334,7 +4920,1026 @@ typedef struct  /******************  Bit definition for FSMC_ECCR3 register  ******************/
  #define  FSMC_ECCR3_ECC3                     ((uint32_t)0xFFFFFFFF)        /*!<ECC result */
 +#endif /* STM32F40_41xxx */
 +#if defined (STM32F427_437xx) || defined (STM32F429_439xx)
 +/******************************************************************************/
 +/*                                                                            */
 +/*                          Flexible Memory Controller                        */
 +/*                                                                            */
 +/******************************************************************************/
 +/******************  Bit definition for FMC_BCR1 register  *******************/
 +#define  FMC_BCR1_MBKEN                     ((uint32_t)0x00000001)        /*!<Memory bank enable bit                 */
 +#define  FMC_BCR1_MUXEN                     ((uint32_t)0x00000002)        /*!<Address/data multiplexing enable bit   */
 +
 +#define  FMC_BCR1_MTYP                      ((uint32_t)0x0000000C)        /*!<MTYP[1:0] bits (Memory type)           */
 +#define  FMC_BCR1_MTYP_0                    ((uint32_t)0x00000004)        /*!<Bit 0 */
 +#define  FMC_BCR1_MTYP_1                    ((uint32_t)0x00000008)        /*!<Bit 1 */
 +
 +#define  FMC_BCR1_MWID                      ((uint32_t)0x00000030)        /*!<MWID[1:0] bits (Memory data bus width) */
 +#define  FMC_BCR1_MWID_0                    ((uint32_t)0x00000010)        /*!<Bit 0 */
 +#define  FMC_BCR1_MWID_1                    ((uint32_t)0x00000020)        /*!<Bit 1 */
 +
 +#define  FMC_BCR1_FACCEN                    ((uint32_t)0x00000040)        /*!<Flash access enable        */
 +#define  FMC_BCR1_BURSTEN                   ((uint32_t)0x00000100)        /*!<Burst enable bit           */
 +#define  FMC_BCR1_WAITPOL                   ((uint32_t)0x00000200)        /*!<Wait signal polarity bit   */
 +#define  FMC_BCR1_WRAPMOD                   ((uint32_t)0x00000400)        /*!<Wrapped burst mode support */
 +#define  FMC_BCR1_WAITCFG                   ((uint32_t)0x00000800)        /*!<Wait timing configuration  */
 +#define  FMC_BCR1_WREN                      ((uint32_t)0x00001000)        /*!<Write enable bit           */
 +#define  FMC_BCR1_WAITEN                    ((uint32_t)0x00002000)        /*!<Wait enable bit            */
 +#define  FMC_BCR1_EXTMOD                    ((uint32_t)0x00004000)        /*!<Extended mode enable       */
 +#define  FMC_BCR1_ASYNCWAIT                 ((uint32_t)0x00008000)        /*!<Asynchronous wait          */
 +#define  FMC_BCR1_CBURSTRW                  ((uint32_t)0x00080000)        /*!<Write burst enable         */
 +#define  FMC_BCR1_CCLKEN                    ((uint32_t)0x00100000)        /*!<Continous clock enable     */
 +
 +/******************  Bit definition for FMC_BCR2 register  *******************/
 +#define  FMC_BCR2_MBKEN                     ((uint32_t)0x00000001)        /*!<Memory bank enable bit                 */
 +#define  FMC_BCR2_MUXEN                     ((uint32_t)0x00000002)        /*!<Address/data multiplexing enable bit   */
 +
 +#define  FMC_BCR2_MTYP                      ((uint32_t)0x0000000C)        /*!<MTYP[1:0] bits (Memory type)           */
 +#define  FMC_BCR2_MTYP_0                    ((uint32_t)0x00000004)        /*!<Bit 0 */
 +#define  FMC_BCR2_MTYP_1                    ((uint32_t)0x00000008)        /*!<Bit 1 */
 +
 +#define  FMC_BCR2_MWID                      ((uint32_t)0x00000030)        /*!<MWID[1:0] bits (Memory data bus width) */
 +#define  FMC_BCR2_MWID_0                    ((uint32_t)0x00000010)        /*!<Bit 0 */
 +#define  FMC_BCR2_MWID_1                    ((uint32_t)0x00000020)        /*!<Bit 1 */
 +
 +#define  FMC_BCR2_FACCEN                    ((uint32_t)0x00000040)        /*!<Flash access enable        */
 +#define  FMC_BCR2_BURSTEN                   ((uint32_t)0x00000100)        /*!<Burst enable bit           */
 +#define  FMC_BCR2_WAITPOL                   ((uint32_t)0x00000200)        /*!<Wait signal polarity bit   */
 +#define  FMC_BCR2_WRAPMOD                   ((uint32_t)0x00000400)        /*!<Wrapped burst mode support */
 +#define  FMC_BCR2_WAITCFG                   ((uint32_t)0x00000800)        /*!<Wait timing configuration  */
 +#define  FMC_BCR2_WREN                      ((uint32_t)0x00001000)        /*!<Write enable bit           */
 +#define  FMC_BCR2_WAITEN                    ((uint32_t)0x00002000)        /*!<Wait enable bit            */
 +#define  FMC_BCR2_EXTMOD                    ((uint32_t)0x00004000)        /*!<Extended mode enable       */
 +#define  FMC_BCR2_ASYNCWAIT                 ((uint32_t)0x00008000)        /*!<Asynchronous wait          */
 +#define  FMC_BCR2_CBURSTRW                  ((uint32_t)0x00080000)        /*!<Write burst enable         */
 +
 +/******************  Bit definition for FMC_BCR3 register  *******************/
 +#define  FMC_BCR3_MBKEN                     ((uint32_t)0x00000001)        /*!<Memory bank enable bit                 */
 +#define  FMC_BCR3_MUXEN                     ((uint32_t)0x00000002)        /*!<Address/data multiplexing enable bit   */
 +
 +#define  FMC_BCR3_MTYP                      ((uint32_t)0x0000000C)        /*!<MTYP[1:0] bits (Memory type)           */
 +#define  FMC_BCR3_MTYP_0                    ((uint32_t)0x00000004)        /*!<Bit 0 */
 +#define  FMC_BCR3_MTYP_1                    ((uint32_t)0x00000008)        /*!<Bit 1 */
 +
 +#define  FMC_BCR3_MWID                      ((uint32_t)0x00000030)        /*!<MWID[1:0] bits (Memory data bus width) */
 +#define  FMC_BCR3_MWID_0                    ((uint32_t)0x00000010)        /*!<Bit 0 */
 +#define  FMC_BCR3_MWID_1                    ((uint32_t)0x00000020)        /*!<Bit 1 */
 +
 +#define  FMC_BCR3_FACCEN                    ((uint32_t)0x00000040)        /*!<Flash access enable        */
 +#define  FMC_BCR3_BURSTEN                   ((uint32_t)0x00000100)        /*!<Burst enable bit           */
 +#define  FMC_BCR3_WAITPOL                   ((uint32_t)0x00000200)        /*!<Wait signal polarity bit   */
 +#define  FMC_BCR3_WRAPMOD                   ((uint32_t)0x00000400)        /*!<Wrapped burst mode support */
 +#define  FMC_BCR3_WAITCFG                   ((uint32_t)0x00000800)        /*!<Wait timing configuration  */
 +#define  FMC_BCR3_WREN                      ((uint32_t)0x00001000)        /*!<Write enable bit           */
 +#define  FMC_BCR3_WAITEN                    ((uint32_t)0x00002000)        /*!<Wait enable bit            */
 +#define  FMC_BCR3_EXTMOD                    ((uint32_t)0x00004000)        /*!<Extended mode enable       */
 +#define  FMC_BCR3_ASYNCWAIT                 ((uint32_t)0x00008000)        /*!<Asynchronous wait          */
 +#define  FMC_BCR3_CBURSTRW                  ((uint32_t)0x00080000)        /*!<Write burst enable         */
 +
 +/******************  Bit definition for FMC_BCR4 register  *******************/
 +#define  FMC_BCR4_MBKEN                     ((uint32_t)0x00000001)        /*!<Memory bank enable bit                 */
 +#define  FMC_BCR4_MUXEN                     ((uint32_t)0x00000002)        /*!<Address/data multiplexing enable bit   */
 +
 +#define  FMC_BCR4_MTYP                      ((uint32_t)0x0000000C)        /*!<MTYP[1:0] bits (Memory type)           */
 +#define  FMC_BCR4_MTYP_0                    ((uint32_t)0x00000004)        /*!<Bit 0 */
 +#define  FMC_BCR4_MTYP_1                    ((uint32_t)0x00000008)        /*!<Bit 1 */
 +
 +#define  FMC_BCR4_MWID                      ((uint32_t)0x00000030)        /*!<MWID[1:0] bits (Memory data bus width) */
 +#define  FMC_BCR4_MWID_0                    ((uint32_t)0x00000010)        /*!<Bit 0 */
 +#define  FMC_BCR4_MWID_1                    ((uint32_t)0x00000020)        /*!<Bit 1 */
 +
 +#define  FMC_BCR4_FACCEN                    ((uint32_t)0x00000040)        /*!<Flash access enable        */
 +#define  FMC_BCR4_BURSTEN                   ((uint32_t)0x00000100)        /*!<Burst enable bit           */
 +#define  FMC_BCR4_WAITPOL                   ((uint32_t)0x00000200)        /*!<Wait signal polarity bit   */
 +#define  FMC_BCR4_WRAPMOD                   ((uint32_t)0x00000400)        /*!<Wrapped burst mode support */
 +#define  FMC_BCR4_WAITCFG                   ((uint32_t)0x00000800)        /*!<Wait timing configuration  */
 +#define  FMC_BCR4_WREN                      ((uint32_t)0x00001000)        /*!<Write enable bit           */
 +#define  FMC_BCR4_WAITEN                    ((uint32_t)0x00002000)        /*!<Wait enable bit            */
 +#define  FMC_BCR4_EXTMOD                    ((uint32_t)0x00004000)        /*!<Extended mode enable       */
 +#define  FMC_BCR4_ASYNCWAIT                 ((uint32_t)0x00008000)        /*!<Asynchronous wait          */
 +#define  FMC_BCR4_CBURSTRW                  ((uint32_t)0x00080000)        /*!<Write burst enable         */
 +
 +/******************  Bit definition for FMC_BTR1 register  ******************/
 +#define  FMC_BTR1_ADDSET                    ((uint32_t)0x0000000F)        /*!<ADDSET[3:0] bits (Address setup phase duration) */
 +#define  FMC_BTR1_ADDSET_0                  ((uint32_t)0x00000001)        /*!<Bit 0 */
 +#define  FMC_BTR1_ADDSET_1                  ((uint32_t)0x00000002)        /*!<Bit 1 */
 +#define  FMC_BTR1_ADDSET_2                  ((uint32_t)0x00000004)        /*!<Bit 2 */
 +#define  FMC_BTR1_ADDSET_3                  ((uint32_t)0x00000008)        /*!<Bit 3 */
 +
 +#define  FMC_BTR1_ADDHLD                    ((uint32_t)0x000000F0)        /*!<ADDHLD[3:0] bits (Address-hold phase duration)  */
 +#define  FMC_BTR1_ADDHLD_0                  ((uint32_t)0x00000010)        /*!<Bit 0 */
 +#define  FMC_BTR1_ADDHLD_1                  ((uint32_t)0x00000020)        /*!<Bit 1 */
 +#define  FMC_BTR1_ADDHLD_2                  ((uint32_t)0x00000040)        /*!<Bit 2 */
 +#define  FMC_BTR1_ADDHLD_3                  ((uint32_t)0x00000080)        /*!<Bit 3 */
 +
 +#define  FMC_BTR1_DATAST                    ((uint32_t)0x0000FF00)        /*!<DATAST [3:0] bits (Data-phase duration) */
 +#define  FMC_BTR1_DATAST_0                  ((uint32_t)0x00000100)        /*!<Bit 0 */
 +#define  FMC_BTR1_DATAST_1                  ((uint32_t)0x00000200)        /*!<Bit 1 */
 +#define  FMC_BTR1_DATAST_2                  ((uint32_t)0x00000400)        /*!<Bit 2 */
 +#define  FMC_BTR1_DATAST_3                  ((uint32_t)0x00000800)        /*!<Bit 3 */
 +#define  FMC_BTR1_DATAST_4                  ((uint32_t)0x00001000)        /*!<Bit 4 */
 +#define  FMC_BTR1_DATAST_5                  ((uint32_t)0x00002000)        /*!<Bit 5 */
 +#define  FMC_BTR1_DATAST_6                  ((uint32_t)0x00004000)        /*!<Bit 6 */
 +#define  FMC_BTR1_DATAST_7                  ((uint32_t)0x00008000)        /*!<Bit 7 */
 +
 +#define  FMC_BTR1_BUSTURN                   ((uint32_t)0x000F0000)        /*!<BUSTURN[3:0] bits (Bus turnaround phase duration) */
 +#define  FMC_BTR1_BUSTURN_0                 ((uint32_t)0x00010000)        /*!<Bit 0 */
 +#define  FMC_BTR1_BUSTURN_1                 ((uint32_t)0x00020000)        /*!<Bit 1 */
 +#define  FMC_BTR1_BUSTURN_2                 ((uint32_t)0x00040000)        /*!<Bit 2 */
 +#define  FMC_BTR1_BUSTURN_3                 ((uint32_t)0x00080000)        /*!<Bit 3 */
 +
 +#define  FMC_BTR1_CLKDIV                    ((uint32_t)0x00F00000)        /*!<CLKDIV[3:0] bits (Clock divide ratio) */
 +#define  FMC_BTR1_CLKDIV_0                  ((uint32_t)0x00100000)        /*!<Bit 0 */
 +#define  FMC_BTR1_CLKDIV_1                  ((uint32_t)0x00200000)        /*!<Bit 1 */
 +#define  FMC_BTR1_CLKDIV_2                  ((uint32_t)0x00400000)        /*!<Bit 2 */
 +#define  FMC_BTR1_CLKDIV_3                  ((uint32_t)0x00800000)        /*!<Bit 3 */
 +
 +#define  FMC_BTR1_DATLAT                    ((uint32_t)0x0F000000)        /*!<DATLA[3:0] bits (Data latency) */
 +#define  FMC_BTR1_DATLAT_0                  ((uint32_t)0x01000000)        /*!<Bit 0 */
 +#define  FMC_BTR1_DATLAT_1                  ((uint32_t)0x02000000)        /*!<Bit 1 */
 +#define  FMC_BTR1_DATLAT_2                  ((uint32_t)0x04000000)        /*!<Bit 2 */
 +#define  FMC_BTR1_DATLAT_3                  ((uint32_t)0x08000000)        /*!<Bit 3 */
 +
 +#define  FMC_BTR1_ACCMOD                    ((uint32_t)0x30000000)        /*!<ACCMOD[1:0] bits (Access mode) */
 +#define  FMC_BTR1_ACCMOD_0                  ((uint32_t)0x10000000)        /*!<Bit 0 */
 +#define  FMC_BTR1_ACCMOD_1                  ((uint32_t)0x20000000)        /*!<Bit 1 */
 +
 +/******************  Bit definition for FMC_BTR2 register  *******************/
 +#define  FMC_BTR2_ADDSET                    ((uint32_t)0x0000000F)        /*!<ADDSET[3:0] bits (Address setup phase duration) */
 +#define  FMC_BTR2_ADDSET_0                  ((uint32_t)0x00000001)        /*!<Bit 0 */
 +#define  FMC_BTR2_ADDSET_1                  ((uint32_t)0x00000002)        /*!<Bit 1 */
 +#define  FMC_BTR2_ADDSET_2                  ((uint32_t)0x00000004)        /*!<Bit 2 */
 +#define  FMC_BTR2_ADDSET_3                  ((uint32_t)0x00000008)        /*!<Bit 3 */
 +
 +#define  FMC_BTR2_ADDHLD                    ((uint32_t)0x000000F0)        /*!<ADDHLD[3:0] bits (Address-hold phase duration) */
 +#define  FMC_BTR2_ADDHLD_0                  ((uint32_t)0x00000010)        /*!<Bit 0 */
 +#define  FMC_BTR2_ADDHLD_1                  ((uint32_t)0x00000020)        /*!<Bit 1 */
 +#define  FMC_BTR2_ADDHLD_2                  ((uint32_t)0x00000040)        /*!<Bit 2 */
 +#define  FMC_BTR2_ADDHLD_3                  ((uint32_t)0x00000080)        /*!<Bit 3 */
 +
 +#define  FMC_BTR2_DATAST                    ((uint32_t)0x0000FF00)        /*!<DATAST [3:0] bits (Data-phase duration) */
 +#define  FMC_BTR2_DATAST_0                  ((uint32_t)0x00000100)        /*!<Bit 0 */
 +#define  FMC_BTR2_DATAST_1                  ((uint32_t)0x00000200)        /*!<Bit 1 */
 +#define  FMC_BTR2_DATAST_2                  ((uint32_t)0x00000400)        /*!<Bit 2 */
 +#define  FMC_BTR2_DATAST_3                  ((uint32_t)0x00000800)        /*!<Bit 3 */
 +#define  FMC_BTR2_DATAST_4                  ((uint32_t)0x00001000)        /*!<Bit 4 */
 +#define  FMC_BTR2_DATAST_5                  ((uint32_t)0x00002000)        /*!<Bit 5 */
 +#define  FMC_BTR2_DATAST_6                  ((uint32_t)0x00004000)        /*!<Bit 6 */
 +#define  FMC_BTR2_DATAST_7                  ((uint32_t)0x00008000)        /*!<Bit 7 */
 +
 +#define  FMC_BTR2_BUSTURN                   ((uint32_t)0x000F0000)        /*!<BUSTURN[3:0] bits (Bus turnaround phase duration) */
 +#define  FMC_BTR2_BUSTURN_0                 ((uint32_t)0x00010000)        /*!<Bit 0 */
 +#define  FMC_BTR2_BUSTURN_1                 ((uint32_t)0x00020000)        /*!<Bit 1 */
 +#define  FMC_BTR2_BUSTURN_2                 ((uint32_t)0x00040000)        /*!<Bit 2 */
 +#define  FMC_BTR2_BUSTURN_3                 ((uint32_t)0x00080000)        /*!<Bit 3 */
 +
 +#define  FMC_BTR2_CLKDIV                    ((uint32_t)0x00F00000)        /*!<CLKDIV[3:0] bits (Clock divide ratio) */
 +#define  FMC_BTR2_CLKDIV_0                  ((uint32_t)0x00100000)        /*!<Bit 0 */
 +#define  FMC_BTR2_CLKDIV_1                  ((uint32_t)0x00200000)        /*!<Bit 1 */
 +#define  FMC_BTR2_CLKDIV_2                  ((uint32_t)0x00400000)        /*!<Bit 2 */
 +#define  FMC_BTR2_CLKDIV_3                  ((uint32_t)0x00800000)        /*!<Bit 3 */
 +
 +#define  FMC_BTR2_DATLAT                    ((uint32_t)0x0F000000)        /*!<DATLA[3:0] bits (Data latency) */
 +#define  FMC_BTR2_DATLAT_0                  ((uint32_t)0x01000000)        /*!<Bit 0 */
 +#define  FMC_BTR2_DATLAT_1                  ((uint32_t)0x02000000)        /*!<Bit 1 */
 +#define  FMC_BTR2_DATLAT_2                  ((uint32_t)0x04000000)        /*!<Bit 2 */
 +#define  FMC_BTR2_DATLAT_3                  ((uint32_t)0x08000000)        /*!<Bit 3 */
 +
 +#define  FMC_BTR2_ACCMOD                    ((uint32_t)0x30000000)        /*!<ACCMOD[1:0] bits (Access mode) */
 +#define  FMC_BTR2_ACCMOD_0                  ((uint32_t)0x10000000)        /*!<Bit 0 */
 +#define  FMC_BTR2_ACCMOD_1                  ((uint32_t)0x20000000)        /*!<Bit 1 */
 +
 +/*******************  Bit definition for FMC_BTR3 register  *******************/
 +#define  FMC_BTR3_ADDSET                    ((uint32_t)0x0000000F)        /*!<ADDSET[3:0] bits (Address setup phase duration) */
 +#define  FMC_BTR3_ADDSET_0                  ((uint32_t)0x00000001)        /*!<Bit 0 */
 +#define  FMC_BTR3_ADDSET_1                  ((uint32_t)0x00000002)        /*!<Bit 1 */
 +#define  FMC_BTR3_ADDSET_2                  ((uint32_t)0x00000004)        /*!<Bit 2 */
 +#define  FMC_BTR3_ADDSET_3                  ((uint32_t)0x00000008)        /*!<Bit 3 */
 +
 +#define  FMC_BTR3_ADDHLD                    ((uint32_t)0x000000F0)        /*!<ADDHLD[3:0] bits (Address-hold phase duration) */
 +#define  FMC_BTR3_ADDHLD_0                  ((uint32_t)0x00000010)        /*!<Bit 0 */
 +#define  FMC_BTR3_ADDHLD_1                  ((uint32_t)0x00000020)        /*!<Bit 1 */
 +#define  FMC_BTR3_ADDHLD_2                  ((uint32_t)0x00000040)        /*!<Bit 2 */
 +#define  FMC_BTR3_ADDHLD_3                  ((uint32_t)0x00000080)        /*!<Bit 3 */
 +
 +#define  FMC_BTR3_DATAST                    ((uint32_t)0x0000FF00)        /*!<DATAST [3:0] bits (Data-phase duration) */
 +#define  FMC_BTR3_DATAST_0                  ((uint32_t)0x00000100)        /*!<Bit 0 */
 +#define  FMC_BTR3_DATAST_1                  ((uint32_t)0x00000200)        /*!<Bit 1 */
 +#define  FMC_BTR3_DATAST_2                  ((uint32_t)0x00000400)        /*!<Bit 2 */
 +#define  FMC_BTR3_DATAST_3                  ((uint32_t)0x00000800)        /*!<Bit 3 */
 +#define  FMC_BTR3_DATAST_4                  ((uint32_t)0x00001000)        /*!<Bit 4 */
 +#define  FMC_BTR3_DATAST_5                  ((uint32_t)0x00002000)        /*!<Bit 5 */
 +#define  FMC_BTR3_DATAST_6                  ((uint32_t)0x00004000)        /*!<Bit 6 */
 +#define  FMC_BTR3_DATAST_7                  ((uint32_t)0x00008000)        /*!<Bit 7 */
 +
 +#define  FMC_BTR3_BUSTURN                   ((uint32_t)0x000F0000)        /*!<BUSTURN[3:0] bits (Bus turnaround phase duration) */
 +#define  FMC_BTR3_BUSTURN_0                 ((uint32_t)0x00010000)        /*!<Bit 0 */
 +#define  FMC_BTR3_BUSTURN_1                 ((uint32_t)0x00020000)        /*!<Bit 1 */
 +#define  FMC_BTR3_BUSTURN_2                 ((uint32_t)0x00040000)        /*!<Bit 2 */
 +#define  FMC_BTR3_BUSTURN_3                 ((uint32_t)0x00080000)        /*!<Bit 3 */
 +
 +#define  FMC_BTR3_CLKDIV                    ((uint32_t)0x00F00000)        /*!<CLKDIV[3:0] bits (Clock divide ratio) */
 +#define  FMC_BTR3_CLKDIV_0                  ((uint32_t)0x00100000)        /*!<Bit 0 */
 +#define  FMC_BTR3_CLKDIV_1                  ((uint32_t)0x00200000)        /*!<Bit 1 */
 +#define  FMC_BTR3_CLKDIV_2                  ((uint32_t)0x00400000)        /*!<Bit 2 */
 +#define  FMC_BTR3_CLKDIV_3                  ((uint32_t)0x00800000)        /*!<Bit 3 */
 +
 +#define  FMC_BTR3_DATLAT                    ((uint32_t)0x0F000000)        /*!<DATLA[3:0] bits (Data latency) */
 +#define  FMC_BTR3_DATLAT_0                  ((uint32_t)0x01000000)        /*!<Bit 0 */
 +#define  FMC_BTR3_DATLAT_1                  ((uint32_t)0x02000000)        /*!<Bit 1 */
 +#define  FMC_BTR3_DATLAT_2                  ((uint32_t)0x04000000)        /*!<Bit 2 */
 +#define  FMC_BTR3_DATLAT_3                  ((uint32_t)0x08000000)        /*!<Bit 3 */
 +
 +#define  FMC_BTR3_ACCMOD                    ((uint32_t)0x30000000)        /*!<ACCMOD[1:0] bits (Access mode) */
 +#define  FMC_BTR3_ACCMOD_0                  ((uint32_t)0x10000000)        /*!<Bit 0 */
 +#define  FMC_BTR3_ACCMOD_1                  ((uint32_t)0x20000000)        /*!<Bit 1 */
 +
 +/******************  Bit definition for FMC_BTR4 register  *******************/
 +#define  FMC_BTR4_ADDSET                    ((uint32_t)0x0000000F)        /*!<ADDSET[3:0] bits (Address setup phase duration) */
 +#define  FMC_BTR4_ADDSET_0                  ((uint32_t)0x00000001)        /*!<Bit 0 */
 +#define  FMC_BTR4_ADDSET_1                  ((uint32_t)0x00000002)        /*!<Bit 1 */
 +#define  FMC_BTR4_ADDSET_2                  ((uint32_t)0x00000004)        /*!<Bit 2 */
 +#define  FMC_BTR4_ADDSET_3                  ((uint32_t)0x00000008)        /*!<Bit 3 */
 +
 +#define  FMC_BTR4_ADDHLD                    ((uint32_t)0x000000F0)        /*!<ADDHLD[3:0] bits (Address-hold phase duration) */
 +#define  FMC_BTR4_ADDHLD_0                  ((uint32_t)0x00000010)        /*!<Bit 0 */
 +#define  FMC_BTR4_ADDHLD_1                  ((uint32_t)0x00000020)        /*!<Bit 1 */
 +#define  FMC_BTR4_ADDHLD_2                  ((uint32_t)0x00000040)        /*!<Bit 2 */
 +#define  FMC_BTR4_ADDHLD_3                  ((uint32_t)0x00000080)        /*!<Bit 3 */
 +
 +#define  FMC_BTR4_DATAST                    ((uint32_t)0x0000FF00)        /*!<DATAST [3:0] bits (Data-phase duration) */
 +#define  FMC_BTR4_DATAST_0                  ((uint32_t)0x00000100)        /*!<Bit 0 */
 +#define  FMC_BTR4_DATAST_1                  ((uint32_t)0x00000200)        /*!<Bit 1 */
 +#define  FMC_BTR4_DATAST_2                  ((uint32_t)0x00000400)        /*!<Bit 2 */
 +#define  FMC_BTR4_DATAST_3                  ((uint32_t)0x00000800)        /*!<Bit 3 */
 +#define  FMC_BTR4_DATAST_4                  ((uint32_t)0x00001000)        /*!<Bit 4 */
 +#define  FMC_BTR4_DATAST_5                  ((uint32_t)0x00002000)        /*!<Bit 5 */
 +#define  FMC_BTR4_DATAST_6                  ((uint32_t)0x00004000)        /*!<Bit 6 */
 +#define  FMC_BTR4_DATAST_7                  ((uint32_t)0x00008000)        /*!<Bit 7 */
 +
 +#define  FMC_BTR4_BUSTURN                   ((uint32_t)0x000F0000)        /*!<BUSTURN[3:0] bits (Bus turnaround phase duration) */
 +#define  FMC_BTR4_BUSTURN_0                 ((uint32_t)0x00010000)        /*!<Bit 0 */
 +#define  FMC_BTR4_BUSTURN_1                 ((uint32_t)0x00020000)        /*!<Bit 1 */
 +#define  FMC_BTR4_BUSTURN_2                 ((uint32_t)0x00040000)        /*!<Bit 2 */
 +#define  FMC_BTR4_BUSTURN_3                 ((uint32_t)0x00080000)        /*!<Bit 3 */
 +
 +#define  FMC_BTR4_CLKDIV                    ((uint32_t)0x00F00000)        /*!<CLKDIV[3:0] bits (Clock divide ratio) */
 +#define  FMC_BTR4_CLKDIV_0                  ((uint32_t)0x00100000)        /*!<Bit 0 */
 +#define  FMC_BTR4_CLKDIV_1                  ((uint32_t)0x00200000)        /*!<Bit 1 */
 +#define  FMC_BTR4_CLKDIV_2                  ((uint32_t)0x00400000)        /*!<Bit 2 */
 +#define  FMC_BTR4_CLKDIV_3                  ((uint32_t)0x00800000)        /*!<Bit 3 */
 +
 +#define  FMC_BTR4_DATLAT                    ((uint32_t)0x0F000000)        /*!<DATLA[3:0] bits (Data latency) */
 +#define  FMC_BTR4_DATLAT_0                  ((uint32_t)0x01000000)        /*!<Bit 0 */
 +#define  FMC_BTR4_DATLAT_1                  ((uint32_t)0x02000000)        /*!<Bit 1 */
 +#define  FMC_BTR4_DATLAT_2                  ((uint32_t)0x04000000)        /*!<Bit 2 */
 +#define  FMC_BTR4_DATLAT_3                  ((uint32_t)0x08000000)        /*!<Bit 3 */
 +
 +#define  FMC_BTR4_ACCMOD                    ((uint32_t)0x30000000)        /*!<ACCMOD[1:0] bits (Access mode) */
 +#define  FMC_BTR4_ACCMOD_0                  ((uint32_t)0x10000000)        /*!<Bit 0 */
 +#define  FMC_BTR4_ACCMOD_1                  ((uint32_t)0x20000000)        /*!<Bit 1 */
 +
 +/******************  Bit definition for FMC_BWTR1 register  ******************/
 +#define  FMC_BWTR1_ADDSET                   ((uint32_t)0x0000000F)        /*!<ADDSET[3:0] bits (Address setup phase duration) */
 +#define  FMC_BWTR1_ADDSET_0                 ((uint32_t)0x00000001)        /*!<Bit 0 */
 +#define  FMC_BWTR1_ADDSET_1                 ((uint32_t)0x00000002)        /*!<Bit 1 */
 +#define  FMC_BWTR1_ADDSET_2                 ((uint32_t)0x00000004)        /*!<Bit 2 */
 +#define  FMC_BWTR1_ADDSET_3                 ((uint32_t)0x00000008)        /*!<Bit 3 */
 +
 +#define  FMC_BWTR1_ADDHLD                   ((uint32_t)0x000000F0)        /*!<ADDHLD[3:0] bits (Address-hold phase duration) */
 +#define  FMC_BWTR1_ADDHLD_0                 ((uint32_t)0x00000010)        /*!<Bit 0 */
 +#define  FMC_BWTR1_ADDHLD_1                 ((uint32_t)0x00000020)        /*!<Bit 1 */
 +#define  FMC_BWTR1_ADDHLD_2                 ((uint32_t)0x00000040)        /*!<Bit 2 */
 +#define  FMC_BWTR1_ADDHLD_3                 ((uint32_t)0x00000080)        /*!<Bit 3 */
 +
 +#define  FMC_BWTR1_DATAST                   ((uint32_t)0x0000FF00)        /*!<DATAST [3:0] bits (Data-phase duration) */
 +#define  FMC_BWTR1_DATAST_0                 ((uint32_t)0x00000100)        /*!<Bit 0 */
 +#define  FMC_BWTR1_DATAST_1                 ((uint32_t)0x00000200)        /*!<Bit 1 */
 +#define  FMC_BWTR1_DATAST_2                 ((uint32_t)0x00000400)        /*!<Bit 2 */
 +#define  FMC_BWTR1_DATAST_3                 ((uint32_t)0x00000800)        /*!<Bit 3 */
 +#define  FMC_BWTR1_DATAST_4                 ((uint32_t)0x00001000)        /*!<Bit 4 */
 +#define  FMC_BWTR1_DATAST_5                 ((uint32_t)0x00002000)        /*!<Bit 5 */
 +#define  FMC_BWTR1_DATAST_6                 ((uint32_t)0x00004000)        /*!<Bit 6 */
 +#define  FMC_BWTR1_DATAST_7                 ((uint32_t)0x00008000)        /*!<Bit 7 */
 +
 +#define  FMC_BWTR1_CLKDIV                   ((uint32_t)0x00F00000)        /*!<CLKDIV[3:0] bits (Clock divide ratio) */
 +#define  FMC_BWTR1_CLKDIV_0                 ((uint32_t)0x00100000)        /*!<Bit 0 */
 +#define  FMC_BWTR1_CLKDIV_1                 ((uint32_t)0x00200000)        /*!<Bit 1 */
 +#define  FMC_BWTR1_CLKDIV_2                 ((uint32_t)0x00400000)        /*!<Bit 2 */
 +#define  FMC_BWTR1_CLKDIV_3                 ((uint32_t)0x00800000)        /*!<Bit 3 */
 +
 +#define  FMC_BWTR1_DATLAT                   ((uint32_t)0x0F000000)        /*!<DATLA[3:0] bits (Data latency) */
 +#define  FMC_BWTR1_DATLAT_0                 ((uint32_t)0x01000000)        /*!<Bit 0 */
 +#define  FMC_BWTR1_DATLAT_1                 ((uint32_t)0x02000000)        /*!<Bit 1 */
 +#define  FMC_BWTR1_DATLAT_2                 ((uint32_t)0x04000000)        /*!<Bit 2 */
 +#define  FMC_BWTR1_DATLAT_3                 ((uint32_t)0x08000000)        /*!<Bit 3 */
 +
 +#define  FMC_BWTR1_ACCMOD                   ((uint32_t)0x30000000)        /*!<ACCMOD[1:0] bits (Access mode) */
 +#define  FMC_BWTR1_ACCMOD_0                 ((uint32_t)0x10000000)        /*!<Bit 0 */
 +#define  FMC_BWTR1_ACCMOD_1                 ((uint32_t)0x20000000)        /*!<Bit 1 */
 +
 +/******************  Bit definition for FMC_BWTR2 register  ******************/
 +#define  FMC_BWTR2_ADDSET                   ((uint32_t)0x0000000F)        /*!<ADDSET[3:0] bits (Address setup phase duration) */
 +#define  FMC_BWTR2_ADDSET_0                 ((uint32_t)0x00000001)        /*!<Bit 0 */
 +#define  FMC_BWTR2_ADDSET_1                 ((uint32_t)0x00000002)        /*!<Bit 1 */
 +#define  FMC_BWTR2_ADDSET_2                 ((uint32_t)0x00000004)        /*!<Bit 2 */
 +#define  FMC_BWTR2_ADDSET_3                 ((uint32_t)0x00000008)        /*!<Bit 3 */
 +
 +#define  FMC_BWTR2_ADDHLD                   ((uint32_t)0x000000F0)        /*!<ADDHLD[3:0] bits (Address-hold phase duration) */
 +#define  FMC_BWTR2_ADDHLD_0                 ((uint32_t)0x00000010)        /*!<Bit 0 */
 +#define  FMC_BWTR2_ADDHLD_1                 ((uint32_t)0x00000020)        /*!<Bit 1 */
 +#define  FMC_BWTR2_ADDHLD_2                 ((uint32_t)0x00000040)        /*!<Bit 2 */
 +#define  FMC_BWTR2_ADDHLD_3                 ((uint32_t)0x00000080)        /*!<Bit 3 */
 +
 +#define  FMC_BWTR2_DATAST                   ((uint32_t)0x0000FF00)        /*!<DATAST [3:0] bits (Data-phase duration) */
 +#define  FMC_BWTR2_DATAST_0                 ((uint32_t)0x00000100)        /*!<Bit 0 */
 +#define  FMC_BWTR2_DATAST_1                 ((uint32_t)0x00000200)        /*!<Bit 1 */
 +#define  FMC_BWTR2_DATAST_2                 ((uint32_t)0x00000400)        /*!<Bit 2 */
 +#define  FMC_BWTR2_DATAST_3                 ((uint32_t)0x00000800)        /*!<Bit 3 */
 +#define  FMC_BWTR2_DATAST_4                 ((uint32_t)0x00001000)        /*!<Bit 4 */
 +#define  FMC_BWTR2_DATAST_5                 ((uint32_t)0x00002000)        /*!<Bit 5 */
 +#define  FMC_BWTR2_DATAST_6                 ((uint32_t)0x00004000)        /*!<Bit 6 */
 +#define  FMC_BWTR2_DATAST_7                 ((uint32_t)0x00008000)        /*!<Bit 7 */
 +
 +#define  FMC_BWTR2_CLKDIV                   ((uint32_t)0x00F00000)        /*!<CLKDIV[3:0] bits (Clock divide ratio) */
 +#define  FMC_BWTR2_CLKDIV_0                 ((uint32_t)0x00100000)        /*!<Bit 0 */
 +#define  FMC_BWTR2_CLKDIV_1                 ((uint32_t)0x00200000)        /*!<Bit 1*/
 +#define  FMC_BWTR2_CLKDIV_2                 ((uint32_t)0x00400000)        /*!<Bit 2 */
 +#define  FMC_BWTR2_CLKDIV_3                 ((uint32_t)0x00800000)        /*!<Bit 3 */
 +
 +#define  FMC_BWTR2_DATLAT                   ((uint32_t)0x0F000000)        /*!<DATLA[3:0] bits (Data latency) */
 +#define  FMC_BWTR2_DATLAT_0                 ((uint32_t)0x01000000)        /*!<Bit 0 */
 +#define  FMC_BWTR2_DATLAT_1                 ((uint32_t)0x02000000)        /*!<Bit 1 */
 +#define  FMC_BWTR2_DATLAT_2                 ((uint32_t)0x04000000)        /*!<Bit 2 */
 +#define  FMC_BWTR2_DATLAT_3                 ((uint32_t)0x08000000)        /*!<Bit 3 */
 +
 +#define  FMC_BWTR2_ACCMOD                   ((uint32_t)0x30000000)        /*!<ACCMOD[1:0] bits (Access mode) */
 +#define  FMC_BWTR2_ACCMOD_0                 ((uint32_t)0x10000000)        /*!<Bit 0 */
 +#define  FMC_BWTR2_ACCMOD_1                 ((uint32_t)0x20000000)        /*!<Bit 1 */
 +
 +/******************  Bit definition for FMC_BWTR3 register  ******************/
 +#define  FMC_BWTR3_ADDSET                   ((uint32_t)0x0000000F)        /*!<ADDSET[3:0] bits (Address setup phase duration) */
 +#define  FMC_BWTR3_ADDSET_0                 ((uint32_t)0x00000001)        /*!<Bit 0 */
 +#define  FMC_BWTR3_ADDSET_1                 ((uint32_t)0x00000002)        /*!<Bit 1 */
 +#define  FMC_BWTR3_ADDSET_2                 ((uint32_t)0x00000004)        /*!<Bit 2 */
 +#define  FMC_BWTR3_ADDSET_3                 ((uint32_t)0x00000008)        /*!<Bit 3 */
 +
 +#define  FMC_BWTR3_ADDHLD                   ((uint32_t)0x000000F0)        /*!<ADDHLD[3:0] bits (Address-hold phase duration) */
 +#define  FMC_BWTR3_ADDHLD_0                 ((uint32_t)0x00000010)        /*!<Bit 0 */
 +#define  FMC_BWTR3_ADDHLD_1                 ((uint32_t)0x00000020)        /*!<Bit 1 */
 +#define  FMC_BWTR3_ADDHLD_2                 ((uint32_t)0x00000040)        /*!<Bit 2 */
 +#define  FMC_BWTR3_ADDHLD_3                 ((uint32_t)0x00000080)        /*!<Bit 3 */
 +
 +#define  FMC_BWTR3_DATAST                   ((uint32_t)0x0000FF00)        /*!<DATAST [3:0] bits (Data-phase duration) */
 +#define  FMC_BWTR3_DATAST_0                 ((uint32_t)0x00000100)        /*!<Bit 0 */
 +#define  FMC_BWTR3_DATAST_1                 ((uint32_t)0x00000200)        /*!<Bit 1 */
 +#define  FMC_BWTR3_DATAST_2                 ((uint32_t)0x00000400)        /*!<Bit 2 */
 +#define  FMC_BWTR3_DATAST_3                 ((uint32_t)0x00000800)        /*!<Bit 3 */
 +#define  FMC_BWTR3_DATAST_4                 ((uint32_t)0x00001000)        /*!<Bit 4 */
 +#define  FMC_BWTR3_DATAST_5                 ((uint32_t)0x00002000)        /*!<Bit 5 */
 +#define  FMC_BWTR3_DATAST_6                 ((uint32_t)0x00004000)        /*!<Bit 6 */
 +#define  FMC_BWTR3_DATAST_7                 ((uint32_t)0x00008000)        /*!<Bit 7 */
 +
 +#define  FMC_BWTR3_CLKDIV                   ((uint32_t)0x00F00000)        /*!<CLKDIV[3:0] bits (Clock divide ratio) */
 +#define  FMC_BWTR3_CLKDIV_0                 ((uint32_t)0x00100000)        /*!<Bit 0 */
 +#define  FMC_BWTR3_CLKDIV_1                 ((uint32_t)0x00200000)        /*!<Bit 1 */
 +#define  FMC_BWTR3_CLKDIV_2                 ((uint32_t)0x00400000)        /*!<Bit 2 */
 +#define  FMC_BWTR3_CLKDIV_3                 ((uint32_t)0x00800000)        /*!<Bit 3 */
 +
 +#define  FMC_BWTR3_DATLAT                   ((uint32_t)0x0F000000)        /*!<DATLA[3:0] bits (Data latency) */
 +#define  FMC_BWTR3_DATLAT_0                 ((uint32_t)0x01000000)        /*!<Bit 0 */
 +#define  FMC_BWTR3_DATLAT_1                 ((uint32_t)0x02000000)        /*!<Bit 1 */
 +#define  FMC_BWTR3_DATLAT_2                 ((uint32_t)0x04000000)        /*!<Bit 2 */
 +#define  FMC_BWTR3_DATLAT_3                 ((uint32_t)0x08000000)        /*!<Bit 3 */
 +
 +#define  FMC_BWTR3_ACCMOD                   ((uint32_t)0x30000000)        /*!<ACCMOD[1:0] bits (Access mode) */
 +#define  FMC_BWTR3_ACCMOD_0                 ((uint32_t)0x10000000)        /*!<Bit 0 */
 +#define  FMC_BWTR3_ACCMOD_1                 ((uint32_t)0x20000000)        /*!<Bit 1 */
 +
 +/******************  Bit definition for FMC_BWTR4 register  ******************/
 +#define  FMC_BWTR4_ADDSET                   ((uint32_t)0x0000000F)        /*!<ADDSET[3:0] bits (Address setup phase duration) */
 +#define  FMC_BWTR4_ADDSET_0                 ((uint32_t)0x00000001)        /*!<Bit 0 */
 +#define  FMC_BWTR4_ADDSET_1                 ((uint32_t)0x00000002)        /*!<Bit 1 */
 +#define  FMC_BWTR4_ADDSET_2                 ((uint32_t)0x00000004)        /*!<Bit 2 */
 +#define  FMC_BWTR4_ADDSET_3                 ((uint32_t)0x00000008)        /*!<Bit 3 */
 +
 +#define  FMC_BWTR4_ADDHLD                   ((uint32_t)0x000000F0)        /*!<ADDHLD[3:0] bits (Address-hold phase duration) */
 +#define  FMC_BWTR4_ADDHLD_0                 ((uint32_t)0x00000010)        /*!<Bit 0 */
 +#define  FMC_BWTR4_ADDHLD_1                 ((uint32_t)0x00000020)        /*!<Bit 1 */
 +#define  FMC_BWTR4_ADDHLD_2                 ((uint32_t)0x00000040)        /*!<Bit 2 */
 +#define  FMC_BWTR4_ADDHLD_3                 ((uint32_t)0x00000080)        /*!<Bit 3 */
 +
 +#define  FMC_BWTR4_DATAST                   ((uint32_t)0x0000FF00)        /*!<DATAST [3:0] bits (Data-phase duration) */
 +#define  FMC_BWTR4_DATAST_0                 ((uint32_t)0x00000100)        /*!<Bit 0 */
 +#define  FMC_BWTR4_DATAST_1                 ((uint32_t)0x00000200)        /*!<Bit 1 */
 +#define  FMC_BWTR4_DATAST_2                 ((uint32_t)0x00000400)        /*!<Bit 2 */
 +#define  FMC_BWTR4_DATAST_3                 ((uint32_t)0x00000800)        /*!<Bit 3 */
 +#define  FMC_BWTR4_DATAST_4                 ((uint32_t)0x00001000)        /*!<Bit 4 */
 +#define  FMC_BWTR4_DATAST_5                 ((uint32_t)0x00002000)        /*!<Bit 5 */
 +#define  FMC_BWTR4_DATAST_6                 ((uint32_t)0x00004000)        /*!<Bit 6 */
 +#define  FMC_BWTR4_DATAST_7                 ((uint32_t)0x00008000)        /*!<Bit 7 */
 +
 +#define  FMC_BWTR4_CLKDIV                   ((uint32_t)0x00F00000)        /*!<CLKDIV[3:0] bits (Clock divide ratio) */
 +#define  FMC_BWTR4_CLKDIV_0                 ((uint32_t)0x00100000)        /*!<Bit 0 */
 +#define  FMC_BWTR4_CLKDIV_1                 ((uint32_t)0x00200000)        /*!<Bit 1 */
 +#define  FMC_BWTR4_CLKDIV_2                 ((uint32_t)0x00400000)        /*!<Bit 2 */
 +#define  FMC_BWTR4_CLKDIV_3                 ((uint32_t)0x00800000)        /*!<Bit 3 */
 +
 +#define  FMC_BWTR4_DATLAT                   ((uint32_t)0x0F000000)        /*!<DATLA[3:0] bits (Data latency) */
 +#define  FMC_BWTR4_DATLAT_0                 ((uint32_t)0x01000000)        /*!<Bit 0 */
 +#define  FMC_BWTR4_DATLAT_1                 ((uint32_t)0x02000000)        /*!<Bit 1 */
 +#define  FMC_BWTR4_DATLAT_2                 ((uint32_t)0x04000000)        /*!<Bit 2 */
 +#define  FMC_BWTR4_DATLAT_3                 ((uint32_t)0x08000000)        /*!<Bit 3 */
 +
 +#define  FMC_BWTR4_ACCMOD                   ((uint32_t)0x30000000)        /*!<ACCMOD[1:0] bits (Access mode) */
 +#define  FMC_BWTR4_ACCMOD_0                 ((uint32_t)0x10000000)        /*!<Bit 0 */
 +#define  FMC_BWTR4_ACCMOD_1                 ((uint32_t)0x20000000)        /*!<Bit 1 */
 +
 +/******************  Bit definition for FMC_PCR2 register  *******************/
 +#define  FMC_PCR2_PWAITEN                   ((uint32_t)0x00000002)        /*!<Wait feature enable bit                   */
 +#define  FMC_PCR2_PBKEN                     ((uint32_t)0x00000004)        /*!<PC Card/NAND Flash memory bank enable bit */
 +#define  FMC_PCR2_PTYP                      ((uint32_t)0x00000008)        /*!<Memory type                               */
 +
 +#define  FMC_PCR2_PWID                      ((uint32_t)0x00000030)        /*!<PWID[1:0] bits (NAND Flash databus width) */
 +#define  FMC_PCR2_PWID_0                    ((uint32_t)0x00000010)        /*!<Bit 0 */
 +#define  FMC_PCR2_PWID_1                    ((uint32_t)0x00000020)        /*!<Bit 1 */
 +
 +#define  FMC_PCR2_ECCEN                     ((uint32_t)0x00000040)        /*!<ECC computation logic enable bit          */
 +
 +#define  FMC_PCR2_TCLR                      ((uint32_t)0x00001E00)        /*!<TCLR[3:0] bits (CLE to RE delay)          */
 +#define  FMC_PCR2_TCLR_0                    ((uint32_t)0x00000200)        /*!<Bit 0 */
 +#define  FMC_PCR2_TCLR_1                    ((uint32_t)0x00000400)        /*!<Bit 1 */
 +#define  FMC_PCR2_TCLR_2                    ((uint32_t)0x00000800)        /*!<Bit 2 */
 +#define  FMC_PCR2_TCLR_3                    ((uint32_t)0x00001000)        /*!<Bit 3 */
 +
 +#define  FMC_PCR2_TAR                       ((uint32_t)0x0001E000)        /*!<TAR[3:0] bits (ALE to RE delay)           */
 +#define  FMC_PCR2_TAR_0                     ((uint32_t)0x00002000)        /*!<Bit 0 */
 +#define  FMC_PCR2_TAR_1                     ((uint32_t)0x00004000)        /*!<Bit 1 */
 +#define  FMC_PCR2_TAR_2                     ((uint32_t)0x00008000)        /*!<Bit 2 */
 +#define  FMC_PCR2_TAR_3                     ((uint32_t)0x00010000)        /*!<Bit 3 */
 +
 +#define  FMC_PCR2_ECCPS                     ((uint32_t)0x000E0000)        /*!<ECCPS[1:0] bits (ECC page size)           */
 +#define  FMC_PCR2_ECCPS_0                   ((uint32_t)0x00020000)        /*!<Bit 0 */
 +#define  FMC_PCR2_ECCPS_1                   ((uint32_t)0x00040000)        /*!<Bit 1 */
 +#define  FMC_PCR2_ECCPS_2                   ((uint32_t)0x00080000)        /*!<Bit 2 */
 +
 +/******************  Bit definition for FMC_PCR3 register  *******************/
 +#define  FMC_PCR3_PWAITEN                   ((uint32_t)0x00000002)        /*!<Wait feature enable bit                   */
 +#define  FMC_PCR3_PBKEN                     ((uint32_t)0x00000004)        /*!<PC Card/NAND Flash memory bank enable bit */
 +#define  FMC_PCR3_PTYP                      ((uint32_t)0x00000008)        /*!<Memory type                               */
 +
 +#define  FMC_PCR3_PWID                      ((uint32_t)0x00000030)        /*!<PWID[1:0] bits (NAND Flash databus width) */
 +#define  FMC_PCR3_PWID_0                    ((uint32_t)0x00000010)        /*!<Bit 0 */
 +#define  FMC_PCR3_PWID_1                    ((uint32_t)0x00000020)        /*!<Bit 1 */
 +
 +#define  FMC_PCR3_ECCEN                     ((uint32_t)0x00000040)        /*!<ECC computation logic enable bit          */
 +
 +#define  FMC_PCR3_TCLR                      ((uint32_t)0x00001E00)        /*!<TCLR[3:0] bits (CLE to RE delay)          */
 +#define  FMC_PCR3_TCLR_0                    ((uint32_t)0x00000200)        /*!<Bit 0 */
 +#define  FMC_PCR3_TCLR_1                    ((uint32_t)0x00000400)        /*!<Bit 1 */
 +#define  FMC_PCR3_TCLR_2                    ((uint32_t)0x00000800)        /*!<Bit 2 */
 +#define  FMC_PCR3_TCLR_3                    ((uint32_t)0x00001000)        /*!<Bit 3 */
 +
 +#define  FMC_PCR3_TAR                       ((uint32_t)0x0001E000)        /*!<TAR[3:0] bits (ALE to RE delay)           */
 +#define  FMC_PCR3_TAR_0                     ((uint32_t)0x00002000)        /*!<Bit 0 */
 +#define  FMC_PCR3_TAR_1                     ((uint32_t)0x00004000)        /*!<Bit 1 */
 +#define  FMC_PCR3_TAR_2                     ((uint32_t)0x00008000)        /*!<Bit 2 */
 +#define  FMC_PCR3_TAR_3                     ((uint32_t)0x00010000)        /*!<Bit 3 */
 +
 +#define  FMC_PCR3_ECCPS                     ((uint32_t)0x000E0000)        /*!<ECCPS[2:0] bits (ECC page size)           */
 +#define  FMC_PCR3_ECCPS_0                   ((uint32_t)0x00020000)        /*!<Bit 0 */
 +#define  FMC_PCR3_ECCPS_1                   ((uint32_t)0x00040000)        /*!<Bit 1 */
 +#define  FMC_PCR3_ECCPS_2                   ((uint32_t)0x00080000)        /*!<Bit 2 */
 +
 +/******************  Bit definition for FMC_PCR4 register  *******************/
 +#define  FMC_PCR4_PWAITEN                   ((uint32_t)0x00000002)        /*!<Wait feature enable bit                   */
 +#define  FMC_PCR4_PBKEN                     ((uint32_t)0x00000004)        /*!<PC Card/NAND Flash memory bank enable bit */
 +#define  FMC_PCR4_PTYP                      ((uint32_t)0x00000008)        /*!<Memory type                               */
 +
 +#define  FMC_PCR4_PWID                      ((uint32_t)0x00000030)        /*!<PWID[1:0] bits (NAND Flash databus width) */
 +#define  FMC_PCR4_PWID_0                    ((uint32_t)0x00000010)        /*!<Bit 0 */
 +#define  FMC_PCR4_PWID_1                    ((uint32_t)0x00000020)        /*!<Bit 1 */
 +
 +#define  FMC_PCR4_ECCEN                     ((uint32_t)0x00000040)        /*!<ECC computation logic enable bit          */
 +
 +#define  FMC_PCR4_TCLR                      ((uint32_t)0x00001E00)        /*!<TCLR[3:0] bits (CLE to RE delay)          */
 +#define  FMC_PCR4_TCLR_0                    ((uint32_t)0x00000200)        /*!<Bit 0 */
 +#define  FMC_PCR4_TCLR_1                    ((uint32_t)0x00000400)        /*!<Bit 1 */
 +#define  FMC_PCR4_TCLR_2                    ((uint32_t)0x00000800)        /*!<Bit 2 */
 +#define  FMC_PCR4_TCLR_3                    ((uint32_t)0x00001000)        /*!<Bit 3 */
 +
 +#define  FMC_PCR4_TAR                       ((uint32_t)0x0001E000)        /*!<TAR[3:0] bits (ALE to RE delay)           */
 +#define  FMC_PCR4_TAR_0                     ((uint32_t)0x00002000)        /*!<Bit 0 */
 +#define  FMC_PCR4_TAR_1                     ((uint32_t)0x00004000)        /*!<Bit 1 */
 +#define  FMC_PCR4_TAR_2                     ((uint32_t)0x00008000)        /*!<Bit 2 */
 +#define  FMC_PCR4_TAR_3                     ((uint32_t)0x00010000)        /*!<Bit 3 */
 +
 +#define  FMC_PCR4_ECCPS                     ((uint32_t)0x000E0000)        /*!<ECCPS[2:0] bits (ECC page size)           */
 +#define  FMC_PCR4_ECCPS_0                   ((uint32_t)0x00020000)        /*!<Bit 0 */
 +#define  FMC_PCR4_ECCPS_1                   ((uint32_t)0x00040000)        /*!<Bit 1 */
 +#define  FMC_PCR4_ECCPS_2                   ((uint32_t)0x00080000)        /*!<Bit 2 */
 +
 +/*******************  Bit definition for FMC_SR2 register  *******************/
 +#define  FMC_SR2_IRS                        ((uint8_t)0x01)               /*!<Interrupt Rising Edge status                */
 +#define  FMC_SR2_ILS                        ((uint8_t)0x02)               /*!<Interrupt Level status                      */
 +#define  FMC_SR2_IFS                        ((uint8_t)0x04)               /*!<Interrupt Falling Edge status               */
 +#define  FMC_SR2_IREN                       ((uint8_t)0x08)               /*!<Interrupt Rising Edge detection Enable bit  */
 +#define  FMC_SR2_ILEN                       ((uint8_t)0x10)               /*!<Interrupt Level detection Enable bit        */
 +#define  FMC_SR2_IFEN                       ((uint8_t)0x20)               /*!<Interrupt Falling Edge detection Enable bit */
 +#define  FMC_SR2_FEMPT                      ((uint8_t)0x40)               /*!<FIFO empty                                  */
 +
 +/*******************  Bit definition for FMC_SR3 register  *******************/
 +#define  FMC_SR3_IRS                        ((uint8_t)0x01)               /*!<Interrupt Rising Edge status                */
 +#define  FMC_SR3_ILS                        ((uint8_t)0x02)               /*!<Interrupt Level status                      */
 +#define  FMC_SR3_IFS                        ((uint8_t)0x04)               /*!<Interrupt Falling Edge status               */
 +#define  FMC_SR3_IREN                       ((uint8_t)0x08)               /*!<Interrupt Rising Edge detection Enable bit  */
 +#define  FMC_SR3_ILEN                       ((uint8_t)0x10)               /*!<Interrupt Level detection Enable bit        */
 +#define  FMC_SR3_IFEN                       ((uint8_t)0x20)               /*!<Interrupt Falling Edge detection Enable bit */
 +#define  FMC_SR3_FEMPT                      ((uint8_t)0x40)               /*!<FIFO empty                                  */
 +
 +/*******************  Bit definition for FMC_SR4 register  *******************/
 +#define  FMC_SR4_IRS                        ((uint8_t)0x01)               /*!<Interrupt Rising Edge status                */
 +#define  FMC_SR4_ILS                        ((uint8_t)0x02)               /*!<Interrupt Level status                      */
 +#define  FMC_SR4_IFS                        ((uint8_t)0x04)               /*!<Interrupt Falling Edge status               */
 +#define  FMC_SR4_IREN                       ((uint8_t)0x08)               /*!<Interrupt Rising Edge detection Enable bit  */
 +#define  FMC_SR4_ILEN                       ((uint8_t)0x10)               /*!<Interrupt Level detection Enable bit        */
 +#define  FMC_SR4_IFEN                       ((uint8_t)0x20)               /*!<Interrupt Falling Edge detection Enable bit */
 +#define  FMC_SR4_FEMPT                      ((uint8_t)0x40)               /*!<FIFO empty                                  */
 +
 +/******************  Bit definition for FMC_PMEM2 register  ******************/
 +#define  FMC_PMEM2_MEMSET2                  ((uint32_t)0x000000FF)        /*!<MEMSET2[7:0] bits (Common memory 2 setup time) */
 +#define  FMC_PMEM2_MEMSET2_0                ((uint32_t)0x00000001)        /*!<Bit 0 */
 +#define  FMC_PMEM2_MEMSET2_1                ((uint32_t)0x00000002)        /*!<Bit 1 */
 +#define  FMC_PMEM2_MEMSET2_2                ((uint32_t)0x00000004)        /*!<Bit 2 */
 +#define  FMC_PMEM2_MEMSET2_3                ((uint32_t)0x00000008)        /*!<Bit 3 */
 +#define  FMC_PMEM2_MEMSET2_4                ((uint32_t)0x00000010)        /*!<Bit 4 */
 +#define  FMC_PMEM2_MEMSET2_5                ((uint32_t)0x00000020)        /*!<Bit 5 */
 +#define  FMC_PMEM2_MEMSET2_6                ((uint32_t)0x00000040)        /*!<Bit 6 */
 +#define  FMC_PMEM2_MEMSET2_7                ((uint32_t)0x00000080)        /*!<Bit 7 */
 +
 +#define  FMC_PMEM2_MEMWAIT2                 ((uint32_t)0x0000FF00)        /*!<MEMWAIT2[7:0] bits (Common memory 2 wait time) */
 +#define  FMC_PMEM2_MEMWAIT2_0               ((uint32_t)0x00000100)        /*!<Bit 0 */
 +#define  FMC_PMEM2_MEMWAIT2_1               ((uint32_t)0x00000200)        /*!<Bit 1 */
 +#define  FMC_PMEM2_MEMWAIT2_2               ((uint32_t)0x00000400)        /*!<Bit 2 */
 +#define  FMC_PMEM2_MEMWAIT2_3               ((uint32_t)0x00000800)        /*!<Bit 3 */
 +#define  FMC_PMEM2_MEMWAIT2_4               ((uint32_t)0x00001000)        /*!<Bit 4 */
 +#define  FMC_PMEM2_MEMWAIT2_5               ((uint32_t)0x00002000)        /*!<Bit 5 */
 +#define  FMC_PMEM2_MEMWAIT2_6               ((uint32_t)0x00004000)        /*!<Bit 6 */
 +#define  FMC_PMEM2_MEMWAIT2_7               ((uint32_t)0x00008000)        /*!<Bit 7 */
 +
 +#define  FMC_PMEM2_MEMHOLD2                 ((uint32_t)0x00FF0000)        /*!<MEMHOLD2[7:0] bits (Common memory 2 hold time) */
 +#define  FMC_PMEM2_MEMHOLD2_0               ((uint32_t)0x00010000)        /*!<Bit 0 */
 +#define  FMC_PMEM2_MEMHOLD2_1               ((uint32_t)0x00020000)        /*!<Bit 1 */
 +#define  FMC_PMEM2_MEMHOLD2_2               ((uint32_t)0x00040000)        /*!<Bit 2 */
 +#define  FMC_PMEM2_MEMHOLD2_3               ((uint32_t)0x00080000)        /*!<Bit 3 */
 +#define  FMC_PMEM2_MEMHOLD2_4               ((uint32_t)0x00100000)        /*!<Bit 4 */
 +#define  FMC_PMEM2_MEMHOLD2_5               ((uint32_t)0x00200000)        /*!<Bit 5 */
 +#define  FMC_PMEM2_MEMHOLD2_6               ((uint32_t)0x00400000)        /*!<Bit 6 */
 +#define  FMC_PMEM2_MEMHOLD2_7               ((uint32_t)0x00800000)        /*!<Bit 7 */
 +
 +#define  FMC_PMEM2_MEMHIZ2                  ((uint32_t)0xFF000000)        /*!<MEMHIZ2[7:0] bits (Common memory 2 databus HiZ time) */
 +#define  FMC_PMEM2_MEMHIZ2_0                ((uint32_t)0x01000000)        /*!<Bit 0 */
 +#define  FMC_PMEM2_MEMHIZ2_1                ((uint32_t)0x02000000)        /*!<Bit 1 */
 +#define  FMC_PMEM2_MEMHIZ2_2                ((uint32_t)0x04000000)        /*!<Bit 2 */
 +#define  FMC_PMEM2_MEMHIZ2_3                ((uint32_t)0x08000000)        /*!<Bit 3 */
 +#define  FMC_PMEM2_MEMHIZ2_4                ((uint32_t)0x10000000)        /*!<Bit 4 */
 +#define  FMC_PMEM2_MEMHIZ2_5                ((uint32_t)0x20000000)        /*!<Bit 5 */
 +#define  FMC_PMEM2_MEMHIZ2_6                ((uint32_t)0x40000000)        /*!<Bit 6 */
 +#define  FMC_PMEM2_MEMHIZ2_7                ((uint32_t)0x80000000)        /*!<Bit 7 */
 +
 +/******************  Bit definition for FMC_PMEM3 register  ******************/
 +#define  FMC_PMEM3_MEMSET3                  ((uint32_t)0x000000FF)        /*!<MEMSET3[7:0] bits (Common memory 3 setup time) */
 +#define  FMC_PMEM3_MEMSET3_0                ((uint32_t)0x00000001)        /*!<Bit 0 */
 +#define  FMC_PMEM3_MEMSET3_1                ((uint32_t)0x00000002)        /*!<Bit 1 */
 +#define  FMC_PMEM3_MEMSET3_2                ((uint32_t)0x00000004)        /*!<Bit 2 */
 +#define  FMC_PMEM3_MEMSET3_3                ((uint32_t)0x00000008)        /*!<Bit 3 */
 +#define  FMC_PMEM3_MEMSET3_4                ((uint32_t)0x00000010)        /*!<Bit 4 */
 +#define  FMC_PMEM3_MEMSET3_5                ((uint32_t)0x00000020)        /*!<Bit 5 */
 +#define  FMC_PMEM3_MEMSET3_6                ((uint32_t)0x00000040)        /*!<Bit 6 */
 +#define  FMC_PMEM3_MEMSET3_7                ((uint32_t)0x00000080)        /*!<Bit 7 */
 +
 +#define  FMC_PMEM3_MEMWAIT3                 ((uint32_t)0x0000FF00)        /*!<MEMWAIT3[7:0] bits (Common memory 3 wait time) */
 +#define  FMC_PMEM3_MEMWAIT3_0               ((uint32_t)0x00000100)        /*!<Bit 0 */
 +#define  FMC_PMEM3_MEMWAIT3_1               ((uint32_t)0x00000200)        /*!<Bit 1 */
 +#define  FMC_PMEM3_MEMWAIT3_2               ((uint32_t)0x00000400)        /*!<Bit 2 */
 +#define  FMC_PMEM3_MEMWAIT3_3               ((uint32_t)0x00000800)        /*!<Bit 3 */
 +#define  FMC_PMEM3_MEMWAIT3_4               ((uint32_t)0x00001000)        /*!<Bit 4 */
 +#define  FMC_PMEM3_MEMWAIT3_5               ((uint32_t)0x00002000)        /*!<Bit 5 */
 +#define  FMC_PMEM3_MEMWAIT3_6               ((uint32_t)0x00004000)        /*!<Bit 6 */
 +#define  FMC_PMEM3_MEMWAIT3_7               ((uint32_t)0x00008000)        /*!<Bit 7 */
 +
 +#define  FMC_PMEM3_MEMHOLD3                 ((uint32_t)0x00FF0000)        /*!<MEMHOLD3[7:0] bits (Common memory 3 hold time) */
 +#define  FMC_PMEM3_MEMHOLD3_0               ((uint32_t)0x00010000)        /*!<Bit 0 */
 +#define  FMC_PMEM3_MEMHOLD3_1               ((uint32_t)0x00020000)        /*!<Bit 1 */
 +#define  FMC_PMEM3_MEMHOLD3_2               ((uint32_t)0x00040000)        /*!<Bit 2 */
 +#define  FMC_PMEM3_MEMHOLD3_3               ((uint32_t)0x00080000)        /*!<Bit 3 */
 +#define  FMC_PMEM3_MEMHOLD3_4               ((uint32_t)0x00100000)        /*!<Bit 4 */
 +#define  FMC_PMEM3_MEMHOLD3_5               ((uint32_t)0x00200000)        /*!<Bit 5 */
 +#define  FMC_PMEM3_MEMHOLD3_6               ((uint32_t)0x00400000)        /*!<Bit 6 */
 +#define  FMC_PMEM3_MEMHOLD3_7               ((uint32_t)0x00800000)        /*!<Bit 7 */
 +
 +#define  FMC_PMEM3_MEMHIZ3                  ((uint32_t)0xFF000000)        /*!<MEMHIZ3[7:0] bits (Common memory 3 databus HiZ time) */
 +#define  FMC_PMEM3_MEMHIZ3_0                ((uint32_t)0x01000000)        /*!<Bit 0 */
 +#define  FMC_PMEM3_MEMHIZ3_1                ((uint32_t)0x02000000)        /*!<Bit 1 */
 +#define  FMC_PMEM3_MEMHIZ3_2                ((uint32_t)0x04000000)        /*!<Bit 2 */
 +#define  FMC_PMEM3_MEMHIZ3_3                ((uint32_t)0x08000000)        /*!<Bit 3 */
 +#define  FMC_PMEM3_MEMHIZ3_4                ((uint32_t)0x10000000)        /*!<Bit 4 */
 +#define  FMC_PMEM3_MEMHIZ3_5                ((uint32_t)0x20000000)        /*!<Bit 5 */
 +#define  FMC_PMEM3_MEMHIZ3_6                ((uint32_t)0x40000000)        /*!<Bit 6 */
 +#define  FMC_PMEM3_MEMHIZ3_7                ((uint32_t)0x80000000)        /*!<Bit 7 */
 +
 +/******************  Bit definition for FMC_PMEM4 register  ******************/
 +#define  FMC_PMEM4_MEMSET4                  ((uint32_t)0x000000FF)        /*!<MEMSET4[7:0] bits (Common memory 4 setup time) */
 +#define  FMC_PMEM4_MEMSET4_0                ((uint32_t)0x00000001)        /*!<Bit 0 */
 +#define  FMC_PMEM4_MEMSET4_1                ((uint32_t)0x00000002)        /*!<Bit 1 */
 +#define  FMC_PMEM4_MEMSET4_2                ((uint32_t)0x00000004)        /*!<Bit 2 */
 +#define  FMC_PMEM4_MEMSET4_3                ((uint32_t)0x00000008)        /*!<Bit 3 */
 +#define  FMC_PMEM4_MEMSET4_4                ((uint32_t)0x00000010)        /*!<Bit 4 */
 +#define  FMC_PMEM4_MEMSET4_5                ((uint32_t)0x00000020)        /*!<Bit 5 */
 +#define  FMC_PMEM4_MEMSET4_6                ((uint32_t)0x00000040)        /*!<Bit 6 */
 +#define  FMC_PMEM4_MEMSET4_7                ((uint32_t)0x00000080)        /*!<Bit 7 */
 +
 +#define  FMC_PMEM4_MEMWAIT4                 ((uint32_t)0x0000FF00)        /*!<MEMWAIT4[7:0] bits (Common memory 4 wait time) */
 +#define  FMC_PMEM4_MEMWAIT4_0               ((uint32_t)0x00000100)        /*!<Bit 0 */
 +#define  FMC_PMEM4_MEMWAIT4_1               ((uint32_t)0x00000200)        /*!<Bit 1 */
 +#define  FMC_PMEM4_MEMWAIT4_2               ((uint32_t)0x00000400)        /*!<Bit 2 */
 +#define  FMC_PMEM4_MEMWAIT4_3               ((uint32_t)0x00000800)        /*!<Bit 3 */
 +#define  FMC_PMEM4_MEMWAIT4_4               ((uint32_t)0x00001000)        /*!<Bit 4 */
 +#define  FMC_PMEM4_MEMWAIT4_5               ((uint32_t)0x00002000)        /*!<Bit 5 */
 +#define  FMC_PMEM4_MEMWAIT4_6               ((uint32_t)0x00004000)        /*!<Bit 6 */
 +#define  FMC_PMEM4_MEMWAIT4_7               ((uint32_t)0x00008000)        /*!<Bit 7 */
 +
 +#define  FMC_PMEM4_MEMHOLD4                 ((uint32_t)0x00FF0000)        /*!<MEMHOLD4[7:0] bits (Common memory 4 hold time) */
 +#define  FMC_PMEM4_MEMHOLD4_0               ((uint32_t)0x00010000)        /*!<Bit 0 */
 +#define  FMC_PMEM4_MEMHOLD4_1               ((uint32_t)0x00020000)        /*!<Bit 1 */
 +#define  FMC_PMEM4_MEMHOLD4_2               ((uint32_t)0x00040000)        /*!<Bit 2 */
 +#define  FMC_PMEM4_MEMHOLD4_3               ((uint32_t)0x00080000)        /*!<Bit 3 */
 +#define  FMC_PMEM4_MEMHOLD4_4               ((uint32_t)0x00100000)        /*!<Bit 4 */
 +#define  FMC_PMEM4_MEMHOLD4_5               ((uint32_t)0x00200000)        /*!<Bit 5 */
 +#define  FMC_PMEM4_MEMHOLD4_6               ((uint32_t)0x00400000)        /*!<Bit 6 */
 +#define  FMC_PMEM4_MEMHOLD4_7               ((uint32_t)0x00800000)        /*!<Bit 7 */
 +
 +#define  FMC_PMEM4_MEMHIZ4                  ((uint32_t)0xFF000000)        /*!<MEMHIZ4[7:0] bits (Common memory 4 databus HiZ time) */
 +#define  FMC_PMEM4_MEMHIZ4_0                ((uint32_t)0x01000000)        /*!<Bit 0 */
 +#define  FMC_PMEM4_MEMHIZ4_1                ((uint32_t)0x02000000)        /*!<Bit 1 */
 +#define  FMC_PMEM4_MEMHIZ4_2                ((uint32_t)0x04000000)        /*!<Bit 2 */
 +#define  FMC_PMEM4_MEMHIZ4_3                ((uint32_t)0x08000000)        /*!<Bit 3 */
 +#define  FMC_PMEM4_MEMHIZ4_4                ((uint32_t)0x10000000)        /*!<Bit 4 */
 +#define  FMC_PMEM4_MEMHIZ4_5                ((uint32_t)0x20000000)        /*!<Bit 5 */
 +#define  FMC_PMEM4_MEMHIZ4_6                ((uint32_t)0x40000000)        /*!<Bit 6 */
 +#define  FMC_PMEM4_MEMHIZ4_7                ((uint32_t)0x80000000)        /*!<Bit 7 */
 +
 +/******************  Bit definition for FMC_PATT2 register  ******************/
 +#define  FMC_PATT2_ATTSET2                  ((uint32_t)0x000000FF)        /*!<ATTSET2[7:0] bits (Attribute memory 2 setup time) */
 +#define  FMC_PATT2_ATTSET2_0                ((uint32_t)0x00000001)        /*!<Bit 0 */
 +#define  FMC_PATT2_ATTSET2_1                ((uint32_t)0x00000002)        /*!<Bit 1 */
 +#define  FMC_PATT2_ATTSET2_2                ((uint32_t)0x00000004)        /*!<Bit 2 */
 +#define  FMC_PATT2_ATTSET2_3                ((uint32_t)0x00000008)        /*!<Bit 3 */
 +#define  FMC_PATT2_ATTSET2_4                ((uint32_t)0x00000010)        /*!<Bit 4 */
 +#define  FMC_PATT2_ATTSET2_5                ((uint32_t)0x00000020)        /*!<Bit 5 */
 +#define  FMC_PATT2_ATTSET2_6                ((uint32_t)0x00000040)        /*!<Bit 6 */
 +#define  FMC_PATT2_ATTSET2_7                ((uint32_t)0x00000080)        /*!<Bit 7 */
 +
 +#define  FMC_PATT2_ATTWAIT2                 ((uint32_t)0x0000FF00)        /*!<ATTWAIT2[7:0] bits (Attribute memory 2 wait time) */
 +#define  FMC_PATT2_ATTWAIT2_0               ((uint32_t)0x00000100)        /*!<Bit 0 */
 +#define  FMC_PATT2_ATTWAIT2_1               ((uint32_t)0x00000200)        /*!<Bit 1 */
 +#define  FMC_PATT2_ATTWAIT2_2               ((uint32_t)0x00000400)        /*!<Bit 2 */
 +#define  FMC_PATT2_ATTWAIT2_3               ((uint32_t)0x00000800)        /*!<Bit 3 */
 +#define  FMC_PATT2_ATTWAIT2_4               ((uint32_t)0x00001000)        /*!<Bit 4 */
 +#define  FMC_PATT2_ATTWAIT2_5               ((uint32_t)0x00002000)        /*!<Bit 5 */
 +#define  FMC_PATT2_ATTWAIT2_6               ((uint32_t)0x00004000)        /*!<Bit 6 */
 +#define  FMC_PATT2_ATTWAIT2_7               ((uint32_t)0x00008000)        /*!<Bit 7 */
 +
 +#define  FMC_PATT2_ATTHOLD2                 ((uint32_t)0x00FF0000)        /*!<ATTHOLD2[7:0] bits (Attribute memory 2 hold time) */
 +#define  FMC_PATT2_ATTHOLD2_0               ((uint32_t)0x00010000)        /*!<Bit 0 */
 +#define  FMC_PATT2_ATTHOLD2_1               ((uint32_t)0x00020000)        /*!<Bit 1 */
 +#define  FMC_PATT2_ATTHOLD2_2               ((uint32_t)0x00040000)        /*!<Bit 2 */
 +#define  FMC_PATT2_ATTHOLD2_3               ((uint32_t)0x00080000)        /*!<Bit 3 */
 +#define  FMC_PATT2_ATTHOLD2_4               ((uint32_t)0x00100000)        /*!<Bit 4 */
 +#define  FMC_PATT2_ATTHOLD2_5               ((uint32_t)0x00200000)        /*!<Bit 5 */
 +#define  FMC_PATT2_ATTHOLD2_6               ((uint32_t)0x00400000)        /*!<Bit 6 */
 +#define  FMC_PATT2_ATTHOLD2_7               ((uint32_t)0x00800000)        /*!<Bit 7 */
 +
 +#define  FMC_PATT2_ATTHIZ2                  ((uint32_t)0xFF000000)        /*!<ATTHIZ2[7:0] bits (Attribute memory 2 databus HiZ time) */
 +#define  FMC_PATT2_ATTHIZ2_0                ((uint32_t)0x01000000)        /*!<Bit 0 */
 +#define  FMC_PATT2_ATTHIZ2_1                ((uint32_t)0x02000000)        /*!<Bit 1 */
 +#define  FMC_PATT2_ATTHIZ2_2                ((uint32_t)0x04000000)        /*!<Bit 2 */
 +#define  FMC_PATT2_ATTHIZ2_3                ((uint32_t)0x08000000)        /*!<Bit 3 */
 +#define  FMC_PATT2_ATTHIZ2_4                ((uint32_t)0x10000000)        /*!<Bit 4 */
 +#define  FMC_PATT2_ATTHIZ2_5                ((uint32_t)0x20000000)        /*!<Bit 5 */
 +#define  FMC_PATT2_ATTHIZ2_6                ((uint32_t)0x40000000)        /*!<Bit 6 */
 +#define  FMC_PATT2_ATTHIZ2_7                ((uint32_t)0x80000000)        /*!<Bit 7 */
 +
 +/******************  Bit definition for FMC_PATT3 register  ******************/
 +#define  FMC_PATT3_ATTSET3                  ((uint32_t)0x000000FF)        /*!<ATTSET3[7:0] bits (Attribute memory 3 setup time) */
 +#define  FMC_PATT3_ATTSET3_0                ((uint32_t)0x00000001)        /*!<Bit 0 */
 +#define  FMC_PATT3_ATTSET3_1                ((uint32_t)0x00000002)        /*!<Bit 1 */
 +#define  FMC_PATT3_ATTSET3_2                ((uint32_t)0x00000004)        /*!<Bit 2 */
 +#define  FMC_PATT3_ATTSET3_3                ((uint32_t)0x00000008)        /*!<Bit 3 */
 +#define  FMC_PATT3_ATTSET3_4                ((uint32_t)0x00000010)        /*!<Bit 4 */
 +#define  FMC_PATT3_ATTSET3_5                ((uint32_t)0x00000020)        /*!<Bit 5 */
 +#define  FMC_PATT3_ATTSET3_6                ((uint32_t)0x00000040)        /*!<Bit 6 */
 +#define  FMC_PATT3_ATTSET3_7                ((uint32_t)0x00000080)        /*!<Bit 7 */
 +
 +#define  FMC_PATT3_ATTWAIT3                 ((uint32_t)0x0000FF00)        /*!<ATTWAIT3[7:0] bits (Attribute memory 3 wait time) */
 +#define  FMC_PATT3_ATTWAIT3_0               ((uint32_t)0x00000100)        /*!<Bit 0 */
 +#define  FMC_PATT3_ATTWAIT3_1               ((uint32_t)0x00000200)        /*!<Bit 1 */
 +#define  FMC_PATT3_ATTWAIT3_2               ((uint32_t)0x00000400)        /*!<Bit 2 */
 +#define  FMC_PATT3_ATTWAIT3_3               ((uint32_t)0x00000800)        /*!<Bit 3 */
 +#define  FMC_PATT3_ATTWAIT3_4               ((uint32_t)0x00001000)        /*!<Bit 4 */
 +#define  FMC_PATT3_ATTWAIT3_5               ((uint32_t)0x00002000)        /*!<Bit 5 */
 +#define  FMC_PATT3_ATTWAIT3_6               ((uint32_t)0x00004000)        /*!<Bit 6 */
 +#define  FMC_PATT3_ATTWAIT3_7               ((uint32_t)0x00008000)        /*!<Bit 7 */
 +
 +#define  FMC_PATT3_ATTHOLD3                 ((uint32_t)0x00FF0000)        /*!<ATTHOLD3[7:0] bits (Attribute memory 3 hold time) */
 +#define  FMC_PATT3_ATTHOLD3_0               ((uint32_t)0x00010000)        /*!<Bit 0 */
 +#define  FMC_PATT3_ATTHOLD3_1               ((uint32_t)0x00020000)        /*!<Bit 1 */
 +#define  FMC_PATT3_ATTHOLD3_2               ((uint32_t)0x00040000)        /*!<Bit 2 */
 +#define  FMC_PATT3_ATTHOLD3_3               ((uint32_t)0x00080000)        /*!<Bit 3 */
 +#define  FMC_PATT3_ATTHOLD3_4               ((uint32_t)0x00100000)        /*!<Bit 4 */
 +#define  FMC_PATT3_ATTHOLD3_5               ((uint32_t)0x00200000)        /*!<Bit 5 */
 +#define  FMC_PATT3_ATTHOLD3_6               ((uint32_t)0x00400000)        /*!<Bit 6 */
 +#define  FMC_PATT3_ATTHOLD3_7               ((uint32_t)0x00800000)        /*!<Bit 7 */
 +
 +#define  FMC_PATT3_ATTHIZ3                  ((uint32_t)0xFF000000)        /*!<ATTHIZ3[7:0] bits (Attribute memory 3 databus HiZ time) */
 +#define  FMC_PATT3_ATTHIZ3_0                ((uint32_t)0x01000000)        /*!<Bit 0 */
 +#define  FMC_PATT3_ATTHIZ3_1                ((uint32_t)0x02000000)        /*!<Bit 1 */
 +#define  FMC_PATT3_ATTHIZ3_2                ((uint32_t)0x04000000)        /*!<Bit 2 */
 +#define  FMC_PATT3_ATTHIZ3_3                ((uint32_t)0x08000000)        /*!<Bit 3 */
 +#define  FMC_PATT3_ATTHIZ3_4                ((uint32_t)0x10000000)        /*!<Bit 4 */
 +#define  FMC_PATT3_ATTHIZ3_5                ((uint32_t)0x20000000)        /*!<Bit 5 */
 +#define  FMC_PATT3_ATTHIZ3_6                ((uint32_t)0x40000000)        /*!<Bit 6 */
 +#define  FMC_PATT3_ATTHIZ3_7                ((uint32_t)0x80000000)        /*!<Bit 7 */
 +
 +/******************  Bit definition for FMC_PATT4 register  ******************/
 +#define  FMC_PATT4_ATTSET4                  ((uint32_t)0x000000FF)        /*!<ATTSET4[7:0] bits (Attribute memory 4 setup time) */
 +#define  FMC_PATT4_ATTSET4_0                ((uint32_t)0x00000001)        /*!<Bit 0 */
 +#define  FMC_PATT4_ATTSET4_1                ((uint32_t)0x00000002)        /*!<Bit 1 */
 +#define  FMC_PATT4_ATTSET4_2                ((uint32_t)0x00000004)        /*!<Bit 2 */
 +#define  FMC_PATT4_ATTSET4_3                ((uint32_t)0x00000008)        /*!<Bit 3 */
 +#define  FMC_PATT4_ATTSET4_4                ((uint32_t)0x00000010)        /*!<Bit 4 */
 +#define  FMC_PATT4_ATTSET4_5                ((uint32_t)0x00000020)        /*!<Bit 5 */
 +#define  FMC_PATT4_ATTSET4_6                ((uint32_t)0x00000040)        /*!<Bit 6 */
 +#define  FMC_PATT4_ATTSET4_7                ((uint32_t)0x00000080)        /*!<Bit 7 */
 +
 +#define  FMC_PATT4_ATTWAIT4                 ((uint32_t)0x0000FF00)        /*!<ATTWAIT4[7:0] bits (Attribute memory 4 wait time) */
 +#define  FMC_PATT4_ATTWAIT4_0               ((uint32_t)0x00000100)        /*!<Bit 0 */
 +#define  FMC_PATT4_ATTWAIT4_1               ((uint32_t)0x00000200)        /*!<Bit 1 */
 +#define  FMC_PATT4_ATTWAIT4_2               ((uint32_t)0x00000400)        /*!<Bit 2 */
 +#define  FMC_PATT4_ATTWAIT4_3               ((uint32_t)0x00000800)        /*!<Bit 3 */
 +#define  FMC_PATT4_ATTWAIT4_4               ((uint32_t)0x00001000)        /*!<Bit 4 */
 +#define  FMC_PATT4_ATTWAIT4_5               ((uint32_t)0x00002000)        /*!<Bit 5 */
 +#define  FMC_PATT4_ATTWAIT4_6               ((uint32_t)0x00004000)        /*!<Bit 6 */
 +#define  FMC_PATT4_ATTWAIT4_7               ((uint32_t)0x00008000)        /*!<Bit 7 */
 +
 +#define  FMC_PATT4_ATTHOLD4                 ((uint32_t)0x00FF0000)        /*!<ATTHOLD4[7:0] bits (Attribute memory 4 hold time) */
 +#define  FMC_PATT4_ATTHOLD4_0               ((uint32_t)0x00010000)        /*!<Bit 0 */
 +#define  FMC_PATT4_ATTHOLD4_1               ((uint32_t)0x00020000)        /*!<Bit 1 */
 +#define  FMC_PATT4_ATTHOLD4_2               ((uint32_t)0x00040000)        /*!<Bit 2 */
 +#define  FMC_PATT4_ATTHOLD4_3               ((uint32_t)0x00080000)        /*!<Bit 3 */
 +#define  FMC_PATT4_ATTHOLD4_4               ((uint32_t)0x00100000)        /*!<Bit 4 */
 +#define  FMC_PATT4_ATTHOLD4_5               ((uint32_t)0x00200000)        /*!<Bit 5 */
 +#define  FMC_PATT4_ATTHOLD4_6               ((uint32_t)0x00400000)        /*!<Bit 6 */
 +#define  FMC_PATT4_ATTHOLD4_7               ((uint32_t)0x00800000)        /*!<Bit 7 */
 +
 +#define  FMC_PATT4_ATTHIZ4                  ((uint32_t)0xFF000000)        /*!<ATTHIZ4[7:0] bits (Attribute memory 4 databus HiZ time) */
 +#define  FMC_PATT4_ATTHIZ4_0                ((uint32_t)0x01000000)        /*!<Bit 0 */
 +#define  FMC_PATT4_ATTHIZ4_1                ((uint32_t)0x02000000)        /*!<Bit 1 */
 +#define  FMC_PATT4_ATTHIZ4_2                ((uint32_t)0x04000000)        /*!<Bit 2 */
 +#define  FMC_PATT4_ATTHIZ4_3                ((uint32_t)0x08000000)        /*!<Bit 3 */
 +#define  FMC_PATT4_ATTHIZ4_4                ((uint32_t)0x10000000)        /*!<Bit 4 */
 +#define  FMC_PATT4_ATTHIZ4_5                ((uint32_t)0x20000000)        /*!<Bit 5 */
 +#define  FMC_PATT4_ATTHIZ4_6                ((uint32_t)0x40000000)        /*!<Bit 6 */
 +#define  FMC_PATT4_ATTHIZ4_7                ((uint32_t)0x80000000)        /*!<Bit 7 */
 +
 +/******************  Bit definition for FMC_PIO4 register  *******************/
 +#define  FMC_PIO4_IOSET4                    ((uint32_t)0x000000FF)        /*!<IOSET4[7:0] bits (I/O 4 setup time) */
 +#define  FMC_PIO4_IOSET4_0                  ((uint32_t)0x00000001)        /*!<Bit 0 */
 +#define  FMC_PIO4_IOSET4_1                  ((uint32_t)0x00000002)        /*!<Bit 1 */
 +#define  FMC_PIO4_IOSET4_2                  ((uint32_t)0x00000004)        /*!<Bit 2 */
 +#define  FMC_PIO4_IOSET4_3                  ((uint32_t)0x00000008)        /*!<Bit 3 */
 +#define  FMC_PIO4_IOSET4_4                  ((uint32_t)0x00000010)        /*!<Bit 4 */
 +#define  FMC_PIO4_IOSET4_5                  ((uint32_t)0x00000020)        /*!<Bit 5 */
 +#define  FMC_PIO4_IOSET4_6                  ((uint32_t)0x00000040)        /*!<Bit 6 */
 +#define  FMC_PIO4_IOSET4_7                  ((uint32_t)0x00000080)        /*!<Bit 7 */
 +
 +#define  FMC_PIO4_IOWAIT4                   ((uint32_t)0x0000FF00)        /*!<IOWAIT4[7:0] bits (I/O 4 wait time) */
 +#define  FMC_PIO4_IOWAIT4_0                 ((uint32_t)0x00000100)        /*!<Bit 0 */
 +#define  FMC_PIO4_IOWAIT4_1                 ((uint32_t)0x00000200)        /*!<Bit 1 */
 +#define  FMC_PIO4_IOWAIT4_2                 ((uint32_t)0x00000400)        /*!<Bit 2 */
 +#define  FMC_PIO4_IOWAIT4_3                 ((uint32_t)0x00000800)        /*!<Bit 3 */
 +#define  FMC_PIO4_IOWAIT4_4                 ((uint32_t)0x00001000)        /*!<Bit 4 */
 +#define  FMC_PIO4_IOWAIT4_5                 ((uint32_t)0x00002000)        /*!<Bit 5 */
 +#define  FMC_PIO4_IOWAIT4_6                 ((uint32_t)0x00004000)        /*!<Bit 6 */
 +#define  FMC_PIO4_IOWAIT4_7                 ((uint32_t)0x00008000)        /*!<Bit 7 */
 +
 +#define  FMC_PIO4_IOHOLD4                   ((uint32_t)0x00FF0000)        /*!<IOHOLD4[7:0] bits (I/O 4 hold time) */
 +#define  FMC_PIO4_IOHOLD4_0                 ((uint32_t)0x00010000)        /*!<Bit 0 */
 +#define  FMC_PIO4_IOHOLD4_1                 ((uint32_t)0x00020000)        /*!<Bit 1 */
 +#define  FMC_PIO4_IOHOLD4_2                 ((uint32_t)0x00040000)        /*!<Bit 2 */
 +#define  FMC_PIO4_IOHOLD4_3                 ((uint32_t)0x00080000)        /*!<Bit 3 */
 +#define  FMC_PIO4_IOHOLD4_4                 ((uint32_t)0x00100000)        /*!<Bit 4 */
 +#define  FMC_PIO4_IOHOLD4_5                 ((uint32_t)0x00200000)        /*!<Bit 5 */
 +#define  FMC_PIO4_IOHOLD4_6                 ((uint32_t)0x00400000)        /*!<Bit 6 */
 +#define  FMC_PIO4_IOHOLD4_7                 ((uint32_t)0x00800000)        /*!<Bit 7 */
 +
 +#define  FMC_PIO4_IOHIZ4                    ((uint32_t)0xFF000000)        /*!<IOHIZ4[7:0] bits (I/O 4 databus HiZ time) */
 +#define  FMC_PIO4_IOHIZ4_0                  ((uint32_t)0x01000000)        /*!<Bit 0 */
 +#define  FMC_PIO4_IOHIZ4_1                  ((uint32_t)0x02000000)        /*!<Bit 1 */
 +#define  FMC_PIO4_IOHIZ4_2                  ((uint32_t)0x04000000)        /*!<Bit 2 */
 +#define  FMC_PIO4_IOHIZ4_3                  ((uint32_t)0x08000000)        /*!<Bit 3 */
 +#define  FMC_PIO4_IOHIZ4_4                  ((uint32_t)0x10000000)        /*!<Bit 4 */
 +#define  FMC_PIO4_IOHIZ4_5                  ((uint32_t)0x20000000)        /*!<Bit 5 */
 +#define  FMC_PIO4_IOHIZ4_6                  ((uint32_t)0x40000000)        /*!<Bit 6 */
 +#define  FMC_PIO4_IOHIZ4_7                  ((uint32_t)0x80000000)        /*!<Bit 7 */
 +
 +/******************  Bit definition for FMC_ECCR2 register  ******************/
 +#define  FMC_ECCR2_ECC2                     ((uint32_t)0xFFFFFFFF)        /*!<ECC result */
 +
 +/******************  Bit definition for FMC_ECCR3 register  ******************/
 +#define  FMC_ECCR3_ECC3                     ((uint32_t)0xFFFFFFFF)        /*!<ECC result */
 +
 +/******************  Bit definition for FMC_SDCR1 register  ******************/
 +#define  FMC_SDCR1_NC                       ((uint32_t)0x00000003)        /*!<NC[1:0] bits (Number of column bits) */
 +#define  FMC_SDCR1_NC_0                     ((uint32_t)0x00000001)        /*!<Bit 0 */
 +#define  FMC_SDCR1_NC_1                     ((uint32_t)0x00000002)        /*!<Bit 1 */
 +
 +#define  FMC_SDCR1_NR                       ((uint32_t)0x0000000C)        /*!<NR[1:0] bits (Number of row bits) */
 +#define  FMC_SDCR1_NR_0                     ((uint32_t)0x00000004)        /*!<Bit 0 */
 +#define  FMC_SDCR1_NR_1                     ((uint32_t)0x00000008)        /*!<Bit 1 */
 +
 +#define  FMC_SDCR1_MWID                     ((uint32_t)0x00000030)        /*!<NR[1:0] bits (Number of row bits) */
 +#define  FMC_SDCR1_MWID_0                   ((uint32_t)0x00000010)        /*!<Bit 0 */
 +#define  FMC_SDCR1_MWID_1                   ((uint32_t)0x00000020)        /*!<Bit 1 */
 +
 +#define  FMC_SDCR1_NB                       ((uint32_t)0x00000040)        /*!<Number of internal bank */
 +
 +#define  FMC_SDCR1_CAS                      ((uint32_t)0x00000180)        /*!<CAS[1:0] bits (CAS latency) */
 +#define  FMC_SDCR1_CAS_0                    ((uint32_t)0x00000080)        /*!<Bit 0 */
 +#define  FMC_SDCR1_CAS_1                    ((uint32_t)0x00000100)        /*!<Bit 1 */
 +
 +#define  FMC_SDCR1_WP                       ((uint32_t)0x00000200)        /*!<Write protection */
 +
 +#define  FMC_SDCR1_SDCLK                    ((uint32_t)0x00000C00)        /*!<SDRAM clock configuration */
 +#define  FMC_SDCR1_SDCLK_0                  ((uint32_t)0x00000400)        /*!<Bit 0 */
 +#define  FMC_SDCR1_SDCLK_1                  ((uint32_t)0x00000800)        /*!<Bit 1 */
 +
 +#define  FMC_SDCR1_RBURST                   ((uint32_t)0x00001000)        /*!<Read burst */
 +
 +#define  FMC_SDCR1_RPIPE                    ((uint32_t)0x00006000)        /*!<Write protection */
 +#define  FMC_SDCR1_RPIPE_0                  ((uint32_t)0x00002000)        /*!<Bit 0 */
 +#define  FMC_SDCR1_RPIPE_1                  ((uint32_t)0x00004000)        /*!<Bit 1 */
 +
 +/******************  Bit definition for FMC_SDCR2 register  ******************/
 +#define  FMC_SDCR2_NC                       ((uint32_t)0x00000003)        /*!<NC[1:0] bits (Number of column bits) */
 +#define  FMC_SDCR2_NC_0                     ((uint32_t)0x00000001)        /*!<Bit 0 */
 +#define  FMC_SDCR2_NC_1                     ((uint32_t)0x00000002)        /*!<Bit 1 */
 +
 +#define  FMC_SDCR2_NR                       ((uint32_t)0x0000000C)        /*!<NR[1:0] bits (Number of row bits) */
 +#define  FMC_SDCR2_NR_0                     ((uint32_t)0x00000004)        /*!<Bit 0 */
 +#define  FMC_SDCR2_NR_1                     ((uint32_t)0x00000008)        /*!<Bit 1 */
 +
 +#define  FMC_SDCR2_MWID                     ((uint32_t)0x00000030)        /*!<NR[1:0] bits (Number of row bits) */
 +#define  FMC_SDCR2_MWID_0                   ((uint32_t)0x00000010)        /*!<Bit 0 */
 +#define  FMC_SDCR2_MWID_1                   ((uint32_t)0x00000020)        /*!<Bit 1 */
 +
 +#define  FMC_SDCR2_NB                       ((uint32_t)0x00000040)        /*!<Number of internal bank */
 +
 +#define  FMC_SDCR2_CAS                      ((uint32_t)0x00000180)        /*!<CAS[1:0] bits (CAS latency) */
 +#define  FMC_SDCR2_CAS_0                    ((uint32_t)0x00000080)        /*!<Bit 0 */
 +#define  FMC_SDCR2_CAS_1                    ((uint32_t)0x00000100)        /*!<Bit 1 */
 +
 +#define  FMC_SDCR2_WP                       ((uint32_t)0x00000200)        /*!<Write protection */
 +
 +#define  FMC_SDCR2_SDCLK                    ((uint32_t)0x00000C00)        /*!<SDCLK[1:0] (SDRAM clock configuration) */
 +#define  FMC_SDCR2_SDCLK_0                  ((uint32_t)0x00000400)        /*!<Bit 0 */
 +#define  FMC_SDCR2_SDCLK_1                  ((uint32_t)0x00000800)        /*!<Bit 1 */
 +
 +#define  FMC_SDCR2_RBURST                   ((uint32_t)0x00001000)        /*!<Read burst */
 +
 +#define  FMC_SDCR2_RPIPE                    ((uint32_t)0x00006000)        /*!<RPIPE[1:0](Read pipe) */
 +#define  FMC_SDCR2_RPIPE_0                  ((uint32_t)0x00002000)        /*!<Bit 0 */
 +#define  FMC_SDCR2_RPIPE_1                  ((uint32_t)0x00004000)        /*!<Bit 1 */
 +
 +/******************  Bit definition for FMC_SDTR1 register  ******************/
 +#define  FMC_SDTR1_TMRD                     ((uint32_t)0x0000000F)        /*!<TMRD[3:0] bits (Load mode register to active) */
 +#define  FMC_SDTR1_TMRD_0                   ((uint32_t)0x00000001)        /*!<Bit 0 */
 +#define  FMC_SDTR1_TMRD_1                   ((uint32_t)0x00000002)        /*!<Bit 1 */
 +#define  FMC_SDTR1_TMRD_2                   ((uint32_t)0x00000004)        /*!<Bit 2 */
 +#define  FMC_SDTR1_TMRD_3                   ((uint32_t)0x00000008)        /*!<Bit 3 */
 +                                            
 +#define  FMC_SDTR1_TXSR                     ((uint32_t)0x000000F0)        /*!<TXSR[3:0] bits (Exit self refresh) */
 +#define  FMC_SDTR1_TXSR_0                   ((uint32_t)0x00000010)        /*!<Bit 0 */
 +#define  FMC_SDTR1_TXSR_1                   ((uint32_t)0x00000020)        /*!<Bit 1 */
 +#define  FMC_SDTR1_TXSR_2                   ((uint32_t)0x00000040)        /*!<Bit 2 */
 +#define  FMC_SDTR1_TXSR_3                   ((uint32_t)0x00000080)        /*!<Bit 3 */
 +
 +#define  FMC_SDTR1_TRAS                     ((uint32_t)0x00000F00)        /*!<TRAS[3:0] bits (Self refresh time) */
 +#define  FMC_SDTR1_TRAS_0                   ((uint32_t)0x00000100)        /*!<Bit 0 */
 +#define  FMC_SDTR1_TRAS_1                   ((uint32_t)0x00000200)        /*!<Bit 1 */
 +#define  FMC_SDTR1_TRAS_2                   ((uint32_t)0x00000400)        /*!<Bit 2 */
 +#define  FMC_SDTR1_TRAS_3                   ((uint32_t)0x00000800)        /*!<Bit 3 */
 +
 +#define  FMC_SDTR1_TRC                      ((uint32_t)0x0000F000)        /*!<TRC[2:0] bits (Row cycle delay) */
 +#define  FMC_SDTR1_TRC_0                    ((uint32_t)0x00001000)        /*!<Bit 0 */
 +#define  FMC_SDTR1_TRC_1                    ((uint32_t)0x00002000)        /*!<Bit 1 */
 +#define  FMC_SDTR1_TRC_2                    ((uint32_t)0x00004000)        /*!<Bit 2 */
 +
 +#define  FMC_SDTR1_TWR                      ((uint32_t)0x000F0000)        /*!<TRC[2:0] bits (Write recovery delay) */
 +#define  FMC_SDTR1_TWR_0                    ((uint32_t)0x00010000)        /*!<Bit 0 */
 +#define  FMC_SDTR1_TWR_1                    ((uint32_t)0x00020000)        /*!<Bit 1 */
 +#define  FMC_SDTR1_TWR_2                    ((uint32_t)0x00040000)        /*!<Bit 2 */
 +
 +#define  FMC_SDTR1_TRP                      ((uint32_t)0x00F00000)        /*!<TRP[2:0] bits (Row precharge delay) */
 +#define  FMC_SDTR1_TRP_0                    ((uint32_t)0x00100000)        /*!<Bit 0 */
 +#define  FMC_SDTR1_TRP_1                    ((uint32_t)0x00200000)        /*!<Bit 1 */
 +#define  FMC_SDTR1_TRP_2                    ((uint32_t)0x00400000)        /*!<Bit 2 */
 +
 +#define  FMC_SDTR1_TRCD                     ((uint32_t)0x0F000000)        /*!<TRP[2:0] bits (Row to column delay) */
 +#define  FMC_SDTR1_TRCD_0                   ((uint32_t)0x01000000)        /*!<Bit 0 */
 +#define  FMC_SDTR1_TRCD_1                   ((uint32_t)0x02000000)        /*!<Bit 1 */
 +#define  FMC_SDTR1_TRCD_2                   ((uint32_t)0x04000000)        /*!<Bit 2 */
 +
 +/******************  Bit definition for FMC_SDTR2 register  ******************/
 +#define  FMC_SDTR2_TMRD                     ((uint32_t)0x0000000F)        /*!<TMRD[3:0] bits (Load mode register to active) */
 +#define  FMC_SDTR2_TMRD_0                   ((uint32_t)0x00000001)        /*!<Bit 0 */
 +#define  FMC_SDTR2_TMRD_1                   ((uint32_t)0x00000002)        /*!<Bit 1 */
 +#define  FMC_SDTR2_TMRD_2                   ((uint32_t)0x00000004)        /*!<Bit 2 */
 +#define  FMC_SDTR2_TMRD_3                   ((uint32_t)0x00000008)        /*!<Bit 3 */
 +                                            
 +#define  FMC_SDTR2_TXSR                     ((uint32_t)0x000000F0)        /*!<TXSR[3:0] bits (Exit self refresh) */
 +#define  FMC_SDTR2_TXSR_0                   ((uint32_t)0x00000010)        /*!<Bit 0 */
 +#define  FMC_SDTR2_TXSR_1                   ((uint32_t)0x00000020)        /*!<Bit 1 */
 +#define  FMC_SDTR2_TXSR_2                   ((uint32_t)0x00000040)        /*!<Bit 2 */
 +#define  FMC_SDTR2_TXSR_3                   ((uint32_t)0x00000080)        /*!<Bit 3 */
 +
 +#define  FMC_SDTR2_TRAS                     ((uint32_t)0x00000F00)        /*!<TRAS[3:0] bits (Self refresh time) */
 +#define  FMC_SDTR2_TRAS_0                   ((uint32_t)0x00000100)        /*!<Bit 0 */
 +#define  FMC_SDTR2_TRAS_1                   ((uint32_t)0x00000200)        /*!<Bit 1 */
 +#define  FMC_SDTR2_TRAS_2                   ((uint32_t)0x00000400)        /*!<Bit 2 */
 +#define  FMC_SDTR2_TRAS_3                   ((uint32_t)0x00000800)        /*!<Bit 3 */
 +
 +#define  FMC_SDTR2_TRC                      ((uint32_t)0x0000F000)        /*!<TRC[2:0] bits (Row cycle delay) */
 +#define  FMC_SDTR2_TRC_0                    ((uint32_t)0x00001000)        /*!<Bit 0 */
 +#define  FMC_SDTR2_TRC_1                    ((uint32_t)0x00002000)        /*!<Bit 1 */
 +#define  FMC_SDTR2_TRC_2                    ((uint32_t)0x00004000)        /*!<Bit 2 */
 +
 +#define  FMC_SDTR2_TWR                      ((uint32_t)0x000F0000)        /*!<TRC[2:0] bits (Write recovery delay) */
 +#define  FMC_SDTR2_TWR_0                    ((uint32_t)0x00010000)        /*!<Bit 0 */
 +#define  FMC_SDTR2_TWR_1                    ((uint32_t)0x00020000)        /*!<Bit 1 */
 +#define  FMC_SDTR2_TWR_2                    ((uint32_t)0x00040000)        /*!<Bit 2 */
 +
 +#define  FMC_SDTR2_TRP                      ((uint32_t)0x00F00000)        /*!<TRP[2:0] bits (Row precharge delay) */
 +#define  FMC_SDTR2_TRP_0                    ((uint32_t)0x00100000)        /*!<Bit 0 */
 +#define  FMC_SDTR2_TRP_1                    ((uint32_t)0x00200000)        /*!<Bit 1 */
 +#define  FMC_SDTR2_TRP_2                    ((uint32_t)0x00400000)        /*!<Bit 2 */
 +
 +#define  FMC_SDTR2_TRCD                     ((uint32_t)0x0F000000)        /*!<TRP[2:0] bits (Row to column delay) */
 +#define  FMC_SDTR2_TRCD_0                   ((uint32_t)0x01000000)        /*!<Bit 0 */
 +#define  FMC_SDTR2_TRCD_1                   ((uint32_t)0x02000000)        /*!<Bit 1 */
 +#define  FMC_SDTR2_TRCD_2                   ((uint32_t)0x04000000)        /*!<Bit 2 */
 +
 +/******************  Bit definition for FMC_SDCMR register  ******************/
 +#define  FMC_SDCMR_MODE                     ((uint32_t)0x00000007)        /*!<MODE[2:0] bits (Command mode) */
 +#define  FMC_SDCMR_MODE_0                   ((uint32_t)0x00000001)        /*!<Bit 0 */
 +#define  FMC_SDCMR_MODE_1                   ((uint32_t)0x00000002)        /*!<Bit 1 */
 +#define  FMC_SDCMR_MODE_2                   ((uint32_t)0x00000003)        /*!<Bit 2 */
 +                                            
 +#define  FMC_SDCMR_CTB2                     ((uint32_t)0x00000008)        /*!<Command target 2 */
 +
 +#define  FMC_SDCMR_CTB1                     ((uint32_t)0x00000010)        /*!<Command target 1 */
 +
 +#define  FMC_SDCMR_NRFS                     ((uint32_t)0x000001E0)        /*!<NRFS[3:0] bits (Number of auto-refresh) */
 +#define  FMC_SDCMR_NRFS_0                   ((uint32_t)0x00000020)        /*!<Bit 0 */
 +#define  FMC_SDCMR_NRFS_1                   ((uint32_t)0x00000040)        /*!<Bit 1 */
 +#define  FMC_SDCMR_NRFS_2                   ((uint32_t)0x00000080)        /*!<Bit 2 */
 +#define  FMC_SDCMR_NRFS_3                   ((uint32_t)0x00000100)        /*!<Bit 3 */
 +
 +#define  FMC_SDCMR_MRD                      ((uint32_t)0x003FFE00)        /*!<MRD[12:0] bits (Mode register definition) */
 +
 +/******************  Bit definition for FMC_SDRTR register  ******************/
 +#define  FMC_SDRTR_CRE                      ((uint32_t)0x00000001)        /*!<Clear refresh error flag */
 +
 +#define  FMC_SDRTR_COUNT                    ((uint32_t)0x00003FFE)        /*!<COUNT[12:0] bits (Refresh timer count) */
 +
 +#define  FMC_SDRTR_REIE                     ((uint32_t)0x00004000)        /*!<RES interupt enable */
 +
 +/******************  Bit definition for FMC_SDSR register  ******************/
 +#define  FMC_SDSR_RE                        ((uint32_t)0x00000001)        /*!<Refresh error flag */
 +
 +#define  FMC_SDSR_MODES1                    ((uint32_t)0x00000006)        /*!<MODES1[1:0]bits (Status mode for bank 1) */
 +#define  FMC_SDSR_MODES1_0                  ((uint32_t)0x00000002)        /*!<Bit 0 */
 +#define  FMC_SDSR_MODES1_1                  ((uint32_t)0x00000004)        /*!<Bit 1 */
 +
 +#define  FMC_SDSR_MODES2                    ((uint32_t)0x00000018)        /*!<MODES2[1:0]bits (Status mode for bank 2) */
 +#define  FMC_SDSR_MODES2_0                  ((uint32_t)0x00000008)        /*!<Bit 0 */
 +#define  FMC_SDSR_MODES2_1                  ((uint32_t)0x00000010)        /*!<Bit 1 */
 +
 +#define  FMC_SDSR_BUSY                      ((uint32_t)0x00000020)        /*!<Busy status */
 +
 +#endif /* STM32F427_437xx ||  STM32F429_439xx */
  /******************************************************************************/
  /*                                                                            */
 @@ -4820,6 +6425,153 @@ typedef struct  #define  IWDG_SR_PVU                         ((uint8_t)0x01)               /*!<Watchdog prescaler value update      */
  #define  IWDG_SR_RVU                         ((uint8_t)0x02)               /*!<Watchdog counter reload value update */
 +/******************************************************************************/
 +/*                                                                            */
 +/*                      LCD-TFT Display Controller (LTDC)                     */
 +/*                                                                            */
 +/******************************************************************************/
 +
 +/********************  Bit definition for LTDC_SSCR register  *****************/
 +
 +#define LTDC_SSCR_VSH                       ((uint32_t)0x000007FF)              /*!< Vertical Synchronization Height */
 +#define LTDC_SSCR_HSW                       ((uint32_t)0x0FFF0000)              /*!< Horizontal Synchronization Width */
 +
 +/********************  Bit definition for LTDC_BPCR register  *****************/
 +
 +#define LTDC_BPCR_AVBP                      ((uint32_t)0x000007FF)              /*!< Accumulated Vertical Back Porch */
 +#define LTDC_BPCR_AHBP                      ((uint32_t)0x0FFF0000)              /*!< Accumulated Horizontal Back Porch */
 +
 +/********************  Bit definition for LTDC_AWCR register  *****************/
 +
 +#define LTDC_AWCR_AAH                       ((uint32_t)0x000007FF)              /*!< Accumulated Active heigh */
 +#define LTDC_AWCR_AAW                       ((uint32_t)0x0FFF0000)              /*!< Accumulated Active Width */
 +
 +/********************  Bit definition for LTDC_TWCR register  *****************/
 +
 +#define LTDC_TWCR_TOTALH                    ((uint32_t)0x000007FF)              /*!< Total Heigh */
 +#define LTDC_TWCR_TOTALW                    ((uint32_t)0x0FFF0000)              /*!< Total Width */
 +
 +/********************  Bit definition for LTDC_GCR register  ******************/
 +
 +#define LTDC_GCR_LTDCEN                     ((uint32_t)0x00000001)              /*!< LCD-TFT controller enable bit */
 +#define LTDC_GCR_DBW                        ((uint32_t)0x00000070)              /*!< Dither Blue Width */
 +#define LTDC_GCR_DGW                        ((uint32_t)0x00000700)              /*!< Dither Green Width */
 +#define LTDC_GCR_DRW                        ((uint32_t)0x00007000)              /*!< Dither Red Width */
 +#define LTDC_GCR_DTEN                       ((uint32_t)0x00010000)              /*!< Dither Enable */
 +#define LTDC_GCR_PCPOL                      ((uint32_t)0x10000000)              /*!< Pixel Clock Polarity */
 +#define LTDC_GCR_DEPOL                      ((uint32_t)0x20000000)              /*!< Data Enable Polarity */
 +#define LTDC_GCR_VSPOL                      ((uint32_t)0x40000000)              /*!< Vertical Synchronization Polarity */
 +#define LTDC_GCR_HSPOL                      ((uint32_t)0x80000000)              /*!< Horizontal Synchronization Polarity */
 +
 +/********************  Bit definition for LTDC_SRCR register  *****************/
 +
 +#define LTDC_SRCR_IMR                      ((uint32_t)0x00000001)               /*!< Immediate Reload */
 +#define LTDC_SRCR_VBR                      ((uint32_t)0x00000002)               /*!< Vertical Blanking Reload */
 +
 +/********************  Bit definition for LTDC_BCCR register  *****************/
 +
 +#define LTDC_BCCR_BCBLUE                    ((uint32_t)0x000000FF)              /*!< Background Blue value */
 +#define LTDC_BCCR_BCGREEN                   ((uint32_t)0x0000FF00)              /*!< Background Green value */
 +#define LTDC_BCCR_BCRED                     ((uint32_t)0x00FF0000)              /*!< Background Red value */
 +
 +/********************  Bit definition for LTDC_IER register  ******************/
 +
 +#define LTDC_IER_LIE                        ((uint32_t)0x00000001)              /*!< Line Interrupt Enable */
 +#define LTDC_IER_FUIE                       ((uint32_t)0x00000002)              /*!< FIFO Underrun Interrupt Enable */
 +#define LTDC_IER_TERRIE                     ((uint32_t)0x00000004)              /*!< Transfer Error Interrupt Enable */
 +#define LTDC_IER_RRIE                       ((uint32_t)0x00000008)              /*!< Register Reload interrupt enable */
 +
 +/********************  Bit definition for LTDC_ISR register  ******************/
 +
 +#define LTDC_ISR_LIF                        ((uint32_t)0x00000001)              /*!< Line Interrupt Flag */
 +#define LTDC_ISR_FUIF                       ((uint32_t)0x00000002)              /*!< FIFO Underrun Interrupt Flag */
 +#define LTDC_ISR_TERRIF                     ((uint32_t)0x00000004)              /*!< Transfer Error Interrupt Flag */
 +#define LTDC_ISR_RRIF                       ((uint32_t)0x00000008)              /*!< Register Reload interrupt Flag */
 +
 +/********************  Bit definition for LTDC_ICR register  ******************/
 +
 +#define LTDC_ICR_CLIF                       ((uint32_t)0x00000001)              /*!< Clears the Line Interrupt Flag */
 +#define LTDC_ICR_CFUIF                      ((uint32_t)0x00000002)              /*!< Clears the FIFO Underrun Interrupt Flag */
 +#define LTDC_ICR_CTERRIF                    ((uint32_t)0x00000004)              /*!< Clears the Transfer Error Interrupt Flag */
 +#define LTDC_ICR_CRRIF                      ((uint32_t)0x00000008)              /*!< Clears Register Reload interrupt Flag */
 +
 +/********************  Bit definition for LTDC_LIPCR register  ****************/
 +
 +#define LTDC_LIPCR_LIPOS                    ((uint32_t)0x000007FF)              /*!< Line Interrupt Position */
 +
 +/********************  Bit definition for LTDC_CPSR register  *****************/
 +
 +#define LTDC_CPSR_CYPOS                     ((uint32_t)0x0000FFFF)              /*!< Current Y Position */
 +#define LTDC_CPSR_CXPOS                     ((uint32_t)0xFFFF0000)              /*!< Current X Position */
 +
 +/********************  Bit definition for LTDC_CDSR register  *****************/
 +
 +#define LTDC_CDSR_VDES                      ((uint32_t)0x00000001)              /*!< Vertical Data Enable Status */
 +#define LTDC_CDSR_HDES                      ((uint32_t)0x00000002)              /*!< Horizontal Data Enable Status */
 +#define LTDC_CDSR_VSYNCS                    ((uint32_t)0x00000004)              /*!< Vertical Synchronization Status */
 +#define LTDC_CDSR_HSYNCS                    ((uint32_t)0x00000008)              /*!< Horizontal Synchronization Status */
 +
 +/********************  Bit definition for LTDC_LxCR register  *****************/
 +
 +#define LTDC_LxCR_LEN                       ((uint32_t)0x00000001)              /*!< Layer Enable */
 +#define LTDC_LxCR_COLKEN                    ((uint32_t)0x00000002)              /*!< Color Keying Enable */
 +#define LTDC_LxCR_CLUTEN                    ((uint32_t)0x00000010)              /*!< Color Lockup Table Enable */
 +
 +/********************  Bit definition for LTDC_LxWHPCR register  **************/
 +
 +#define LTDC_LxWHPCR_WHSTPOS                ((uint32_t)0x00000FFF)              /*!< Window Horizontal Start Position */
 +#define LTDC_LxWHPCR_WHSPPOS                ((uint32_t)0xFFFF0000)              /*!< Window Horizontal Stop Position */
 +
 +/********************  Bit definition for LTDC_LxWVPCR register  **************/
 +
 +#define LTDC_LxWVPCR_WVSTPOS                ((uint32_t)0x00000FFF)              /*!< Window Vertical Start Position */
 +#define LTDC_LxWVPCR_WVSPPOS                ((uint32_t)0xFFFF0000)              /*!< Window Vertical Stop Position */
 +
 +/********************  Bit definition for LTDC_LxCKCR register  ***************/
 +
 +#define LTDC_LxCKCR_CKBLUE                  ((uint32_t)0x000000FF)              /*!< Color Key Blue value */
 +#define LTDC_LxCKCR_CKGREEN                 ((uint32_t)0x0000FF00)              /*!< Color Key Green value */
 +#define LTDC_LxCKCR_CKRED                   ((uint32_t)0x00FF0000)              /*!< Color Key Red value */
 +
 +/********************  Bit definition for LTDC_LxPFCR register  ***************/
 +
 +#define LTDC_LxPFCR_PF                      ((uint32_t)0x00000007)              /*!< Pixel Format */
 +
 +/********************  Bit definition for LTDC_LxCACR register  ***************/
 +
 +#define LTDC_LxCACR_CONSTA                  ((uint32_t)0x000000FF)              /*!< Constant Alpha */
 +
 +/********************  Bit definition for LTDC_LxDCCR register  ***************/
 +
 +#define LTDC_LxDCCR_DCBLUE                  ((uint32_t)0x000000FF)              /*!< Default Color Blue */
 +#define LTDC_LxDCCR_DCGREEN                 ((uint32_t)0x0000FF00)              /*!< Default Color Green */
 +#define LTDC_LxDCCR_DCRED                   ((uint32_t)0x00FF0000)              /*!< Default Color Red */
 +#define LTDC_LxDCCR_DCALPHA                 ((uint32_t)0xFF000000)              /*!< Default Color Alpha */
 +                                
 +/********************  Bit definition for LTDC_LxBFCR register  ***************/
 +
 +#define LTDC_LxBFCR_BF2                     ((uint32_t)0x00000007)              /*!< Blending Factor 2 */
 +#define LTDC_LxBFCR_BF1                     ((uint32_t)0x00000700)              /*!< Blending Factor 1 */
 +
 +/********************  Bit definition for LTDC_LxCFBAR register  **************/
 +
 +#define LTDC_LxCFBAR_CFBADD                 ((uint32_t)0xFFFFFFFF)              /*!< Color Frame Buffer Start Address */
 +
 +/********************  Bit definition for LTDC_LxCFBLR register  **************/
 +
 +#define LTDC_LxCFBLR_CFBLL                  ((uint32_t)0x00001FFF)              /*!< Color Frame Buffer Line Length */
 +#define LTDC_LxCFBLR_CFBP                   ((uint32_t)0x1FFF0000)              /*!< Color Frame Buffer Pitch in bytes */
 +
 +/********************  Bit definition for LTDC_LxCFBLNR register  *************/
 +
 +#define LTDC_LxCFBLNR_CFBLNBR               ((uint32_t)0x000007FF)              /*!< Frame Buffer Line Number */
 +
 +/********************  Bit definition for LTDC_LxCLUTWR register  *************/
 +
 +#define LTDC_LxCLUTWR_BLUE                  ((uint32_t)0x000000FF)              /*!< Blue value */
 +#define LTDC_LxCLUTWR_GREEN                 ((uint32_t)0x0000FF00)              /*!< Green value */
 +#define LTDC_LxCLUTWR_RED                   ((uint32_t)0x00FF0000)              /*!< Red value */
 +#define LTDC_LxCLUTWR_CLUTADD               ((uint32_t)0xFF000000)              /*!< CLUT address */
  /******************************************************************************/
  /*                                                                            */
 @@ -4850,13 +6602,21 @@ typedef struct  #define  PWR_CR_DBP                          ((uint32_t)0x00000100)     /*!< Disable Backup Domain write protection                     */
  #define  PWR_CR_FPDS                         ((uint32_t)0x00000200)     /*!< Flash power down in Stop mode                              */
 -#define  PWR_CR_LPLVDS                       ((uint32_t)0x00000400)     /*!< Low-Power Regulator Low Voltage Scaling in Stop mode       */
 -#define  PWR_CR_MRLVDS                       ((uint32_t)0x00000800)     /*!< Main regulator Low Voltage Scaling in Stop mode            */
 +#define  PWR_CR_LPUDS                        ((uint32_t)0x00000400)     /*!< Low-Power Regulator in Stop under-drive mode               */
 +#define  PWR_CR_MRUDS                        ((uint32_t)0x00000800)     /*!< Main regulator in Stop under-drive mode                    */
 +
 +#define  PWR_CR_ADCDC1                       ((uint32_t)0x00002000)     /*!< Refer to AN4073 on how to use this bit */ 
  #define  PWR_CR_VOS                          ((uint32_t)0x0000C000)     /*!< VOS[1:0] bits (Regulator voltage scaling output selection) */
  #define  PWR_CR_VOS_0                        ((uint32_t)0x00004000)     /*!< Bit 0 */
  #define  PWR_CR_VOS_1                        ((uint32_t)0x00008000)     /*!< Bit 1 */
 +#define  PWR_CR_ODEN                         ((uint32_t)0x00010000)     /*!< Over Drive enable                   */
 +#define  PWR_CR_ODSWEN                       ((uint32_t)0x00020000)     /*!< Over Drive switch enabled           */
 +#define  PWR_CR_UDEN                         ((uint32_t)0x000C0000)     /*!< Under Drive enable in stop mode     */
 +#define  PWR_CR_UDEN_0                       ((uint32_t)0x00040000)     /*!< Bit 0                               */
 +#define  PWR_CR_UDEN_1                       ((uint32_t)0x00080000)     /*!< Bit 1                               */
 +
  /* Legacy define */
  #define  PWR_CR_PMODE                        PWR_CR_VOS
 @@ -4868,6 +6628,9 @@ typedef struct  #define  PWR_CSR_EWUP                        ((uint32_t)0x00000100)     /*!< Enable WKUP pin                                  */
  #define  PWR_CSR_BRE                         ((uint32_t)0x00000200)     /*!< Backup regulator enable                          */
  #define  PWR_CSR_VOSRDY                      ((uint32_t)0x00004000)     /*!< Regulator voltage scaling output selection ready */
 +#define  PWR_CSR_ODRDY                       ((uint32_t)0x00010000)     /*!< Over Drive generator ready                       */
 +#define  PWR_CSR_ODSWRDY                     ((uint32_t)0x00020000)     /*!< Over Drive Switch ready                          */
 +#define  PWR_CSR_UDSWRDY                     ((uint32_t)0x000C0000)     /*!< Under Drive ready                                */
  /* Legacy define */
  #define  PWR_CSR_REGRDY                      PWR_CSR_VOSRDY
 @@ -4906,7 +6669,8 @@ typedef struct  #define  RCC_CR_PLLRDY                       ((uint32_t)0x02000000)
  #define  RCC_CR_PLLI2SON                     ((uint32_t)0x04000000)
  #define  RCC_CR_PLLI2SRDY                    ((uint32_t)0x08000000)
 -
 +#define  RCC_CR_PLLSAION                     ((uint32_t)0x10000000)
 +#define  RCC_CR_PLLSAIRDY                    ((uint32_t)0x20000000)
  /********************  Bit definition for RCC_PLLCFGR register  ***************/
  #define  RCC_PLLCFGR_PLLM                    ((uint32_t)0x0000003F)
 @@ -5038,6 +6802,7 @@ typedef struct  #define  RCC_CIR_HSERDYF                     ((uint32_t)0x00000008)
  #define  RCC_CIR_PLLRDYF                     ((uint32_t)0x00000010)
  #define  RCC_CIR_PLLI2SRDYF                  ((uint32_t)0x00000020)
 +#define  RCC_CIR_PLLSAIRDYF                  ((uint32_t)0x00000040)
  #define  RCC_CIR_CSSF                        ((uint32_t)0x00000080)
  #define  RCC_CIR_LSIRDYIE                    ((uint32_t)0x00000100)
  #define  RCC_CIR_LSERDYIE                    ((uint32_t)0x00000200)
 @@ -5045,12 +6810,14 @@ typedef struct  #define  RCC_CIR_HSERDYIE                    ((uint32_t)0x00000800)
  #define  RCC_CIR_PLLRDYIE                    ((uint32_t)0x00001000)
  #define  RCC_CIR_PLLI2SRDYIE                 ((uint32_t)0x00002000)
 +#define  RCC_CIR_PLLSAIRDYIE                 ((uint32_t)0x00004000)
  #define  RCC_CIR_LSIRDYC                     ((uint32_t)0x00010000)
  #define  RCC_CIR_LSERDYC                     ((uint32_t)0x00020000)
  #define  RCC_CIR_HSIRDYC                     ((uint32_t)0x00040000)
  #define  RCC_CIR_HSERDYC                     ((uint32_t)0x00080000)
  #define  RCC_CIR_PLLRDYC                     ((uint32_t)0x00100000)
  #define  RCC_CIR_PLLI2SRDYC                  ((uint32_t)0x00200000)
 +#define  RCC_CIR_PLLSAIRDYC                  ((uint32_t)0x00400000)
  #define  RCC_CIR_CSSC                        ((uint32_t)0x00800000)
  /********************  Bit definition for RCC_AHB1RSTR register  **************/
 @@ -5063,9 +6830,12 @@ typedef struct  #define  RCC_AHB1RSTR_GPIOGRST               ((uint32_t)0x00000040)
  #define  RCC_AHB1RSTR_GPIOHRST               ((uint32_t)0x00000080)
  #define  RCC_AHB1RSTR_GPIOIRST               ((uint32_t)0x00000100)
 +#define  RCC_AHB1RSTR_GPIOJRST               ((uint32_t)0x00000200)
 +#define  RCC_AHB1RSTR_GPIOKRST               ((uint32_t)0x00000400)
  #define  RCC_AHB1RSTR_CRCRST                 ((uint32_t)0x00001000)
  #define  RCC_AHB1RSTR_DMA1RST                ((uint32_t)0x00200000)
  #define  RCC_AHB1RSTR_DMA2RST                ((uint32_t)0x00400000)
 +#define  RCC_AHB1RSTR_DMA2DRST               ((uint32_t)0x00800000)
  #define  RCC_AHB1RSTR_ETHMACRST              ((uint32_t)0x02000000)
  #define  RCC_AHB1RSTR_OTGHRST                ((uint32_t)0x10000000)
 @@ -5079,8 +6849,13 @@ typedef struct  #define  RCC_AHB2RSTR_OTGFSRST               ((uint32_t)0x00000080)
  /********************  Bit definition for RCC_AHB3RSTR register  **************/
 +#if defined(STM32F40_41xxx)
  #define  RCC_AHB3RSTR_FSMCRST                ((uint32_t)0x00000001)
 +#endif /* STM32F40_41xxx */
 +#if defined (STM32F427_437xx) || defined (STM32F429_439xx)
 +#define  RCC_AHB3RSTR_FMCRST                ((uint32_t)0x00000001)
 +#endif /* STM32F427_437xx ||  STM32F429_439xx */
  /********************  Bit definition for RCC_APB1RSTR register  **************/
  #define  RCC_APB1RSTR_TIM2RST                ((uint32_t)0x00000001)
  #define  RCC_APB1RSTR_TIM3RST                ((uint32_t)0x00000002)
 @@ -5123,6 +6898,8 @@ typedef struct  #define  RCC_APB2RSTR_TIM11RST               ((uint32_t)0x00040000)
  #define  RCC_APB2RSTR_SPI5RST                ((uint32_t)0x00100000)
  #define  RCC_APB2RSTR_SPI6RST                ((uint32_t)0x00200000)
 +#define  RCC_APB2RSTR_SAI1RST                ((uint32_t)0x00400000)
 +#define  RCC_APB2RSTR_LTDCRST                ((uint32_t)0x04000000)
  /* Old SPI1RST bit definition, maintained for legacy purpose */
  #define  RCC_APB2RSTR_SPI1                   RCC_APB2RSTR_SPI1RST
 @@ -5137,11 +6914,14 @@ typedef struct  #define  RCC_AHB1ENR_GPIOGEN                 ((uint32_t)0x00000040)
  #define  RCC_AHB1ENR_GPIOHEN                 ((uint32_t)0x00000080)
  #define  RCC_AHB1ENR_GPIOIEN                 ((uint32_t)0x00000100)
 +#define  RCC_AHB1ENR_GPIOJEN                 ((uint32_t)0x00000200)
 +#define  RCC_AHB1ENR_GPIOKEN                 ((uint32_t)0x00000400)
  #define  RCC_AHB1ENR_CRCEN                   ((uint32_t)0x00001000)
  #define  RCC_AHB1ENR_BKPSRAMEN               ((uint32_t)0x00040000)
  #define  RCC_AHB1ENR_CCMDATARAMEN            ((uint32_t)0x00100000)
  #define  RCC_AHB1ENR_DMA1EN                  ((uint32_t)0x00200000)
  #define  RCC_AHB1ENR_DMA2EN                  ((uint32_t)0x00400000)
 +#define  RCC_AHB1ENR_DMA2DEN                 ((uint32_t)0x00800000)
  #define  RCC_AHB1ENR_ETHMACEN                ((uint32_t)0x02000000)
  #define  RCC_AHB1ENR_ETHMACTXEN              ((uint32_t)0x04000000)
  #define  RCC_AHB1ENR_ETHMACRXEN              ((uint32_t)0x08000000)
 @@ -5157,7 +6937,14 @@ typedef struct  #define  RCC_AHB2ENR_OTGFSEN                 ((uint32_t)0x00000080)
  /********************  Bit definition for RCC_AHB3ENR register  ***************/
 +
 +#if defined(STM32F40_41xxx)
  #define  RCC_AHB3ENR_FSMCEN                  ((uint32_t)0x00000001)
 +#endif /* STM32F40_41xxx */
 +
 +#if defined (STM32F427_437xx) || defined (STM32F429_439xx)
 +#define  RCC_AHB3ENR_FMCEN                  ((uint32_t)0x00000001)
 +#endif /* STM32F427_437xx ||  STM32F429_439xx */
  /********************  Bit definition for RCC_APB1ENR register  ***************/
  #define  RCC_APB1ENR_TIM2EN                  ((uint32_t)0x00000001)
 @@ -5203,6 +6990,8 @@ typedef struct  #define  RCC_APB2ENR_TIM11EN                 ((uint32_t)0x00040000)
  #define  RCC_APB2ENR_SPI5EN                  ((uint32_t)0x00100000)
  #define  RCC_APB2ENR_SPI6EN                  ((uint32_t)0x00200000)
 +#define  RCC_APB2ENR_SAI1EN                  ((uint32_t)0x00400000)
 +#define  RCC_APB2ENR_LTDCEN                  ((uint32_t)0x04000000)
  /********************  Bit definition for RCC_AHB1LPENR register  *************/
  #define  RCC_AHB1LPENR_GPIOALPEN             ((uint32_t)0x00000001)
 @@ -5214,6 +7003,8 @@ typedef struct  #define  RCC_AHB1LPENR_GPIOGLPEN             ((uint32_t)0x00000040)
  #define  RCC_AHB1LPENR_GPIOHLPEN             ((uint32_t)0x00000080)
  #define  RCC_AHB1LPENR_GPIOILPEN             ((uint32_t)0x00000100)
 +#define  RCC_AHB1LPENR_GPIOJLPEN             ((uint32_t)0x00000200)
 +#define  RCC_AHB1LPENR_GPIOKLPEN             ((uint32_t)0x00000400)
  #define  RCC_AHB1LPENR_CRCLPEN               ((uint32_t)0x00001000)
  #define  RCC_AHB1LPENR_FLITFLPEN             ((uint32_t)0x00008000)
  #define  RCC_AHB1LPENR_SRAM1LPEN             ((uint32_t)0x00010000)
 @@ -5222,6 +7013,7 @@ typedef struct  #define  RCC_AHB1LPENR_SRAM3LPEN             ((uint32_t)0x00080000)
  #define  RCC_AHB1LPENR_DMA1LPEN              ((uint32_t)0x00200000)
  #define  RCC_AHB1LPENR_DMA2LPEN              ((uint32_t)0x00400000)
 +#define  RCC_AHB1LPENR_DMA2DLPEN             ((uint32_t)0x00800000)
  #define  RCC_AHB1LPENR_ETHMACLPEN            ((uint32_t)0x02000000)
  #define  RCC_AHB1LPENR_ETHMACTXLPEN          ((uint32_t)0x04000000)
  #define  RCC_AHB1LPENR_ETHMACRXLPEN          ((uint32_t)0x08000000)
 @@ -5237,7 +7029,13 @@ typedef struct  #define  RCC_AHB2LPENR_OTGFSLPEN             ((uint32_t)0x00000080)
  /********************  Bit definition for RCC_AHB3LPENR register  *************/
 +#if defined(STM32F40_41xxx)
  #define  RCC_AHB3LPENR_FSMCLPEN              ((uint32_t)0x00000001)
 +#endif /* STM32F40_41xxx */
 +
 +#if defined (STM32F427_437xx) || defined (STM32F429_439xx)
 +#define  RCC_AHB3LPENR_FMCLPEN              ((uint32_t)0x00000001)
 +#endif /* STM32F427_437xx ||  STM32F429_439xx */
  /********************  Bit definition for RCC_APB1LPENR register  *************/
  #define  RCC_APB1LPENR_TIM2LPEN              ((uint32_t)0x00000001)
 @@ -5283,6 +7081,8 @@ typedef struct  #define  RCC_APB2LPENR_TIM11LPEN             ((uint32_t)0x00040000)
  #define  RCC_APB2LPENR_SPI5LPEN              ((uint32_t)0x00100000)
  #define  RCC_APB2LPENR_SPI6LPEN              ((uint32_t)0x00200000)
 +#define  RCC_APB2LPENR_SAI1LPEN              ((uint32_t)0x00400000)
 +#define  RCC_APB2LPENR_LTDCLPEN              ((uint32_t)0x04000000)
  /********************  Bit definition for RCC_BDCR register  ******************/
  #define  RCC_BDCR_LSEON                      ((uint32_t)0x00000001)
 @@ -5316,9 +7116,20 @@ typedef struct  /********************  Bit definition for RCC_PLLI2SCFGR register  ************/
  #define  RCC_PLLI2SCFGR_PLLI2SN              ((uint32_t)0x00007FC0)
 +#define  RCC_PLLI2SCFGR_PLLI2SQ              ((uint32_t)0x0F000000)
  #define  RCC_PLLI2SCFGR_PLLI2SR              ((uint32_t)0x70000000)
 +/********************  Bit definition for RCC_PLLSAICFGR register  ************/
 +#define  RCC_PLLSAICFGR_PLLI2SN              ((uint32_t)0x00007FC0)
 +#define  RCC_PLLSAICFGR_PLLI2SQ              ((uint32_t)0x0F000000)
 +#define  RCC_PLLSAICFGR_PLLI2SR              ((uint32_t)0x70000000)
 +
  /********************  Bit definition for RCC_DCKCFGR register  ***************/
 +#define  RCC_DCKCFGR_PLLI2SDIVQ              ((uint32_t)0x0000001F)
 +#define  RCC_DCKCFGR_PLLSAIDIVQ              ((uint32_t)0x00001F00)
 +#define  RCC_DCKCFGR_PLLSAIDIVR              ((uint32_t)0x00030000)
 +#define  RCC_DCKCFGR_SAI1ASRC                ((uint32_t)0x00300000)
 +#define  RCC_DCKCFGR_SAI1BSRC                ((uint32_t)0x00C00000)
  #define  RCC_DCKCFGR_TIMPRE                  ((uint32_t)0x01000000)
 @@ -5715,6 +7526,155 @@ typedef struct  /********************  Bits definition for RTC_BKP19R register  ***************/
  #define RTC_BKP19R                           ((uint32_t)0xFFFFFFFF)
 +/******************************************************************************/
 +/*                                                                            */
 +/*                          Serial Audio Interface                            */
 +/*                                                                            */
 +/******************************************************************************/
 +/********************  Bit definition for SAI_GCR register  *******************/
 +#define  SAI_GCR_SYNCIN                  ((uint32_t)0x00000003)        /*!<SYNCIN[1:0] bits (Synchronization Inputs)   */
 +#define  SAI_GCR_SYNCIN_0                ((uint32_t)0x00000001)        /*!<Bit 0 */
 +#define  SAI_GCR_SYNCIN_1                ((uint32_t)0x00000002)        /*!<Bit 1 */
 +
 +#define  SAI_GCR_SYNCOUT                 ((uint32_t)0x00000030)        /*!<SYNCOUT[1:0] bits (Synchronization Outputs) */
 +#define  SAI_GCR_SYNCOUT_0               ((uint32_t)0x00000010)        /*!<Bit 0 */
 +#define  SAI_GCR_SYNCOUT_1               ((uint32_t)0x00000020)        /*!<Bit 1 */
 +
 +/*******************  Bit definition for SAI_xCR1 register  *******************/
 +#define  SAI_xCR1_MODE                    ((uint32_t)0x00000003)        /*!<MODE[1:0] bits (Audio Block Mode)           */
 +#define  SAI_xCR1_MODE_0                  ((uint32_t)0x00000001)        /*!<Bit 0 */
 +#define  SAI_xCR1_MODE_1                  ((uint32_t)0x00000002)        /*!<Bit 1 */
 +
 +#define  SAI_xCR1_PRTCFG                  ((uint32_t)0x0000000C)        /*!<PRTCFG[1:0] bits (Protocol Configuration)   */
 +#define  SAI_xCR1_PRTCFG_0                ((uint32_t)0x00000004)        /*!<Bit 0 */
 +#define  SAI_xCR1_PRTCFG_1                ((uint32_t)0x00000008)        /*!<Bit 1 */
 +
 +#define  SAI_xCR1_DS                      ((uint32_t)0x000000E0)        /*!<DS[1:0] bits (Data Size) */
 +#define  SAI_xCR1_DS_0                    ((uint32_t)0x00000020)        /*!<Bit 0 */
 +#define  SAI_xCR1_DS_1                    ((uint32_t)0x00000040)        /*!<Bit 1 */
 +#define  SAI_xCR1_DS_2                    ((uint32_t)0x00000080)        /*!<Bit 2 */
 +
 +#define  SAI_xCR1_LSBFIRST                ((uint32_t)0x00000100)        /*!<LSB First Configuration  */
 +#define  SAI_xCR1_CKSTR                   ((uint32_t)0x00000200)        /*!<ClocK STRobing edge      */
 +
 +#define  SAI_xCR1_SYNCEN                  ((uint32_t)0x00000C00)        /*!<SYNCEN[1:0](SYNChronization ENable) */
 +#define  SAI_xCR1_SYNCEN_0                ((uint32_t)0x00000400)        /*!<Bit 0 */
 +#define  SAI_xCR1_SYNCEN_1                ((uint32_t)0x00000800)        /*!<Bit 1 */
 +
 +#define  SAI_xCR1_MONO                    ((uint32_t)0x00001000)        /*!<Mono mode                  */
 +#define  SAI_xCR1_OUTDRIV                 ((uint32_t)0x00002000)        /*!<Output Drive               */
 +#define  SAI_xCR1_SAIEN                   ((uint32_t)0x00010000)        /*!<Audio Block enable         */
 +#define  SAI_xCR1_DMAEN                   ((uint32_t)0x00020000)        /*!<DMA enable                 */
 +#define  SAI_xCR1_NODIV                   ((uint32_t)0x00080000)        /*!<No Divider Configuration   */
 +
 +#define  SAI_xCR1_MCKDIV                  ((uint32_t)0x00780000)        /*!<MCKDIV[3:0] (Master ClocK Divider)  */
 +#define  SAI_xCR1_MCKDIV_0                ((uint32_t)0x00080000)        /*!<Bit 0  */
 +#define  SAI_xCR1_MCKDIV_1                ((uint32_t)0x00100000)        /*!<Bit 1  */
 +#define  SAI_xCR1_MCKDIV_2                ((uint32_t)0x00200000)        /*!<Bit 2  */
 +#define  SAI_xCR1_MCKDIV_3                ((uint32_t)0x00400000)        /*!<Bit 3  */
 +
 +/*******************  Bit definition for SAI_xCR2 register  *******************/
 +#define  SAI_xCR2_FTH                     ((uint32_t)0x00000003)        /*!<FTH[1:0](Fifo THreshold)  */
 +#define  SAI_xCR2_FTH_0                   ((uint32_t)0x00000001)        /*!<Bit 0 */
 +#define  SAI_xCR2_FTH_1                   ((uint32_t)0x00000002)        /*!<Bit 1 */
 +
 +#define  SAI_xCR2_FFLUSH                  ((uint32_t)0x00000008)        /*!<Fifo FLUSH                       */
 +#define  SAI_xCR2_TRIS                    ((uint32_t)0x00000010)        /*!<TRIState Management on data line */
 +#define  SAI_xCR2_MUTE                    ((uint32_t)0x00000020)        /*!<Mute mode                        */
 +#define  SAI_xCR2_MUTEVAL                 ((uint32_t)0x00000040)        /*!<Muate value                      */
 +
 +#define  SAI_xCR2_MUTECNT                  ((uint32_t)0x00001F80)       /*!<MUTECNT[5:0] (MUTE counter) */
 +#define  SAI_xCR2_MUTECNT_0               ((uint32_t)0x00000080)        /*!<Bit 0 */
 +#define  SAI_xCR2_MUTECNT_1               ((uint32_t)0x00000100)        /*!<Bit 1 */
 +#define  SAI_xCR2_MUTECNT_2               ((uint32_t)0x00000200)        /*!<Bit 2 */
 +#define  SAI_xCR2_MUTECNT_3               ((uint32_t)0x00000400)        /*!<Bit 3 */
 +#define  SAI_xCR2_MUTECNT_4               ((uint32_t)0x00000800)        /*!<Bit 4 */
 +#define  SAI_xCR2_MUTECNT_5               ((uint32_t)0x00001000)        /*!<Bit 5 */
 +
 +#define  SAI_xCR2_CPL                     ((uint32_t)0x00080000)        /*!< Complement Bit             */
 +
 +#define  SAI_xCR2_COMP                    ((uint32_t)0x0000C000)        /*!<COMP[1:0] (Companding mode) */
 +#define  SAI_xCR2_COMP_0                  ((uint32_t)0x00004000)        /*!<Bit 0 */
 +#define  SAI_xCR2_COMP_1                  ((uint32_t)0x00008000)        /*!<Bit 1 */
 +
 +/******************  Bit definition for SAI_xFRCR register  *******************/
 +#define  SAI_xFRCR_FRL                    ((uint32_t)0x000000FF)        /*!<FRL[1:0](Frame length)  */
 +#define  SAI_xFRCR_FRL_0                  ((uint32_t)0x00000001)        /*!<Bit 0 */
 +#define  SAI_xFRCR_FRL_1                  ((uint32_t)0x00000002)        /*!<Bit 1 */
 +#define  SAI_xFRCR_FRL_2                  ((uint32_t)0x00000004)        /*!<Bit 2 */
 +#define  SAI_xFRCR_FRL_3                  ((uint32_t)0x00000008)        /*!<Bit 3 */
 +#define  SAI_xFRCR_FRL_4                  ((uint32_t)0x00000010)        /*!<Bit 4 */
 +#define  SAI_xFRCR_FRL_5                  ((uint32_t)0x00000020)        /*!<Bit 5 */
 +#define  SAI_xFRCR_FRL_6                  ((uint32_t)0x00000040)        /*!<Bit 6 */
 +#define  SAI_xFRCR_FRL_7                  ((uint32_t)0x00000080)        /*!<Bit 7 */
 +
 +#define  SAI_xFRCR_FSALL                  ((uint32_t)0x00007F00)        /*!<FRL[1:0] (Frame synchronization active level length)  */
 +#define  SAI_xFRCR_FSALL_0                ((uint32_t)0x00000100)        /*!<Bit 0 */
 +#define  SAI_xFRCR_FSALL_1                ((uint32_t)0x00000200)        /*!<Bit 1 */
 +#define  SAI_xFRCR_FSALL_2                ((uint32_t)0x00000400)        /*!<Bit 2 */
 +#define  SAI_xFRCR_FSALL_3                ((uint32_t)0x00000800)        /*!<Bit 3 */
 +#define  SAI_xFRCR_FSALL_4                ((uint32_t)0x00001000)        /*!<Bit 4 */
 +#define  SAI_xFRCR_FSALL_5                ((uint32_t)0x00002000)        /*!<Bit 5 */
 +#define  SAI_xFRCR_FSALL_6                ((uint32_t)0x00004000)        /*!<Bit 6 */
 +
 +#define  SAI_xFRCR_FSDEF                  ((uint32_t)0x00010000)        /*!< Frame Synchronization Definition */
 +#define  SAI_xFRCR_FSPO                   ((uint32_t)0x00020000)        /*!<Frame Synchronization POLarity    */
 +#define  SAI_xFRCR_FSOFF                  ((uint32_t)0x00040000)        /*!<Frame Synchronization OFFset      */
 +
 +/******************  Bit definition for SAI_xSLOTR register  *******************/
 +#define  SAI_xSLOTR_FBOFF                 ((uint32_t)0x0000001F)        /*!<FRL[4:0](First Bit Offset)  */
 +#define  SAI_xSLOTR_FBOFF_0               ((uint32_t)0x00000001)        /*!<Bit 0 */
 +#define  SAI_xSLOTR_FBOFF_1               ((uint32_t)0x00000002)        /*!<Bit 1 */
 +#define  SAI_xSLOTR_FBOFF_2               ((uint32_t)0x00000004)        /*!<Bit 2 */
 +#define  SAI_xSLOTR_FBOFF_3               ((uint32_t)0x00000008)        /*!<Bit 3 */
 +#define  SAI_xSLOTR_FBOFF_4               ((uint32_t)0x00000010)        /*!<Bit 4 */
 +                                     
 +#define  SAI_xSLOTR_SLOTSZ                ((uint32_t)0x000000C0)        /*!<SLOTSZ[1:0] (Slot size)  */
 +#define  SAI_xSLOTR_SLOTSZ_0              ((uint32_t)0x00000040)        /*!<Bit 0 */
 +#define  SAI_xSLOTR_SLOTSZ_1              ((uint32_t)0x00000080)        /*!<Bit 1 */
 +
 +#define  SAI_xSLOTR_NBSLOT                ((uint32_t)0x00000F00)        /*!<NBSLOT[3:0] (Number of Slot in audio Frame)  */
 +#define  SAI_xSLOTR_NBSLOT_0              ((uint32_t)0x00000100)        /*!<Bit 0 */
 +#define  SAI_xSLOTR_NBSLOT_1              ((uint32_t)0x00000200)        /*!<Bit 1 */
 +#define  SAI_xSLOTR_NBSLOT_2              ((uint32_t)0x00000400)        /*!<Bit 2 */
 +#define  SAI_xSLOTR_NBSLOT_3              ((uint32_t)0x00000800)        /*!<Bit 3 */
 +
 +#define  SAI_xSLOTR_SLOTEN                ((uint32_t)0xFFFF0000)        /*!<SLOTEN[15:0] (Slot Enable)  */
 +
 +/*******************  Bit definition for SAI_xIMR register  *******************/
 +#define  SAI_xIMR_OVRUDRIE                ((uint32_t)0x00000001)        /*!<Overrun underrun interrupt enable                              */
 +#define  SAI_xIMR_MUTEDETIE               ((uint32_t)0x00000002)        /*!<Mute detection interrupt enable                                */
 +#define  SAI_xIMR_WCKCFGIE                ((uint32_t)0x00000004)        /*!<Wrong Clock Configuration interrupt enable                     */
 +#define  SAI_xIMR_FREQIE                  ((uint32_t)0x00000008)        /*!<FIFO request interrupt enable                                  */
 +#define  SAI_xIMR_CNRDYIE                 ((uint32_t)0x00000010)        /*!<Codec not ready interrupt enable                               */
 +#define  SAI_xIMR_AFSDETIE                ((uint32_t)0x00000020)        /*!<Anticipated frame synchronization detection interrupt enable   */
 +#define  SAI_xIMR_LFSDETIE                ((uint32_t)0x00000040)        /*!<Late frame synchronization detection interrupt enable          */
 +
 +/********************  Bit definition for SAI_xSR register  *******************/
 +#define  SAI_xSR_OVRUDR                   ((uint32_t)0x00000001)         /*!<Overrun underrun                               */
 +#define  SAI_xSR_MUTEDET                  ((uint32_t)0x00000002)         /*!<Mute detection                                 */
 +#define  SAI_xSR_WCKCFG                   ((uint32_t)0x00000004)         /*!<Wrong Clock Configuration                      */
 +#define  SAI_xSR_FREQ                     ((uint32_t)0x00000008)         /*!<FIFO request                                   */
 +#define  SAI_xSR_CNRDY                    ((uint32_t)0x00000010)         /*!<Codec not ready                                */
 +#define  SAI_xSR_AFSDET                   ((uint32_t)0x00000020)         /*!<Anticipated frame synchronization detection    */
 +#define  SAI_xSR_LFSDET                   ((uint32_t)0x00000040)         /*!<Late frame synchronization detection           */
 +
 +#define  SAI_xSR_FLVL                     ((uint32_t)0x00070000)         /*!<FLVL[2:0] (FIFO Level Threshold)               */
 +#define  SAI_xSR_FLVL_0                   ((uint32_t)0x00010000)         /*!<Bit 0 */
 +#define  SAI_xSR_FLVL_1                   ((uint32_t)0x00020000)         /*!<Bit 1 */
 +#define  SAI_xSR_FLVL_2                   ((uint32_t)0x00030000)         /*!<Bit 2 */
 +
 +/******************  Bit definition for SAI_xCLRFR register  ******************/
 +#define  SAI_xCLRFR_COVRUDR               ((uint32_t)0x00000001)        /*!<Clear Overrun underrun                               */
 +#define  SAI_xCLRFR_CMUTEDET              ((uint32_t)0x00000002)        /*!<Clear Mute detection                                 */
 +#define  SAI_xCLRFR_CWCKCFG               ((uint32_t)0x00000004)        /*!<Clear Wrong Clock Configuration                      */
 +#define  SAI_xCLRFR_CFREQ                 ((uint32_t)0x00000008)        /*!<Clear FIFO request                                   */
 +#define  SAI_xCLRFR_CCNRDY                ((uint32_t)0x00000010)        /*!<Clear Codec not ready                                */
 +#define  SAI_xCLRFR_CAFSDET               ((uint32_t)0x00000020)        /*!<Clear Anticipated frame synchronization detection    */
 +#define  SAI_xCLRFR_CLFSDET               ((uint32_t)0x00000040)        /*!<Clear Late frame synchronization detection           */
 +
 +/******************  Bit definition for SAI_xDR register  ******************/
 +#define  SAI_xDR_DATA                     ((uint32_t)0xFFFFFFFF)        
  /******************************************************************************/
  /*                                                                            */
 @@ -5964,13 +7924,23 @@ typedef struct  /******************************************************************************/
  /******************  Bit definition for SYSCFG_MEMRMP register  ***************/  
  #define SYSCFG_MEMRMP_MEM_MODE          ((uint32_t)0x00000007) /*!< SYSCFG_Memory Remap Config */
 -#define SYSCFG_MEMRMP_MEM_MODE_0        ((uint32_t)0x00000001)
 -#define SYSCFG_MEMRMP_MEM_MODE_1        ((uint32_t)0x00000002)
 -#define SYSCFG_MEMRMP_MEM_MODE_2        ((uint32_t)0x00000004)
 +#define SYSCFG_MEMRMP_MEM_MODE_0        ((uint32_t)0x00000001) /*!<Bit 0 */
 +#define SYSCFG_MEMRMP_MEM_MODE_1        ((uint32_t)0x00000002) /*!<Bit 1 */
 +#define SYSCFG_MEMRMP_MEM_MODE_2        ((uint32_t)0x00000004) /*!<Bit 2 */
 +
 +#define SYSCFG_MEMRMP_FB_MODE           ((uint32_t)0x00000100) /*!< User Flash Bank mode */
 +
 +#define SYSCFG_MEMRMP_SWP_FMC           ((uint32_t)0x00000C00) /*!< FMC memory mapping swap */
 +#define SYSCFG_MEMRMP_SWP_FMC_0         ((uint32_t)0x00000400) /*!<Bit 0 */
 +#define SYSCFG_MEMRMP_SWP_FMC_1         ((uint32_t)0x00000800) /*!<Bit 1 */
 -#define SYSCFG_MEMRMP_UFB_MODE          ((uint32_t)0x00000100) /*!< User Flash Bank mode */
  /******************  Bit definition for SYSCFG_PMC register  ******************/
 +#define SYSCFG_PMC_ADCxDC2              ((uint32_t)0x00070000) /*!< Refer to AN4073 on how to use this bit  */
 +#define SYSCFG_PMC_ADC1DC2              ((uint32_t)0x00010000) /*!< Refer to AN4073 on how to use this bit  */
 +#define SYSCFG_PMC_ADC2DC2              ((uint32_t)0x00020000) /*!< Refer to AN4073 on how to use this bit  */
 +#define SYSCFG_PMC_ADC3DC2              ((uint32_t)0x00040000) /*!< Refer to AN4073 on how to use this bit  */
 +
  #define SYSCFG_PMC_MII_RMII_SEL         ((uint32_t)0x00800000) /*!<Ethernet PHY interface selection */
  /* Old MII_RMII_SEL bit definition, maintained for legacy purpose */
  #define SYSCFG_PMC_MII_RMII             SYSCFG_PMC_MII_RMII_SEL
 @@ -5992,6 +7962,8 @@ typedef struct  #define SYSCFG_EXTICR1_EXTI0_PG         ((uint16_t)0x0006) /*!<PG[0] pin */
  #define SYSCFG_EXTICR1_EXTI0_PH         ((uint16_t)0x0007) /*!<PH[0] pin */
  #define SYSCFG_EXTICR1_EXTI0_PI         ((uint16_t)0x0008) /*!<PI[0] pin */
 +#define SYSCFG_EXTICR1_EXTI0_PJ         ((uint16_t)0x0009) /*!<PJ[0] pin */
 +#define SYSCFG_EXTICR1_EXTI0_PK         ((uint16_t)0x000A) /*!<PK[0] pin */
  /** 
    * @brief   EXTI1 configuration  
 @@ -6005,6 +7977,8 @@ typedef struct  #define SYSCFG_EXTICR1_EXTI1_PG         ((uint16_t)0x0060) /*!<PG[1] pin */
  #define SYSCFG_EXTICR1_EXTI1_PH         ((uint16_t)0x0070) /*!<PH[1] pin */
  #define SYSCFG_EXTICR1_EXTI1_PI         ((uint16_t)0x0080) /*!<PI[1] pin */
 +#define SYSCFG_EXTICR1_EXTI1_PJ         ((uint16_t)0x0090) /*!<PJ[1] pin */
 +#define SYSCFG_EXTICR1_EXTI1_PK         ((uint16_t)0x00A0) /*!<PK[1] pin */
  /** 
    * @brief   EXTI2 configuration  
 @@ -6018,6 +7992,8 @@ typedef struct  #define SYSCFG_EXTICR1_EXTI2_PG         ((uint16_t)0x0600) /*!<PG[2] pin */
  #define SYSCFG_EXTICR1_EXTI2_PH         ((uint16_t)0x0700) /*!<PH[2] pin */
  #define SYSCFG_EXTICR1_EXTI2_PI         ((uint16_t)0x0800) /*!<PI[2] pin */
 +#define SYSCFG_EXTICR1_EXTI2_PJ         ((uint16_t)0x0900) /*!<PJ[2] pin */
 +#define SYSCFG_EXTICR1_EXTI2_PK         ((uint16_t)0x0A00) /*!<PK[2] pin */
  /** 
    * @brief   EXTI3 configuration  
 @@ -6031,6 +8007,8 @@ typedef struct  #define SYSCFG_EXTICR1_EXTI3_PG         ((uint16_t)0x6000) /*!<PG[3] pin */
  #define SYSCFG_EXTICR1_EXTI3_PH         ((uint16_t)0x7000) /*!<PH[3] pin */
  #define SYSCFG_EXTICR1_EXTI3_PI         ((uint16_t)0x8000) /*!<PI[3] pin */
 +#define SYSCFG_EXTICR1_EXTI3_PJ         ((uint16_t)0x9000) /*!<PJ[3] pin */
 +#define SYSCFG_EXTICR1_EXTI3_PK         ((uint16_t)0xA000) /*!<PK[3] pin */
  /*****************  Bit definition for SYSCFG_EXTICR2 register  ***************/
  #define SYSCFG_EXTICR2_EXTI4            ((uint16_t)0x000F) /*!<EXTI 4 configuration */
 @@ -6049,6 +8027,8 @@ typedef struct  #define SYSCFG_EXTICR2_EXTI4_PG         ((uint16_t)0x0006) /*!<PG[4] pin */
  #define SYSCFG_EXTICR2_EXTI4_PH         ((uint16_t)0x0007) /*!<PH[4] pin */
  #define SYSCFG_EXTICR2_EXTI4_PI         ((uint16_t)0x0008) /*!<PI[4] pin */
 +#define SYSCFG_EXTICR2_EXTI4_PJ         ((uint16_t)0x0009) /*!<PJ[4] pin */
 +#define SYSCFG_EXTICR2_EXTI4_PK         ((uint16_t)0x000A) /*!<PK[4] pin */
  /** 
    * @brief   EXTI5 configuration  
 @@ -6062,6 +8042,8 @@ typedef struct  #define SYSCFG_EXTICR2_EXTI5_PG         ((uint16_t)0x0060) /*!<PG[5] pin */
  #define SYSCFG_EXTICR2_EXTI5_PH         ((uint16_t)0x0070) /*!<PH[5] pin */
  #define SYSCFG_EXTICR2_EXTI5_PI         ((uint16_t)0x0080) /*!<PI[5] pin */
 +#define SYSCFG_EXTICR2_EXTI5_PJ         ((uint16_t)0x0090) /*!<PJ[5] pin */
 +#define SYSCFG_EXTICR2_EXTI5_PK         ((uint16_t)0x00A0) /*!<PK[5] pin */
  /** 
    * @brief   EXTI6 configuration  
 @@ -6075,6 +8057,8 @@ typedef struct  #define SYSCFG_EXTICR2_EXTI6_PG         ((uint16_t)0x0600) /*!<PG[6] pin */
  #define SYSCFG_EXTICR2_EXTI6_PH         ((uint16_t)0x0700) /*!<PH[6] pin */
  #define SYSCFG_EXTICR2_EXTI6_PI         ((uint16_t)0x0800) /*!<PI[6] pin */
 +#define SYSCFG_EXTICR2_EXTI6_PJ         ((uint16_t)0x0900) /*!<PJ[6] pin */
 +#define SYSCFG_EXTICR2_EXTI6_PK         ((uint16_t)0x0A00) /*!<PK[6] pin */
  /** 
    * @brief   EXTI7 configuration  
 @@ -6088,6 +8072,8 @@ typedef struct  #define SYSCFG_EXTICR2_EXTI7_PG         ((uint16_t)0x6000) /*!<PG[7] pin */
  #define SYSCFG_EXTICR2_EXTI7_PH         ((uint16_t)0x7000) /*!<PH[7] pin */
  #define SYSCFG_EXTICR2_EXTI7_PI         ((uint16_t)0x8000) /*!<PI[7] pin */
 +#define SYSCFG_EXTICR2_EXTI7_PJ         ((uint16_t)0x9000) /*!<PJ[7] pin */
 +#define SYSCFG_EXTICR2_EXTI7_PK         ((uint16_t)0xA000) /*!<PK[7] pin */
  /*****************  Bit definition for SYSCFG_EXTICR3 register  ***************/
  #define SYSCFG_EXTICR3_EXTI8            ((uint16_t)0x000F) /*!<EXTI 8 configuration */
 @@ -6107,6 +8093,7 @@ typedef struct  #define SYSCFG_EXTICR3_EXTI8_PG         ((uint16_t)0x0006) /*!<PG[8] pin */
  #define SYSCFG_EXTICR3_EXTI8_PH         ((uint16_t)0x0007) /*!<PH[8] pin */
  #define SYSCFG_EXTICR3_EXTI8_PI         ((uint16_t)0x0008) /*!<PI[8] pin */
 +#define SYSCFG_EXTICR3_EXTI8_PJ         ((uint16_t)0x0009) /*!<PJ[8] pin */
  /** 
    * @brief   EXTI9 configuration  
 @@ -6120,6 +8107,7 @@ typedef struct  #define SYSCFG_EXTICR3_EXTI9_PG         ((uint16_t)0x0060) /*!<PG[9] pin */
  #define SYSCFG_EXTICR3_EXTI9_PH         ((uint16_t)0x0070) /*!<PH[9] pin */
  #define SYSCFG_EXTICR3_EXTI9_PI         ((uint16_t)0x0080) /*!<PI[9] pin */
 +#define SYSCFG_EXTICR3_EXTI9_PJ         ((uint16_t)0x0090) /*!<PJ[9] pin */
  /** 
    * @brief   EXTI10 configuration  
 @@ -6133,6 +8121,7 @@ typedef struct  #define SYSCFG_EXTICR3_EXTI10_PG        ((uint16_t)0x0600) /*!<PG[10] pin */
  #define SYSCFG_EXTICR3_EXTI10_PH        ((uint16_t)0x0700) /*!<PH[10] pin */
  #define SYSCFG_EXTICR3_EXTI10_PI        ((uint16_t)0x0800) /*!<PI[10] pin */
 +#define SYSCFG_EXTICR3_EXTI10_PJ        ((uint16_t)0x0900) /*!<PJ[10] pin */
  /** 
    * @brief   EXTI11 configuration  
 @@ -6146,6 +8135,7 @@ typedef struct  #define SYSCFG_EXTICR3_EXTI11_PG        ((uint16_t)0x6000) /*!<PG[11] pin */
  #define SYSCFG_EXTICR3_EXTI11_PH        ((uint16_t)0x7000) /*!<PH[11] pin */
  #define SYSCFG_EXTICR3_EXTI11_PI        ((uint16_t)0x8000) /*!<PI[11] pin */
 +#define SYSCFG_EXTICR3_EXTI11_PJ        ((uint16_t)0x9000) /*!<PJ[11] pin */
  /*****************  Bit definition for SYSCFG_EXTICR4 register  ***************/
  #define SYSCFG_EXTICR4_EXTI12           ((uint16_t)0x000F) /*!<EXTI 12 configuration */
 @@ -6163,6 +8153,8 @@ typedef struct  #define SYSCFG_EXTICR4_EXTI12_PF        ((uint16_t)0x0005) /*!<PF[12] pin */
  #define SYSCFG_EXTICR4_EXTI12_PG        ((uint16_t)0x0006) /*!<PG[12] pin */
  #define SYSCFG_EXTICR4_EXTI12_PH        ((uint16_t)0x0007) /*!<PH[12] pin */
 +#define SYSCFG_EXTICR4_EXTI12_PI        ((uint16_t)0x0008) /*!<PI[12] pin */
 +#define SYSCFG_EXTICR4_EXTI12_PJ        ((uint16_t)0x0009) /*!<PJ[12] pin */
  /** 
    * @brief   EXTI13 configuration  
 @@ -6175,6 +8167,8 @@ typedef struct  #define SYSCFG_EXTICR4_EXTI13_PF        ((uint16_t)0x0050) /*!<PF[13] pin */
  #define SYSCFG_EXTICR4_EXTI13_PG        ((uint16_t)0x0060) /*!<PG[13] pin */
  #define SYSCFG_EXTICR4_EXTI13_PH        ((uint16_t)0x0070) /*!<PH[13] pin */
 +#define SYSCFG_EXTICR4_EXTI13_PI        ((uint16_t)0x0008) /*!<PI[13] pin */
 +#define SYSCFG_EXTICR4_EXTI13_PJ        ((uint16_t)0x0009) /*!<PJ[13] pin */
  /** 
    * @brief   EXTI14 configuration  
 @@ -6187,6 +8181,8 @@ typedef struct  #define SYSCFG_EXTICR4_EXTI14_PF        ((uint16_t)0x0500) /*!<PF[14] pin */
  #define SYSCFG_EXTICR4_EXTI14_PG        ((uint16_t)0x0600) /*!<PG[14] pin */
  #define SYSCFG_EXTICR4_EXTI14_PH        ((uint16_t)0x0700) /*!<PH[14] pin */
 +#define SYSCFG_EXTICR4_EXTI14_PI        ((uint16_t)0x0800) /*!<PI[14] pin */
 +#define SYSCFG_EXTICR4_EXTI14_PJ        ((uint16_t)0x0900) /*!<PJ[14] pin */
  /** 
    * @brief   EXTI15 configuration  
 @@ -6199,6 +8195,8 @@ typedef struct  #define SYSCFG_EXTICR4_EXTI15_PF        ((uint16_t)0x5000) /*!<PF[15] pin */
  #define SYSCFG_EXTICR4_EXTI15_PG        ((uint16_t)0x6000) /*!<PG[15] pin */
  #define SYSCFG_EXTICR4_EXTI15_PH        ((uint16_t)0x7000) /*!<PH[15] pin */
 +#define SYSCFG_EXTICR4_EXTI15_PI        ((uint16_t)0x8000) /*!<PI[15] pin */
 +#define SYSCFG_EXTICR4_EXTI15_PJ        ((uint16_t)0x9000) /*!<PJ[15] pin */
  /******************  Bit definition for SYSCFG_CMPCR register  ****************/  
  #define SYSCFG_CMPCR_CMP_PD             ((uint32_t)0x00000001) /*!<Compensation cell ready flag */
 @@ -6664,7 +8662,7 @@ typedef struct  /* Old IWDGSTOP bit definition, maintained for legacy purpose */
  #define  DBGMCU_APB1_FZ_DBG_IWDEG_STOP           DBGMCU_APB1_FZ_DBG_IWDG_STOP
 -/********************  Bit definition for DBGMCU_APB2_FZ register  ************/
 +/********************  Bit definition for DBGMCU_APB1_FZ register  ************/
  #define  DBGMCU_APB1_FZ_DBG_TIM1_STOP        ((uint32_t)0x00000001)
  #define  DBGMCU_APB1_FZ_DBG_TIM8_STOP        ((uint32_t)0x00000002)
  #define  DBGMCU_APB1_FZ_DBG_TIM9_STOP        ((uint32_t)0x00010000)
 diff --git a/stm/lib/stm32f4xx_adc.c b/stm/lib/stm32f4xx_adc.c index eacc6b51f..9e230c08e 100644 --- a/stm/lib/stm32f4xx_adc.c +++ b/stm/lib/stm32f4xx_adc.c @@ -105,7 +105,6 @@  /* Includes ------------------------------------------------------------------*/
  #include "stm32f4xx_adc.h"
  #include "stm32f4xx_rcc.h"
 -#include "stm32f4xx_conf.h"
  /** @addtogroup STM32F4xx_StdPeriph_Driver
    * @{
 diff --git a/stm/lib/stm32f4xx_conf.h b/stm/lib/stm32f4xx_conf.h index 27029ce14..515a93c6e 100644 --- a/stm/lib/stm32f4xx_conf.h +++ b/stm/lib/stm32f4xx_conf.h @@ -2,8 +2,8 @@    ******************************************************************************
    * @file    Project/STM32F4xx_StdPeriph_Templates/stm32f4xx_conf.h  
    * @author  MCD Application Team
 -  * @version V1.1.0
 -  * @date    18-January-2013
 +  * @version V1.3.0
 +  * @date    13-November-2013
    * @brief   Library configuration file.
    ******************************************************************************
    * @attention
 @@ -31,32 +31,60 @@  /* Includes ------------------------------------------------------------------*/
  /* Uncomment the line below to enable peripheral header file inclusion */
 -//#include "stm32f4xx_adc.h"
 -//#include "stm32f4xx_can.h"
 +#include "stm32f4xx_adc.h"
  //#include "stm32f4xx_crc.h"
 -//#include "stm32f4xx_cryp.h"
 -//#include "stm32f4xx_dac.h"
  //#include "stm32f4xx_dbgmcu.h"
 -//#include "stm32f4xx_dcmi.h"
 -//#include "stm32f4xx_dma.h"
 -//#include "stm32f4xx_exti.h"
 -//#include "stm32f4xx_flash.h"
 -//#include "stm32f4xx_fsmc.h"
 -//#include "stm32f4xx_hash.h"
 -//#include "stm32f4xx_gpio.h"
 -//#include "stm32f4xx_i2c.h"
 +#include "stm32f4xx_dma.h"
 +#include "stm32f4xx_exti.h"
 +#include "stm32f4xx_flash.h"
 +#include "stm32f4xx_gpio.h"
 +#include "stm32f4xx_i2c.h"
  //#include "stm32f4xx_iwdg.h"
 -//#include "stm32f4xx_pwr.h"
 -//#include "stm32f4xx_rcc.h"
 -//#include "stm32f4xx_rng.h"
 -//#include "stm32f4xx_rtc.h"
 -//#include "stm32f4xx_sdio.h"
 -//#include "stm32f4xx_spi.h"
 -//#include "stm32f4xx_syscfg.h"
 -//#include "stm32f4xx_tim.h"
 -//#include "stm32f4xx_usart.h"
 +#include "stm32f4xx_pwr.h"
 +#include "stm32f4xx_rcc.h"
 +#include "stm32f4xx_rtc.h"
 +#include "stm32f4xx_sdio.h"
 +#include "stm32f4xx_spi.h"
 +#include "stm32f4xx_syscfg.h"
 +#include "stm32f4xx_tim.h"
 +#include "stm32f4xx_usart.h"
  //#include "stm32f4xx_wwdg.h"
 -//#include "misc.h" /* High level functions for NVIC and SysTick (add-on to CMSIS functions) */
 +#include "stm_misc.h" /* High level functions for NVIC and SysTick (add-on to CMSIS functions) */
 +
 +#if defined (STM32F429_439xx)
 +#include "stm32f4xx_cryp.h"
 +#include "stm32f4xx_hash.h"
 +#include "stm32f4xx_rng.h"
 +#include "stm32f4xx_can.h"
 +#include "stm32f4xx_dac.h"
 +#include "stm32f4xx_dcmi.h"
 +#include "stm32f4xx_dma2d.h"
 +#include "stm32f4xx_fmc.h"
 +#include "stm32f4xx_ltdc.h"
 +#include "stm32f4xx_sai.h"
 +#endif /* STM32F429_439xx */
 +
 +#if defined (STM32F427_437xx)
 +#include "stm32f4xx_cryp.h"
 +#include "stm32f4xx_hash.h"
 +#include "stm32f4xx_rng.h"
 +#include "stm32f4xx_can.h"
 +#include "stm32f4xx_dac.h"
 +#include "stm32f4xx_dcmi.h"
 +#include "stm32f4xx_dma2d.h"
 +#include "stm32f4xx_fmc.h"
 +#include "stm32f4xx_sai.h"
 +#endif /* STM32F427_437xx */
 +
 +#if defined (STM32F40_41xxx)
 +//#include "stm32f4xx_cryp.h"
 +//#include "stm32f4xx_hash.h"
 +#include "stm32f4xx_rng.h"
 +//#include "stm32f4xx_can.h"
 +#include "stm32f4xx_dac.h"
 +//#include "stm32f4xx_dcmi.h"
 +//#include "stm32f4xx_fsmc.h"
 +#endif /* STM32F40_41xxx */
  /* Exported types ------------------------------------------------------------*/
  /* Exported constants --------------------------------------------------------*/
 diff --git a/stm/lib/stm32f4xx_dac.c b/stm/lib/stm32f4xx_dac.c index bc19fb3b3..daff78d88 100644 --- a/stm/lib/stm32f4xx_dac.c +++ b/stm/lib/stm32f4xx_dac.c @@ -2,8 +2,8 @@    ******************************************************************************
    * @file    stm32f4xx_dac.c
    * @author  MCD Application Team
 -  * @version V1.1.0
 -  * @date    11-January-2013
 +  * @version V1.3.0
 +  * @date    08-November-2013
     * @brief   This file provides firmware functions to manage the following 
    *          functionalities of the Digital-to-Analog Converter (DAC) peripheral: 
    *           + DAC channels configuration: trigger, output buffer, data format
 @@ -128,7 +128,6 @@  /* Includes ------------------------------------------------------------------*/
 -#include "stm32f4xx_conf.h"
  #include "stm32f4xx_dac.h"
  #include "stm32f4xx_rcc.h"
 diff --git a/stm/lib/stm32f4xx_dac.h b/stm/lib/stm32f4xx_dac.h index 62c0c8728..224bec1a1 100644 --- a/stm/lib/stm32f4xx_dac.h +++ b/stm/lib/stm32f4xx_dac.h @@ -2,8 +2,8 @@    ******************************************************************************
    * @file    stm32f4xx_dac.h
    * @author  MCD Application Team
 -  * @version V1.1.0
 -  * @date    11-January-2013
 +  * @version V1.3.0
 +  * @date    08-November-2013
    * @brief   This file contains all the functions prototypes for the DAC firmware 
    *          library.
    ******************************************************************************
 diff --git a/stm/lib/stm32f4xx_dma.c b/stm/lib/stm32f4xx_dma.c index 856ec4bc3..ef86764ea 100644 --- a/stm/lib/stm32f4xx_dma.c +++ b/stm/lib/stm32f4xx_dma.c @@ -2,8 +2,8 @@    ******************************************************************************
    * @file    stm32f4xx_dma.c
    * @author  MCD Application Team
 -  * @version V1.1.0
 -  * @date    11-January-2013
 +  * @version V1.3.0
 +  * @date    08-November-2013
    * @brief   This file provides firmware functions to manage the following 
    *          functionalities of the Direct Memory Access controller (DMA):           
    *           + Initialization and Configuration
 @@ -121,7 +121,6 @@    */ 
  /* Includes ------------------------------------------------------------------*/
 -#include "stm32f4xx_conf.h"
  #include "stm32f4xx_dma.h"
  #include "stm32f4xx_rcc.h"
 diff --git a/stm/lib/stm32f4xx_dma.h b/stm/lib/stm32f4xx_dma.h index d7e987e47..3a105d1b4 100644 --- a/stm/lib/stm32f4xx_dma.h +++ b/stm/lib/stm32f4xx_dma.h @@ -2,8 +2,8 @@    ******************************************************************************
    * @file    stm32f4xx_dma.h
    * @author  MCD Application Team
 -  * @version V1.1.0
 -  * @date    11-January-2013
 +  * @version V1.3.0
 +  * @date    08-November-2013
    * @brief   This file contains all the functions prototypes for the DMA firmware 
    *          library.
    ******************************************************************************
 diff --git a/stm/lib/stm32f4xx_exti.c b/stm/lib/stm32f4xx_exti.c index 6160cbd7b..4eb676417 100644 --- a/stm/lib/stm32f4xx_exti.c +++ b/stm/lib/stm32f4xx_exti.c @@ -2,8 +2,8 @@    ******************************************************************************
    * @file    stm32f4xx_exti.c
    * @author  MCD Application Team
 -  * @version V1.1.0
 -  * @date    11-January-2013
 +  * @version V1.3.0
 +  * @date    08-November-2013
    * @brief   This file provides firmware functions to manage the following 
    *          functionalities of the EXTI peripheral:           
    *           + Initialization and Configuration
 @@ -65,7 +65,6 @@    */
  /* Includes ------------------------------------------------------------------*/
 -#include "stm32f4xx_conf.h"
  #include "stm32f4xx_exti.h"
  /** @addtogroup STM32F4xx_StdPeriph_Driver
 @@ -264,13 +263,11 @@ void EXTI_ClearFlag(uint32_t EXTI_Line)    */
  ITStatus EXTI_GetITStatus(uint32_t EXTI_Line)
  {
 -  ITStatus bitstatus = RESET;
 -  uint32_t enablestatus = 0;
 +  FlagStatus bitstatus = RESET;
    /* Check the parameters */
    assert_param(IS_GET_EXTI_LINE(EXTI_Line));
 -  enablestatus =  EXTI->IMR & EXTI_Line;
 -  if (((EXTI->PR & EXTI_Line) != (uint32_t)RESET) && (enablestatus != (uint32_t)RESET))
 +  if ((EXTI->PR & EXTI_Line) != (uint32_t)RESET)
    {
      bitstatus = SET;
    }
 @@ -279,6 +276,7 @@ ITStatus EXTI_GetITStatus(uint32_t EXTI_Line)      bitstatus = RESET;
    }
    return bitstatus;
 +  
  }
  /**
 diff --git a/stm/lib/stm32f4xx_exti.h b/stm/lib/stm32f4xx_exti.h index b6eb85395..39105e3b7 100644 --- a/stm/lib/stm32f4xx_exti.h +++ b/stm/lib/stm32f4xx_exti.h @@ -2,8 +2,8 @@    ******************************************************************************
    * @file    stm32f4xx_exti.h
    * @author  MCD Application Team
 -  * @version V1.1.0
 -  * @date    11-January-2013
 +  * @version V1.3.0
 +  * @date    08-November-2013
    * @brief   This file contains all the functions prototypes for the EXTI firmware
    *          library.
    ******************************************************************************
 diff --git a/stm/lib/stm32f4xx_flash.c b/stm/lib/stm32f4xx_flash.c index ba16c3f57..f3551b116 100644 --- a/stm/lib/stm32f4xx_flash.c +++ b/stm/lib/stm32f4xx_flash.c @@ -2,8 +2,8 @@    ******************************************************************************
    * @file    stm32f4xx_flash.c
    * @author  MCD Application Team
 -  * @version V1.1.0
 -  * @date    11-January-2013
 +  * @version V1.3.0
 +  * @date    08-November-2013
    * @brief   This file provides firmware functions to manage the following 
    *          functionalities of the FLASH peripheral:
    *            + FLASH Interface configuration
 @@ -70,7 +70,6 @@  /* Includes ------------------------------------------------------------------*/
  #include "stm32f4xx_flash.h"
 -#include "stm32f4xx_conf.h"
  /** @addtogroup STM32F4xx_StdPeriph_Driver
    * @{
 @@ -108,6 +107,8 @@            To correctly read data from FLASH memory, the number of wait states (LATENCY) 
            must be correctly programmed according to the frequency of the CPU clock 
            (HCLK) and the supply voltage of the device.
 +    [..]      
 +      For STM32F405xx/07xx and STM32F415xx/17xx devices
   +-------------------------------------------------------------------------------------+     
   | Latency       |                HCLK clock frequency (MHz)                           |
   |               |---------------------------------------------------------------------|     
 @@ -124,11 +125,57 @@   |---------------|----------------|----------------|-----------------|-----------------| 
   |4WS(5CPU cycle)|120< HCLK <= 150|96 < HCLK <= 120|88 < HCLK <= 110 |80 < HCLK <= 100 |
   |---------------|----------------|----------------|-----------------|-----------------| 
 - |5WS(6CPU cycle)|120< HCLK <= 168|120< HCLK <= 144|110 < HCLK <= 132|100 < HCLK <= 120| 
 + |5WS(6CPU cycle)|150< HCLK <= 168|120< HCLK <= 144|110 < HCLK <= 132|100 < HCLK <= 120| 
   |---------------|----------------|----------------|-----------------|-----------------| 
   |6WS(7CPU cycle)|      NA        |144< HCLK <= 168|132 < HCLK <= 154|120 < HCLK <= 140| 
   |---------------|----------------|----------------|-----------------|-----------------| 
   |7WS(8CPU cycle)|      NA        |      NA        |154 < HCLK <= 168|140 < HCLK <= 160|
 + +---------------|----------------|----------------|-----------------|-----------------+ 
 +
 +    [..]      
 +      For STM32F42xxx/43xxx devices
 + +-------------------------------------------------------------------------------------+     
 + | Latency       |                HCLK clock frequency (MHz)                           |
 + |               |---------------------------------------------------------------------|     
 + |               | voltage range  | voltage range  | voltage range   | voltage range   |
 + |               | 2.7 V - 3.6 V  | 2.4 V - 2.7 V  | 2.1 V - 2.4 V   | 1.8 V - 2.1 V   |
 + |---------------|----------------|----------------|-----------------|-----------------|              
 + |0WS(1CPU cycle)|0 < HCLK <= 30  |0 < HCLK <= 24  |0 < HCLK <= 22   |0 < HCLK <= 20   |
 + |---------------|----------------|----------------|-----------------|-----------------|   
 + |1WS(2CPU cycle)|30 < HCLK <= 60 |24 < HCLK <= 48 |22 < HCLK <= 44  |20 < HCLK <= 40  | 
 + |---------------|----------------|----------------|-----------------|-----------------|   
 + |2WS(3CPU cycle)|60 < HCLK <= 90 |48 < HCLK <= 72 |44 < HCLK <= 66  |40 < HCLK <= 60  |
 + |---------------|----------------|----------------|-----------------|-----------------| 
 + |3WS(4CPU cycle)|90 < HCLK <= 120|72 < HCLK <= 96 |66 < HCLK <= 88  |60 < HCLK <= 80  |
 + |---------------|----------------|----------------|-----------------|-----------------| 
 + |4WS(5CPU cycle)|120< HCLK <= 150|96 < HCLK <= 120|88 < HCLK <= 110 |80 < HCLK <= 100 |
 + |---------------|----------------|----------------|-----------------|-----------------| 
 + |5WS(6CPU cycle)|120< HCLK <= 180|120< HCLK <= 144|110 < HCLK <= 132|100 < HCLK <= 120| 
 + |---------------|----------------|----------------|-----------------|-----------------| 
 + |6WS(7CPU cycle)|      NA        |144< HCLK <= 168|132 < HCLK <= 154|120 < HCLK <= 140| 
 + |---------------|----------------|----------------|-----------------|-----------------| 
 + |7WS(8CPU cycle)|      NA        |168< HCLK <= 180|154 < HCLK <= 176|140 < HCLK <= 160|
 + |---------------|----------------|----------------|-----------------|-----------------| 
 + |8WS(9CPU cycle)|      NA        |      NA        |176 < HCLK <= 180|160 < HCLK <= 168|
 + +-------------------------------------------------------------------------------------+
 +   
 +    [..]
 +    For STM32F401x devices
 + +-------------------------------------------------------------------------------------+     
 + | Latency       |                HCLK clock frequency (MHz)                           |
 + |               |---------------------------------------------------------------------|     
 + |               | voltage range  | voltage range  | voltage range   | voltage range   |
 + |               | 2.7 V - 3.6 V  | 2.4 V - 2.7 V  | 2.1 V - 2.4 V   | 1.8 V - 2.1 V   |
 + |---------------|----------------|----------------|-----------------|-----------------|              
 + |0WS(1CPU cycle)|0 < HCLK <= 30  |0 < HCLK <= 24  |0 < HCLK <= 22   |0 < HCLK <= 20   |
 + |---------------|----------------|----------------|-----------------|-----------------|   
 + |1WS(2CPU cycle)|30 < HCLK <= 60 |24 < HCLK <= 48 |22 < HCLK <= 44  |20 < HCLK <= 40  | 
 + |---------------|----------------|----------------|-----------------|-----------------|   
 + |2WS(3CPU cycle)|60 < HCLK <= 84 |48 < HCLK <= 72 |44 < HCLK <= 66  |40 < HCLK <= 60  |
 + |---------------|----------------|----------------|-----------------|-----------------| 
 + |3WS(4CPU cycle)|      NA        |72 < HCLK <= 84 |66 < HCLK <= 84  |60 < HCLK <= 80  |
 + |---------------|----------------|----------------|-----------------|-----------------| 
 + |4WS(5CPU cycle)|      NA        |      NA        |      NA         |80 < HCLK <= 84  | 
   +-------------------------------------------------------------------------------------+ 
   [..]
 @@ -140,16 +187,20 @@   |---------------|----------------|----------------|-----------------|-----------------|-----------------------------|   
   |PSIZE[1:0]     |      10        |               01                 |       00        |           11                |
   +-------------------------------------------------------------------------------------------------------------------+  
 -      -@- When VOS bit (in PWR_CR register) is reset to 0 , the maximum value of HCLK is 144 MHz.
 -          You can use PWR_MainRegulatorModeConfig() function to set or reset this bit.
 -      -@- On STM32F40xx/41xx devices: 
 -           (++) when VOS = '0', the maximum value of fHCLK = 144MHz. 
 -           (++) when VOS = '1', the maximum value of fHCLK = 168MHz. 
 +
 +      -@- On STM32F405xx/407xx and STM32F415xx/417xx devices: 
 +           (++) when VOS = '0' Scale 2 mode, the maximum value of fHCLK = 144MHz. 
 +           (++) when VOS = '1' Scale 1 mode, the maximum value of fHCLK = 168MHz. 
            [..] 
 -          On STM32F427x/437x devices:
 -           (++) when VOS[1:0] = '0x01', the maximum value of fHCLK is 120MHz.
 -           (++) when VOS[1:0] = '0x10', the maximum value of fHCLK is 144MHz.
 -           (++) when VOS[1:0] = '0x11', the maximum value of f  is 168MHz  
 +          On STM32F42xxx/43xxx devices:
 +           (++) when VOS[1:0] = '0x01' Scale 3 mode, the maximum value of fHCLK is 120MHz.
 +           (++) when VOS[1:0] = '0x10' Scale 2 mode, the maximum value of fHCLK is 144MHz if OverDrive OFF and 168MHz if OverDrive ON.
 +           (++) when VOS[1:0] = '0x11' Scale 1 mode, the maximum value of fHCLK is 168MHz if OverDrive OFF and 180MHz if OverDrive ON. 
 +          [..]  
 +          On STM32F401x devices:
 +           (++) when VOS[1:0] = '0x01' Scale 3 mode, the maximum value of fHCLK is 60MHz.
 +           (++) when VOS[1:0] = '0x10' Scale 2 mode, the maximum value of fHCLK is 84MHz.
 +           For more details please refer product DataSheet 
             You can use PWR_MainRegulatorModeConfig() function to control VOS bits.
        (+) void FLASH_PrefetchBufferCmd(FunctionalState NewState)
 @@ -176,9 +227,22 @@    *            @arg FLASH_Latency_4: FLASH Four Latency cycles 
    *            @arg FLASH_Latency_5: FLASH Five Latency cycles 
    *            @arg FLASH_Latency_6: FLASH Six Latency cycles
 -  *            @arg FLASH_Latency_7: FLASH Seven Latency cycles  
 -  *          For STM32F40xx/41xx and STM32F427x/437x devices this parameter can be   
 -  *          a value between FLASH_Latency_0 and FLASH_Latency_7.   
 +  *            @arg FLASH_Latency_7: FLASH Seven Latency cycles 
 +  *            @arg FLASH_Latency_8: FLASH Eight Latency cycles
 +  *            @arg FLASH_Latency_9: FLASH Nine Latency cycles
 +  *            @arg FLASH_Latency_10: FLASH Teen Latency cycles 
 +  *            @arg FLASH_Latency_11: FLASH Eleven Latency cycles 
 +  *            @arg FLASH_Latency_12: FLASH Twelve Latency cycles
 +  *            @arg FLASH_Latency_13: FLASH Thirteen Latency cycles        
 +  *            @arg FLASH_Latency_14: FLASH Fourteen Latency cycles
 +  *            @arg FLASH_Latency_15: FLASH Fifteen Latency cycles 
 +  *              
 +  * @note For STM32F405xx/407xx, STM32F415xx/417xx and STM32F401xx devices this parameter    
 +  *       can be a value between FLASH_Latency_0 and FLASH_Latency_7.
 +  *         
 +  * @note For STM32F42xxx/43xxx devices this parameter can be a value between 
 +  *       FLASH_Latency_0 and FLASH_Latency_15. 
 +  *         
    * @retval None
    */
  void FLASH_SetLatency(uint32_t FLASH_Latency)
 @@ -296,7 +360,10 @@ void FLASH_DataCacheReset(void)        (+) FLASH_Status FLASH_ProgramDoubleWord(uint32_t Address, uint64_t Data)
        (+) FLASH_Status FLASH_ProgramWord(uint32_t Address, uint32_t Data)
        (+) FLASH_Status FLASH_ProgramHalfWord(uint32_t Address, uint16_t Data)
 -      (+) FLASH_Status FLASH_ProgramByte(uint32_t Address, uint8_t Data)  
 +      (+) FLASH_Status FLASH_ProgramByte(uint32_t Address, uint8_t Data)
 +          The following functions can be used only for STM32F42xxx/43xxx devices. 
 +      (+) FLASH_Status FLASH_EraseAllBank1Sectors(uint8_t VoltageRange)
 +      (+) FLASH_Status FLASH_EraseAllBank2Sectors(uint8_t VoltageRange)    
      [..]   
        Any operation of erase or program should follow these steps:
        (#) Call the FLASH_Unlock() function to enable the FLASH control register access
 @@ -343,10 +410,15 @@ void FLASH_Lock(void)    *         the erase operation is performed before the program one.
    *   
    * @param  FLASH_Sector: The Sector number to be erased.
 -  *          For STM32F40xx/41xx devices this parameter can be a value between  
 -  *          FLASH_Sector_0 and FLASH_Sector_11.
 -  *          For STM32F427x/437x devices this parameter can be a value between 
 -  *          FLASH_Sector_0 and FLASH_Sector_23.          
 +  *
 +  *  @note  For STM32F405xx/407xx and STM32F415xx/417xx devices this parameter can 
 +  *         be a value between FLASH_Sector_0 and FLASH_Sector_11.
 +  *           
 +  *         For STM32F42xxx/43xxx devices this parameter can be a value between 
 +  *         FLASH_Sector_0 and FLASH_Sector_23.
 +  *           
 +  *         For STM32F401xx devices this parameter can be a value between 
 +  *         FLASH_Sector_0 and FLASH_Sector_5.             
    *    
    * @param  VoltageRange: The device voltage range which defines the erase parallelism.  
    *          This parameter can be one of the following values:
 @@ -458,7 +530,7 @@ FLASH_Status FLASH_EraseAllSectors(uint8_t VoltageRange)    if(status == FLASH_COMPLETE)
    {
      /* if the previous operation is completed, proceed to erase all sectors */
 -#if defined (STM32F427X)   
 +#if defined (STM32F427_437xx) || defined (STM32F429_439xx)    
      FLASH->CR &= CR_PSIZE_MASK;
      FLASH->CR |= tmp_psize;
      FLASH->CR |= (FLASH_CR_MER1 | FLASH_CR_MER2);
 @@ -469,9 +541,9 @@ FLASH_Status FLASH_EraseAllSectors(uint8_t VoltageRange)      /* if the erase operation is completed, disable the MER Bit */
      FLASH->CR &= ~(FLASH_CR_MER1 | FLASH_CR_MER2);
 -#endif /* STM32F427X */
 +#endif /* STM32F427_437xx ||  STM32F429_439xx */
 -#ifdef STM32F40XX
 +#if defined (STM32F40_41xxx) || defined (STM32F401xx) 
      FLASH->CR &= CR_PSIZE_MASK;
      FLASH->CR |= tmp_psize;
      FLASH->CR |= FLASH_CR_MER;
 @@ -482,7 +554,140 @@ FLASH_Status FLASH_EraseAllSectors(uint8_t VoltageRange)      /* if the erase operation is completed, disable the MER Bit */
      FLASH->CR &= (~FLASH_CR_MER);
 -#endif /* STM32F40XX */
 +#endif /* STM32F40_41xxx || STM32F401xx */
 +
 +  }   
 +  /* Return the Erase Status */
 +  return status;
 +}
 +
 +/**
 +  * @brief  Erases all FLASH Sectors in Bank 1.
 +  *
 +  * @note   This function can be used only for STM32F42xxx/43xxx devices.
 +  *      
 +  * @note   If an erase and a program operations are requested simultaneously,    
 +  *         the erase operation is performed before the program one. 
 +  *  
 +  * @param  VoltageRange: The device voltage range which defines the erase parallelism.  
 +  *          This parameter can be one of the following values:
 +  *            @arg VoltageRange_1: when the device voltage range is 1.8V to 2.1V, 
 +  *                                  the operation will be done by byte (8-bit) 
 +  *            @arg VoltageRange_2: when the device voltage range is 2.1V to 2.7V,
 +  *                                  the operation will be done by half word (16-bit)
 +  *            @arg VoltageRange_3: when the device voltage range is 2.7V to 3.6V,
 +  *                                  the operation will be done by word (32-bit)
 +  *            @arg VoltageRange_4: when the device voltage range is 2.7V to 3.6V + External Vpp, 
 +  *                                  the operation will be done by double word (64-bit)
 +  *       
 +  * @retval FLASH Status: The returned value can be: FLASH_BUSY, FLASH_ERROR_PROGRAM,
 +  *                       FLASH_ERROR_WRP, FLASH_ERROR_OPERATION or FLASH_COMPLETE.
 +  */
 +FLASH_Status FLASH_EraseAllBank1Sectors(uint8_t VoltageRange)
 +{
 +  uint32_t tmp_psize = 0x0;
 +  FLASH_Status status = FLASH_COMPLETE;
 +  
 +  /* Wait for last operation to be completed */
 +  status = FLASH_WaitForLastOperation();
 +  assert_param(IS_VOLTAGERANGE(VoltageRange));
 +  
 +  if(VoltageRange == VoltageRange_1)
 +  {
 +     tmp_psize = FLASH_PSIZE_BYTE;
 +  }
 +  else if(VoltageRange == VoltageRange_2)
 +  {
 +    tmp_psize = FLASH_PSIZE_HALF_WORD;
 +  }
 +  else if(VoltageRange == VoltageRange_3)
 +  {
 +    tmp_psize = FLASH_PSIZE_WORD;
 +  }
 +  else
 +  {
 +    tmp_psize = FLASH_PSIZE_DOUBLE_WORD;
 +  }  
 +  if(status == FLASH_COMPLETE)
 +  {
 +    /* if the previous operation is completed, proceed to erase all sectors */
 +     FLASH->CR &= CR_PSIZE_MASK;
 +     FLASH->CR |= tmp_psize;
 +     FLASH->CR |= FLASH_CR_MER1;
 +     FLASH->CR |= FLASH_CR_STRT;
 +    
 +    /* Wait for last operation to be completed */
 +    status = FLASH_WaitForLastOperation();
 +
 +    /* if the erase operation is completed, disable the MER Bit */
 +    FLASH->CR &= (~FLASH_CR_MER1);
 +
 +  }   
 +  /* Return the Erase Status */
 +  return status;
 +}
 +
 +
 +/**
 +  * @brief  Erases all FLASH Sectors in Bank 2.
 +  *
 +  * @note   This function can be used only for STM32F42xxx/43xxx devices.
 +  *     
 +  * @note   If an erase and a program operations are requested simultaneously,    
 +  *         the erase operation is performed before the program one.
 +  *     
 +  * @param  VoltageRange: The device voltage range which defines the erase parallelism.  
 +  *          This parameter can be one of the following values:
 +  *            @arg VoltageRange_1: when the device voltage range is 1.8V to 2.1V, 
 +  *                                  the operation will be done by byte (8-bit) 
 +  *            @arg VoltageRange_2: when the device voltage range is 2.1V to 2.7V,
 +  *                                  the operation will be done by half word (16-bit)
 +  *            @arg VoltageRange_3: when the device voltage range is 2.7V to 3.6V,
 +  *                                  the operation will be done by word (32-bit)
 +  *            @arg VoltageRange_4: when the device voltage range is 2.7V to 3.6V + External Vpp, 
 +  *                                  the operation will be done by double word (64-bit)
 +  *       
 +  * @retval FLASH Status: The returned value can be: FLASH_BUSY, FLASH_ERROR_PROGRAM,
 +  *                       FLASH_ERROR_WRP, FLASH_ERROR_OPERATION or FLASH_COMPLETE.
 +  */
 +FLASH_Status FLASH_EraseAllBank2Sectors(uint8_t VoltageRange)
 +{
 +  uint32_t tmp_psize = 0x0;
 +  FLASH_Status status = FLASH_COMPLETE;
 +  
 +  /* Wait for last operation to be completed */
 +  status = FLASH_WaitForLastOperation();
 +  assert_param(IS_VOLTAGERANGE(VoltageRange));
 +  
 +  if(VoltageRange == VoltageRange_1)
 +  {
 +     tmp_psize = FLASH_PSIZE_BYTE;
 +  }
 +  else if(VoltageRange == VoltageRange_2)
 +  {
 +    tmp_psize = FLASH_PSIZE_HALF_WORD;
 +  }
 +  else if(VoltageRange == VoltageRange_3)
 +  {
 +    tmp_psize = FLASH_PSIZE_WORD;
 +  }
 +  else
 +  {
 +    tmp_psize = FLASH_PSIZE_DOUBLE_WORD;
 +  }  
 +  if(status == FLASH_COMPLETE)
 +  {
 +    /* if the previous operation is completed, proceed to erase all sectors */
 +     FLASH->CR &= CR_PSIZE_MASK;
 +     FLASH->CR |= tmp_psize;
 +     FLASH->CR |= FLASH_CR_MER2;
 +     FLASH->CR |= FLASH_CR_STRT;
 +    
 +    /* Wait for last operation to be completed */
 +    status = FLASH_WaitForLastOperation();
 +
 +    /* if the erase operation is completed, disable the MER Bit */
 +    FLASH->CR &= (~FLASH_CR_MER2);
    }   
    /* Return the Erase Status */
 @@ -676,6 +881,9 @@ FLASH_Status FLASH_ProgramByte(uint32_t Address, uint8_t Data)        (+) void FLASH_OB_Lock(void)
        (+) void FLASH_OB_WRPConfig(uint32_t OB_WRP, FunctionalState NewState)
        (+) void FLASH_OB_WRP1Config(uint32_t OB_WRP, FunctionalState NewState)  
 +      (+) void FLASH_OB_PCROPSelectionConfig(uint8_t OB_PCROPSelect)
 +      (+) void FLASH_OB_PCROPConfig(uint32_t OB_PCROP, FunctionalState NewState)
 +      (+) void FLASH_OB_PCROP1Config(uint32_t OB_PCROP, FunctionalState NewState) 
        (+) void FLASH_OB_RDPConfig(uint8_t OB_RDP)
        (+) void FLASH_OB_UserConfig(uint8_t OB_IWDG, uint8_t OB_STOP, uint8_t OB_STDBY)
        (+) void FLASH_OB_BORConfig(uint8_t OB_BOR)
 @@ -683,9 +891,14 @@ FLASH_Status FLASH_ProgramByte(uint32_t Address, uint8_t Data)        (+) FLASH_Status FLASH_OB_Launch(void)
        (+) uint32_t FLASH_OB_GetUser(void)						
        (+) uint8_t FLASH_OB_GetWRP(void)
 -      (+) uint8_t FLASH_OB_GetWRP1(void)  						
 +      (+) uint8_t FLASH_OB_GetWRP1(void)
 +      (+) uint8_t FLASH_OB_GetPCROP(void)
 +      (+) uint8_t FLASH_OB_GetPCROP1(void)    						
        (+) uint8_t FLASH_OB_GetRDP(void)							
        (+) uint8_t FLASH_OB_GetBOR(void)
 +    [..]  
 +      The following function can be used only for STM32F42xxx/43xxx devices. 
 +      (+) void FLASH_OB_BootConfig(uint8_t OB_BOOT)
      [..]   
       Any operation of erase or program should follow these steps:
        (#) Call the FLASH_OB_Unlock() function to enable the FLASH option control 
 @@ -742,7 +955,8 @@ void FLASH_OB_Lock(void)  }
  /**
 -  * @brief  Enables or disables the write protection of the desired sectors
 +  * @brief  Enables or disables the write protection of the desired sectors, for the first
 +  *         1 Mb of the Flash  
    *
    * @note   When the memory read protection level is selected (RDP level = 1), 
    *         it is not possible to program or erase the flash sector i if CortexM4  
 @@ -781,8 +995,11 @@ void FLASH_OB_WRPConfig(uint32_t OB_WRP, FunctionalState NewState)  }
  /**
 -  * @brief  Enables or disables the write protection of the desired sectors
 -  * @note   This function can be used only for STM32F427x/437x devices.
 +  * @brief  Enables or disables the write protection of the desired sectors, for the second
 +  *         1 Mb of the Flash  
 +  *           
 +  * @note   This function can be used only for STM32F42xxx/43xxx devices.
 +  *   
    * @note   When the memory read out protection is selected (RDP level = 1), 
    *         it is not possible to program or erase the flash sector i if CortexM4  
    *         debug features are connected or boot code is executed in RAM, even if nWRPi = 1 
 @@ -820,6 +1037,124 @@ void FLASH_OB_WRP1Config(uint32_t OB_WRP, FunctionalState NewState)  }
  /**
 +  * @brief  Select the Protection Mode (SPRMOD). 
 +  * 
 +  * @note   This function can be used only for STM32F42xxx/43xxx and STM32F401xx devices.       
 +  * 
 +  * @note   After PCROP activation, Option Byte modification is not possible. 
 +  *         Exception made for the global Read Out Protection modification level (level1 to level0) 
 +  * @note   Once SPRMOD bit is active unprotection of a protected sector is not possible 
 +  *   
 +  * @note   Read a protected sector will set RDERR Flag and write a protected sector will set WRPERR Flag
 +  *   
 +  * @note   Some Precautions should be taken when activating the PCROP feature :
 +  *         The active value of nWRPi bits is inverted when PCROP mode is active, this means if SPRMOD = 1
 +  *         and WRPi = 1 (default value), then the user sector i is read/write protected.
 +  *         In order to avoid activation of PCROP Mode for undesired sectors, please follow the
 +  *         below safety sequence :       
 +  *         - Disable PCROP for all Sectors using FLASH_OB_PCROPConfig(OB_PCROP_Sector_All, DISABLE) function 
 +  *           for Bank1 or FLASH_OB_PCROP1Config(OB_PCROP_Sector_All, DISABLE) function for Bank2   
 +  *         - Enable PCROP for the desired Sector i using FLASH_OB_PCROPConfig(Sector i, ENABLE) function
 +  *         - Activate the PCROP Mode FLASH_OB_PCROPSelectionConfig() function. 
 +  * 
 +  * @param  OB_PCROP:  Select the Protection Mode of nWPRi bits 
 +  *          This parameter can be one of the following values:
 +  *            @arg OB_PcROP_Disable: nWRPi control the write protection of respective user sectors.
 +  *            @arg OB_PcROP_Enable: nWRPi control the  read&write protection (PCROP) of respective user sectors.
 +  * @retval None
 +  */
 +void FLASH_OB_PCROPSelectionConfig(uint8_t OB_PcROP)
 +{  
 +  uint8_t optiontmp = 0xFF;
 +      
 +  /* Check the parameters */
 +  assert_param(IS_OB_PCROP_SELECT(OB_PcROP));
 +  
 +  /* Mask SPRMOD bit */
 +  optiontmp =  (uint8_t)((*(__IO uint8_t *)OPTCR_BYTE3_ADDRESS) & (uint8_t)0x7F); 
 +  /* Update Option Byte */
 +  *(__IO uint8_t *)OPTCR_BYTE3_ADDRESS = (uint8_t)(OB_PcROP | optiontmp); 
 +    
 +}
 +
 +/**
 +  * @brief  Enables or disables the read/write protection (PCROP) of the desired 
 +  *         sectors, for the first 1 MB of the Flash.
 +  *           
 +  * @note   This function can be used only for STM32F42xxx/43xxx and STM32F401xx devices. 
 +  *   
 +  * @param  OB_PCROP: specifies the sector(s) to be read/write protected or unprotected.
 +  *          This parameter can be one of the following values:
 +  *            @arg OB_PCROP: A value between OB_PCROP_Sector0 and OB_PCROP_Sector11 for 
 +  *                           STM32F42xxx/43xxx devices and between OB_PCROP_Sector0 and 
 +  *                           OB_PCROP_Sector5 for STM32F401xx devices.
 +  *            @arg OB_PCROP_Sector_All                         
 +  * @param  Newstate: new state of the Write Protection.
 +  *          This parameter can be: ENABLE or DISABLE.
 +  * @retval None  
 +  */
 +void FLASH_OB_PCROPConfig(uint32_t OB_PCROP, FunctionalState NewState)
 +{ 
 +  FLASH_Status status = FLASH_COMPLETE;
 +  
 +  /* Check the parameters */
 +  assert_param(IS_OB_PCROP(OB_PCROP));
 +  assert_param(IS_FUNCTIONAL_STATE(NewState));
 +    
 +  status = FLASH_WaitForLastOperation();
 +
 +  if(status == FLASH_COMPLETE)
 +  { 
 +    if(NewState != DISABLE)
 +    {
 +      *(__IO uint16_t*)OPTCR_BYTE2_ADDRESS |= (uint16_t)OB_PCROP;    
 +    }
 +    else
 +    {
 +      *(__IO uint16_t*)OPTCR_BYTE2_ADDRESS &= (~OB_PCROP);
 +    }
 +  }
 +}
 +
 +/**
 +   * @brief Enables or disables the read/write protection (PCROP) of the desired 
 +  *         sectors
 +  *           
 +  * @note   This function can be used only for STM32F42xxx/43xxx devices.
 +  *   
 +  * @param  OB_PCROP: specifies the sector(s) to be read/write protected or unprotected.
 +  *          This parameter can be one of the following values:
 +  *            @arg OB_PCROP: A value between OB_PCROP_Sector12 and OB_PCROP_Sector23 
 +  *            @arg OB_PCROP_Sector_All                    
 +  * @param  Newstate: new state of the Write Protection.
 +  *          This parameter can be: ENABLE or DISABLE.
 +  * @retval None  
 +  */
 +void FLASH_OB_PCROP1Config(uint32_t OB_PCROP, FunctionalState NewState)
 +{ 
 +  FLASH_Status status = FLASH_COMPLETE;
 +  
 +  /* Check the parameters */
 +  assert_param(IS_OB_PCROP(OB_PCROP));
 +  assert_param(IS_FUNCTIONAL_STATE(NewState));
 +    
 +  status = FLASH_WaitForLastOperation();
 +
 +  if(status == FLASH_COMPLETE)
 +  { 
 +    if(NewState != DISABLE)
 +    {
 +      *(__IO uint16_t*)OPTCR1_BYTE2_ADDRESS |= (uint16_t)OB_PCROP;
 +    }
 +    else
 +    {
 +      *(__IO uint16_t*)OPTCR1_BYTE2_ADDRESS &= (~OB_PCROP);
 +    }
 +  }
 +}
 +
 +
 +/**
    * @brief  Sets the read protection level.
    * @param  OB_RDP: specifies the read protection level.
    *          This parameter can be one of the following values:
 @@ -827,7 +1162,7 @@ void FLASH_OB_WRP1Config(uint32_t OB_WRP, FunctionalState NewState)    *            @arg OB_RDP_Level_1: Read protection of the memory
    *            @arg OB_RDP_Level_2: Full chip protection
    *   
 -  * !!!Warning!!! When enabling OB_RDP level 2 it's no more possible to go back to level 1 or 0
 +  * /!\ Warning /!\ When enabling OB_RDP level 2 it's no more possible to go back to level 1 or 0
    *    
    * @retval None
    */
 @@ -878,8 +1213,15 @@ void FLASH_OB_UserConfig(uint8_t OB_IWDG, uint8_t OB_STOP, uint8_t OB_STDBY)    if(status == FLASH_COMPLETE)
    { 
 +#if defined (STM32F427_437xx) || defined (STM32F429_439xx)     
 +    /* Mask OPTLOCK, OPTSTRT, BOR_LEV and BFB2 bits */
 +    optiontmp =  (uint8_t)((*(__IO uint8_t *)OPTCR_BYTE0_ADDRESS) & (uint8_t)0x1F);
 +#endif /* STM32F427_437xx ||  STM32F429_439xx */
 +
 +#if defined (STM32F40_41xxx) || defined (STM32F401xx) 
      /* Mask OPTLOCK, OPTSTRT and BOR_LEV bits */
      optiontmp =  (uint8_t)((*(__IO uint8_t *)OPTCR_BYTE0_ADDRESS) & (uint8_t)0x0F); 
 +#endif /* STM32F40_41xxx || STM32F401xx */ 
      /* Update User Option Byte */
      *(__IO uint8_t *)OPTCR_BYTE0_ADDRESS = OB_IWDG | (uint8_t)(OB_STDBY | (uint8_t)(OB_STOP | ((uint8_t)optiontmp))); 
 @@ -887,6 +1229,28 @@ void FLASH_OB_UserConfig(uint8_t OB_IWDG, uint8_t OB_STOP, uint8_t OB_STDBY)  }
  /**
 +  * @brief  Configure the Dual Bank Boot.
 +  *   
 +  * @note   This function can be used only for STM32F42xxx/43xxx devices.
 +  *      
 +  * @param  OB_BOOT: specifies the Dual Bank Boot Option byte.
 +  *          This parameter can be one of the following values:
 +  *            @arg OB_Dual_BootEnabled: Dual Bank Boot Enable
 +  *            @arg OB_Dual_BootDisabled: Dual Bank Boot Disabled
 +  * @retval None
 +  */
 +void FLASH_OB_BootConfig(uint8_t OB_BOOT)
 +{
 +  /* Check the parameters */
 +  assert_param(IS_OB_BOOT(OB_BOOT));
 +
 +  /* Set Dual Bank Boot */
 +  *(__IO uint8_t *)OPTCR_BYTE0_ADDRESS &= (~FLASH_OPTCR_BFB2);
 +  *(__IO uint8_t *)OPTCR_BYTE0_ADDRESS |= OB_BOOT;
 +
 +}
 +
 +/**
    * @brief  Sets the BOR Level. 
    * @param  OB_BOR: specifies the Option Bytes BOR Reset Level.
    *          This parameter can be one of the following values:
 @@ -951,7 +1315,9 @@ uint16_t FLASH_OB_GetWRP(void)  /**
    * @brief  Returns the FLASH Write Protection Option Bytes value.
 -  * @note   This function can be used only for STM32F427x/437x devices.  
 +  *   
 +  * @note   This function can be used only for STM32F42xxx/43xxx devices.
 +  *   
    * @param  None
    * @retval The FLASH Write Protection  Option Bytes value
    */
 @@ -962,6 +1328,34 @@ uint16_t FLASH_OB_GetWRP1(void)  }
  /**
 +  * @brief  Returns the FLASH PC Read/Write Protection Option Bytes value.
 +  *   
 +  * @note   This function can be used only for STM32F42xxx/43xxx devices and STM32F401xx devices.
 +  *   
 +  * @param  None
 +  * @retval The FLASH PC Read/Write Protection Option Bytes value
 +  */
 +uint16_t FLASH_OB_GetPCROP(void)
 +{
 +  /* Return the FLASH PC Read/write protection Register value */
 +  return (*(__IO uint16_t *)(OPTCR_BYTE2_ADDRESS));
 +}
 +
 +/**
 +  * @brief  Returns the FLASH PC Read/Write Protection Option Bytes value.
 +  *   
 +  * @note   This function can be used only for STM32F42xxx/43xxx devices. 
 +  *     
 +  * @param  None
 +  * @retval The FLASH PC Read/Write Protection Option Bytes value
 +  */
 +uint16_t FLASH_OB_GetPCROP1(void)
 +{
 +  /* Return the FLASH write protection Register value */
 +  return (*(__IO uint16_t *)(OPTCR1_BYTE2_ADDRESS));
 +}
 +
 +/**
    * @brief  Returns the FLASH Read Protection level.
    * @param  None
    * @retval FLASH ReadOut Protection Status:
 @@ -1049,6 +1443,7 @@ void FLASH_ITConfig(uint32_t FLASH_IT, FunctionalState NewState)    *            @arg FLASH_FLAG_PGAERR: FLASH Programming Alignment error flag
    *            @arg FLASH_FLAG_PGPERR: FLASH Programming Parallelism error flag
    *            @arg FLASH_FLAG_PGSERR: FLASH Programming Sequence error flag
 +  *            @arg FLASH_FLAG_RDERR: FLASH (PCROP) Read Protection error flag (STM32F42/43xxx and STM32F401xx devices) 
    *            @arg FLASH_FLAG_BSY: FLASH Busy flag
    * @retval The new state of FLASH_FLAG (SET or RESET).
    */
 @@ -1079,7 +1474,8 @@ FlagStatus FLASH_GetFlagStatus(uint32_t FLASH_FLAG)    *            @arg FLASH_FLAG_WRPERR: FLASH Write protected error flag 
    *            @arg FLASH_FLAG_PGAERR: FLASH Programming Alignment error flag 
    *            @arg FLASH_FLAG_PGPERR: FLASH Programming Parallelism error flag
 -  *            @arg FLASH_FLAG_PGSERR: FLASH Programming Sequence error flag  
 +  *            @arg FLASH_FLAG_PGSERR: FLASH Programming Sequence error flag
 +  *            @arg FLASH_FLAG_RDERR: FLASH Read Protection error flag (STM32F42/43xxx and STM32F401xx devices)   
    * @retval None
    */
  void FLASH_ClearFlag(uint32_t FLASH_FLAG)
 @@ -1095,7 +1491,7 @@ void FLASH_ClearFlag(uint32_t FLASH_FLAG)    * @brief  Returns the FLASH Status.
    * @param  None
    * @retval FLASH Status: The returned value can be: FLASH_BUSY, FLASH_ERROR_PROGRAM,
 -  *                       FLASH_ERROR_WRP, FLASH_ERROR_OPERATION or FLASH_COMPLETE.
 +  *                       FLASH_ERROR_WRP, FLASH_ERROR_RD, FLASH_ERROR_OPERATION or FLASH_COMPLETE.
    */
  FLASH_Status FLASH_GetStatus(void)
  {
 @@ -1113,19 +1509,26 @@ FLASH_Status FLASH_GetStatus(void)      }
      else
      {
 -      if((FLASH->SR & (uint32_t)0xEF) != (uint32_t)0x00)
 -      {
 -        flashstatus = FLASH_ERROR_PROGRAM; 
 -      }
 -      else
 +      if((FLASH->SR & FLASH_FLAG_RDERR) != (uint32_t)0x00)
 +      { 
 +        flashstatus = FLASH_ERROR_RD;
 +      } 
 +      else 
        {
 -        if((FLASH->SR & FLASH_FLAG_OPERR) != (uint32_t)0x00)
 +        if((FLASH->SR & (uint32_t)0xEF) != (uint32_t)0x00)
          {
 -          flashstatus = FLASH_ERROR_OPERATION;
 +          flashstatus = FLASH_ERROR_PROGRAM; 
          }
          else
          {
 -          flashstatus = FLASH_COMPLETE;
 +          if((FLASH->SR & FLASH_FLAG_OPERR) != (uint32_t)0x00)
 +          {
 +            flashstatus = FLASH_ERROR_OPERATION;
 +          }
 +          else
 +          {
 +            flashstatus = FLASH_COMPLETE;
 +          }
          }
        }
      }
 diff --git a/stm/lib/stm32f4xx_flash.h b/stm/lib/stm32f4xx_flash.h index 55380b7ab..ee3e9a9fe 100644 --- a/stm/lib/stm32f4xx_flash.h +++ b/stm/lib/stm32f4xx_flash.h @@ -2,8 +2,8 @@    ******************************************************************************
    * @file    stm32f4xx_flash.h
    * @author  MCD Application Team
 -  * @version V1.1.0
 -  * @date    11-January-2013
 +  * @version V1.3.0
 +  * @date    08-November-2013
    * @brief   This file contains all the functions prototypes for the FLASH 
    *          firmware library.
    ******************************************************************************
 @@ -52,6 +52,7 @@  typedef enum
  { 
    FLASH_BUSY = 1,
 +  FLASH_ERROR_RD,
    FLASH_ERROR_PGS,
    FLASH_ERROR_PGP,
    FLASH_ERROR_PGA,
 @@ -78,6 +79,15 @@ typedef enum  #define FLASH_Latency_5                ((uint8_t)0x0005)  /*!< FLASH Five Latency cycles     */
  #define FLASH_Latency_6                ((uint8_t)0x0006)  /*!< FLASH Six Latency cycles      */
  #define FLASH_Latency_7                ((uint8_t)0x0007)  /*!< FLASH Seven Latency cycles    */
 +#define FLASH_Latency_8                ((uint8_t)0x0008)  /*!< FLASH Eight Latency cycles    */
 +#define FLASH_Latency_9                ((uint8_t)0x0009)  /*!< FLASH Nine Latency cycles     */
 +#define FLASH_Latency_10               ((uint8_t)0x000A)  /*!< FLASH Ten Latency cycles      */
 +#define FLASH_Latency_11               ((uint8_t)0x000B)  /*!< FLASH Eleven Latency cycles   */
 +#define FLASH_Latency_12               ((uint8_t)0x000C)  /*!< FLASH Twelve Latency cycles   */
 +#define FLASH_Latency_13               ((uint8_t)0x000D)  /*!< FLASH Thirteen Latency cycles */
 +#define FLASH_Latency_14               ((uint8_t)0x000E)  /*!< FLASH Fourteen Latency cycles */
 +#define FLASH_Latency_15               ((uint8_t)0x000F)  /*!< FLASH Fifteen Latency cycles  */
 +
  #define IS_FLASH_LATENCY(LATENCY) (((LATENCY) == FLASH_Latency_0)  || \
                                     ((LATENCY) == FLASH_Latency_1)  || \
 @@ -86,8 +96,15 @@ typedef enum                                     ((LATENCY) == FLASH_Latency_4)  || \
                                     ((LATENCY) == FLASH_Latency_5)  || \
                                     ((LATENCY) == FLASH_Latency_6)  || \
 -                                   ((LATENCY) == FLASH_Latency_7))
 -
 +                                   ((LATENCY) == FLASH_Latency_7)  || \
 +                                   ((LATENCY) == FLASH_Latency_8)  || \
 +                                   ((LATENCY) == FLASH_Latency_9)  || \
 +                                   ((LATENCY) == FLASH_Latency_10) || \
 +                                   ((LATENCY) == FLASH_Latency_11) || \
 +                                   ((LATENCY) == FLASH_Latency_12) || \
 +                                   ((LATENCY) == FLASH_Latency_13) || \
 +                                   ((LATENCY) == FLASH_Latency_14) || \
 +                                   ((LATENCY) == FLASH_Latency_15))
  /**
    * @}
    */ 
 @@ -149,8 +166,20 @@ typedef enum                                   ((SECTOR) == FLASH_Sector_20)  || ((SECTOR) == FLASH_Sector_21)  ||\
                                   ((SECTOR) == FLASH_Sector_22)  || ((SECTOR) == FLASH_Sector_23))
 +#if defined (STM32F427_437xx) || defined (STM32F429_439xx)
  #define IS_FLASH_ADDRESS(ADDRESS) ((((ADDRESS) >= 0x08000000) && ((ADDRESS) < 0x081FFFFF)) ||\
                                     (((ADDRESS) >= 0x1FFF7800) && ((ADDRESS) < 0x1FFF7A0F)))  
 +#endif /* STM32F427_437xx ||  STM32F429_439xx */
 +
 +#if defined (STM32F40_41xxx)
 +#define IS_FLASH_ADDRESS(ADDRESS) ((((ADDRESS) >= 0x08000000) && ((ADDRESS) < 0x080FFFFF)) ||\
 +                                   (((ADDRESS) >= 0x1FFF7800) && ((ADDRESS) < 0x1FFF7A0F))) 
 +#endif /* STM32F40_41xxx */
 +
 +#if defined (STM32F401xx)                                   
 +#define IS_FLASH_ADDRESS(ADDRESS) ((((ADDRESS) >= 0x08000000) && ((ADDRESS) < 0x0803FFFF)) ||\
 +                                   (((ADDRESS) >= 0x1FFF7800) && ((ADDRESS) < 0x1FFF7A0F)))                                                                       
 +#endif /* STM32F401xx */
  /**
    * @}
    */ 
 @@ -189,6 +218,50 @@ typedef enum    * @}
    */
 +/** @defgroup  Selection_Protection_Mode
 +  * @{
 +  */
 +#define OB_PcROP_Disable   ((uint8_t)0x00) /*!< Disabled PcROP, nWPRi bits used for Write Protection on sector i */
 +#define OB_PcROP_Enable    ((uint8_t)0x80) /*!< Enable PcROP, nWPRi bits used for PCRoP Protection on sector i   */
 +#define IS_OB_PCROP_SELECT(PCROP) (((PCROP) == OB_PcROP_Disable) || ((PCROP) == OB_PcROP_Enable))
 +/**
 +  * @}
 +  */
 +
 +/** @defgroup Option_Bytes_PC_ReadWrite_Protection 
 +  * @{
 +  */ 
 +#define OB_PCROP_Sector_0        ((uint32_t)0x00000001) /*!< PC Read/Write protection of Sector0      */
 +#define OB_PCROP_Sector_1        ((uint32_t)0x00000002) /*!< PC Read/Write protection of Sector1      */
 +#define OB_PCROP_Sector_2        ((uint32_t)0x00000004) /*!< PC Read/Write protection of Sector2      */
 +#define OB_PCROP_Sector_3        ((uint32_t)0x00000008) /*!< PC Read/Write protection of Sector3      */
 +#define OB_PCROP_Sector_4        ((uint32_t)0x00000010) /*!< PC Read/Write protection of Sector4      */
 +#define OB_PCROP_Sector_5        ((uint32_t)0x00000020) /*!< PC Read/Write protection of Sector5      */
 +#define OB_PCROP_Sector_6        ((uint32_t)0x00000040) /*!< PC Read/Write protection of Sector6      */
 +#define OB_PCROP_Sector_7        ((uint32_t)0x00000080) /*!< PC Read/Write protection of Sector7      */
 +#define OB_PCROP_Sector_8        ((uint32_t)0x00000100) /*!< PC Read/Write protection of Sector8      */
 +#define OB_PCROP_Sector_9        ((uint32_t)0x00000200) /*!< PC Read/Write protection of Sector9      */
 +#define OB_PCROP_Sector_10       ((uint32_t)0x00000400) /*!< PC Read/Write protection of Sector10     */
 +#define OB_PCROP_Sector_11       ((uint32_t)0x00000800) /*!< PC Read/Write protection of Sector11     */
 +#define OB_PCROP_Sector_12       ((uint32_t)0x00000001) /*!< PC Read/Write protection of Sector12     */
 +#define OB_PCROP_Sector_13       ((uint32_t)0x00000002) /*!< PC Read/Write protection of Sector13     */
 +#define OB_PCROP_Sector_14       ((uint32_t)0x00000004) /*!< PC Read/Write protection of Sector14     */
 +#define OB_PCROP_Sector_15       ((uint32_t)0x00000008) /*!< PC Read/Write protection of Sector15     */
 +#define OB_PCROP_Sector_16       ((uint32_t)0x00000010) /*!< PC Read/Write protection of Sector16     */
 +#define OB_PCROP_Sector_17       ((uint32_t)0x00000020) /*!< PC Read/Write protection of Sector17     */
 +#define OB_PCROP_Sector_18       ((uint32_t)0x00000040) /*!< PC Read/Write protection of Sector18     */
 +#define OB_PCROP_Sector_19       ((uint32_t)0x00000080) /*!< PC Read/Write protection of Sector19     */
 +#define OB_PCROP_Sector_20       ((uint32_t)0x00000100) /*!< PC Read/Write protection of Sector20     */
 +#define OB_PCROP_Sector_21       ((uint32_t)0x00000200) /*!< PC Read/Write protection of Sector21     */
 +#define OB_PCROP_Sector_22       ((uint32_t)0x00000400) /*!< PC Read/Write protection of Sector22     */
 +#define OB_PCROP_Sector_23       ((uint32_t)0x00000800) /*!< PC Read/Write protection of Sector23     */
 +#define OB_PCROP_Sector_All      ((uint32_t)0x00000FFF) /*!< PC Read/Write protection of all Sectors  */
 +
 +#define IS_OB_PCROP(SECTOR)((((SECTOR) & (uint32_t)0xFFFFF000) == 0x00000000) && ((SECTOR) != 0x00000000))
 +/**
 +  * @}
 +  */
 +
  /** @defgroup FLASH_Option_Bytes_Read_Protection 
    * @{
    */
 @@ -246,6 +319,16 @@ typedef enum  /**
    * @}
    */
 +  
 +/** @defgroup FLASH_Dual_Boot
 +  * @{
 +  */
 +#define OB_Dual_BootEnabled   ((uint8_t)0x10) /*!< Dual Bank Boot Enable                             */
 +#define OB_Dual_BootDisabled  ((uint8_t)0x00) /*!< Dual Bank Boot Disable, always boot on User Flash */
 +#define IS_OB_BOOT(BOOT) (((BOOT) == OB_Dual_BootEnabled) || ((BOOT) == OB_Dual_BootDisabled))
 +/**
 +  * @}
 +  */
  /** @defgroup FLASH_Interrupts 
    * @{
 @@ -266,12 +349,13 @@ typedef enum  #define FLASH_FLAG_PGAERR              ((uint32_t)0x00000020)  /*!< FLASH Programming Alignment error flag    */
  #define FLASH_FLAG_PGPERR              ((uint32_t)0x00000040)  /*!< FLASH Programming Parallelism error flag  */
  #define FLASH_FLAG_PGSERR              ((uint32_t)0x00000080)  /*!< FLASH Programming Sequence error flag     */
 +#define FLASH_FLAG_RDERR               ((uint32_t)0x00000100)  /*!< Read Protection error flag (PCROP)        */
  #define FLASH_FLAG_BSY                 ((uint32_t)0x00010000)  /*!< FLASH Busy flag                           */ 
  #define IS_FLASH_CLEAR_FLAG(FLAG) ((((FLAG) & (uint32_t)0xFFFFFE0C) == 0x00000000) && ((FLAG) != 0x00000000))
  #define IS_FLASH_GET_FLAG(FLAG)  (((FLAG) == FLASH_FLAG_EOP)    || ((FLAG) == FLASH_FLAG_OPERR)  || \
                                    ((FLAG) == FLASH_FLAG_WRPERR) || ((FLAG) == FLASH_FLAG_PGAERR) || \
                                    ((FLAG) == FLASH_FLAG_PGPERR) || ((FLAG) == FLASH_FLAG_PGSERR) || \
 -                                  ((FLAG) == FLASH_FLAG_BSY))
 +                                  ((FLAG) == FLASH_FLAG_BSY)    || ((FLAG) == FLASH_FLAG_RDERR))
  /**
    * @}
    */
 @@ -346,23 +430,31 @@ void         FLASH_Unlock(void);  void         FLASH_Lock(void);
  FLASH_Status FLASH_EraseSector(uint32_t FLASH_Sector, uint8_t VoltageRange);
  FLASH_Status FLASH_EraseAllSectors(uint8_t VoltageRange);
 +FLASH_Status FLASH_EraseAllBank1Sectors(uint8_t VoltageRange);
 +FLASH_Status FLASH_EraseAllBank2Sectors(uint8_t VoltageRange);
  FLASH_Status FLASH_ProgramDoubleWord(uint32_t Address, uint64_t Data);
  FLASH_Status FLASH_ProgramWord(uint32_t Address, uint32_t Data);
  FLASH_Status FLASH_ProgramHalfWord(uint32_t Address, uint16_t Data);
  FLASH_Status FLASH_ProgramByte(uint32_t Address, uint8_t Data);
  /* Option Bytes Programming functions *****************************************/ 
 -void          FLASH_OB_Unlock(void);
 +void         FLASH_OB_Unlock(void);
  void         FLASH_OB_Lock(void);
  void         FLASH_OB_WRPConfig(uint32_t OB_WRP, FunctionalState NewState);
  void         FLASH_OB_WRP1Config(uint32_t OB_WRP, FunctionalState NewState);
 +void         FLASH_OB_PCROPSelectionConfig(uint8_t OB_PcROP);
 +void         FLASH_OB_PCROPConfig(uint32_t OB_PCROP, FunctionalState NewState);
 +void         FLASH_OB_PCROP1Config(uint32_t OB_PCROP, FunctionalState NewState);
  void         FLASH_OB_RDPConfig(uint8_t OB_RDP);
  void         FLASH_OB_UserConfig(uint8_t OB_IWDG, uint8_t OB_STOP, uint8_t OB_STDBY);
  void         FLASH_OB_BORConfig(uint8_t OB_BOR);
 +void         FLASH_OB_BootConfig(uint8_t OB_BOOT);
  FLASH_Status FLASH_OB_Launch(void);
  uint8_t      FLASH_OB_GetUser(void);
  uint16_t     FLASH_OB_GetWRP(void);
  uint16_t     FLASH_OB_GetWRP1(void);
 +uint16_t     FLASH_OB_GetPCROP(void);
 +uint16_t     FLASH_OB_GetPCROP1(void);
  FlagStatus   FLASH_OB_GetRDP(void);
  uint8_t      FLASH_OB_GetBOR(void);
 diff --git a/stm/lib/stm32f4xx_gpio.c b/stm/lib/stm32f4xx_gpio.c index bdd91e665..c099e948e 100644 --- a/stm/lib/stm32f4xx_gpio.c +++ b/stm/lib/stm32f4xx_gpio.c @@ -2,8 +2,8 @@    ******************************************************************************
    * @file    stm32f4xx_gpio.c
    * @author  MCD Application Team
 -  * @version V1.1.0
 -  * @date    11-January-2013
 +  * @version V1.3.0
 +  * @date    08-November-2013
    * @brief   This file provides firmware functions to manage the following 
    *          functionalities of the GPIO peripheral:           
    *           + Initialization and Configuration
 @@ -81,7 +81,6 @@    */
  /* Includes ------------------------------------------------------------------*/
 -#include "stm32f4xx_conf.h"
  #include "stm32f4xx_gpio.h"
  #include "stm32f4xx_rcc.h"
 @@ -120,8 +119,9 @@  /**
    * @brief  De-initializes the GPIOx peripheral registers to their default reset values.
    * @note   By default, The GPIO pins are configured in input floating mode (except JTAG pins).
 -  * @param  GPIOx: where x can be (A..I) to select the GPIO peripheral for 
 -  *                STM32F40xx/41xx and STM32F427x/437x devices. 
 +  * @param  GPIOx: where x can be (A..K) to select the GPIO peripheral for STM32F405xx/407xx and STM32F415xx/417xx devices
 +  *                      x can be (A..I) to select the GPIO peripheral for STM32F42xxx/43xxx devices.
 +  *                      x can be (A, B, C, D and H) to select the GPIO peripheral for STM32F401xx devices.  
    * @retval None
    */
  void GPIO_DeInit(GPIO_TypeDef* GPIOx)
 @@ -169,20 +169,32 @@ void GPIO_DeInit(GPIO_TypeDef* GPIOx)      RCC_AHB1PeriphResetCmd(RCC_AHB1Periph_GPIOH, ENABLE);
      RCC_AHB1PeriphResetCmd(RCC_AHB1Periph_GPIOH, DISABLE);
    }
 +
 +  else if (GPIOx == GPIOI)
 +  {
 +    RCC_AHB1PeriphResetCmd(RCC_AHB1Periph_GPIOI, ENABLE);
 +    RCC_AHB1PeriphResetCmd(RCC_AHB1Periph_GPIOI, DISABLE);
 +  }
 +  else if (GPIOx == GPIOJ)
 +  {
 +    RCC_AHB1PeriphResetCmd(RCC_AHB1Periph_GPIOJ, ENABLE);
 +    RCC_AHB1PeriphResetCmd(RCC_AHB1Periph_GPIOJ, DISABLE);
 +  }
    else
    {
 -    if (GPIOx == GPIOI)
 +    if (GPIOx == GPIOK)
      {
 -      RCC_AHB1PeriphResetCmd(RCC_AHB1Periph_GPIOI, ENABLE);
 -      RCC_AHB1PeriphResetCmd(RCC_AHB1Periph_GPIOI, DISABLE);
 +      RCC_AHB1PeriphResetCmd(RCC_AHB1Periph_GPIOK, ENABLE);
 +      RCC_AHB1PeriphResetCmd(RCC_AHB1Periph_GPIOK, DISABLE);
      }
    }
  }
  /**
    * @brief  Initializes the GPIOx peripheral according to the specified parameters in the GPIO_InitStruct.
 -  * @param  GPIOx: where x can be (A..I) to select the GPIO peripheral for 
 -  *                STM32F40xx/41xx and STM32F427x/437x devices. 
 +  * @param  GPIOx: where x can be (A..K) to select the GPIO peripheral for STM32F405xx/407xx and STM32F415xx/417xx devices
 +  *                      x can be (A..I) to select the GPIO peripheral for STM32F42xxx/43xxx devices.
 +  *                      x can be (A, B, C, D and H) to select the GPIO peripheral for STM32F401xx devices.   
    * @param  GPIO_InitStruct: pointer to a GPIO_InitTypeDef structure that contains
    *         the configuration information for the specified GPIO peripheral.
    * @retval None
 @@ -255,8 +267,9 @@ void GPIO_StructInit(GPIO_InitTypeDef* GPIO_InitStruct)    *         GPIOx_PUPDR, GPIOx_AFRL and GPIOx_AFRH.
    * @note   The configuration of the locked GPIO pins can no longer be modified
    *         until the next reset.
 -  * @param  GPIOx: where x can be (A..I) to select the GPIO peripheral for 
 -  *                STM32F40xx/41xx and STM32F427x/437x devices.
 +  * @param  GPIOx: where x can be (A..K) to select the GPIO peripheral for STM32F405xx/407xx and STM32F415xx/417xx devices
 +  *                      x can be (A..I) to select the GPIO peripheral for STM32F42xxx/43xxx devices.
 +  *                      x can be (A, B, C, D and H) to select the GPIO peripheral for STM32F401xx devices. 
    * @param  GPIO_Pin: specifies the port bit to be locked.
    *          This parameter can be any combination of GPIO_Pin_x where x can be (0..15).
    * @retval None
 @@ -300,8 +313,9 @@ void GPIO_PinLockConfig(GPIO_TypeDef* GPIOx, uint16_t GPIO_Pin)  /**
    * @brief  Reads the specified input port pin.
 -  * @param  GPIOx: where x can be (A..I) to select the GPIO peripheral for 
 -  *                STM32F40xx/41xx and STM32F427x/437x devices.
 +  * @param  GPIOx: where x can be (A..K) to select the GPIO peripheral for STM32F405xx/407xx and STM32F415xx/417xx devices
 +  *                      x can be (A..I) to select the GPIO peripheral for STM32F42xxx/43xxx devices.
 +  *                      x can be (A, B, C, D and H) to select the GPIO peripheral for STM32F401xx devices. 
    * @param  GPIO_Pin: specifies the port bit to read.
    *         This parameter can be GPIO_Pin_x where x can be (0..15).
    * @retval The input port pin value.
 @@ -327,8 +341,9 @@ uint8_t GPIO_ReadInputDataBit(GPIO_TypeDef* GPIOx, uint16_t GPIO_Pin)  /**
    * @brief  Reads the specified GPIO input data port.
 -  * @param  GPIOx: where x can be (A..I) to select the GPIO peripheral for 
 -  *                STM32F40xx/41xx and STM32F427x/437x devices. 
 +  * @param  GPIOx: where x can be (A..K) to select the GPIO peripheral for STM32F405xx/407xx and STM32F415xx/417xx devices
 +  *                      x can be (A..I) to select the GPIO peripheral for STM32F42xxx/43xxx devices.
 +  *                      x can be (A, B, C, D and H) to select the GPIO peripheral for STM32F401xx devices. 
    * @retval GPIO input data port value.
    */
  uint16_t GPIO_ReadInputData(GPIO_TypeDef* GPIOx)
 @@ -341,8 +356,9 @@ uint16_t GPIO_ReadInputData(GPIO_TypeDef* GPIOx)  /**
    * @brief  Reads the specified output data port bit.
 -  * @param  GPIOx: where x can be (A..I) to select the GPIO peripheral for 
 -  *                STM32F40xx/41xx and STM32F427x/437x devices. 
 +  * @param  GPIOx: where x can be (A..K) to select the GPIO peripheral for STM32F405xx/407xx and STM32F415xx/417xx devices
 +  *                      x can be (A..I) to select the GPIO peripheral for STM32F42xxx/43xxx devices.
 +  *                      x can be (A, B, C, D and H) to select the GPIO peripheral for STM32F401xx devices. 
    * @param  GPIO_Pin: specifies the port bit to read.
    *          This parameter can be GPIO_Pin_x where x can be (0..15).
    * @retval The output port pin value.
 @@ -368,8 +384,9 @@ uint8_t GPIO_ReadOutputDataBit(GPIO_TypeDef* GPIOx, uint16_t GPIO_Pin)  /**
    * @brief  Reads the specified GPIO output data port.
 -  * @param  GPIOx: where x can be (A..I) to select the GPIO peripheral for 
 -  *                STM32F40xx/41xx and STM32F427x/437x devices.  
 +  * @param  GPIOx: where x can be (A..K) to select the GPIO peripheral for STM32F405xx/407xx and STM32F415xx/417xx devices
 +  *                      x can be (A..I) to select the GPIO peripheral for STM32F42xxx/43xxx devices.
 +  *                      x can be (A, B, C, D and H) to select the GPIO peripheral for STM32F401xx devices. 
    * @retval GPIO output data port value.
    */
  uint16_t GPIO_ReadOutputData(GPIO_TypeDef* GPIOx)
 @@ -385,8 +402,9 @@ uint16_t GPIO_ReadOutputData(GPIO_TypeDef* GPIOx)    * @note   This functions uses GPIOx_BSRR register to allow atomic read/modify 
    *         accesses. In this way, there is no risk of an IRQ occurring between
    *         the read and the modify access.
 -  * @param  GPIOx: where x can be (A..I) to select the GPIO peripheral for 
 -  *                STM32F40xx/41xx and STM32F427x/437x devices.  
 +  * @param  GPIOx: where x can be (A..K) to select the GPIO peripheral for STM32F405xx/407xx and STM32F415xx/417xx devices
 +  *                      x can be (A..I) to select the GPIO peripheral for STM32F42xxx/43xxx devices.
 +  *                      x can be (A, B, C, D and H) to select the GPIO peripheral for STM32F401xx devices. 
    * @param  GPIO_Pin: specifies the port bits to be written.
    *          This parameter can be any combination of GPIO_Pin_x where x can be (0..15).
    * @retval None
 @@ -405,8 +423,9 @@ void GPIO_SetBits(GPIO_TypeDef* GPIOx, uint16_t GPIO_Pin)    * @note   This functions uses GPIOx_BSRR register to allow atomic read/modify 
    *         accesses. In this way, there is no risk of an IRQ occurring between
    *         the read and the modify access.
 -  * @param  GPIOx: where x can be (A..I) to select the GPIO peripheral for 
 -  *                STM32F40xx/41xx and STM32F427x/437x devices. 
 +  * @param  GPIOx: where x can be (A..K) to select the GPIO peripheral for STM32F405xx/407xx and STM32F415xx/417xx devices
 +  *                      x can be (A..I) to select the GPIO peripheral for STM32F42xxx/43xxx devices.
 +  *                      x can be (A, B, C, D and H) to select the GPIO peripheral for STM32F401xx devices. 
    * @param  GPIO_Pin: specifies the port bits to be written.
    *          This parameter can be any combination of GPIO_Pin_x where x can be (0..15).
    * @retval None
 @@ -422,8 +441,9 @@ void GPIO_ResetBits(GPIO_TypeDef* GPIOx, uint16_t GPIO_Pin)  /**
    * @brief  Sets or clears the selected data port bit.
 -  * @param  GPIOx: where x can be (A..I) to select the GPIO peripheral for 
 -  *                STM32F40xx/41xx and STM32F427x/437x devices.  
 +  * @param  GPIOx: where x can be (A..K) to select the GPIO peripheral for STM32F405xx/407xx and STM32F415xx/417xx devices
 +  *                      x can be (A..I) to select the GPIO peripheral for STM32F42xxx/43xxx devices.
 +  *                      x can be (A, B, C, D and H) to select the GPIO peripheral for STM32F401xx devices. 
    * @param  GPIO_Pin: specifies the port bit to be written.
    *          This parameter can be one of GPIO_Pin_x where x can be (0..15).
    * @param  BitVal: specifies the value to be written to the selected bit.
 @@ -451,8 +471,9 @@ void GPIO_WriteBit(GPIO_TypeDef* GPIOx, uint16_t GPIO_Pin, BitAction BitVal)  /**
    * @brief  Writes data to the specified GPIO data port.
 -  * @param  GPIOx: where x can be (A..I) to select the GPIO peripheral for 
 -  *                STM32F40xx/41xx and STM32F427x/437x devices.  
 +  * @param  GPIOx: where x can be (A..K) to select the GPIO peripheral for STM32F405xx/407xx and STM32F415xx/417xx devices
 +  *                      x can be (A..I) to select the GPIO peripheral for STM32F42xxx/43xxx devices.
 +  *                      x can be (A, B, C, D and H) to select the GPIO peripheral for STM32F401xx devices. 
    * @param  PortVal: specifies the value to be written to the port output data register.
    * @retval None
    */
 @@ -466,8 +487,9 @@ void GPIO_Write(GPIO_TypeDef* GPIOx, uint16_t PortVal)  /**
    * @brief  Toggles the specified GPIO pins..
 -  * @param  GPIOx: where x can be (A..I) to select the GPIO peripheral for 
 -  *                STM32F40xx/41xx and STM32F427x/437x devices.  
 +  * @param  GPIOx: where x can be (A..K) to select the GPIO peripheral for STM32F405xx/407xx and STM32F415xx/417xx devices
 +  *                      x can be (A..I) to select the GPIO peripheral for STM32F42xxx/43xxx devices.
 +  *                      x can be (A, B, C, D and H) to select the GPIO peripheral for STM32F401xx devices. 
    * @param  GPIO_Pin: Specifies the pins to be toggled.
    * @retval None
    */
 @@ -497,8 +519,9 @@ void GPIO_ToggleBits(GPIO_TypeDef* GPIOx, uint16_t GPIO_Pin)  /**
    * @brief  Changes the mapping of the specified pin.
 -  * @param  GPIOx: where x can be (A..I) to select the GPIO peripheral for 
 -  *                STM32F40xx/41xx and STM32F427x/437x devices. 
 +  * @param  GPIOx: where x can be (A..K) to select the GPIO peripheral for STM32F405xx/407xx and STM32F415xx/417xx devices
 +  *                      x can be (A..I) to select the GPIO peripheral for STM32F42xxx/43xxx devices.
 +  *                      x can be (A, B, C, D and H) to select the GPIO peripheral for STM32F401xx devices. 
    * @param  GPIO_PinSource: specifies the pin for the Alternate function.
    *         This parameter can be GPIO_PinSourcex where x can be (0..15).
    * @param  GPIO_AFSelection: selects the pin to used as Alternate function.
 @@ -524,7 +547,8 @@ void GPIO_ToggleBits(GPIO_TypeDef* GPIOx, uint16_t GPIO_Pin)    *            @arg GPIO_AF_SPI2: Connect SPI2/I2S2 pins to AF5
    *            @arg GPIO_AF_SPI4: Connect SPI4 pins to AF5 
    *            @arg GPIO_AF_SPI5: Connect SPI5 pins to AF5 
 -  *            @arg GPIO_AF_SPI6: Connect SPI6 pins to AF5       
 +  *            @arg GPIO_AF_SPI6: Connect SPI6 pins to AF5
 +  *            @arg GPIO_AF_SAI1: Connect SAI1 pins to AF6 for STM32F42xxx/43xxx devices.       
    *            @arg GPIO_AF_SPI3: Connect SPI3/I2S3 pins to AF6
    *            @arg GPIO_AF_I2S3ext: Connect I2S3ext pins to AF7
    *            @arg GPIO_AF_USART1: Connect USART1 pins to AF7
 @@ -543,10 +567,12 @@ void GPIO_ToggleBits(GPIO_TypeDef* GPIOx, uint16_t GPIO_Pin)    *            @arg GPIO_AF_OTG_FS: Connect OTG_FS pins to AF10
    *            @arg GPIO_AF_OTG_HS: Connect OTG_HS pins to AF10
    *            @arg GPIO_AF_ETH: Connect ETHERNET pins to AF11
 -  *            @arg GPIO_AF_FSMC: Connect FSMC pins to AF12   
 +  *            @arg GPIO_AF_FSMC: Connect FSMC pins to AF12 
 +  *            @arg GPIO_AF_FMC: Connect FMC pins to AF12 for STM32F42xxx/43xxx devices.   
    *            @arg GPIO_AF_OTG_HS_FS: Connect OTG HS (configured in FS) pins to AF12
    *            @arg GPIO_AF_SDIO: Connect SDIO pins to AF12
 -  *            @arg GPIO_AF_DCMI: Connect DCMI pins to AF13 
 +  *            @arg GPIO_AF_DCMI: Connect DCMI pins to AF13
 +  *            @arg GPIO_AF_LTDC: Connect LTDC pins to AF14 for STM32F429xx/439xx devices. 
    *            @arg GPIO_AF_EVENTOUT: Connect EVENTOUT pins to AF15
    * @retval None
    */
 diff --git a/stm/lib/stm32f4xx_gpio.h b/stm/lib/stm32f4xx_gpio.h index 0cf96c5b1..d93b14197 100644 --- a/stm/lib/stm32f4xx_gpio.h +++ b/stm/lib/stm32f4xx_gpio.h @@ -2,8 +2,8 @@    ******************************************************************************
    * @file    stm32f4xx_gpio.h
    * @author  MCD Application Team
 -  * @version V1.1.0
 -  * @date    11-January-2013
 +  * @version V1.3.0
 +  * @date    08-November-2013
    * @brief   This file contains all the functions prototypes for the GPIO firmware
    *          library.  
    ******************************************************************************
 @@ -55,9 +55,10 @@                                      ((PERIPH) == GPIOF) || \
                                      ((PERIPH) == GPIOG) || \
                                      ((PERIPH) == GPIOH) || \
 -                                    ((PERIPH) == GPIOI))
 -
 -                                                                                                
 +                                    ((PERIPH) == GPIOI) || \
 +                                    ((PERIPH) == GPIOJ) || \
 +                                    ((PERIPH) == GPIOK))
 +                                                                                             
  /** 
    * @brief  GPIO Configuration Mode enumeration 
    */   
 @@ -87,13 +88,20 @@ typedef enum    */  
  typedef enum
  { 
 -  GPIO_Speed_2MHz   = 0x00, /*!< Low speed */
 -  GPIO_Speed_25MHz  = 0x01, /*!< Medium speed */
 -  GPIO_Speed_50MHz  = 0x02, /*!< Fast speed */
 -  GPIO_Speed_100MHz = 0x03  /*!< High speed on 30 pF (80 MHz Output max speed on 15 pF) */
 +  GPIO_Low_Speed     = 0x00, /*!< Low speed    */
 +  GPIO_Medium_Speed  = 0x01, /*!< Medium speed */
 +  GPIO_Fast_Speed    = 0x02, /*!< Fast speed   */
 +  GPIO_High_Speed    = 0x03  /*!< High speed   */
  }GPIOSpeed_TypeDef;
 -#define IS_GPIO_SPEED(SPEED) (((SPEED) == GPIO_Speed_2MHz) || ((SPEED) == GPIO_Speed_25MHz) || \
 -                              ((SPEED) == GPIO_Speed_50MHz)||  ((SPEED) == GPIO_Speed_100MHz)) 
 +
 +/* Add legacy definition */
 +#define  GPIO_Speed_2MHz    GPIO_Low_Speed    
 +#define  GPIO_Speed_25MHz   GPIO_Medium_Speed 
 +#define  GPIO_Speed_50MHz   GPIO_Fast_Speed 
 +#define  GPIO_Speed_100MHz  GPIO_High_Speed  
 +  
 +#define IS_GPIO_SPEED(SPEED) (((SPEED) == GPIO_Low_Speed) || ((SPEED) == GPIO_Medium_Speed) || \
 +                              ((SPEED) == GPIO_Fast_Speed)||  ((SPEED) == GPIO_High_Speed)) 
  /** 
    * @brief  GPIO Configuration PullUp PullDown enumeration 
 @@ -282,6 +290,8 @@ typedef struct    */ 
  #define GPIO_AF_SPI3          ((uint8_t)0x06)  /* SPI3/I2S3 Alternate Function mapping */
 +#define GPIO_AF_SAI1          ((uint8_t)0x06)  /* SAI1 Alternate Function mapping      */
 +
  /** 
    * @brief   AF 7 selection  
    */ 
 @@ -308,6 +318,9 @@ typedef struct  #define GPIO_AF_TIM13         ((uint8_t)0x09)  /* TIM13 Alternate Function mapping */
  #define GPIO_AF_TIM14         ((uint8_t)0x09)  /* TIM14 Alternate Function mapping */
 +#define GPIO_AF9_I2C2          ((uint8_t)0x09)  /* I2C2 Alternate Function mapping (Only for STM32F401xx Devices) */
 +#define GPIO_AF9_I2C3          ((uint8_t)0x09)  /* I2C3 Alternate Function mapping (Only for STM32F401xx Devices) */
 +
  /** 
    * @brief   AF 10 selection  
    */ 
 @@ -322,7 +335,13 @@ typedef struct  /** 
    * @brief   AF 12 selection  
    */ 
 +#if defined (STM32F40_41xxx)
  #define GPIO_AF_FSMC             ((uint8_t)0xC)  /* FSMC Alternate Function mapping                     */
 +#endif /* STM32F40_41xxx */
 +
 +#if defined (STM32F427_437xx) || defined (STM32F429_439xx)
 +#define GPIO_AF_FMC              ((uint8_t)0xC)  /* FMC Alternate Function mapping                      */
 +#endif /* STM32F427_437xx ||  STM32F429_439xx */
  #define GPIO_AF_OTG_HS_FS        ((uint8_t)0xC)  /* OTG HS configured in FS, Alternate Function mapping */
  #define GPIO_AF_SDIO             ((uint8_t)0xC)  /* SDIO Alternate Function mapping                     */
 @@ -333,10 +352,55 @@ typedef struct  #define GPIO_AF_DCMI          ((uint8_t)0x0D)  /* DCMI Alternate Function mapping */
  /** 
 +  * @brief   AF 14 selection  
 +  */
 +
 +#define GPIO_AF_LTDC          ((uint8_t)0x0E)  /* LCD-TFT Alternate Function mapping */
 +
 +/** 
    * @brief   AF 15 selection  
    */ 
  #define GPIO_AF_EVENTOUT      ((uint8_t)0x0F)  /* EVENTOUT Alternate Function mapping */
 +#if defined (STM32F40_41xxx)
 +#define IS_GPIO_AF(AF)   (((AF) == GPIO_AF_RTC_50Hz)  || ((AF) == GPIO_AF_TIM14)     || \
 +                          ((AF) == GPIO_AF_MCO)       || ((AF) == GPIO_AF_TAMPER)    || \
 +                          ((AF) == GPIO_AF_SWJ)       || ((AF) == GPIO_AF_TRACE)     || \
 +                          ((AF) == GPIO_AF_TIM1)      || ((AF) == GPIO_AF_TIM2)      || \
 +                          ((AF) == GPIO_AF_TIM3)      || ((AF) == GPIO_AF_TIM4)      || \
 +                          ((AF) == GPIO_AF_TIM5)      || ((AF) == GPIO_AF_TIM8)      || \
 +                          ((AF) == GPIO_AF_I2C1)      || ((AF) == GPIO_AF_I2C2)      || \
 +                          ((AF) == GPIO_AF_I2C3)      || ((AF) == GPIO_AF_SPI1)      || \
 +                          ((AF) == GPIO_AF_SPI2)      || ((AF) == GPIO_AF_TIM13)     || \
 +                          ((AF) == GPIO_AF_SPI3)      || ((AF) == GPIO_AF_TIM14)     || \
 +                          ((AF) == GPIO_AF_USART1)    || ((AF) == GPIO_AF_USART2)    || \
 +                          ((AF) == GPIO_AF_USART3)    || ((AF) == GPIO_AF_UART4)     || \
 +                          ((AF) == GPIO_AF_UART5)     || ((AF) == GPIO_AF_USART6)    || \
 +                          ((AF) == GPIO_AF_CAN1)      || ((AF) == GPIO_AF_CAN2)      || \
 +                          ((AF) == GPIO_AF_OTG_FS)    || ((AF) == GPIO_AF_OTG_HS)    || \
 +                          ((AF) == GPIO_AF_ETH)       || ((AF) == GPIO_AF_OTG_HS_FS) || \
 +                          ((AF) == GPIO_AF_SDIO)      || ((AF) == GPIO_AF_DCMI)      || \
 +                          ((AF) == GPIO_AF_EVENTOUT)  || ((AF) == GPIO_AF_FSMC))
 +#endif /* STM32F40_41xxx */
 +
 +#if defined (STM32F401xx)
 +#define IS_GPIO_AF(AF)   (((AF) == GPIO_AF_RTC_50Hz)  || ((AF) == GPIO_AF_TIM14)     || \
 +                          ((AF) == GPIO_AF_MCO)       || ((AF) == GPIO_AF_TAMPER)    || \
 +                          ((AF) == GPIO_AF_SWJ)       || ((AF) == GPIO_AF_TRACE)     || \
 +                          ((AF) == GPIO_AF_TIM1)      || ((AF) == GPIO_AF_TIM2)      || \
 +                          ((AF) == GPIO_AF_TIM3)      || ((AF) == GPIO_AF_TIM4)      || \
 +                          ((AF) == GPIO_AF_TIM5)      || ((AF) == GPIO_AF_TIM8)      || \
 +                          ((AF) == GPIO_AF_I2C1)      || ((AF) == GPIO_AF_I2C2)      || \
 +                          ((AF) == GPIO_AF_I2C3)      || ((AF) == GPIO_AF_SPI1)      || \
 +                          ((AF) == GPIO_AF_SPI2)      || ((AF) == GPIO_AF_TIM13)     || \
 +                          ((AF) == GPIO_AF_SPI3)      || ((AF) == GPIO_AF_TIM14)     || \
 +                          ((AF) == GPIO_AF_USART1)    || ((AF) == GPIO_AF_USART2)    || \
 +                          ((AF) == GPIO_AF_SDIO)      || ((AF) == GPIO_AF_USART6)    || \
 +                          ((AF) == GPIO_AF_OTG_FS)    || ((AF) == GPIO_AF_OTG_HS)    || \
 +                          ((AF) == GPIO_AF_EVENTOUT)  || ((AF) == GPIO_AF_SPI4))
 +#endif /* STM32F401xx */
 +
 +#if defined (STM32F427_437xx) || defined (STM32F429_439xx)
  #define IS_GPIO_AF(AF)   (((AF) == GPIO_AF_RTC_50Hz)  || ((AF) == GPIO_AF_TIM14)     || \
                            ((AF) == GPIO_AF_MCO)       || ((AF) == GPIO_AF_TAMPER)    || \
                            ((AF) == GPIO_AF_SWJ)       || ((AF) == GPIO_AF_TRACE)     || \
 @@ -357,8 +421,10 @@ typedef struct                            ((AF) == GPIO_AF_EVENTOUT)  || ((AF) == GPIO_AF_SPI4)      || \
                            ((AF) == GPIO_AF_SPI5)      || ((AF) == GPIO_AF_SPI6)      || \
                            ((AF) == GPIO_AF_UART7)     || ((AF) == GPIO_AF_UART8)     || \
 -                          ((AF) == GPIO_AF_FSMC))
 -
 +                          ((AF) == GPIO_AF_FMC)       ||  ((AF) == GPIO_AF_SAI1)     || \
 +                          ((AF) == GPIO_AF_LTDC))
 +#endif /* STM32F427_437xx ||  STM32F429_439xx */
 +                          
  /**
    * @}
    */ 
 diff --git a/stm/lib/stm32f4xx_i2c.c b/stm/lib/stm32f4xx_i2c.c new file mode 100644 index 000000000..4580c0dd7 --- /dev/null +++ b/stm/lib/stm32f4xx_i2c.c @@ -0,0 +1,1462 @@ +/**
 +  ******************************************************************************
 +  * @file    stm32f4xx_i2c.c
 +  * @author  MCD Application Team
 +  * @version V1.3.0
 +  * @date    08-November-2013
 +  * @brief   This file provides firmware functions to manage the following 
 +  *          functionalities of the Inter-integrated circuit (I2C)
 +  *           + Initialization and Configuration
 +  *           + Data transfers
 +  *           + PEC management
 +  *           + DMA transfers management
 +  *           + Interrupts, events and flags management 
 +  *           
 +    @verbatim    
 + ===============================================================================
 +                    ##### How to use this driver #####
 + ===============================================================================
 +    [..]
 +      (#) Enable peripheral clock using RCC_APB1PeriphClockCmd(RCC_APB1Periph_I2Cx, ENABLE)
 +          function for I2C1, I2C2 or I2C3.
 +  
 +      (#) Enable SDA, SCL  and SMBA (when used) GPIO clocks using 
 +          RCC_AHBPeriphClockCmd() function. 
 +  
 +      (#) Peripherals alternate function: 
 +        (++) Connect the pin to the desired peripherals' Alternate 
 +             Function (AF) using GPIO_PinAFConfig() function
 +        (++) Configure the desired pin in alternate function by:
 +             GPIO_InitStruct->GPIO_Mode = GPIO_Mode_AF
 +        (++) Select the type, pull-up/pull-down and output speed via 
 +             GPIO_PuPd, GPIO_OType and GPIO_Speed members
 +        (++) Call GPIO_Init() function
 +             Recommended configuration is Push-Pull, Pull-up, Open-Drain.
 +             Add an external pull up if necessary (typically 4.7 KOhm).      
 +          
 +      (#) Program the Mode, duty cycle , Own address, Ack, Speed and Acknowledged
 +          Address using the I2C_Init() function.
 +  
 +      (#) Optionally you can enable/configure the following parameters without
 +          re-initialization (i.e there is no need to call again I2C_Init() function):
 +        (++) Enable the acknowledge feature using I2C_AcknowledgeConfig() function
 +        (++) Enable the dual addressing mode using I2C_DualAddressCmd() function
 +        (++) Enable the general call using the I2C_GeneralCallCmd() function
 +        (++) Enable the clock stretching using I2C_StretchClockCmd() function
 +        (++) Enable the fast mode duty cycle using the I2C_FastModeDutyCycleConfig()
 +             function.
 +        (++) Configure the NACK position for Master Receiver mode in case of 
 +             2 bytes reception using the function I2C_NACKPositionConfig().  
 +        (++) Enable the PEC Calculation using I2C_CalculatePEC() function
 +        (++) For SMBus Mode: 
 +          (+++) Enable the Address Resolution Protocol (ARP) using I2C_ARPCmd() function
 +          (+++) Configure the SMBusAlert pin using I2C_SMBusAlertConfig() function
 +  
 +      (#) Enable the NVIC and the corresponding interrupt using the function 
 +          I2C_ITConfig() if you need to use interrupt mode. 
 +  
 +      (#) When using the DMA mode 
 +        (++) Configure the DMA using DMA_Init() function
 +        (++) Active the needed channel Request using I2C_DMACmd() or
 +             I2C_DMALastTransferCmd() function.
 +        -@@- When using DMA mode, I2C interrupts may be used at the same time to
 +             control the communication flow (Start/Stop/Ack... events and errors).
 +   
 +      (#) Enable the I2C using the I2C_Cmd() function.
 +   
 +      (#) Enable the DMA using the DMA_Cmd() function when using DMA mode in the 
 +          transfers. 
 +  
 +    @endverbatim  
 +  ******************************************************************************
 +  * @attention
 +  *
 +  * <h2><center>© COPYRIGHT 2013 STMicroelectronics</center></h2>
 +  *
 +  * Licensed under MCD-ST Liberty SW License Agreement V2, (the "License");
 +  * You may not use this file except in compliance with the License.
 +  * You may obtain a copy of the License at:
 +  *
 +  *        http://www.st.com/software_license_agreement_liberty_v2
 +  *
 +  * Unless required by applicable law or agreed to in writing, software 
 +  * distributed under the License is distributed on an "AS IS" BASIS, 
 +  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 +  * See the License for the specific language governing permissions and
 +  * limitations under the License.
 +  *
 +  ******************************************************************************  
 +  */ 
 +
 +/* Includes ------------------------------------------------------------------*/
 +#include "stm32f4xx_i2c.h"
 +#include "stm32f4xx_rcc.h"
 +
 +/** @addtogroup STM32F4xx_StdPeriph_Driver
 +  * @{
 +  */
 +
 +/** @defgroup I2C 
 +  * @brief I2C driver modules
 +  * @{
 +  */ 
 +
 +/* Private typedef -----------------------------------------------------------*/
 +/* Private define ------------------------------------------------------------*/
 +
 +#define CR1_CLEAR_MASK    ((uint16_t)0xFBF5)      /*<! I2C registers Masks */
 +#define FLAG_MASK         ((uint32_t)0x00FFFFFF)  /*<! I2C FLAG mask */
 +#define ITEN_MASK         ((uint32_t)0x07000000)  /*<! I2C Interrupt Enable mask */
 +
 +/* Private macro -------------------------------------------------------------*/
 +/* Private variables ---------------------------------------------------------*/
 +/* Private function prototypes -----------------------------------------------*/
 +/* Private functions ---------------------------------------------------------*/
 +
 +/** @defgroup I2C_Private_Functions
 +  * @{
 +  */
 +
 +/** @defgroup I2C_Group1 Initialization and Configuration functions
 + *  @brief   Initialization and Configuration functions 
 + *
 +@verbatim   
 + ===============================================================================
 +            ##### Initialization and Configuration functions #####
 + ===============================================================================  
 +
 +@endverbatim
 +  * @{
 +  */
 +
 +/**
 +  * @brief  Deinitialize the I2Cx peripheral registers to their default reset values.
 +  * @param  I2Cx: where x can be 1, 2 or 3 to select the I2C peripheral.
 +  * @retval None
 +  */
 +void I2C_DeInit(I2C_TypeDef* I2Cx)
 +{
 +  /* Check the parameters */
 +  assert_param(IS_I2C_ALL_PERIPH(I2Cx));
 +
 +  if (I2Cx == I2C1)
 +  {
 +    /* Enable I2C1 reset state */
 +    RCC_APB1PeriphResetCmd(RCC_APB1Periph_I2C1, ENABLE);
 +    /* Release I2C1 from reset state */
 +    RCC_APB1PeriphResetCmd(RCC_APB1Periph_I2C1, DISABLE);    
 +  }
 +  else if (I2Cx == I2C2)
 +  {
 +    /* Enable I2C2 reset state */
 +    RCC_APB1PeriphResetCmd(RCC_APB1Periph_I2C2, ENABLE);
 +    /* Release I2C2 from reset state */
 +    RCC_APB1PeriphResetCmd(RCC_APB1Periph_I2C2, DISABLE);      
 +  }
 +  else 
 +  {
 +    if (I2Cx == I2C3)
 +    {
 +      /* Enable I2C3 reset state */
 +      RCC_APB1PeriphResetCmd(RCC_APB1Periph_I2C3, ENABLE);
 +      /* Release I2C3 from reset state */
 +      RCC_APB1PeriphResetCmd(RCC_APB1Periph_I2C3, DISABLE);     
 +    }
 +  }
 +}
 +
 +/**
 +  * @brief  Initializes the I2Cx peripheral according to the specified 
 +  *         parameters in the I2C_InitStruct.
 +  *           
 +  * @note   To use the I2C at 400 KHz (in fast mode), the PCLK1 frequency 
 +  *         (I2C peripheral input clock) must be a multiple of 10 MHz.  
 +  *           
 +  * @param  I2Cx: where x can be 1, 2 or 3 to select the I2C peripheral.
 +  * @param  I2C_InitStruct: pointer to a I2C_InitTypeDef structure that contains 
 +  *         the configuration information for the specified I2C peripheral.
 +  * @retval None
 +  */
 +void I2C_Init(I2C_TypeDef* I2Cx, I2C_InitTypeDef* I2C_InitStruct)
 +{
 +  uint16_t tmpreg = 0, freqrange = 0;
 +  uint16_t result = 0x04;
 +  uint32_t pclk1 = 8000000;
 +  RCC_ClocksTypeDef  rcc_clocks;
 +  /* Check the parameters */
 +  assert_param(IS_I2C_ALL_PERIPH(I2Cx));
 +  assert_param(IS_I2C_CLOCK_SPEED(I2C_InitStruct->I2C_ClockSpeed));
 +  assert_param(IS_I2C_MODE(I2C_InitStruct->I2C_Mode));
 +  assert_param(IS_I2C_DUTY_CYCLE(I2C_InitStruct->I2C_DutyCycle));
 +  assert_param(IS_I2C_OWN_ADDRESS1(I2C_InitStruct->I2C_OwnAddress1));
 +  assert_param(IS_I2C_ACK_STATE(I2C_InitStruct->I2C_Ack));
 +  assert_param(IS_I2C_ACKNOWLEDGE_ADDRESS(I2C_InitStruct->I2C_AcknowledgedAddress));
 +
 +/*---------------------------- I2Cx CR2 Configuration ------------------------*/
 +  /* Get the I2Cx CR2 value */
 +  tmpreg = I2Cx->CR2;
 +  /* Clear frequency FREQ[5:0] bits */
 +  tmpreg &= (uint16_t)~((uint16_t)I2C_CR2_FREQ);
 +  /* Get pclk1 frequency value */
 +  RCC_GetClocksFreq(&rcc_clocks);
 +  pclk1 = rcc_clocks.PCLK1_Frequency;
 +  /* Set frequency bits depending on pclk1 value */
 +  freqrange = (uint16_t)(pclk1 / 1000000);
 +  tmpreg |= freqrange;
 +  /* Write to I2Cx CR2 */
 +  I2Cx->CR2 = tmpreg;
 +
 +/*---------------------------- I2Cx CCR Configuration ------------------------*/
 +  /* Disable the selected I2C peripheral to configure TRISE */
 +  I2Cx->CR1 &= (uint16_t)~((uint16_t)I2C_CR1_PE);
 +  /* Reset tmpreg value */
 +  /* Clear F/S, DUTY and CCR[11:0] bits */
 +  tmpreg = 0;
 +
 +  /* Configure speed in standard mode */
 +  if (I2C_InitStruct->I2C_ClockSpeed <= 100000)
 +  {
 +    /* Standard mode speed calculate */
 +    result = (uint16_t)(pclk1 / (I2C_InitStruct->I2C_ClockSpeed << 1));
 +    /* Test if CCR value is under 0x4*/
 +    if (result < 0x04)
 +    {
 +      /* Set minimum allowed value */
 +      result = 0x04;  
 +    }
 +    /* Set speed value for standard mode */
 +    tmpreg |= result;	  
 +    /* Set Maximum Rise Time for standard mode */
 +    I2Cx->TRISE = freqrange + 1; 
 +  }
 +  /* Configure speed in fast mode */
 +  /* To use the I2C at 400 KHz (in fast mode), the PCLK1 frequency (I2C peripheral
 +     input clock) must be a multiple of 10 MHz */
 +  else /*(I2C_InitStruct->I2C_ClockSpeed <= 400000)*/
 +  {
 +    if (I2C_InitStruct->I2C_DutyCycle == I2C_DutyCycle_2)
 +    {
 +      /* Fast mode speed calculate: Tlow/Thigh = 2 */
 +      result = (uint16_t)(pclk1 / (I2C_InitStruct->I2C_ClockSpeed * 3));
 +    }
 +    else /*I2C_InitStruct->I2C_DutyCycle == I2C_DutyCycle_16_9*/
 +    {
 +      /* Fast mode speed calculate: Tlow/Thigh = 16/9 */
 +      result = (uint16_t)(pclk1 / (I2C_InitStruct->I2C_ClockSpeed * 25));
 +      /* Set DUTY bit */
 +      result |= I2C_DutyCycle_16_9;
 +    }
 +
 +    /* Test if CCR value is under 0x1*/
 +    if ((result & I2C_CCR_CCR) == 0)
 +    {
 +      /* Set minimum allowed value */
 +      result |= (uint16_t)0x0001;  
 +    }
 +    /* Set speed value and set F/S bit for fast mode */
 +    tmpreg |= (uint16_t)(result | I2C_CCR_FS);
 +    /* Set Maximum Rise Time for fast mode */
 +    I2Cx->TRISE = (uint16_t)(((freqrange * (uint16_t)300) / (uint16_t)1000) + (uint16_t)1);  
 +  }
 +
 +  /* Write to I2Cx CCR */
 +  I2Cx->CCR = tmpreg;
 +  /* Enable the selected I2C peripheral */
 +  I2Cx->CR1 |= I2C_CR1_PE;
 +
 +/*---------------------------- I2Cx CR1 Configuration ------------------------*/
 +  /* Get the I2Cx CR1 value */
 +  tmpreg = I2Cx->CR1;
 +  /* Clear ACK, SMBTYPE and  SMBUS bits */
 +  tmpreg &= CR1_CLEAR_MASK;
 +  /* Configure I2Cx: mode and acknowledgement */
 +  /* Set SMBTYPE and SMBUS bits according to I2C_Mode value */
 +  /* Set ACK bit according to I2C_Ack value */
 +  tmpreg |= (uint16_t)((uint32_t)I2C_InitStruct->I2C_Mode | I2C_InitStruct->I2C_Ack);
 +  /* Write to I2Cx CR1 */
 +  I2Cx->CR1 = tmpreg;
 +
 +/*---------------------------- I2Cx OAR1 Configuration -----------------------*/
 +  /* Set I2Cx Own Address1 and acknowledged address */
 +  I2Cx->OAR1 = (I2C_InitStruct->I2C_AcknowledgedAddress | I2C_InitStruct->I2C_OwnAddress1);
 +}
 +
 +/**
 +  * @brief  Fills each I2C_InitStruct member with its default value.
 +  * @param  I2C_InitStruct: pointer to an I2C_InitTypeDef structure which will be initialized.
 +  * @retval None
 +  */
 +void I2C_StructInit(I2C_InitTypeDef* I2C_InitStruct)
 +{
 +/*---------------- Reset I2C init structure parameters values ----------------*/
 +  /* initialize the I2C_ClockSpeed member */
 +  I2C_InitStruct->I2C_ClockSpeed = 5000;
 +  /* Initialize the I2C_Mode member */
 +  I2C_InitStruct->I2C_Mode = I2C_Mode_I2C;
 +  /* Initialize the I2C_DutyCycle member */
 +  I2C_InitStruct->I2C_DutyCycle = I2C_DutyCycle_2;
 +  /* Initialize the I2C_OwnAddress1 member */
 +  I2C_InitStruct->I2C_OwnAddress1 = 0;
 +  /* Initialize the I2C_Ack member */
 +  I2C_InitStruct->I2C_Ack = I2C_Ack_Disable;
 +  /* Initialize the I2C_AcknowledgedAddress member */
 +  I2C_InitStruct->I2C_AcknowledgedAddress = I2C_AcknowledgedAddress_7bit;
 +}
 +
 +/**
 +  * @brief  Enables or disables the specified I2C peripheral.
 +  * @param  I2Cx: where x can be 1, 2 or 3 to select the I2C peripheral.
 +  * @param  NewState: new state of the I2Cx peripheral. 
 +  *          This parameter can be: ENABLE or DISABLE.
 +  * @retval None
 +  */
 +void I2C_Cmd(I2C_TypeDef* I2Cx, FunctionalState NewState)
 +{
 +  /* Check the parameters */
 +  assert_param(IS_I2C_ALL_PERIPH(I2Cx));
 +  assert_param(IS_FUNCTIONAL_STATE(NewState));
 +  if (NewState != DISABLE)
 +  {
 +    /* Enable the selected I2C peripheral */
 +    I2Cx->CR1 |= I2C_CR1_PE;
 +  }
 +  else
 +  {
 +    /* Disable the selected I2C peripheral */
 +    I2Cx->CR1 &= (uint16_t)~((uint16_t)I2C_CR1_PE);
 +  }
 +}
 +
 +/**
 +  * @brief  Enables or disables the Analog filter of I2C peripheral.
 +  * 
 +  * @note   This function can be used only for STM32F42xxx/STM3243xxx and STM32F401xx devices.
 +  *        
 +  * @param  I2Cx: where x can be 1, 2 or 3 to select the I2C peripheral.
 +  * @param  NewState: new state of the Analog filter. 
 +  *          This parameter can be: ENABLE or DISABLE.
 +  * @note   This function should be called before initializing and enabling
 +            the I2C Peripheral.
 +  * @retval None
 +  */
 +void I2C_AnalogFilterCmd(I2C_TypeDef* I2Cx, FunctionalState NewState)
 +{
 +  /* Check the parameters */
 +  assert_param(IS_I2C_ALL_PERIPH(I2Cx));
 +  assert_param(IS_FUNCTIONAL_STATE(NewState));
 +  if (NewState != DISABLE)
 +  {
 +    /* Enable the analog filter */
 +    I2Cx->FLTR &= (uint16_t)~((uint16_t)I2C_FLTR_ANOFF);    
 +  }
 +  else
 +  {
 +    /* Disable the analog filter */
 +    I2Cx->FLTR |= I2C_FLTR_ANOFF;
 +  }
 +}
 +
 +/**
 +  * @brief  Configures the Digital noise filter of I2C peripheral.
 +  * 
 +  * @note   This function can be used only for STM32F42xxx/STM3243xxx and STM32F401xx devices.
 +  *       
 +  * @param  I2Cx: where x can be 1, 2 or 3 to select the I2C peripheral.
 +  * @param  I2C_DigitalFilter: Coefficient of digital noise filter. 
 +  *          This parameter can be a number between 0x00 and 0x0F.
 +  * @note   This function should be called before initializing and enabling
 +            the I2C Peripheral.
 +  * @retval None
 +  */
 +void I2C_DigitalFilterConfig(I2C_TypeDef* I2Cx, uint16_t I2C_DigitalFilter)
 +{
 +  uint16_t tmpreg = 0;
 +  
 +  /* Check the parameters */
 +  assert_param(IS_I2C_ALL_PERIPH(I2Cx));
 +  assert_param(IS_I2C_DIGITAL_FILTER(I2C_DigitalFilter));
 +  
 +  /* Get the old register value */
 +  tmpreg = I2Cx->FLTR;
 +  
 +  /* Reset I2Cx DNF bit [3:0] */
 +  tmpreg &= (uint16_t)~((uint16_t)I2C_FLTR_DNF);
 +  
 +  /* Set I2Cx DNF coefficient */
 +  tmpreg |= (uint16_t)((uint16_t)I2C_DigitalFilter & I2C_FLTR_DNF);
 +  
 +  /* Store the new register value */
 +  I2Cx->FLTR = tmpreg;
 +}
 +
 +/**
 +  * @brief  Generates I2Cx communication START condition.
 +  * @param  I2Cx: where x can be 1, 2 or 3 to select the I2C peripheral.
 +  * @param  NewState: new state of the I2C START condition generation.
 +  *          This parameter can be: ENABLE or DISABLE.
 +  * @retval None.
 +  */
 +void I2C_GenerateSTART(I2C_TypeDef* I2Cx, FunctionalState NewState)
 +{
 +  /* Check the parameters */
 +  assert_param(IS_I2C_ALL_PERIPH(I2Cx));
 +  assert_param(IS_FUNCTIONAL_STATE(NewState));
 +  if (NewState != DISABLE)
 +  {
 +    /* Generate a START condition */
 +    I2Cx->CR1 |= I2C_CR1_START;
 +  }
 +  else
 +  {
 +    /* Disable the START condition generation */
 +    I2Cx->CR1 &= (uint16_t)~((uint16_t)I2C_CR1_START);
 +  }
 +}
 +
 +/**
 +  * @brief  Generates I2Cx communication STOP condition.
 +  * @param  I2Cx: where x can be 1, 2 or 3 to select the I2C peripheral.
 +  * @param  NewState: new state of the I2C STOP condition generation.
 +  *          This parameter can be: ENABLE or DISABLE.
 +  * @retval None.
 +  */
 +void I2C_GenerateSTOP(I2C_TypeDef* I2Cx, FunctionalState NewState)
 +{
 +  /* Check the parameters */
 +  assert_param(IS_I2C_ALL_PERIPH(I2Cx));
 +  assert_param(IS_FUNCTIONAL_STATE(NewState));
 +  if (NewState != DISABLE)
 +  {
 +    /* Generate a STOP condition */
 +    I2Cx->CR1 |= I2C_CR1_STOP;
 +  }
 +  else
 +  {
 +    /* Disable the STOP condition generation */
 +    I2Cx->CR1 &= (uint16_t)~((uint16_t)I2C_CR1_STOP);
 +  }
 +}
 +
 +/**
 +  * @brief  Transmits the address byte to select the slave device.
 +  * @param  I2Cx: where x can be 1, 2 or 3 to select the I2C peripheral.
 +  * @param  Address: specifies the slave address which will be transmitted
 +  * @param  I2C_Direction: specifies whether the I2C device will be a Transmitter
 +  *         or a Receiver. 
 +  *          This parameter can be one of the following values
 +  *            @arg I2C_Direction_Transmitter: Transmitter mode
 +  *            @arg I2C_Direction_Receiver: Receiver mode
 +  * @retval None.
 +  */
 +void I2C_Send7bitAddress(I2C_TypeDef* I2Cx, uint8_t Address, uint8_t I2C_Direction)
 +{
 +  /* Check the parameters */
 +  assert_param(IS_I2C_ALL_PERIPH(I2Cx));
 +  assert_param(IS_I2C_DIRECTION(I2C_Direction));
 +  /* Test on the direction to set/reset the read/write bit */
 +  if (I2C_Direction != I2C_Direction_Transmitter)
 +  {
 +    /* Set the address bit0 for read */
 +    Address |= I2C_OAR1_ADD0;
 +  }
 +  else
 +  {
 +    /* Reset the address bit0 for write */
 +    Address &= (uint8_t)~((uint8_t)I2C_OAR1_ADD0);
 +  }
 +  /* Send the address */
 +  I2Cx->DR = Address;
 +}
 +
 +/**
 +  * @brief  Enables or disables the specified I2C acknowledge feature.
 +  * @param  I2Cx: where x can be 1, 2 or 3 to select the I2C peripheral.
 +  * @param  NewState: new state of the I2C Acknowledgement.
 +  *          This parameter can be: ENABLE or DISABLE.
 +  * @retval None.
 +  */
 +void I2C_AcknowledgeConfig(I2C_TypeDef* I2Cx, FunctionalState NewState)
 +{
 +  /* Check the parameters */
 +  assert_param(IS_I2C_ALL_PERIPH(I2Cx));
 +  assert_param(IS_FUNCTIONAL_STATE(NewState));
 +  if (NewState != DISABLE)
 +  {
 +    /* Enable the acknowledgement */
 +    I2Cx->CR1 |= I2C_CR1_ACK;
 +  }
 +  else
 +  {
 +    /* Disable the acknowledgement */
 +    I2Cx->CR1 &= (uint16_t)~((uint16_t)I2C_CR1_ACK);
 +  }
 +}
 +
 +/**
 +  * @brief  Configures the specified I2C own address2.
 +  * @param  I2Cx: where x can be 1, 2 or 3 to select the I2C peripheral.
 +  * @param  Address: specifies the 7bit I2C own address2.
 +  * @retval None.
 +  */
 +void I2C_OwnAddress2Config(I2C_TypeDef* I2Cx, uint8_t Address)
 +{
 +  uint16_t tmpreg = 0;
 +
 +  /* Check the parameters */
 +  assert_param(IS_I2C_ALL_PERIPH(I2Cx));
 +
 +  /* Get the old register value */
 +  tmpreg = I2Cx->OAR2;
 +
 +  /* Reset I2Cx Own address2 bit [7:1] */
 +  tmpreg &= (uint16_t)~((uint16_t)I2C_OAR2_ADD2);
 +
 +  /* Set I2Cx Own address2 */
 +  tmpreg |= (uint16_t)((uint16_t)Address & (uint16_t)0x00FE);
 +
 +  /* Store the new register value */
 +  I2Cx->OAR2 = tmpreg;
 +}
 +
 +/**
 +  * @brief  Enables or disables the specified I2C dual addressing mode.
 +  * @param  I2Cx: where x can be 1, 2 or 3 to select the I2C peripheral.
 +  * @param  NewState: new state of the I2C dual addressing mode.
 +  *          This parameter can be: ENABLE or DISABLE.
 +  * @retval None
 +  */
 +void I2C_DualAddressCmd(I2C_TypeDef* I2Cx, FunctionalState NewState)
 +{
 +  /* Check the parameters */
 +  assert_param(IS_I2C_ALL_PERIPH(I2Cx));
 +  assert_param(IS_FUNCTIONAL_STATE(NewState));
 +  if (NewState != DISABLE)
 +  {
 +    /* Enable dual addressing mode */
 +    I2Cx->OAR2 |= I2C_OAR2_ENDUAL;
 +  }
 +  else
 +  {
 +    /* Disable dual addressing mode */
 +    I2Cx->OAR2 &= (uint16_t)~((uint16_t)I2C_OAR2_ENDUAL);
 +  }
 +}
 +
 +/**
 +  * @brief  Enables or disables the specified I2C general call feature.
 +  * @param  I2Cx: where x can be 1, 2 or 3 to select the I2C peripheral.
 +  * @param  NewState: new state of the I2C General call.
 +  *          This parameter can be: ENABLE or DISABLE.
 +  * @retval None
 +  */
 +void I2C_GeneralCallCmd(I2C_TypeDef* I2Cx, FunctionalState NewState)
 +{
 +  /* Check the parameters */
 +  assert_param(IS_I2C_ALL_PERIPH(I2Cx));
 +  assert_param(IS_FUNCTIONAL_STATE(NewState));
 +  if (NewState != DISABLE)
 +  {
 +    /* Enable generall call */
 +    I2Cx->CR1 |= I2C_CR1_ENGC;
 +  }
 +  else
 +  {
 +    /* Disable generall call */
 +    I2Cx->CR1 &= (uint16_t)~((uint16_t)I2C_CR1_ENGC);
 +  }
 +}
 +
 +/**
 +  * @brief  Enables or disables the specified I2C software reset.
 +  * @note   When software reset is enabled, the I2C IOs are released (this can
 +  *         be useful to recover from bus errors).  
 +  * @param  I2Cx: where x can be 1, 2 or 3 to select the I2C peripheral.
 +  * @param  NewState: new state of the I2C software reset.
 +  *          This parameter can be: ENABLE or DISABLE.
 +  * @retval None
 +  */
 +void I2C_SoftwareResetCmd(I2C_TypeDef* I2Cx, FunctionalState NewState)
 +{
 +  /* Check the parameters */
 +  assert_param(IS_I2C_ALL_PERIPH(I2Cx));
 +  assert_param(IS_FUNCTIONAL_STATE(NewState));
 +  if (NewState != DISABLE)
 +  {
 +    /* Peripheral under reset */
 +    I2Cx->CR1 |= I2C_CR1_SWRST;
 +  }
 +  else
 +  {
 +    /* Peripheral not under reset */
 +    I2Cx->CR1 &= (uint16_t)~((uint16_t)I2C_CR1_SWRST);
 +  }
 +}
 +
 +/**
 +  * @brief  Enables or disables the specified I2C Clock stretching.
 +  * @param  I2Cx: where x can be 1, 2 or 3 to select the I2C peripheral.
 +  * @param  NewState: new state of the I2Cx Clock stretching.
 +  *          This parameter can be: ENABLE or DISABLE.
 +  * @retval None
 +  */
 +void I2C_StretchClockCmd(I2C_TypeDef* I2Cx, FunctionalState NewState)
 +{
 +  /* Check the parameters */
 +  assert_param(IS_I2C_ALL_PERIPH(I2Cx));
 +  assert_param(IS_FUNCTIONAL_STATE(NewState));
 +  if (NewState == DISABLE)
 +  {
 +    /* Enable the selected I2C Clock stretching */
 +    I2Cx->CR1 |= I2C_CR1_NOSTRETCH;
 +  }
 +  else
 +  {
 +    /* Disable the selected I2C Clock stretching */
 +    I2Cx->CR1 &= (uint16_t)~((uint16_t)I2C_CR1_NOSTRETCH);
 +  }
 +}
 +
 +/**
 +  * @brief  Selects the specified I2C fast mode duty cycle.
 +  * @param  I2Cx: where x can be 1, 2 or 3 to select the I2C peripheral.
 +  * @param  I2C_DutyCycle: specifies the fast mode duty cycle.
 +  *          This parameter can be one of the following values:
 +  *            @arg I2C_DutyCycle_2: I2C fast mode Tlow/Thigh = 2
 +  *            @arg I2C_DutyCycle_16_9: I2C fast mode Tlow/Thigh = 16/9
 +  * @retval None
 +  */
 +void I2C_FastModeDutyCycleConfig(I2C_TypeDef* I2Cx, uint16_t I2C_DutyCycle)
 +{
 +  /* Check the parameters */
 +  assert_param(IS_I2C_ALL_PERIPH(I2Cx));
 +  assert_param(IS_I2C_DUTY_CYCLE(I2C_DutyCycle));
 +  if (I2C_DutyCycle != I2C_DutyCycle_16_9)
 +  {
 +    /* I2C fast mode Tlow/Thigh=2 */
 +    I2Cx->CCR &= I2C_DutyCycle_2;
 +  }
 +  else
 +  {
 +    /* I2C fast mode Tlow/Thigh=16/9 */
 +    I2Cx->CCR |= I2C_DutyCycle_16_9;
 +  }
 +}
 +
 +/**
 +  * @brief  Selects the specified I2C NACK position in master receiver mode.
 +  * @note   This function is useful in I2C Master Receiver mode when the number
 +  *         of data to be received is equal to 2. In this case, this function 
 +  *         should be called (with parameter I2C_NACKPosition_Next) before data 
 +  *         reception starts,as described in the 2-byte reception procedure 
 +  *         recommended in Reference Manual in Section: Master receiver.                
 +  * @param  I2Cx: where x can be 1, 2 or 3 to select the I2C peripheral.
 +  * @param  I2C_NACKPosition: specifies the NACK position. 
 +  *          This parameter can be one of the following values:
 +  *            @arg I2C_NACKPosition_Next: indicates that the next byte will be the last
 +  *                                        received byte.  
 +  *            @arg I2C_NACKPosition_Current: indicates that current byte is the last 
 +  *                                           received byte.
 +  *            
 +  * @note    This function configures the same bit (POS) as I2C_PECPositionConfig() 
 +  *          but is intended to be used in I2C mode while I2C_PECPositionConfig() 
 +  *          is intended to used in SMBUS mode. 
 +  *            
 +  * @retval None
 +  */
 +void I2C_NACKPositionConfig(I2C_TypeDef* I2Cx, uint16_t I2C_NACKPosition)
 +{
 +  /* Check the parameters */
 +  assert_param(IS_I2C_ALL_PERIPH(I2Cx));
 +  assert_param(IS_I2C_NACK_POSITION(I2C_NACKPosition));
 +  
 +  /* Check the input parameter */
 +  if (I2C_NACKPosition == I2C_NACKPosition_Next)
 +  {
 +    /* Next byte in shift register is the last received byte */
 +    I2Cx->CR1 |= I2C_NACKPosition_Next;
 +  }
 +  else
 +  {
 +    /* Current byte in shift register is the last received byte */
 +    I2Cx->CR1 &= I2C_NACKPosition_Current;
 +  }
 +}
 +
 +/**
 +  * @brief  Drives the SMBusAlert pin high or low for the specified I2C.
 +  * @param  I2Cx: where x can be 1, 2 or 3 to select the I2C peripheral.
 +  * @param  I2C_SMBusAlert: specifies SMBAlert pin level. 
 +  *          This parameter can be one of the following values:
 +  *            @arg I2C_SMBusAlert_Low: SMBAlert pin driven low
 +  *            @arg I2C_SMBusAlert_High: SMBAlert pin driven high
 +  * @retval None
 +  */
 +void I2C_SMBusAlertConfig(I2C_TypeDef* I2Cx, uint16_t I2C_SMBusAlert)
 +{
 +  /* Check the parameters */
 +  assert_param(IS_I2C_ALL_PERIPH(I2Cx));
 +  assert_param(IS_I2C_SMBUS_ALERT(I2C_SMBusAlert));
 +  if (I2C_SMBusAlert == I2C_SMBusAlert_Low)
 +  {
 +    /* Drive the SMBusAlert pin Low */
 +    I2Cx->CR1 |= I2C_SMBusAlert_Low;
 +  }
 +  else
 +  {
 +    /* Drive the SMBusAlert pin High  */
 +    I2Cx->CR1 &= I2C_SMBusAlert_High;
 +  }
 +}
 +
 +/**
 +  * @brief  Enables or disables the specified I2C ARP.
 +  * @param  I2Cx: where x can be 1, 2 or 3 to select the I2C peripheral.
 +  * @param  NewState: new state of the I2Cx ARP. 
 +  *          This parameter can be: ENABLE or DISABLE.
 +  * @retval None
 +  */
 +void I2C_ARPCmd(I2C_TypeDef* I2Cx, FunctionalState NewState)
 +{
 +  /* Check the parameters */
 +  assert_param(IS_I2C_ALL_PERIPH(I2Cx));
 +  assert_param(IS_FUNCTIONAL_STATE(NewState));
 +  if (NewState != DISABLE)
 +  {
 +    /* Enable the selected I2C ARP */
 +    I2Cx->CR1 |= I2C_CR1_ENARP;
 +  }
 +  else
 +  {
 +    /* Disable the selected I2C ARP */
 +    I2Cx->CR1 &= (uint16_t)~((uint16_t)I2C_CR1_ENARP);
 +  }
 +}
 +/**
 +  * @}
 +  */
 +
 +/** @defgroup I2C_Group2 Data transfers functions
 + *  @brief   Data transfers functions 
 + *
 +@verbatim   
 + ===============================================================================
 +                  ##### Data transfers functions #####
 + ===============================================================================  
 +
 +@endverbatim
 +  * @{
 +  */
 +
 +/**
 +  * @brief  Sends a data byte through the I2Cx peripheral.
 +  * @param  I2Cx: where x can be 1, 2 or 3 to select the I2C peripheral.
 +  * @param  Data: Byte to be transmitted..
 +  * @retval None
 +  */
 +void I2C_SendData(I2C_TypeDef* I2Cx, uint8_t Data)
 +{
 +  /* Check the parameters */
 +  assert_param(IS_I2C_ALL_PERIPH(I2Cx));
 +  /* Write in the DR register the data to be sent */
 +  I2Cx->DR = Data;
 +}
 +
 +/**
 +  * @brief  Returns the most recent received data by the I2Cx peripheral.
 +  * @param  I2Cx: where x can be 1, 2 or 3 to select the I2C peripheral.
 +  * @retval The value of the received data.
 +  */
 +uint8_t I2C_ReceiveData(I2C_TypeDef* I2Cx)
 +{
 +  /* Check the parameters */
 +  assert_param(IS_I2C_ALL_PERIPH(I2Cx));
 +  /* Return the data in the DR register */
 +  return (uint8_t)I2Cx->DR;
 +}
 +
 +/**
 +  * @}
 +  */
 +
 +/** @defgroup I2C_Group3 PEC management functions
 + *  @brief   PEC management functions 
 + *
 +@verbatim   
 + ===============================================================================
 +                  ##### PEC management functions #####
 + ===============================================================================  
 +
 +@endverbatim
 +  * @{
 +  */
 +
 +/**
 +  * @brief  Enables or disables the specified I2C PEC transfer.
 +  * @param  I2Cx: where x can be 1, 2 or 3 to select the I2C peripheral.
 +  * @param  NewState: new state of the I2C PEC transmission.
 +  *          This parameter can be: ENABLE or DISABLE.
 +  * @retval None
 +  */
 +void I2C_TransmitPEC(I2C_TypeDef* I2Cx, FunctionalState NewState)
 +{
 +  /* Check the parameters */
 +  assert_param(IS_I2C_ALL_PERIPH(I2Cx));
 +  assert_param(IS_FUNCTIONAL_STATE(NewState));
 +  if (NewState != DISABLE)
 +  {
 +    /* Enable the selected I2C PEC transmission */
 +    I2Cx->CR1 |= I2C_CR1_PEC;
 +  }
 +  else
 +  {
 +    /* Disable the selected I2C PEC transmission */
 +    I2Cx->CR1 &= (uint16_t)~((uint16_t)I2C_CR1_PEC);
 +  }
 +}
 +
 +/**
 +  * @brief  Selects the specified I2C PEC position.
 +  * @param  I2Cx: where x can be 1, 2 or 3 to select the I2C peripheral.
 +  * @param  I2C_PECPosition: specifies the PEC position. 
 +  *          This parameter can be one of the following values:
 +  *            @arg I2C_PECPosition_Next: indicates that the next byte is PEC
 +  *            @arg I2C_PECPosition_Current: indicates that current byte is PEC
 +  *       
 +  * @note    This function configures the same bit (POS) as I2C_NACKPositionConfig()
 +  *          but is intended to be used in SMBUS mode while I2C_NACKPositionConfig() 
 +  *          is intended to used in I2C mode.
 +  *                
 +  * @retval None
 +  */
 +void I2C_PECPositionConfig(I2C_TypeDef* I2Cx, uint16_t I2C_PECPosition)
 +{
 +  /* Check the parameters */
 +  assert_param(IS_I2C_ALL_PERIPH(I2Cx));
 +  assert_param(IS_I2C_PEC_POSITION(I2C_PECPosition));
 +  if (I2C_PECPosition == I2C_PECPosition_Next)
 +  {
 +    /* Next byte in shift register is PEC */
 +    I2Cx->CR1 |= I2C_PECPosition_Next;
 +  }
 +  else
 +  {
 +    /* Current byte in shift register is PEC */
 +    I2Cx->CR1 &= I2C_PECPosition_Current;
 +  }
 +}
 +
 +/**
 +  * @brief  Enables or disables the PEC value calculation of the transferred bytes.
 +  * @param  I2Cx: where x can be 1, 2 or 3 to select the I2C peripheral.
 +  * @param  NewState: new state of the I2Cx PEC value calculation.
 +  *          This parameter can be: ENABLE or DISABLE.
 +  * @retval None
 +  */
 +void I2C_CalculatePEC(I2C_TypeDef* I2Cx, FunctionalState NewState)
 +{
 +  /* Check the parameters */
 +  assert_param(IS_I2C_ALL_PERIPH(I2Cx));
 +  assert_param(IS_FUNCTIONAL_STATE(NewState));
 +  if (NewState != DISABLE)
 +  {
 +    /* Enable the selected I2C PEC calculation */
 +    I2Cx->CR1 |= I2C_CR1_ENPEC;
 +  }
 +  else
 +  {
 +    /* Disable the selected I2C PEC calculation */
 +    I2Cx->CR1 &= (uint16_t)~((uint16_t)I2C_CR1_ENPEC);
 +  }
 +}
 +
 +/**
 +  * @brief  Returns the PEC value for the specified I2C.
 +  * @param  I2Cx: where x can be 1, 2 or 3 to select the I2C peripheral.
 +  * @retval The PEC value.
 +  */
 +uint8_t I2C_GetPEC(I2C_TypeDef* I2Cx)
 +{
 +  /* Check the parameters */
 +  assert_param(IS_I2C_ALL_PERIPH(I2Cx));
 +  /* Return the selected I2C PEC value */
 +  return ((I2Cx->SR2) >> 8);
 +}
 +
 +/**
 +  * @}
 +  */
 +
 +/** @defgroup I2C_Group4 DMA transfers management functions
 + *  @brief   DMA transfers management functions 
 + *
 +@verbatim   
 + ===============================================================================
 +                ##### DMA transfers management functions #####
 + ===============================================================================  
 +  This section provides functions allowing to configure the I2C DMA channels 
 +  requests.
 +  
 +@endverbatim
 +  * @{
 +  */
 +
 +/**
 +  * @brief  Enables or disables the specified I2C DMA requests.
 +  * @param  I2Cx: where x can be 1, 2 or 3 to select the I2C peripheral.
 +  * @param  NewState: new state of the I2C DMA transfer.
 +  *          This parameter can be: ENABLE or DISABLE.
 +  * @retval None
 +  */
 +void I2C_DMACmd(I2C_TypeDef* I2Cx, FunctionalState NewState)
 +{
 +  /* Check the parameters */
 +  assert_param(IS_I2C_ALL_PERIPH(I2Cx));
 +  assert_param(IS_FUNCTIONAL_STATE(NewState));
 +  if (NewState != DISABLE)
 +  {
 +    /* Enable the selected I2C DMA requests */
 +    I2Cx->CR2 |= I2C_CR2_DMAEN;
 +  }
 +  else
 +  {
 +    /* Disable the selected I2C DMA requests */
 +    I2Cx->CR2 &= (uint16_t)~((uint16_t)I2C_CR2_DMAEN);
 +  }
 +}
 +
 +/**
 +  * @brief  Specifies that the next DMA transfer is the last one.
 +  * @param  I2Cx: where x can be 1, 2 or 3 to select the I2C peripheral.
 +  * @param  NewState: new state of the I2C DMA last transfer.
 +  *          This parameter can be: ENABLE or DISABLE.
 +  * @retval None
 +  */
 +void I2C_DMALastTransferCmd(I2C_TypeDef* I2Cx, FunctionalState NewState)
 +{
 +  /* Check the parameters */
 +  assert_param(IS_I2C_ALL_PERIPH(I2Cx));
 +  assert_param(IS_FUNCTIONAL_STATE(NewState));
 +  if (NewState != DISABLE)
 +  {
 +    /* Next DMA transfer is the last transfer */
 +    I2Cx->CR2 |= I2C_CR2_LAST;
 +  }
 +  else
 +  {
 +    /* Next DMA transfer is not the last transfer */
 +    I2Cx->CR2 &= (uint16_t)~((uint16_t)I2C_CR2_LAST);
 +  }
 +}
 +
 +/**
 +  * @}
 +  */
 +
 +/** @defgroup I2C_Group5 Interrupts events and flags management functions
 + *  @brief   Interrupts, events and flags management functions
 + *
 +@verbatim   
 + ===============================================================================
 +          ##### Interrupts, events and flags management functions #####
 + ===============================================================================
 +    [..]
 +    This section provides functions allowing to configure the I2C Interrupts 
 +    sources and check or clear the flags or pending bits status.
 +    The user should identify which mode will be used in his application to manage 
 +    the communication: Polling mode, Interrupt mode or DMA mode. 
 +
 +
 +                ##### I2C State Monitoring Functions #####                   
 + =============================================================================== 
 +    [..]  
 +    This I2C driver provides three different ways for I2C state monitoring
 +    depending on the application requirements and constraints:
 +         
 +   
 +     (#) Basic state monitoring (Using I2C_CheckEvent() function)
 +     
 +        It compares the status registers (SR1 and SR2) content to a given event
 +        (can be the combination of one or more flags).
 +        It returns SUCCESS if the current status includes the given flags 
 +        and returns ERROR if one or more flags are missing in the current status.
 +
 +          (++) When to use
 +             (+++) This function is suitable for most applications as well as for startup 
 +               activity since the events are fully described in the product reference 
 +               manual (RM0090).
 +             (+++) It is also suitable for users who need to define their own events.
 +
 +          (++) Limitations
 +               If an error occurs (ie. error flags are set besides to the monitored 
 +               flags), the I2C_CheckEvent() function may return SUCCESS despite 
 +               the communication hold or corrupted real state. 
 +               In this case, it is advised to use error interrupts to monitor 
 +               the error events and handle them in the interrupt IRQ handler.
 +         
 +     -@@- For error management, it is advised to use the following functions:
 +        (+@@) I2C_ITConfig() to configure and enable the error interrupts (I2C_IT_ERR).
 +        (+@@) I2Cx_ER_IRQHandler() which is called when the error interrupt occurs.
 +              Where x is the peripheral instance (I2C1, I2C2 ...)
 +        (+@@) I2C_GetFlagStatus() or I2C_GetITStatus()  to be called into the 
 +              I2Cx_ER_IRQHandler() function in order to determine which error occurred.
 +        (+@@) I2C_ClearFlag() or I2C_ClearITPendingBit() and/or I2C_SoftwareResetCmd() 
 +              and/or I2C_GenerateStop() in order to clear the error flag and source 
 +              and return to correct  communication status.
 +             
 + 
 +     (#) Advanced state monitoring (Using the function I2C_GetLastEvent())
 +
 +        Using the function I2C_GetLastEvent() which returns the image of both status 
 +        registers in a single word (uint32_t) (Status Register 2 value is shifted left 
 +        by 16 bits and concatenated to Status Register 1).
 +
 +          (++) When to use
 +             (+++) This function is suitable for the same applications above but it 
 +               allows to overcome the mentioned limitation of I2C_GetFlagStatus() 
 +               function.
 +             (+++) The returned value could be compared to events already defined in 
 +               the library (stm32f4xx_i2c.h) or to custom values defined by user.
 +               This function is suitable when multiple flags are monitored at the 
 +               same time.
 +             (+++) At the opposite of I2C_CheckEvent() function, this function allows 
 +               user to choose when an event is accepted (when all events flags are 
 +               set and no other flags are set or just when the needed flags are set 
 +               like I2C_CheckEvent() function.
 +
 +          (++) Limitations
 +             (+++) User may need to define his own events.
 +             (+++) Same remark concerning the error management is applicable for this 
 +               function if user decides to check only regular communication flags 
 +               (and ignores error flags).
 +      
 + 
 +     (#) Flag-based state monitoring (Using the function I2C_GetFlagStatus())
 +     
 +      Using the function I2C_GetFlagStatus() which simply returns the status of 
 +      one single flag (ie. I2C_FLAG_RXNE ...). 
 +
 +          (++) When to use
 +             (+++) This function could be used for specific applications or in debug 
 +               phase.
 +             (+++) It is suitable when only one flag checking is needed (most I2C 
 +               events are monitored through multiple flags).
 +          (++) Limitations: 
 +             (+++) When calling this function, the Status register is accessed. 
 +               Some flags are cleared when the status register is accessed. 
 +               So checking the status of one Flag, may clear other ones.
 +             (+++) Function may need to be called twice or more in order to monitor 
 +               one single event.
 + 
 +   For detailed description of Events, please refer to section I2C_Events in 
 +   stm32f4xx_i2c.h file.
 +       
 +@endverbatim
 +  * @{
 +  */
 +   
 +/**
 +  * @brief  Reads the specified I2C register and returns its value.
 +  * @param  I2C_Register: specifies the register to read.
 +  *          This parameter can be one of the following values:
 +  *            @arg I2C_Register_CR1:  CR1 register.
 +  *            @arg I2C_Register_CR2:   CR2 register.
 +  *            @arg I2C_Register_OAR1:  OAR1 register.
 +  *            @arg I2C_Register_OAR2:  OAR2 register.
 +  *            @arg I2C_Register_DR:    DR register.
 +  *            @arg I2C_Register_SR1:   SR1 register.
 +  *            @arg I2C_Register_SR2:   SR2 register.
 +  *            @arg I2C_Register_CCR:   CCR register.
 +  *            @arg I2C_Register_TRISE: TRISE register.
 +  * @retval The value of the read register.
 +  */
 +uint16_t I2C_ReadRegister(I2C_TypeDef* I2Cx, uint8_t I2C_Register)
 +{
 +  __IO uint32_t tmp = 0;
 +
 +  /* Check the parameters */
 +  assert_param(IS_I2C_ALL_PERIPH(I2Cx));
 +  assert_param(IS_I2C_REGISTER(I2C_Register));
 +
 +  tmp = (uint32_t) I2Cx;
 +  tmp += I2C_Register;
 +
 +  /* Return the selected register value */
 +  return (*(__IO uint16_t *) tmp);
 +}
 +
 +/**
 +  * @brief  Enables or disables the specified I2C interrupts.
 +  * @param  I2Cx: where x can be 1, 2 or 3 to select the I2C peripheral.
 +  * @param  I2C_IT: specifies the I2C interrupts sources to be enabled or disabled. 
 +  *          This parameter can be any combination of the following values:
 +  *            @arg I2C_IT_BUF: Buffer interrupt mask
 +  *            @arg I2C_IT_EVT: Event interrupt mask
 +  *            @arg I2C_IT_ERR: Error interrupt mask
 +  * @param  NewState: new state of the specified I2C interrupts.
 +  *          This parameter can be: ENABLE or DISABLE.
 +  * @retval None
 +  */
 +void I2C_ITConfig(I2C_TypeDef* I2Cx, uint16_t I2C_IT, FunctionalState NewState)
 +{
 +  /* Check the parameters */
 +  assert_param(IS_I2C_ALL_PERIPH(I2Cx));
 +  assert_param(IS_FUNCTIONAL_STATE(NewState));
 +  assert_param(IS_I2C_CONFIG_IT(I2C_IT));
 +  
 +  if (NewState != DISABLE)
 +  {
 +    /* Enable the selected I2C interrupts */
 +    I2Cx->CR2 |= I2C_IT;
 +  }
 +  else
 +  {
 +    /* Disable the selected I2C interrupts */
 +    I2Cx->CR2 &= (uint16_t)~I2C_IT;
 +  }
 +}
 +
 +/*
 + ===============================================================================
 +                          1. Basic state monitoring                    
 + ===============================================================================  
 + */
 +
 +/**
 +  * @brief  Checks whether the last I2Cx Event is equal to the one passed
 +  *         as parameter.
 +  * @param  I2Cx: where x can be 1, 2 or 3 to select the I2C peripheral.
 +  * @param  I2C_EVENT: specifies the event to be checked. 
 +  *          This parameter can be one of the following values:
 +  *            @arg I2C_EVENT_SLAVE_TRANSMITTER_ADDRESS_MATCHED: EV1
 +  *            @arg I2C_EVENT_SLAVE_RECEIVER_ADDRESS_MATCHED: EV1
 +  *            @arg I2C_EVENT_SLAVE_TRANSMITTER_SECONDADDRESS_MATCHED: EV1
 +  *            @arg I2C_EVENT_SLAVE_RECEIVER_SECONDADDRESS_MATCHED: EV1
 +  *            @arg I2C_EVENT_SLAVE_GENERALCALLADDRESS_MATCHED: EV1
 +  *            @arg I2C_EVENT_SLAVE_BYTE_RECEIVED: EV2
 +  *            @arg (I2C_EVENT_SLAVE_BYTE_RECEIVED | I2C_FLAG_DUALF): EV2
 +  *            @arg (I2C_EVENT_SLAVE_BYTE_RECEIVED | I2C_FLAG_GENCALL): EV2
 +  *            @arg I2C_EVENT_SLAVE_BYTE_TRANSMITTED: EV3
 +  *            @arg (I2C_EVENT_SLAVE_BYTE_TRANSMITTED | I2C_FLAG_DUALF): EV3
 +  *            @arg (I2C_EVENT_SLAVE_BYTE_TRANSMITTED | I2C_FLAG_GENCALL): EV3
 +  *            @arg I2C_EVENT_SLAVE_ACK_FAILURE: EV3_2
 +  *            @arg I2C_EVENT_SLAVE_STOP_DETECTED: EV4
 +  *            @arg I2C_EVENT_MASTER_MODE_SELECT: EV5
 +  *            @arg I2C_EVENT_MASTER_TRANSMITTER_MODE_SELECTED: EV6     
 +  *            @arg I2C_EVENT_MASTER_RECEIVER_MODE_SELECTED: EV6
 +  *            @arg I2C_EVENT_MASTER_BYTE_RECEIVED: EV7
 +  *            @arg I2C_EVENT_MASTER_BYTE_TRANSMITTING: EV8
 +  *            @arg I2C_EVENT_MASTER_BYTE_TRANSMITTED: EV8_2
 +  *            @arg I2C_EVENT_MASTER_MODE_ADDRESS10: EV9
 +  *     
 +  * @note   For detailed description of Events, please refer to section I2C_Events
 +  *         in stm32f4xx_i2c.h file.
 +  *    
 +  * @retval An ErrorStatus enumeration value:
 +  *           - SUCCESS: Last event is equal to the I2C_EVENT
 +  *           - ERROR: Last event is different from the I2C_EVENT
 +  */
 +ErrorStatus I2C_CheckEvent(I2C_TypeDef* I2Cx, uint32_t I2C_EVENT)
 +{
 +  uint32_t lastevent = 0;
 +  uint32_t flag1 = 0, flag2 = 0;
 +  ErrorStatus status = ERROR;
 +
 +  /* Check the parameters */
 +  assert_param(IS_I2C_ALL_PERIPH(I2Cx));
 +  assert_param(IS_I2C_EVENT(I2C_EVENT));
 +
 +  /* Read the I2Cx status register */
 +  flag1 = I2Cx->SR1;
 +  flag2 = I2Cx->SR2;
 +  flag2 = flag2 << 16;
 +
 +  /* Get the last event value from I2C status register */
 +  lastevent = (flag1 | flag2) & FLAG_MASK;
 +
 +  /* Check whether the last event contains the I2C_EVENT */
 +  if ((lastevent & I2C_EVENT) == I2C_EVENT)
 +  {
 +    /* SUCCESS: last event is equal to I2C_EVENT */
 +    status = SUCCESS;
 +  }
 +  else
 +  {
 +    /* ERROR: last event is different from I2C_EVENT */
 +    status = ERROR;
 +  }
 +  /* Return status */
 +  return status;
 +}
 +
 +/*
 + ===============================================================================
 +                          2. Advanced state monitoring                   
 + ===============================================================================  
 + */
 +
 +/**
 +  * @brief  Returns the last I2Cx Event.
 +  * @param  I2Cx: where x can be 1, 2 or 3 to select the I2C peripheral.
 +  *     
 +  * @note   For detailed description of Events, please refer to section I2C_Events
 +  *         in stm32f4xx_i2c.h file.
 +  *    
 +  * @retval The last event
 +  */
 +uint32_t I2C_GetLastEvent(I2C_TypeDef* I2Cx)
 +{
 +  uint32_t lastevent = 0;
 +  uint32_t flag1 = 0, flag2 = 0;
 +
 +  /* Check the parameters */
 +  assert_param(IS_I2C_ALL_PERIPH(I2Cx));
 +
 +  /* Read the I2Cx status register */
 +  flag1 = I2Cx->SR1;
 +  flag2 = I2Cx->SR2;
 +  flag2 = flag2 << 16;
 +
 +  /* Get the last event value from I2C status register */
 +  lastevent = (flag1 | flag2) & FLAG_MASK;
 +
 +  /* Return status */
 +  return lastevent;
 +}
 +
 +/*
 + ===============================================================================
 +                          3. Flag-based state monitoring                   
 + ===============================================================================  
 + */
 +
 +/**
 +  * @brief  Checks whether the specified I2C flag is set or not.
 +  * @param  I2Cx: where x can be 1, 2 or 3 to select the I2C peripheral.
 +  * @param  I2C_FLAG: specifies the flag to check. 
 +  *          This parameter can be one of the following values:
 +  *            @arg I2C_FLAG_DUALF: Dual flag (Slave mode)
 +  *            @arg I2C_FLAG_SMBHOST: SMBus host header (Slave mode)
 +  *            @arg I2C_FLAG_SMBDEFAULT: SMBus default header (Slave mode)
 +  *            @arg I2C_FLAG_GENCALL: General call header flag (Slave mode)
 +  *            @arg I2C_FLAG_TRA: Transmitter/Receiver flag
 +  *            @arg I2C_FLAG_BUSY: Bus busy flag
 +  *            @arg I2C_FLAG_MSL: Master/Slave flag
 +  *            @arg I2C_FLAG_SMBALERT: SMBus Alert flag
 +  *            @arg I2C_FLAG_TIMEOUT: Timeout or Tlow error flag
 +  *            @arg I2C_FLAG_PECERR: PEC error in reception flag
 +  *            @arg I2C_FLAG_OVR: Overrun/Underrun flag (Slave mode)
 +  *            @arg I2C_FLAG_AF: Acknowledge failure flag
 +  *            @arg I2C_FLAG_ARLO: Arbitration lost flag (Master mode)
 +  *            @arg I2C_FLAG_BERR: Bus error flag
 +  *            @arg I2C_FLAG_TXE: Data register empty flag (Transmitter)
 +  *            @arg I2C_FLAG_RXNE: Data register not empty (Receiver) flag
 +  *            @arg I2C_FLAG_STOPF: Stop detection flag (Slave mode)
 +  *            @arg I2C_FLAG_ADD10: 10-bit header sent flag (Master mode)
 +  *            @arg I2C_FLAG_BTF: Byte transfer finished flag
 +  *            @arg I2C_FLAG_ADDR: Address sent flag (Master mode) "ADSL"
 +  *                                Address matched flag (Slave mode)"ENDAD"
 +  *            @arg I2C_FLAG_SB: Start bit flag (Master mode)
 +  * @retval The new state of I2C_FLAG (SET or RESET).
 +  */
 +FlagStatus I2C_GetFlagStatus(I2C_TypeDef* I2Cx, uint32_t I2C_FLAG)
 +{
 +  FlagStatus bitstatus = RESET;
 +  __IO uint32_t i2creg = 0, i2cxbase = 0;
 +
 +  /* Check the parameters */
 +  assert_param(IS_I2C_ALL_PERIPH(I2Cx));
 +  assert_param(IS_I2C_GET_FLAG(I2C_FLAG));
 +
 +  /* Get the I2Cx peripheral base address */
 +  i2cxbase = (uint32_t)I2Cx;
 +  
 +  /* Read flag register index */
 +  i2creg = I2C_FLAG >> 28;
 +  
 +  /* Get bit[23:0] of the flag */
 +  I2C_FLAG &= FLAG_MASK;
 +  
 +  if(i2creg != 0)
 +  {
 +    /* Get the I2Cx SR1 register address */
 +    i2cxbase += 0x14;
 +  }
 +  else
 +  {
 +    /* Flag in I2Cx SR2 Register */
 +    I2C_FLAG = (uint32_t)(I2C_FLAG >> 16);
 +    /* Get the I2Cx SR2 register address */
 +    i2cxbase += 0x18;
 +  }
 +  
 +  if(((*(__IO uint32_t *)i2cxbase) & I2C_FLAG) != (uint32_t)RESET)
 +  {
 +    /* I2C_FLAG is set */
 +    bitstatus = SET;
 +  }
 +  else
 +  {
 +    /* I2C_FLAG is reset */
 +    bitstatus = RESET;
 +  }
 +  
 +  /* Return the I2C_FLAG status */
 +  return  bitstatus;
 +}
 +
 +/**
 +  * @brief  Clears the I2Cx's pending flags.
 +  * @param  I2Cx: where x can be 1, 2 or 3 to select the I2C peripheral.
 +  * @param  I2C_FLAG: specifies the flag to clear. 
 +  *          This parameter can be any combination of the following values:
 +  *            @arg I2C_FLAG_SMBALERT: SMBus Alert flag
 +  *            @arg I2C_FLAG_TIMEOUT: Timeout or Tlow error flag
 +  *            @arg I2C_FLAG_PECERR: PEC error in reception flag
 +  *            @arg I2C_FLAG_OVR: Overrun/Underrun flag (Slave mode)
 +  *            @arg I2C_FLAG_AF: Acknowledge failure flag
 +  *            @arg I2C_FLAG_ARLO: Arbitration lost flag (Master mode)
 +  *            @arg I2C_FLAG_BERR: Bus error flag
 +  *   
 +  * @note   STOPF (STOP detection) is cleared by software sequence: a read operation 
 +  *          to I2C_SR1 register (I2C_GetFlagStatus()) followed by a write operation 
 +  *          to I2C_CR1 register (I2C_Cmd() to re-enable the I2C peripheral).
 +  * @note   ADD10 (10-bit header sent) is cleared by software sequence: a read 
 +  *          operation to I2C_SR1 (I2C_GetFlagStatus()) followed by writing the 
 +  *          second byte of the address in DR register.
 +  * @note   BTF (Byte Transfer Finished) is cleared by software sequence: a read 
 +  *          operation to I2C_SR1 register (I2C_GetFlagStatus()) followed by a 
 +  *          read/write to I2C_DR register (I2C_SendData()).
 +  * @note   ADDR (Address sent) is cleared by software sequence: a read operation to 
 +  *          I2C_SR1 register (I2C_GetFlagStatus()) followed by a read operation to 
 +  *          I2C_SR2 register ((void)(I2Cx->SR2)).
 +  * @note   SB (Start Bit) is cleared software sequence: a read operation to I2C_SR1
 +  *          register (I2C_GetFlagStatus()) followed by a write operation to I2C_DR
 +  *          register (I2C_SendData()).
 +  *  
 +  * @retval None
 +  */
 +void I2C_ClearFlag(I2C_TypeDef* I2Cx, uint32_t I2C_FLAG)
 +{
 +  uint32_t flagpos = 0;
 +  /* Check the parameters */
 +  assert_param(IS_I2C_ALL_PERIPH(I2Cx));
 +  assert_param(IS_I2C_CLEAR_FLAG(I2C_FLAG));
 +  /* Get the I2C flag position */
 +  flagpos = I2C_FLAG & FLAG_MASK;
 +  /* Clear the selected I2C flag */
 +  I2Cx->SR1 = (uint16_t)~flagpos;
 +}
 +
 +/**
 +  * @brief  Checks whether the specified I2C interrupt has occurred or not.
 +  * @param  I2Cx: where x can be 1, 2 or 3 to select the I2C peripheral.
 +  * @param  I2C_IT: specifies the interrupt source to check. 
 +  *          This parameter can be one of the following values:
 +  *            @arg I2C_IT_SMBALERT: SMBus Alert flag
 +  *            @arg I2C_IT_TIMEOUT: Timeout or Tlow error flag
 +  *            @arg I2C_IT_PECERR: PEC error in reception flag
 +  *            @arg I2C_IT_OVR: Overrun/Underrun flag (Slave mode)
 +  *            @arg I2C_IT_AF: Acknowledge failure flag
 +  *            @arg I2C_IT_ARLO: Arbitration lost flag (Master mode)
 +  *            @arg I2C_IT_BERR: Bus error flag
 +  *            @arg I2C_IT_TXE: Data register empty flag (Transmitter)
 +  *            @arg I2C_IT_RXNE: Data register not empty (Receiver) flag
 +  *            @arg I2C_IT_STOPF: Stop detection flag (Slave mode)
 +  *            @arg I2C_IT_ADD10: 10-bit header sent flag (Master mode)
 +  *            @arg I2C_IT_BTF: Byte transfer finished flag
 +  *            @arg I2C_IT_ADDR: Address sent flag (Master mode) "ADSL"
 +  *                              Address matched flag (Slave mode)"ENDAD"
 +  *            @arg I2C_IT_SB: Start bit flag (Master mode)
 +  * @retval The new state of I2C_IT (SET or RESET).
 +  */
 +ITStatus I2C_GetITStatus(I2C_TypeDef* I2Cx, uint32_t I2C_IT)
 +{
 +  ITStatus bitstatus = RESET;
 +  uint32_t enablestatus = 0;
 +
 +  /* Check the parameters */
 +  assert_param(IS_I2C_ALL_PERIPH(I2Cx));
 +  assert_param(IS_I2C_GET_IT(I2C_IT));
 +
 +  /* Check if the interrupt source is enabled or not */
 +  enablestatus = (uint32_t)(((I2C_IT & ITEN_MASK) >> 16) & (I2Cx->CR2)) ;
 +  
 +  /* Get bit[23:0] of the flag */
 +  I2C_IT &= FLAG_MASK;
 +
 +  /* Check the status of the specified I2C flag */
 +  if (((I2Cx->SR1 & I2C_IT) != (uint32_t)RESET) && enablestatus)
 +  {
 +    /* I2C_IT is set */
 +    bitstatus = SET;
 +  }
 +  else
 +  {
 +    /* I2C_IT is reset */
 +    bitstatus = RESET;
 +  }
 +  /* Return the I2C_IT status */
 +  return  bitstatus;
 +}
 +
 +/**
 +  * @brief  Clears the I2Cx's interrupt pending bits.
 +  * @param  I2Cx: where x can be 1, 2 or 3 to select the I2C peripheral.
 +  * @param  I2C_IT: specifies the interrupt pending bit to clear. 
 +  *          This parameter can be any combination of the following values:
 +  *            @arg I2C_IT_SMBALERT: SMBus Alert interrupt
 +  *            @arg I2C_IT_TIMEOUT: Timeout or Tlow error interrupt
 +  *            @arg I2C_IT_PECERR: PEC error in reception  interrupt
 +  *            @arg I2C_IT_OVR: Overrun/Underrun interrupt (Slave mode)
 +  *            @arg I2C_IT_AF: Acknowledge failure interrupt
 +  *            @arg I2C_IT_ARLO: Arbitration lost interrupt (Master mode)
 +  *            @arg I2C_IT_BERR: Bus error interrupt
 +  * 
 +  * @note   STOPF (STOP detection) is cleared by software sequence: a read operation 
 +  *          to I2C_SR1 register (I2C_GetITStatus()) followed by a write operation to 
 +  *          I2C_CR1 register (I2C_Cmd() to re-enable the I2C peripheral).
 +  * @note   ADD10 (10-bit header sent) is cleared by software sequence: a read 
 +  *          operation to I2C_SR1 (I2C_GetITStatus()) followed by writing the second 
 +  *          byte of the address in I2C_DR register.
 +  * @note   BTF (Byte Transfer Finished) is cleared by software sequence: a read 
 +  *          operation to I2C_SR1 register (I2C_GetITStatus()) followed by a 
 +  *          read/write to I2C_DR register (I2C_SendData()).
 +  * @note   ADDR (Address sent) is cleared by software sequence: a read operation to 
 +  *          I2C_SR1 register (I2C_GetITStatus()) followed by a read operation to 
 +  *          I2C_SR2 register ((void)(I2Cx->SR2)).
 +  * @note   SB (Start Bit) is cleared by software sequence: a read operation to 
 +  *          I2C_SR1 register (I2C_GetITStatus()) followed by a write operation to 
 +  *          I2C_DR register (I2C_SendData()).
 +  * @retval None
 +  */
 +void I2C_ClearITPendingBit(I2C_TypeDef* I2Cx, uint32_t I2C_IT)
 +{
 +  uint32_t flagpos = 0;
 +  /* Check the parameters */
 +  assert_param(IS_I2C_ALL_PERIPH(I2Cx));
 +  assert_param(IS_I2C_CLEAR_IT(I2C_IT));
 +
 +  /* Get the I2C flag position */
 +  flagpos = I2C_IT & FLAG_MASK;
 +
 +  /* Clear the selected I2C flag */
 +  I2Cx->SR1 = (uint16_t)~flagpos;
 +}
 +
 +/**
 +  * @}
 +  */
 +
 +/**
 +  * @}
 +  */ 
 +
 +/**
 +  * @}
 +  */ 
 +
 +/**
 +  * @}
 +  */ 
 +
 +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/
 diff --git a/stm/lib/stm32f4xx_i2c.h b/stm/lib/stm32f4xx_i2c.h new file mode 100644 index 000000000..87ca21284 --- /dev/null +++ b/stm/lib/stm32f4xx_i2c.h @@ -0,0 +1,711 @@ +/**
 +  ******************************************************************************
 +  * @file    stm32f4xx_i2c.h
 +  * @author  MCD Application Team
 +  * @version V1.3.0
 +  * @date    08-November-2013
 +  * @brief   This file contains all the functions prototypes for the I2C firmware 
 +  *          library.
 +  ******************************************************************************
 +  * @attention
 +  *
 +  * <h2><center>© COPYRIGHT 2013 STMicroelectronics</center></h2>
 +  *
 +  * Licensed under MCD-ST Liberty SW License Agreement V2, (the "License");
 +  * You may not use this file except in compliance with the License.
 +  * You may obtain a copy of the License at:
 +  *
 +  *        http://www.st.com/software_license_agreement_liberty_v2
 +  *
 +  * Unless required by applicable law or agreed to in writing, software 
 +  * distributed under the License is distributed on an "AS IS" BASIS, 
 +  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 +  * See the License for the specific language governing permissions and
 +  * limitations under the License.
 +  *
 +  ******************************************************************************  
 +  */ 
 +
 +/* Define to prevent recursive inclusion -------------------------------------*/
 +#ifndef __STM32F4xx_I2C_H
 +#define __STM32F4xx_I2C_H
 +
 +#ifdef __cplusplus
 + extern "C" {
 +#endif
 +
 +/* Includes ------------------------------------------------------------------*/
 +#include "stm32f4xx.h"
 +
 +/** @addtogroup STM32F4xx_StdPeriph_Driver
 +  * @{
 +  */
 +
 +/** @addtogroup I2C
 +  * @{
 +  */
 +
 +/* Exported types ------------------------------------------------------------*/
 +
 +/** 
 +  * @brief  I2C Init structure definition  
 +  */
 +
 +typedef struct
 +{
 +  uint32_t I2C_ClockSpeed;          /*!< Specifies the clock frequency.
 +                                         This parameter must be set to a value lower than 400kHz */
 +
 +  uint16_t I2C_Mode;                /*!< Specifies the I2C mode.
 +                                         This parameter can be a value of @ref I2C_mode */
 +
 +  uint16_t I2C_DutyCycle;           /*!< Specifies the I2C fast mode duty cycle.
 +                                         This parameter can be a value of @ref I2C_duty_cycle_in_fast_mode */
 +
 +  uint16_t I2C_OwnAddress1;         /*!< Specifies the first device own address.
 +                                         This parameter can be a 7-bit or 10-bit address. */
 +
 +  uint16_t I2C_Ack;                 /*!< Enables or disables the acknowledgement.
 +                                         This parameter can be a value of @ref I2C_acknowledgement */
 +
 +  uint16_t I2C_AcknowledgedAddress; /*!< Specifies if 7-bit or 10-bit address is acknowledged.
 +                                         This parameter can be a value of @ref I2C_acknowledged_address */
 +}I2C_InitTypeDef;
 +
 +/* Exported constants --------------------------------------------------------*/
 +
 +
 +/** @defgroup I2C_Exported_Constants
 +  * @{
 +  */
 +
 +#define IS_I2C_ALL_PERIPH(PERIPH) (((PERIPH) == I2C1) || \
 +                                   ((PERIPH) == I2C2) || \
 +                                   ((PERIPH) == I2C3))
 +
 +/** @defgroup I2C_Digital_Filter
 +  * @{
 +  */
 +
 +#define IS_I2C_DIGITAL_FILTER(FILTER)   ((FILTER) <= 0x0000000F)
 +/**
 +  * @}
 +  */
 +
 +
 +/** @defgroup I2C_mode 
 +  * @{
 +  */
 +
 +#define I2C_Mode_I2C                    ((uint16_t)0x0000)
 +#define I2C_Mode_SMBusDevice            ((uint16_t)0x0002)  
 +#define I2C_Mode_SMBusHost              ((uint16_t)0x000A)
 +#define IS_I2C_MODE(MODE) (((MODE) == I2C_Mode_I2C) || \
 +                           ((MODE) == I2C_Mode_SMBusDevice) || \
 +                           ((MODE) == I2C_Mode_SMBusHost))
 +/**
 +  * @}
 +  */
 +
 +/** @defgroup I2C_duty_cycle_in_fast_mode 
 +  * @{
 +  */
 +
 +#define I2C_DutyCycle_16_9              ((uint16_t)0x4000) /*!< I2C fast mode Tlow/Thigh = 16/9 */
 +#define I2C_DutyCycle_2                 ((uint16_t)0xBFFF) /*!< I2C fast mode Tlow/Thigh = 2 */
 +#define IS_I2C_DUTY_CYCLE(CYCLE) (((CYCLE) == I2C_DutyCycle_16_9) || \
 +                                  ((CYCLE) == I2C_DutyCycle_2))
 +/**
 +  * @}
 +  */ 
 +
 +/** @defgroup I2C_acknowledgement
 +  * @{
 +  */
 +
 +#define I2C_Ack_Enable                  ((uint16_t)0x0400)
 +#define I2C_Ack_Disable                 ((uint16_t)0x0000)
 +#define IS_I2C_ACK_STATE(STATE) (((STATE) == I2C_Ack_Enable) || \
 +                                 ((STATE) == I2C_Ack_Disable))
 +/**
 +  * @}
 +  */
 +
 +/** @defgroup I2C_transfer_direction 
 +  * @{
 +  */
 +
 +#define  I2C_Direction_Transmitter      ((uint8_t)0x00)
 +#define  I2C_Direction_Receiver         ((uint8_t)0x01)
 +#define IS_I2C_DIRECTION(DIRECTION) (((DIRECTION) == I2C_Direction_Transmitter) || \
 +                                     ((DIRECTION) == I2C_Direction_Receiver))
 +/**
 +  * @}
 +  */
 +
 +/** @defgroup I2C_acknowledged_address 
 +  * @{
 +  */
 +
 +#define I2C_AcknowledgedAddress_7bit    ((uint16_t)0x4000)
 +#define I2C_AcknowledgedAddress_10bit   ((uint16_t)0xC000)
 +#define IS_I2C_ACKNOWLEDGE_ADDRESS(ADDRESS) (((ADDRESS) == I2C_AcknowledgedAddress_7bit) || \
 +                                             ((ADDRESS) == I2C_AcknowledgedAddress_10bit))
 +/**
 +  * @}
 +  */ 
 +
 +/** @defgroup I2C_registers 
 +  * @{
 +  */
 +
 +#define I2C_Register_CR1                ((uint8_t)0x00)
 +#define I2C_Register_CR2                ((uint8_t)0x04)
 +#define I2C_Register_OAR1               ((uint8_t)0x08)
 +#define I2C_Register_OAR2               ((uint8_t)0x0C)
 +#define I2C_Register_DR                 ((uint8_t)0x10)
 +#define I2C_Register_SR1                ((uint8_t)0x14)
 +#define I2C_Register_SR2                ((uint8_t)0x18)
 +#define I2C_Register_CCR                ((uint8_t)0x1C)
 +#define I2C_Register_TRISE              ((uint8_t)0x20)
 +#define IS_I2C_REGISTER(REGISTER) (((REGISTER) == I2C_Register_CR1) || \
 +                                   ((REGISTER) == I2C_Register_CR2) || \
 +                                   ((REGISTER) == I2C_Register_OAR1) || \
 +                                   ((REGISTER) == I2C_Register_OAR2) || \
 +                                   ((REGISTER) == I2C_Register_DR) || \
 +                                   ((REGISTER) == I2C_Register_SR1) || \
 +                                   ((REGISTER) == I2C_Register_SR2) || \
 +                                   ((REGISTER) == I2C_Register_CCR) || \
 +                                   ((REGISTER) == I2C_Register_TRISE))
 +/**
 +  * @}
 +  */
 +
 +/** @defgroup I2C_NACK_position 
 +  * @{
 +  */
 +
 +#define I2C_NACKPosition_Next           ((uint16_t)0x0800)
 +#define I2C_NACKPosition_Current        ((uint16_t)0xF7FF)
 +#define IS_I2C_NACK_POSITION(POSITION)  (((POSITION) == I2C_NACKPosition_Next) || \
 +                                         ((POSITION) == I2C_NACKPosition_Current))
 +/**
 +  * @}
 +  */ 
 +
 +/** @defgroup I2C_SMBus_alert_pin_level 
 +  * @{
 +  */
 +
 +#define I2C_SMBusAlert_Low              ((uint16_t)0x2000)
 +#define I2C_SMBusAlert_High             ((uint16_t)0xDFFF)
 +#define IS_I2C_SMBUS_ALERT(ALERT) (((ALERT) == I2C_SMBusAlert_Low) || \
 +                                   ((ALERT) == I2C_SMBusAlert_High))
 +/**
 +  * @}
 +  */
 +
 +/** @defgroup I2C_PEC_position 
 +  * @{
 +  */
 +
 +#define I2C_PECPosition_Next            ((uint16_t)0x0800)
 +#define I2C_PECPosition_Current         ((uint16_t)0xF7FF)
 +#define IS_I2C_PEC_POSITION(POSITION) (((POSITION) == I2C_PECPosition_Next) || \
 +                                       ((POSITION) == I2C_PECPosition_Current))
 +/**
 +  * @}
 +  */ 
 +
 +/** @defgroup I2C_interrupts_definition 
 +  * @{
 +  */
 +
 +#define I2C_IT_BUF                      ((uint16_t)0x0400)
 +#define I2C_IT_EVT                      ((uint16_t)0x0200)
 +#define I2C_IT_ERR                      ((uint16_t)0x0100)
 +#define IS_I2C_CONFIG_IT(IT) ((((IT) & (uint16_t)0xF8FF) == 0x00) && ((IT) != 0x00))
 +/**
 +  * @}
 +  */ 
 +
 +/** @defgroup I2C_interrupts_definition 
 +  * @{
 +  */
 +
 +#define I2C_IT_SMBALERT                 ((uint32_t)0x01008000)
 +#define I2C_IT_TIMEOUT                  ((uint32_t)0x01004000)
 +#define I2C_IT_PECERR                   ((uint32_t)0x01001000)
 +#define I2C_IT_OVR                      ((uint32_t)0x01000800)
 +#define I2C_IT_AF                       ((uint32_t)0x01000400)
 +#define I2C_IT_ARLO                     ((uint32_t)0x01000200)
 +#define I2C_IT_BERR                     ((uint32_t)0x01000100)
 +#define I2C_IT_TXE                      ((uint32_t)0x06000080)
 +#define I2C_IT_RXNE                     ((uint32_t)0x06000040)
 +#define I2C_IT_STOPF                    ((uint32_t)0x02000010)
 +#define I2C_IT_ADD10                    ((uint32_t)0x02000008)
 +#define I2C_IT_BTF                      ((uint32_t)0x02000004)
 +#define I2C_IT_ADDR                     ((uint32_t)0x02000002)
 +#define I2C_IT_SB                       ((uint32_t)0x02000001)
 +
 +#define IS_I2C_CLEAR_IT(IT) ((((IT) & (uint16_t)0x20FF) == 0x00) && ((IT) != (uint16_t)0x00))
 +
 +#define IS_I2C_GET_IT(IT) (((IT) == I2C_IT_SMBALERT) || ((IT) == I2C_IT_TIMEOUT) || \
 +                           ((IT) == I2C_IT_PECERR) || ((IT) == I2C_IT_OVR) || \
 +                           ((IT) == I2C_IT_AF) || ((IT) == I2C_IT_ARLO) || \
 +                           ((IT) == I2C_IT_BERR) || ((IT) == I2C_IT_TXE) || \
 +                           ((IT) == I2C_IT_RXNE) || ((IT) == I2C_IT_STOPF) || \
 +                           ((IT) == I2C_IT_ADD10) || ((IT) == I2C_IT_BTF) || \
 +                           ((IT) == I2C_IT_ADDR) || ((IT) == I2C_IT_SB))
 +/**
 +  * @}
 +  */
 +
 +/** @defgroup I2C_flags_definition 
 +  * @{
 +  */
 +
 +/** 
 +  * @brief  SR2 register flags  
 +  */
 +
 +#define I2C_FLAG_DUALF                  ((uint32_t)0x00800000)
 +#define I2C_FLAG_SMBHOST                ((uint32_t)0x00400000)
 +#define I2C_FLAG_SMBDEFAULT             ((uint32_t)0x00200000)
 +#define I2C_FLAG_GENCALL                ((uint32_t)0x00100000)
 +#define I2C_FLAG_TRA                    ((uint32_t)0x00040000)
 +#define I2C_FLAG_BUSY                   ((uint32_t)0x00020000)
 +#define I2C_FLAG_MSL                    ((uint32_t)0x00010000)
 +
 +/** 
 +  * @brief  SR1 register flags  
 +  */
 +
 +#define I2C_FLAG_SMBALERT               ((uint32_t)0x10008000)
 +#define I2C_FLAG_TIMEOUT                ((uint32_t)0x10004000)
 +#define I2C_FLAG_PECERR                 ((uint32_t)0x10001000)
 +#define I2C_FLAG_OVR                    ((uint32_t)0x10000800)
 +#define I2C_FLAG_AF                     ((uint32_t)0x10000400)
 +#define I2C_FLAG_ARLO                   ((uint32_t)0x10000200)
 +#define I2C_FLAG_BERR                   ((uint32_t)0x10000100)
 +#define I2C_FLAG_TXE                    ((uint32_t)0x10000080)
 +#define I2C_FLAG_RXNE                   ((uint32_t)0x10000040)
 +#define I2C_FLAG_STOPF                  ((uint32_t)0x10000010)
 +#define I2C_FLAG_ADD10                  ((uint32_t)0x10000008)
 +#define I2C_FLAG_BTF                    ((uint32_t)0x10000004)
 +#define I2C_FLAG_ADDR                   ((uint32_t)0x10000002)
 +#define I2C_FLAG_SB                     ((uint32_t)0x10000001)
 +
 +#define IS_I2C_CLEAR_FLAG(FLAG) ((((FLAG) & (uint16_t)0x20FF) == 0x00) && ((FLAG) != (uint16_t)0x00))
 +
 +#define IS_I2C_GET_FLAG(FLAG) (((FLAG) == I2C_FLAG_DUALF) || ((FLAG) == I2C_FLAG_SMBHOST) || \
 +                               ((FLAG) == I2C_FLAG_SMBDEFAULT) || ((FLAG) == I2C_FLAG_GENCALL) || \
 +                               ((FLAG) == I2C_FLAG_TRA) || ((FLAG) == I2C_FLAG_BUSY) || \
 +                               ((FLAG) == I2C_FLAG_MSL) || ((FLAG) == I2C_FLAG_SMBALERT) || \
 +                               ((FLAG) == I2C_FLAG_TIMEOUT) || ((FLAG) == I2C_FLAG_PECERR) || \
 +                               ((FLAG) == I2C_FLAG_OVR) || ((FLAG) == I2C_FLAG_AF) || \
 +                               ((FLAG) == I2C_FLAG_ARLO) || ((FLAG) == I2C_FLAG_BERR) || \
 +                               ((FLAG) == I2C_FLAG_TXE) || ((FLAG) == I2C_FLAG_RXNE) || \
 +                               ((FLAG) == I2C_FLAG_STOPF) || ((FLAG) == I2C_FLAG_ADD10) || \
 +                               ((FLAG) == I2C_FLAG_BTF) || ((FLAG) == I2C_FLAG_ADDR) || \
 +                               ((FLAG) == I2C_FLAG_SB))
 +/**
 +  * @}
 +  */
 +
 +/** @defgroup I2C_Events 
 +  * @{
 +  */
 +
 +/**
 + ===============================================================================
 +               I2C Master Events (Events grouped in order of communication)
 + ===============================================================================
 + */
 +
 +/** 
 +  * @brief  Communication start
 +  * 
 +  * After sending the START condition (I2C_GenerateSTART() function) the master 
 +  * has to wait for this event. It means that the Start condition has been correctly 
 +  * released on the I2C bus (the bus is free, no other devices is communicating).
 +  * 
 +  */
 +/* --EV5 */
 +#define  I2C_EVENT_MASTER_MODE_SELECT                      ((uint32_t)0x00030001)  /* BUSY, MSL and SB flag */
 +
 +/** 
 +  * @brief  Address Acknowledge
 +  * 
 +  * After checking on EV5 (start condition correctly released on the bus), the 
 +  * master sends the address of the slave(s) with which it will communicate 
 +  * (I2C_Send7bitAddress() function, it also determines the direction of the communication: 
 +  * Master transmitter or Receiver). Then the master has to wait that a slave acknowledges 
 +  * his address. If an acknowledge is sent on the bus, one of the following events will 
 +  * be set:
 +  * 
 +  *  1) In case of Master Receiver (7-bit addressing): the I2C_EVENT_MASTER_RECEIVER_MODE_SELECTED 
 +  *     event is set.
 +  *  
 +  *  2) In case of Master Transmitter (7-bit addressing): the I2C_EVENT_MASTER_TRANSMITTER_MODE_SELECTED 
 +  *     is set
 +  *  
 +  *  3) In case of 10-Bit addressing mode, the master (just after generating the START 
 +  *  and checking on EV5) has to send the header of 10-bit addressing mode (I2C_SendData() 
 +  *  function). Then master should wait on EV9. It means that the 10-bit addressing 
 +  *  header has been correctly sent on the bus. Then master should send the second part of 
 +  *  the 10-bit address (LSB) using the function I2C_Send7bitAddress(). Then master 
 +  *  should wait for event EV6. 
 +  *     
 +  */
 +
 +/* --EV6 */
 +#define  I2C_EVENT_MASTER_TRANSMITTER_MODE_SELECTED        ((uint32_t)0x00070082)  /* BUSY, MSL, ADDR, TXE and TRA flags */
 +#define  I2C_EVENT_MASTER_RECEIVER_MODE_SELECTED           ((uint32_t)0x00030002)  /* BUSY, MSL and ADDR flags */
 +/* --EV9 */
 +#define  I2C_EVENT_MASTER_MODE_ADDRESS10                   ((uint32_t)0x00030008)  /* BUSY, MSL and ADD10 flags */
 +
 +/** 
 +  * @brief Communication events
 +  * 
 +  * If a communication is established (START condition generated and slave address 
 +  * acknowledged) then the master has to check on one of the following events for 
 +  * communication procedures:
 +  *  
 +  * 1) Master Receiver mode: The master has to wait on the event EV7 then to read 
 +  *    the data received from the slave (I2C_ReceiveData() function).
 +  * 
 +  * 2) Master Transmitter mode: The master has to send data (I2C_SendData() 
 +  *    function) then to wait on event EV8 or EV8_2.
 +  *    These two events are similar: 
 +  *     - EV8 means that the data has been written in the data register and is 
 +  *       being shifted out.
 +  *     - EV8_2 means that the data has been physically shifted out and output 
 +  *       on the bus.
 +  *     In most cases, using EV8 is sufficient for the application.
 +  *     Using EV8_2 leads to a slower communication but ensure more reliable test.
 +  *     EV8_2 is also more suitable than EV8 for testing on the last data transmission 
 +  *     (before Stop condition generation).
 +  *     
 +  *  @note In case the  user software does not guarantee that this event EV7 is 
 +  *        managed before the current byte end of transfer, then user may check on EV7 
 +  *        and BTF flag at the same time (ie. (I2C_EVENT_MASTER_BYTE_RECEIVED | I2C_FLAG_BTF)).
 +  *        In this case the communication may be slower.
 +  * 
 +  */
 +
 +/* Master RECEIVER mode -----------------------------*/ 
 +/* --EV7 */
 +#define  I2C_EVENT_MASTER_BYTE_RECEIVED                    ((uint32_t)0x00030040)  /* BUSY, MSL and RXNE flags */
 +
 +/* Master TRANSMITTER mode --------------------------*/
 +/* --EV8 */
 +#define I2C_EVENT_MASTER_BYTE_TRANSMITTING                 ((uint32_t)0x00070080) /* TRA, BUSY, MSL, TXE flags */
 +/* --EV8_2 */
 +#define  I2C_EVENT_MASTER_BYTE_TRANSMITTED                 ((uint32_t)0x00070084)  /* TRA, BUSY, MSL, TXE and BTF flags */
 +
 +
 +/**
 + ===============================================================================
 +               I2C Slave Events (Events grouped in order of communication)
 + ===============================================================================
 + */
 +
 +
 +/** 
 +  * @brief  Communication start events
 +  * 
 +  * Wait on one of these events at the start of the communication. It means that 
 +  * the I2C peripheral detected a Start condition on the bus (generated by master 
 +  * device) followed by the peripheral address. The peripheral generates an ACK 
 +  * condition on the bus (if the acknowledge feature is enabled through function 
 +  * I2C_AcknowledgeConfig()) and the events listed above are set :
 +  *  
 +  * 1) In normal case (only one address managed by the slave), when the address 
 +  *   sent by the master matches the own address of the peripheral (configured by 
 +  *   I2C_OwnAddress1 field) the I2C_EVENT_SLAVE_XXX_ADDRESS_MATCHED event is set 
 +  *   (where XXX could be TRANSMITTER or RECEIVER).
 +  *    
 +  * 2) In case the address sent by the master matches the second address of the 
 +  *   peripheral (configured by the function I2C_OwnAddress2Config() and enabled 
 +  *   by the function I2C_DualAddressCmd()) the events I2C_EVENT_SLAVE_XXX_SECONDADDRESS_MATCHED 
 +  *   (where XXX could be TRANSMITTER or RECEIVER) are set.
 +  *   
 +  * 3) In case the address sent by the master is General Call (address 0x00) and 
 +  *   if the General Call is enabled for the peripheral (using function I2C_GeneralCallCmd()) 
 +  *   the following event is set I2C_EVENT_SLAVE_GENERALCALLADDRESS_MATCHED.   
 +  * 
 +  */
 +
 +/* --EV1  (all the events below are variants of EV1) */   
 +/* 1) Case of One Single Address managed by the slave */
 +#define  I2C_EVENT_SLAVE_RECEIVER_ADDRESS_MATCHED          ((uint32_t)0x00020002) /* BUSY and ADDR flags */
 +#define  I2C_EVENT_SLAVE_TRANSMITTER_ADDRESS_MATCHED       ((uint32_t)0x00060082) /* TRA, BUSY, TXE and ADDR flags */
 +
 +/* 2) Case of Dual address managed by the slave */
 +#define  I2C_EVENT_SLAVE_RECEIVER_SECONDADDRESS_MATCHED    ((uint32_t)0x00820000)  /* DUALF and BUSY flags */
 +#define  I2C_EVENT_SLAVE_TRANSMITTER_SECONDADDRESS_MATCHED ((uint32_t)0x00860080)  /* DUALF, TRA, BUSY and TXE flags */
 +
 +/* 3) Case of General Call enabled for the slave */
 +#define  I2C_EVENT_SLAVE_GENERALCALLADDRESS_MATCHED        ((uint32_t)0x00120000)  /* GENCALL and BUSY flags */
 +
 +/** 
 +  * @brief  Communication events
 +  * 
 +  * Wait on one of these events when EV1 has already been checked and: 
 +  * 
 +  * - Slave RECEIVER mode:
 +  *     - EV2: When the application is expecting a data byte to be received. 
 +  *     - EV4: When the application is expecting the end of the communication: master 
 +  *       sends a stop condition and data transmission is stopped.
 +  *    
 +  * - Slave Transmitter mode:
 +  *    - EV3: When a byte has been transmitted by the slave and the application is expecting 
 +  *      the end of the byte transmission. The two events I2C_EVENT_SLAVE_BYTE_TRANSMITTED and
 +  *      I2C_EVENT_SLAVE_BYTE_TRANSMITTING are similar. The second one can optionally be 
 +  *      used when the user software doesn't guarantee the EV3 is managed before the
 +  *      current byte end of transfer.
 +  *    - EV3_2: When the master sends a NACK in order to tell slave that data transmission 
 +  *      shall end (before sending the STOP condition). In this case slave has to stop sending 
 +  *      data bytes and expect a Stop condition on the bus.
 +  *      
 +  *  @note In case the  user software does not guarantee that the event EV2 is 
 +  *        managed before the current byte end of transfer, then user may check on EV2 
 +  *        and BTF flag at the same time (ie. (I2C_EVENT_SLAVE_BYTE_RECEIVED | I2C_FLAG_BTF)).
 +  *        In this case the communication may be slower.
 +  *
 +  */
 +
 +/* Slave RECEIVER mode --------------------------*/ 
 +/* --EV2 */
 +#define  I2C_EVENT_SLAVE_BYTE_RECEIVED                     ((uint32_t)0x00020040)  /* BUSY and RXNE flags */
 +/* --EV4  */
 +#define  I2C_EVENT_SLAVE_STOP_DETECTED                     ((uint32_t)0x00000010)  /* STOPF flag */
 +
 +/* Slave TRANSMITTER mode -----------------------*/
 +/* --EV3 */
 +#define  I2C_EVENT_SLAVE_BYTE_TRANSMITTED                  ((uint32_t)0x00060084)  /* TRA, BUSY, TXE and BTF flags */
 +#define  I2C_EVENT_SLAVE_BYTE_TRANSMITTING                 ((uint32_t)0x00060080)  /* TRA, BUSY and TXE flags */
 +/* --EV3_2 */
 +#define  I2C_EVENT_SLAVE_ACK_FAILURE                       ((uint32_t)0x00000400)  /* AF flag */
 +
 +/*
 + ===============================================================================
 +                          End of Events Description
 + ===============================================================================
 + */
 +
 +#define IS_I2C_EVENT(EVENT) (((EVENT) == I2C_EVENT_SLAVE_TRANSMITTER_ADDRESS_MATCHED) || \
 +                             ((EVENT) == I2C_EVENT_SLAVE_RECEIVER_ADDRESS_MATCHED) || \
 +                             ((EVENT) == I2C_EVENT_SLAVE_TRANSMITTER_SECONDADDRESS_MATCHED) || \
 +                             ((EVENT) == I2C_EVENT_SLAVE_RECEIVER_SECONDADDRESS_MATCHED) || \
 +                             ((EVENT) == I2C_EVENT_SLAVE_GENERALCALLADDRESS_MATCHED) || \
 +                             ((EVENT) == I2C_EVENT_SLAVE_BYTE_RECEIVED) || \
 +                             ((EVENT) == (I2C_EVENT_SLAVE_BYTE_RECEIVED | I2C_FLAG_DUALF)) || \
 +                             ((EVENT) == (I2C_EVENT_SLAVE_BYTE_RECEIVED | I2C_FLAG_GENCALL)) || \
 +                             ((EVENT) == I2C_EVENT_SLAVE_BYTE_TRANSMITTED) || \
 +                             ((EVENT) == (I2C_EVENT_SLAVE_BYTE_TRANSMITTED | I2C_FLAG_DUALF)) || \
 +                             ((EVENT) == (I2C_EVENT_SLAVE_BYTE_TRANSMITTED | I2C_FLAG_GENCALL)) || \
 +                             ((EVENT) == I2C_EVENT_SLAVE_STOP_DETECTED) || \
 +                             ((EVENT) == I2C_EVENT_MASTER_MODE_SELECT) || \
 +                             ((EVENT) == I2C_EVENT_MASTER_TRANSMITTER_MODE_SELECTED) || \
 +                             ((EVENT) == I2C_EVENT_MASTER_RECEIVER_MODE_SELECTED) || \
 +                             ((EVENT) == I2C_EVENT_MASTER_BYTE_RECEIVED) || \
 +                             ((EVENT) == I2C_EVENT_MASTER_BYTE_TRANSMITTED) || \
 +                             ((EVENT) == I2C_EVENT_MASTER_BYTE_TRANSMITTING) || \
 +                             ((EVENT) == I2C_EVENT_MASTER_MODE_ADDRESS10) || \
 +                             ((EVENT) == I2C_EVENT_SLAVE_ACK_FAILURE))
 +/**
 +  * @}
 +  */
 +
 +/** @defgroup I2C_own_address1 
 +  * @{
 +  */
 +
 +#define IS_I2C_OWN_ADDRESS1(ADDRESS1) ((ADDRESS1) <= 0x3FF)
 +/**
 +  * @}
 +  */
 +
 +/** @defgroup I2C_clock_speed 
 +  * @{
 +  */
 +
 +#define IS_I2C_CLOCK_SPEED(SPEED) (((SPEED) >= 0x1) && ((SPEED) <= 400000))
 +/**
 +  * @}
 +  */
 +
 +/**
 +  * @}
 +  */
 +
 +/* Exported macro ------------------------------------------------------------*/
 +/* Exported functions --------------------------------------------------------*/ 
 +
 +/*  Function used to set the I2C configuration to the default reset state *****/
 +void I2C_DeInit(I2C_TypeDef* I2Cx);
 +
 +/* Initialization and Configuration functions *********************************/
 +void I2C_Init(I2C_TypeDef* I2Cx, I2C_InitTypeDef* I2C_InitStruct);
 +void I2C_StructInit(I2C_InitTypeDef* I2C_InitStruct);
 +void I2C_Cmd(I2C_TypeDef* I2Cx, FunctionalState NewState);
 +void I2C_DigitalFilterConfig(I2C_TypeDef* I2Cx, uint16_t I2C_DigitalFilter);
 +void I2C_AnalogFilterCmd(I2C_TypeDef* I2Cx, FunctionalState NewState);
 +void I2C_GenerateSTART(I2C_TypeDef* I2Cx, FunctionalState NewState);
 +void I2C_GenerateSTOP(I2C_TypeDef* I2Cx, FunctionalState NewState);
 +void I2C_Send7bitAddress(I2C_TypeDef* I2Cx, uint8_t Address, uint8_t I2C_Direction);
 +void I2C_AcknowledgeConfig(I2C_TypeDef* I2Cx, FunctionalState NewState);
 +void I2C_OwnAddress2Config(I2C_TypeDef* I2Cx, uint8_t Address);
 +void I2C_DualAddressCmd(I2C_TypeDef* I2Cx, FunctionalState NewState);
 +void I2C_GeneralCallCmd(I2C_TypeDef* I2Cx, FunctionalState NewState);
 +void I2C_SoftwareResetCmd(I2C_TypeDef* I2Cx, FunctionalState NewState);
 +void I2C_StretchClockCmd(I2C_TypeDef* I2Cx, FunctionalState NewState);
 +void I2C_FastModeDutyCycleConfig(I2C_TypeDef* I2Cx, uint16_t I2C_DutyCycle);
 +void I2C_NACKPositionConfig(I2C_TypeDef* I2Cx, uint16_t I2C_NACKPosition);
 +void I2C_SMBusAlertConfig(I2C_TypeDef* I2Cx, uint16_t I2C_SMBusAlert);
 +void I2C_ARPCmd(I2C_TypeDef* I2Cx, FunctionalState NewState);
 +
 +/* Data transfers functions ***************************************************/ 
 +void I2C_SendData(I2C_TypeDef* I2Cx, uint8_t Data);
 +uint8_t I2C_ReceiveData(I2C_TypeDef* I2Cx);
 +
 +/* PEC management functions ***************************************************/ 
 +void I2C_TransmitPEC(I2C_TypeDef* I2Cx, FunctionalState NewState);
 +void I2C_PECPositionConfig(I2C_TypeDef* I2Cx, uint16_t I2C_PECPosition);
 +void I2C_CalculatePEC(I2C_TypeDef* I2Cx, FunctionalState NewState);
 +uint8_t I2C_GetPEC(I2C_TypeDef* I2Cx);
 +
 +/* DMA transfers management functions *****************************************/
 +void I2C_DMACmd(I2C_TypeDef* I2Cx, FunctionalState NewState);
 +void I2C_DMALastTransferCmd(I2C_TypeDef* I2Cx, FunctionalState NewState);
 +
 +/* Interrupts, events and flags management functions **************************/
 +uint16_t I2C_ReadRegister(I2C_TypeDef* I2Cx, uint8_t I2C_Register);
 +void I2C_ITConfig(I2C_TypeDef* I2Cx, uint16_t I2C_IT, FunctionalState NewState);
 +
 +/* 
 + ===============================================================================
 +                          I2C State Monitoring Functions
 + ===============================================================================
 +  This I2C driver provides three different ways for I2C state monitoring
 +  depending on the application requirements and constraints:
 +         
 +   
 +     1. Basic state monitoring (Using I2C_CheckEvent() function)
 +     -----------------------------------------------------------
 +        It compares the status registers (SR1 and SR2) content to a given event
 +        (can be the combination of one or more flags).
 +        It returns SUCCESS if the current status includes the given flags 
 +        and returns ERROR if one or more flags are missing in the current status.
 +
 +          - When to use
 +             - This function is suitable for most applications as well as for startup 
 +               activity since the events are fully described in the product reference 
 +               manual (RM0090).
 +             - It is also suitable for users who need to define their own events.
 +
 +          - Limitations
 +             - If an error occurs (ie. error flags are set besides to the monitored 
 +               flags), the I2C_CheckEvent() function may return SUCCESS despite 
 +               the communication hold or corrupted real state. 
 +               In this case, it is advised to use error interrupts to monitor 
 +               the error events and handle them in the interrupt IRQ handler.
 +         
 +     Note 
 +         For error management, it is advised to use the following functions:
 +           - I2C_ITConfig() to configure and enable the error interrupts (I2C_IT_ERR).
 +           - I2Cx_ER_IRQHandler() which is called when the error interrupt occurs.
 +             Where x is the peripheral instance (I2C1, I2C2 ...)
 +           - I2C_GetFlagStatus() or I2C_GetITStatus()  to be called into the 
 +             I2Cx_ER_IRQHandler() function in order to determine which error occurred.
 +           - I2C_ClearFlag() or I2C_ClearITPendingBit() and/or I2C_SoftwareResetCmd() 
 +             and/or I2C_GenerateStop() in order to clear the error flag and source 
 +             and return to correct  communication status.
 +             
 + 
 +     2. Advanced state monitoring (Using the function I2C_GetLastEvent())
 +     -------------------------------------------------------------------- 
 +        Using the function I2C_GetLastEvent() which returns the image of both status 
 +        registers in a single word (uint32_t) (Status Register 2 value is shifted left 
 +        by 16 bits and concatenated to Status Register 1).
 +
 +          - When to use
 +             - This function is suitable for the same applications above but it 
 +               allows to overcome the mentioned limitation of I2C_GetFlagStatus() 
 +               function.
 +             - The returned value could be compared to events already defined in 
 +               this file or to custom values defined by user.
 +               This function is suitable when multiple flags are monitored at the 
 +               same time.
 +             - At the opposite of I2C_CheckEvent() function, this function allows 
 +               user to choose when an event is accepted (when all events flags are 
 +               set and no other flags are set or just when the needed flags are set 
 +               like I2C_CheckEvent() function.
 +
 +          - Limitations
 +             - User may need to define his own events.
 +             - Same remark concerning the error management is applicable for this 
 +               function if user decides to check only regular communication flags 
 +               (and ignores error flags).
 +      
 + 
 +     3. Flag-based state monitoring (Using the function I2C_GetFlagStatus())
 +     -----------------------------------------------------------------------
 +     
 +      Using the function I2C_GetFlagStatus() which simply returns the status of 
 +      one single flag (ie. I2C_FLAG_RXNE ...). 
 +
 +          - When to use
 +             - This function could be used for specific applications or in debug 
 +               phase.
 +             - It is suitable when only one flag checking is needed (most I2C 
 +               events are monitored through multiple flags).
 +          - Limitations: 
 +             - When calling this function, the Status register is accessed. 
 +               Some flags are cleared when the status register is accessed. 
 +               So checking the status of one Flag, may clear other ones.
 +             - Function may need to be called twice or more in order to monitor 
 +               one single event.           
 + */
 +
 +/*
 + ===============================================================================
 +                          1. Basic state monitoring
 + ===============================================================================
 + */
 +ErrorStatus I2C_CheckEvent(I2C_TypeDef* I2Cx, uint32_t I2C_EVENT);
 +/*
 + ===============================================================================
 +                          2. Advanced state monitoring
 + ===============================================================================
 + */
 +uint32_t I2C_GetLastEvent(I2C_TypeDef* I2Cx);
 +/*
 + ===============================================================================
 +                          3. Flag-based state monitoring
 + ===============================================================================
 + */
 +FlagStatus I2C_GetFlagStatus(I2C_TypeDef* I2Cx, uint32_t I2C_FLAG);
 +
 +
 +void I2C_ClearFlag(I2C_TypeDef* I2Cx, uint32_t I2C_FLAG);
 +ITStatus I2C_GetITStatus(I2C_TypeDef* I2Cx, uint32_t I2C_IT);
 +void I2C_ClearITPendingBit(I2C_TypeDef* I2Cx, uint32_t I2C_IT);
 +
 +#ifdef __cplusplus
 +}
 +#endif
 +
 +#endif /*__STM32F4xx_I2C_H */
 +
 +/**
 +  * @}
 +  */ 
 +
 +/**
 +  * @}
 +  */ 
 +
 +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/
 diff --git a/stm/lib/stm32f4xx_pwr.c b/stm/lib/stm32f4xx_pwr.c index 322ecfb8e..61b8515e1 100644 --- a/stm/lib/stm32f4xx_pwr.c +++ b/stm/lib/stm32f4xx_pwr.c @@ -2,8 +2,8 @@    ******************************************************************************
    * @file    stm32f4xx_pwr.c
    * @author  MCD Application Team
 -  * @version V1.1.0
 -  * @date    11-January-2013
 +  * @version V1.3.0
 +  * @date    08-November-2013
    * @brief   This file provides firmware functions to manage the following 
    *          functionalities of the Power Controller (PWR) peripheral:           
    *           + Backup Domain Access
 @@ -35,7 +35,6 @@    */ 
  /* Includes ------------------------------------------------------------------*/
 -#include "stm32f4xx_conf.h"
  #include "stm32f4xx_pwr.h"
  #include "stm32f4xx_rcc.h"
 @@ -72,6 +71,13 @@  #define PMODE_BitNumber           0x0E
  #define CR_PMODE_BB               (PERIPH_BB_BASE + (CR_OFFSET * 32) + (PMODE_BitNumber * 4))
 +/* Alias word address of ODEN bit */
 +#define ODEN_BitNumber           0x10
 +#define CR_ODEN_BB               (PERIPH_BB_BASE + (CR_OFFSET * 32) + (ODEN_BitNumber * 4))
 +
 +/* Alias word address of ODSWEN bit */
 +#define ODSWEN_BitNumber         0x11
 +#define CR_ODSWEN_BB             (PERIPH_BB_BASE + (CR_OFFSET * 32) + (ODSWEN_BitNumber * 4))
  /* --- CSR Register ---*/
 @@ -87,7 +93,7 @@  /* ------------------ PWR registers bit mask ------------------------ */
  /* CR register bit mask */
 -#define CR_DS_MASK               ((uint32_t)0xFFFFFFFC)
 +#define CR_DS_MASK               ((uint32_t)0xFFFFF3FC)
  #define CR_PLS_MASK              ((uint32_t)0xFFFFFF1F)
  #define CR_VOS_MASK              ((uint32_t)0xFFFF3FFF)
 @@ -284,20 +290,56 @@ void PWR_WakeUpPinCmd(FunctionalState NewState)            key, from being accessed. The backup SRAM can be erased only through 
            the Flash interface when a protection level change from level 1 to 
            level 0 is requested. 
 -      -@- Refer to the description of Read protection (RDP) in the Flash 
 -          programming manual.
 +      -@- Refer to the description of Read protection (RDP) in the reference manual.
        (+) The main internal regulator can be configured to have a tradeoff between 
            performance and power consumption when the device does not operate at 
 -          the maximum frequency. This is done through PWR_MainRegulatorModeConfig() 
 -          function which configure VOS bit in PWR_CR register: 
 +          the maximum frequency. 
 +      (+) For STM32F405xx/407xx and STM32F415xx/417xx  Devices, the regulator can be     
 +          configured on the fly through PWR_MainRegulatorModeConfig() function which  
 +          configure VOS bit in PWR_CR register:
          (++) When this bit is set (Regulator voltage output Scale 1 mode selected) 
               the System frequency can go up to 168 MHz. 
          (++) When this bit is reset (Regulator voltage output Scale 2 mode selected) 
               the System frequency can go up to 144 MHz.
 -              
 +             
 +       (+) For STM32F42xxx/43xxx Devices, the regulator can be configured through    
 +           PWR_MainRegulatorModeConfig() function which configure VOS[1:0] bits in
 +           PWR_CR register:  
 +           which configure VOS[1:0] bits in PWR_CR register: 
 +        (++) When VOS[1:0] = 11 (Regulator voltage output Scale 1 mode selected) 
 +             the System frequency can go up to 168 MHz. 
 +        (++) When VOS[1:0] = 10 (Regulator voltage output Scale 2 mode selected) 
 +             the System frequency can go up to 144 MHz.  
 +        (++) When VOS[1:0] = 01 (Regulator voltage output Scale 3 mode selected) 
 +             the System frequency can go up to 120 MHz. 
 +                          
 +       (+) For STM32F42xxx/43xxx Devices, the scale can be modified only when the PLL 
 +           is OFF and the HSI or HSE clock source is selected as system clock. 
 +           The new value programmed is active only when the PLL is ON.
 +           When the PLL is OFF, the voltage scale 3 is automatically selected. 
          Refer to the datasheets for more details.
 -           
 +        
 +       (+) For STM32F42xxx/43xxx Devices, in Run mode: the main regulator has
 +           2 operating modes available:
 +        (++) Normal mode: The CPU and core logic operate at maximum frequency at a given 
 +             voltage scaling (scale 1, scale 2 or scale 3)
 +        (++) Over-drive mode: This mode allows the CPU and the core logic to operate at a 
 +            higher frequency than the normal mode for a given voltage scaling (scale 1,  
 +            scale 2 or scale 3). This mode is enabled through PWR_OverDriveCmd() function and
 +            PWR_OverDriveSWCmd() function, to enter or exit from Over-drive mode please follow 
 +            the sequence described in Reference manual.
 +             
 +       (+) For STM32F42xxx/43xxx Devices, in Stop mode: the main regulator or low power regulator 
 +           supplies a low power voltage to the 1.2V domain, thus preserving the content of registers 
 +           and internal SRAM. 2 operating modes are available:
 +         (++) Normal mode: the 1.2V domain is preserved in nominal leakage mode. This mode is only 
 +              available when the main regulator or the low power regulator is used in Scale 3 or 
 +              low voltage mode.
 +         (++) Under-drive mode: the 1.2V domain is preserved in reduced leakage mode. This mode is only
 +              available when the main regulator or the low power regulator is in low voltage mode.
 +              This mode is enabled through PWR_UnderDriveCmd() function.
 +            
  @endverbatim
    * @{
    */
 @@ -327,12 +369,12 @@ void PWR_BackupRegulatorCmd(FunctionalState NewState)    *            @arg PWR_Regulator_Voltage_Scale2: Regulator voltage output Scale 2 mode, 
    *                                                System frequency up to 144 MHz.    
    *            @arg PWR_Regulator_Voltage_Scale3: Regulator voltage output Scale 3 mode, 
 -  *                                                System frequency up to 120 MHz
 +  *                                                System frequency up to 120 MHz (only for STM32F42xxx/43xxx devices)
    * @retval None
    */
  void PWR_MainRegulatorModeConfig(uint32_t PWR_Regulator_Voltage)
  {
 -	uint32_t tmpreg = 0;
 +  uint32_t tmpreg = 0;
    /* Check the parameters */
    assert_param(IS_PWR_REGULATOR_VOLTAGE(PWR_Regulator_Voltage));
 @@ -350,6 +392,84 @@ void PWR_MainRegulatorModeConfig(uint32_t PWR_Regulator_Voltage)  }
  /**
 +  * @brief  Enables or disables the Over-Drive.
 +  * 
 +  * @note   This function can be used only for STM32F42xxx/STM3243xxx devices.
 +  *         This mode allows the CPU and the core logic to operate at a higher frequency
 +  *         than the normal mode for a given voltage scaling (scale 1, scale 2 or scale 3).   
 +  * 
 +  * @note   It is recommended to enter or exit Over-drive mode when the application is not running 
 +  *          critical tasks and when the system clock source is either HSI or HSE. 
 +  *          During the Over-drive switch activation, no peripheral clocks should be enabled.   
 +  *          The peripheral clocks must be enabled once the Over-drive mode is activated.
 +  *            
 +  * @param  NewState: new state of the Over Drive mode.
 +  *          This parameter can be: ENABLE or DISABLE.
 +  * @retval None
 +  */
 +void PWR_OverDriveCmd(FunctionalState NewState)
 +{
 +  /* Check the parameters */
 +  assert_param(IS_FUNCTIONAL_STATE(NewState));
 +  
 +  /* Set/Reset the ODEN bit to enable/disable the Over Drive mode */
 +  *(__IO uint32_t *) CR_ODEN_BB = (uint32_t)NewState;
 +}
 +
 +/**
 +  * @brief  Enables or disables the Over-Drive switching.
 +  * 
 +  * @note   This function can be used only for STM32F42xxx/STM3243xxx devices. 
 +  *       
 +  * @param  NewState: new state of the Over Drive switching mode.
 +  *          This parameter can be: ENABLE or DISABLE.
 +  * @retval None
 +  */
 +void PWR_OverDriveSWCmd(FunctionalState NewState)
 +{
 +  /* Check the parameters */
 +  assert_param(IS_FUNCTIONAL_STATE(NewState));
 +
 +  /* Set/Reset the ODSWEN bit to enable/disable the Over Drive switching mode */
 +  *(__IO uint32_t *) CR_ODSWEN_BB = (uint32_t)NewState;
 +}
 +
 +/**
 +  * @brief   Enables or disables the Under-Drive mode.
 +  * 
 +  * @note   This function can be used only for STM32F42xxx/STM3243xxx devices.
 +  * @note    This mode is enabled only with STOP low power mode.
 +  *          In this mode, the 1.2V domain is preserved in reduced leakage mode. This 
 +  *          mode is only available when the main regulator or the low power regulator 
 +  *          is in low voltage mode
 +  *        
 +  * @note   If the Under-drive mode was enabled, it is automatically disabled after 
 +  *         exiting Stop mode. 
 +  *         When the voltage regulator operates in Under-drive mode, an additional  
 +  *         startup delay is induced when waking up from Stop mode.
 +  *                    
 +  * @param  NewState: new state of the Under Drive mode.
 +  *          This parameter can be: ENABLE or DISABLE.
 +  * @retval None
 +  */
 +void PWR_UnderDriveCmd(FunctionalState NewState)
 +{
 +  /* Check the parameters */
 +  assert_param(IS_FUNCTIONAL_STATE(NewState));
 +
 +  if (NewState != DISABLE)
 +  {
 +    /* Set the UDEN[1:0] bits to enable the Under Drive mode */
 +    PWR->CR |= (uint32_t)PWR_CR_UDEN;
 +  }
 +  else
 +  {
 +    /* Reset the UDEN[1:0] bits to disable the Under Drive mode */
 +    PWR->CR &= (uint32_t)(~PWR_CR_UDEN);
 +  }
 +}
 +
 +/**
    * @}
    */
 @@ -423,8 +543,10 @@ void PWR_FlashPowerDownCmd(FunctionalState NewState)        the Stop mode using the PWR_FlashPowerDownCmd() function. 
        (+) Entry:
 -        (++) The Stop mode is entered using the PWR_EnterSTOPMode(PWR_Regulator_LowPower,) 
 -             function with regulator in LowPower or with Regulator ON.
 +        (++) The Stop mode is entered using the PWR_EnterSTOPMode(PWR_MainRegulator_ON) 
 +             function with:
 +          (+++) Main regulator ON.
 +          (+++) Low Power regulator ON.
        (+) Exit:
          (++) Any EXTI Line (Internal or External) configured in Interrupt/Event mode.
 @@ -508,12 +630,12 @@ void PWR_FlashPowerDownCmd(FunctionalState NewState)    * @note   When the voltage regulator operates in low power mode, an additional 
    *         startup delay is incurred when waking up from Stop mode. 
    *         By keeping the internal regulator ON during Stop mode, the consumption 
 -  *         is higher although the startup time is reduced.           
 +  *         is higher although the startup time is reduced.
    *     
    * @param  PWR_Regulator: specifies the regulator state in STOP mode.
    *          This parameter can be one of the following values:
 -  *            @arg PWR_Regulator_ON: STOP mode with regulator ON
 -  *            @arg PWR_Regulator_LowPower: STOP mode with regulator in low power mode
 +  *            @arg PWR_MainRegulator_ON: STOP mode with regulator ON
 +  *            @arg PWR_LowPowerRegulator_ON: STOP mode with low power regulator ON
    * @param  PWR_STOPEntry: specifies if STOP mode in entered with WFI or WFE instruction.
    *          This parameter can be one of the following values:
    *            @arg PWR_STOPEntry_WFI: enter STOP mode with WFI instruction
 @@ -530,10 +652,74 @@ void PWR_EnterSTOPMode(uint32_t PWR_Regulator, uint8_t PWR_STOPEntry)    /* Select the regulator state in STOP mode ---------------------------------*/
    tmpreg = PWR->CR;
 -  /* Clear PDDS and LPDSR bits */
 +  /* Clear PDDS and LPDS bits */
 +  tmpreg &= CR_DS_MASK;
 +  
 +  /* Set LPDS, MRLVDS and LPLVDS bits according to PWR_Regulator value */
 +  tmpreg |= PWR_Regulator;
 +  
 +  /* Store the new value */
 +  PWR->CR = tmpreg;
 +  
 +  /* Set SLEEPDEEP bit of Cortex System Control Register */
 +  SCB->SCR |= SCB_SCR_SLEEPDEEP_Msk;
 +  
 +  /* Select STOP mode entry --------------------------------------------------*/
 +  if(PWR_STOPEntry == PWR_STOPEntry_WFI)
 +  {   
 +    /* Request Wait For Interrupt */
 +    __WFI();
 +  }
 +  else
 +  {
 +    /* Request Wait For Event */
 +    __WFE();
 +  }
 +  /* Reset SLEEPDEEP bit of Cortex System Control Register */
 +  SCB->SCR &= (uint32_t)~((uint32_t)SCB_SCR_SLEEPDEEP_Msk);  
 +}
 +
 +/**
 +  * @brief  Enters in Under-Drive STOP mode.
 +  *  
 +  * @note   This mode is only available for STM32F42xxx/STM3243xxx devices. 
 +  * 
 +  * @note    This mode can be selected only when the Under-Drive is already active 
 +  *         
 +  * @note   In Stop mode, all I/O pins keep the same state as in Run mode.
 +  * @note   When exiting Stop mode by issuing an interrupt or a wakeup event, 
 +  *         the HSI RC oscillator is selected as system clock.
 +  * @note   When the voltage regulator operates in low power mode, an additional 
 +  *         startup delay is incurred when waking up from Stop mode. 
 +  *         By keeping the internal regulator ON during Stop mode, the consumption 
 +  *         is higher although the startup time is reduced.
 +  *     
 +  * @param  PWR_Regulator: specifies the regulator state in STOP mode.
 +  *          This parameter can be one of the following values:
 +  *            @arg PWR_MainRegulator_UnderDrive_ON:  Main Regulator in under-drive mode 
 +  *                 and Flash memory in power-down when the device is in Stop under-drive mode
 +  *            @arg PWR_LowPowerRegulator_UnderDrive_ON:  Low Power Regulator in under-drive mode 
 +  *                and Flash memory in power-down when the device is in Stop under-drive mode
 +  * @param  PWR_STOPEntry: specifies if STOP mode in entered with WFI or WFE instruction.
 +  *          This parameter can be one of the following values:
 +  *            @arg PWR_STOPEntry_WFI: enter STOP mode with WFI instruction
 +  *            @arg PWR_STOPEntry_WFE: enter STOP mode with WFE instruction
 +  * @retval None
 +  */
 +void PWR_EnterUnderDriveSTOPMode(uint32_t PWR_Regulator, uint8_t PWR_STOPEntry)
 +{
 +  uint32_t tmpreg = 0;
 +  
 +  /* Check the parameters */
 +  assert_param(IS_PWR_REGULATOR_UNDERDRIVE(PWR_Regulator));
 +  assert_param(IS_PWR_STOP_ENTRY(PWR_STOPEntry));
 +  
 +  /* Select the regulator state in STOP mode ---------------------------------*/
 +  tmpreg = PWR->CR;
 +  /* Clear PDDS and LPDS bits */
    tmpreg &= CR_DS_MASK;
 -  /* Set LPDSR bit according to PWR_Regulator value */
 +  /* Set LPDS, MRLUDS and LPLUDS bits according to PWR_Regulator value */
    tmpreg |= PWR_Regulator;
    /* Store the new value */
 @@ -622,7 +808,13 @@ void PWR_EnterSTANDBYMode(void)    *                  when the device wakes up from Standby mode or by a system reset 
    *                  or power reset.  
    *            @arg PWR_FLAG_VOSRDY: This flag indicates that the Regulator voltage 
 -  *                 scaling output selection is ready. 
 +  *                 scaling output selection is ready.
 +  *            @arg PWR_FLAG_ODRDY: This flag indicates that the Over-drive mode
 +  *                 is ready (STM32F42xxx/43xxx devices) 
 +  *            @arg PWR_FLAG_ODSWRDY: This flag indicates that the Over-drive mode
 +  *                 switcching is ready (STM32F42xxx/43xxx devices) 
 +  *            @arg PWR_FLAG_UDRDY: This flag indicates that the Under-drive mode
 +  *                 is enabled in Stop mode (STM32F42xxx/43xxx devices)
    * @retval The new state of PWR_FLAG (SET or RESET).
    */
  FlagStatus PWR_GetFlagStatus(uint32_t PWR_FLAG)
 @@ -650,14 +842,28 @@ FlagStatus PWR_GetFlagStatus(uint32_t PWR_FLAG)    *          This parameter can be one of the following values:
    *            @arg PWR_FLAG_WU: Wake Up flag
    *            @arg PWR_FLAG_SB: StandBy flag
 +  *            @arg PWR_FLAG_UDRDY: Under-drive ready flag (STM32F42xxx/43xxx devices)
    * @retval None
    */
  void PWR_ClearFlag(uint32_t PWR_FLAG)
  {
    /* Check the parameters */
    assert_param(IS_PWR_CLEAR_FLAG(PWR_FLAG));
 -         
 +  
 +#if defined (STM32F427_437xx) || defined (STM32F429_439xx)
 +  if (PWR_FLAG != PWR_FLAG_UDRDY)
 +  {
 +    PWR->CR |=  PWR_FLAG << 2;
 +  }
 +  else
 +  {
 +    PWR->CSR |= PWR_FLAG_UDRDY;
 +  }
 +#endif /* STM32F427_437xx ||  STM32F429_439xx */
 +
 +#if defined (STM32F40_41xxx) || defined (STM32F401xx) 
    PWR->CR |=  PWR_FLAG << 2;
 +#endif /* STM32F40_41xxx */
  }
  /**
 diff --git a/stm/lib/stm32f4xx_pwr.h b/stm/lib/stm32f4xx_pwr.h index 0212501f8..4ce588db6 100644 --- a/stm/lib/stm32f4xx_pwr.h +++ b/stm/lib/stm32f4xx_pwr.h @@ -2,8 +2,8 @@    ******************************************************************************
    * @file    stm32f4xx_pwr.h
    * @author  MCD Application Team
 -  * @version V1.1.0
 -  * @date    11-January-2013
 +  * @version V1.3.0
 +  * @date    08-November-2013
    * @brief   This file contains all the functions prototypes for the PWR firmware 
    *          library.
    ******************************************************************************
 @@ -55,7 +55,6 @@  /** @defgroup PWR_PVD_detection_level 
    * @{
    */ 
 -
  #define PWR_PVDLevel_0                  PWR_CR_PLS_LEV0
  #define PWR_PVDLevel_1                  PWR_CR_PLS_LEV1
  #define PWR_PVDLevel_2                  PWR_CR_PLS_LEV2
 @@ -77,34 +76,52 @@  /** @defgroup PWR_Regulator_state_in_STOP_mode 
    * @{
    */
 +#define PWR_MainRegulator_ON                        ((uint32_t)0x00000000)
 +#define PWR_LowPowerRegulator_ON                    PWR_CR_LPDS
 +
 +/* --- PWR_Legacy ---*/
 +#define PWR_Regulator_ON                            PWR_MainRegulator_ON
 +#define PWR_Regulator_LowPower                      PWR_LowPowerRegulator_ON
 +
 +#define IS_PWR_REGULATOR(REGULATOR) (((REGULATOR) == PWR_MainRegulator_ON) || \
 +                                     ((REGULATOR) == PWR_LowPowerRegulator_ON))
 -#define PWR_Regulator_ON                ((uint32_t)0x00000000)
 -#define PWR_Regulator_LowPower          PWR_CR_LPDS
 -#define IS_PWR_REGULATOR(REGULATOR) (((REGULATOR) == PWR_Regulator_ON) || \
 -                                     ((REGULATOR) == PWR_Regulator_LowPower))
  /**
    * @}
    */
 -/** @defgroup PWR_STOP_mode_entry 
 +/** @defgroup PWR_Regulator_state_in_UnderDrive_mode 
    * @{
    */
 +#define PWR_MainRegulator_UnderDrive_ON               PWR_CR_MRUDS
 +#define PWR_LowPowerRegulator_UnderDrive_ON           ((uint32_t)(PWR_CR_LPDS | PWR_CR_LPUDS))
 +
 +#define IS_PWR_REGULATOR_UNDERDRIVE(REGULATOR) (((REGULATOR) == PWR_MainRegulator_UnderDrive_ON) || \
 +                                                ((REGULATOR) == PWR_LowPowerRegulator_UnderDrive_ON))
 +
 +/**
 +  * @}
 +  */
 +/** @defgroup PWR_STOP_mode_entry 
 +  * @{
 +  */
  #define PWR_STOPEntry_WFI               ((uint8_t)0x01)
  #define PWR_STOPEntry_WFE               ((uint8_t)0x02)
  #define IS_PWR_STOP_ENTRY(ENTRY) (((ENTRY) == PWR_STOPEntry_WFI) || ((ENTRY) == PWR_STOPEntry_WFE))
 +/**
 +  * @}
 +  */
  /** @defgroup PWR_Regulator_Voltage_Scale 
    * @{
    */
 -
  #define PWR_Regulator_Voltage_Scale1    ((uint32_t)0x0000C000)
  #define PWR_Regulator_Voltage_Scale2    ((uint32_t)0x00008000)
  #define PWR_Regulator_Voltage_Scale3    ((uint32_t)0x00004000)
  #define IS_PWR_REGULATOR_VOLTAGE(VOLTAGE) (((VOLTAGE) == PWR_Regulator_Voltage_Scale1) || \
                                             ((VOLTAGE) == PWR_Regulator_Voltage_Scale2) || \
                                             ((VOLTAGE) == PWR_Regulator_Voltage_Scale3))
 - 
  /**
    * @}
    */
 @@ -112,26 +129,27 @@  /** @defgroup PWR_Flag 
    * @{
    */
 -
  #define PWR_FLAG_WU                     PWR_CSR_WUF
  #define PWR_FLAG_SB                     PWR_CSR_SBF
  #define PWR_FLAG_PVDO                   PWR_CSR_PVDO
  #define PWR_FLAG_BRR                    PWR_CSR_BRR
  #define PWR_FLAG_VOSRDY                 PWR_CSR_VOSRDY
 +#define PWR_FLAG_ODRDY                  PWR_CSR_ODRDY
 +#define PWR_FLAG_ODSWRDY                PWR_CSR_ODSWRDY
 +#define PWR_FLAG_UDRDY                  PWR_CSR_UDSWRDY
 -/** @defgroup PWR_Flag_Legacy 
 -  * @{
 -  */
 +/* --- FLAG Legacy ---*/
  #define PWR_FLAG_REGRDY                  PWR_FLAG_VOSRDY               
 -/**
 -  * @}
 -  */
  #define IS_PWR_GET_FLAG(FLAG) (((FLAG) == PWR_FLAG_WU) || ((FLAG) == PWR_FLAG_SB) || \
                                 ((FLAG) == PWR_FLAG_PVDO) || ((FLAG) == PWR_FLAG_BRR) || \
 -                               ((FLAG) == PWR_FLAG_VOSRDY))
 +                               ((FLAG) == PWR_FLAG_VOSRDY) || ((FLAG) == PWR_FLAG_ODRDY) || \
 +                               ((FLAG) == PWR_FLAG_ODSWRDY) || ((FLAG) == PWR_FLAG_UDRDY))
 +
 +
 +#define IS_PWR_CLEAR_FLAG(FLAG) (((FLAG) == PWR_FLAG_WU) || ((FLAG) == PWR_FLAG_SB) || \
 +                                 ((FLAG) == PWR_FLAG_UDRDY))
 -#define IS_PWR_CLEAR_FLAG(FLAG) (((FLAG) == PWR_FLAG_WU) || ((FLAG) == PWR_FLAG_SB))
  /**
    * @}
    */
 @@ -159,12 +177,16 @@ void PWR_WakeUpPinCmd(FunctionalState NewState);  /* Main and Backup Regulators configuration functions *************************/ 
  void PWR_BackupRegulatorCmd(FunctionalState NewState);
  void PWR_MainRegulatorModeConfig(uint32_t PWR_Regulator_Voltage);
 +void PWR_OverDriveCmd(FunctionalState NewState);
 +void PWR_OverDriveSWCmd(FunctionalState NewState);
 +void PWR_UnderDriveCmd(FunctionalState NewState);
  /* FLASH Power Down configuration functions ***********************************/ 
  void PWR_FlashPowerDownCmd(FunctionalState NewState);
  /* Low Power modes configuration functions ************************************/ 
  void PWR_EnterSTOPMode(uint32_t PWR_Regulator, uint8_t PWR_STOPEntry);
 +void PWR_EnterUnderDriveSTOPMode(uint32_t PWR_Regulator, uint8_t PWR_STOPEntry);
  void PWR_EnterSTANDBYMode(void);
  /* Flags management functions *************************************************/ 
 diff --git a/stm/lib/stm32f4xx_rcc.c b/stm/lib/stm32f4xx_rcc.c index 6e74bc6f0..4c5b47b3f 100644 --- a/stm/lib/stm32f4xx_rcc.c +++ b/stm/lib/stm32f4xx_rcc.c @@ -2,8 +2,8 @@    ******************************************************************************
    * @file    stm32f4xx_rcc.c
    * @author  MCD Application Team
 -  * @version V1.1.0
 -  * @date    11-January-2013
 +  * @version V1.3.0
 +  * @date    08-November-2013
    * @brief   This file provides firmware functions to manage the following 
    *          functionalities of the Reset and clock control (RCC) peripheral:
    *           + Internal/external clocks, PLL, CSS and MCO configuration
 @@ -57,7 +57,6 @@  /* Includes ------------------------------------------------------------------*/
  #include "stm32f4xx_rcc.h"
 -#include "stm32f4xx_conf.h"
  /** @addtogroup STM32F4xx_StdPeriph_Driver
    * @{
 @@ -87,6 +86,10 @@  #define PLLI2SON_BitNumber        0x1A
  #define CR_PLLI2SON_BB            (PERIPH_BB_BASE + (CR_OFFSET * 32) + (PLLI2SON_BitNumber * 4))
 +/* Alias word address of PLLSAION bit */
 +#define PLLSAION_BitNumber        0x1C
 +#define CR_PLLSAION_BB            (PERIPH_BB_BASE + (CR_OFFSET * 32) + (PLLSAION_BitNumber * 4))
 +
  /* --- CFGR Register ---*/
  /* Alias word address of I2SSRC bit */
  #define CFGR_OFFSET               (RCC_OFFSET + 0x08)
 @@ -172,7 +175,11 @@ static __I uint8_t APBAHBPrescTable[16] = {0, 0, 0, 0, 1, 2, 3, 4, 1, 2, 3, 4, 6               the random analog generator (<=48 MHz) and the SDIO (<= 48 MHz).
        (#) PLLI2S (clocked by HSI or HSE), used to generate an accurate clock to achieve 
 -          high-quality audio performance on the I2S interface.
 +          high-quality audio performance on the I2S interface or SAI interface in case 
 +          of STM32F429x/439x devices.
 +     
 +      (#) PLLSAI clocked by (HSI or HSE), used to generate an accurate clock to SAI 
 +          interface and LCD TFT controller available only for STM32F42xxx/43xxx devices.
        (#) CSS (Clock security system), once enable and if a HSE clock failure occurs 
           (HSE used directly or through PLL as System clock source), the System clock
 @@ -211,8 +218,8 @@ void RCC_DeInit(void)    /* Reset CFGR register */
    RCC->CFGR = 0x00000000;
 -  /* Reset HSEON, CSSON, PLLON and PLLI2S bits */
 -  RCC->CR &= (uint32_t)0xFAF6FFFF;
 +  /* Reset HSEON, CSSON, PLLON, PLLI2S and PLLSAI(STM32F42/43xxx devices) bits */
 +  RCC->CR &= (uint32_t)0xEAF6FFFF;
    /* Reset PLLCFGR register */
    RCC->PLLCFGR = 0x24003010;
 @@ -220,16 +227,17 @@ void RCC_DeInit(void)    /* Reset PLLI2SCFGR register */
    RCC->PLLI2SCFGR = 0x20003000;
 +  /* Reset PLLSAICFGR register, only available for STM32F42/43xxx devices */
 +  RCC->PLLSAICFGR = 0x24003000;
 + 
    /* Reset HSEBYP bit */
    RCC->CR &= (uint32_t)0xFFFBFFFF;
    /* Disable all interrupts */
    RCC->CIR = 0x00000000;
 -#ifdef STM32F427X 
 -  /* Disable Timers clock prescalers selection */
 -  RCC->DCKCFGR = 0x00000000;
 -#endif /* STM32F427X */ 
 +  /* Disable Timers clock prescalers selection, only available for STM32F42/43xxx devices */
 +  RCC->DCKCFGR = 0x00000000; 
  }
 @@ -482,9 +490,13 @@ void RCC_PLLCmd(FunctionalState NewState)    *(__IO uint32_t *) CR_PLLON_BB = (uint32_t)NewState;
  }
 +#if defined (STM32F40_41xxx) || defined (STM32F401xx)
  /**
    * @brief  Configures the PLLI2S clock multiplication and division factors.
    *  
 +  * @note   This function can be used only for STM32F405xx/407xx, STM32F415xx/417xx 
 +  *         or STM32F401xx devices. 
 +  *    
    * @note   This function must be used only when the PLLI2S is disabled.
    * @note   PLLI2S clock source is common with the main PLL (configured in 
    *         RCC_PLLConfig function )  
 @@ -509,6 +521,44 @@ void RCC_PLLI2SConfig(uint32_t PLLI2SN, uint32_t PLLI2SR)    RCC->PLLI2SCFGR = (PLLI2SN << 6) | (PLLI2SR << 28);
  }
 +#endif /* STM32F40_41xxx || STM32F401xx */
 +
 +#if defined (STM32F427_437xx) || defined (STM32F429_439xx)
 +/**
 +  * @brief  Configures the PLLI2S clock multiplication and division factors.
 +  * 
 +  * @note   This function can be used only for STM32F42xxx/43xxx devices 
 +  *         
 +  * @note   This function must be used only when the PLLI2S is disabled.
 +  * @note   PLLI2S clock source is common with the main PLL (configured in 
 +  *         RCC_PLLConfig function )  
 +  *             
 +  * @param  PLLI2SN: specifies the multiplication factor for PLLI2S VCO output clock
 +  *          This parameter must be a number between 192 and 432.
 +  * @note   You have to set the PLLI2SN parameter correctly to ensure that the VCO 
 +  *         output frequency is between 192 and 432 MHz.
 +  * 
 +  * @param  PLLI2SQ: specifies the division factor for SAI1 clock
 +  *          This parameter must be a number between 2 and 15.
 +  *                 
 +  * @param  PLLI2SR: specifies the division factor for I2S clock
 +  *          This parameter must be a number between 2 and 7.
 +  * @note   You have to set the PLLI2SR parameter correctly to not exceed 192 MHz
 +  *         on the I2S clock frequency.
 +  * @note   the PLLI2SR parameter is only available with STM32F42xxx/43xxx devices.  
 +  *   
 +  * @retval None
 +  */
 +void RCC_PLLI2SConfig(uint32_t PLLI2SN, uint32_t PLLI2SQ, uint32_t PLLI2SR)
 +{
 +  /* Check the parameters */
 +  assert_param(IS_RCC_PLLI2SN_VALUE(PLLI2SN));
 +  assert_param(IS_RCC_PLLI2SQ_VALUE(PLLI2SQ));
 +  assert_param(IS_RCC_PLLI2SR_VALUE(PLLI2SR));
 +
 +  RCC->PLLI2SCFGR = (PLLI2SN << 6) | (PLLI2SQ << 24) | (PLLI2SR << 28);
 +}
 +#endif /* STM32F427_437xx ||  STM32F429_439xx */
  /**
    * @brief  Enables or disables the PLLI2S. 
 @@ -524,6 +574,53 @@ void RCC_PLLI2SCmd(FunctionalState NewState)  }
  /**
 +  * @brief  Configures the PLLSAI clock multiplication and division factors.
 +  *
 +  * @note   This function can be used only for STM32F42xxx/43xxx devices 
 +  *        
 +  * @note   This function must be used only when the PLLSAI is disabled.
 +  * @note   PLLSAI clock source is common with the main PLL (configured in 
 +  *         RCC_PLLConfig function )  
 +  *             
 +  * @param  PLLSAIN: specifies the multiplication factor for PLLSAI VCO output clock
 +  *          This parameter must be a number between 192 and 432.
 +  * @note   You have to set the PLLSAIN parameter correctly to ensure that the VCO 
 +  *         output frequency is between 192 and 432 MHz.
 +  *           
 +  * @param  PLLSAIQ: specifies the division factor for SAI1 clock
 +  *          This parameter must be a number between 2 and 15.
 +  *            
 +  * @param  PLLSAIR: specifies the division factor for LTDC clock
 +  *          This parameter must be a number between 2 and 7.
 +  *   
 +  * @retval None
 +  */
 +void RCC_PLLSAIConfig(uint32_t PLLSAIN, uint32_t PLLSAIQ, uint32_t PLLSAIR)
 +{
 +  /* Check the parameters */
 +  assert_param(IS_RCC_PLLSAIN_VALUE(PLLSAIN));
 +  assert_param(IS_RCC_PLLSAIR_VALUE(PLLSAIR));
 +
 +  RCC->PLLSAICFGR = (PLLSAIN << 6) | (PLLSAIQ << 24) | (PLLSAIR << 28);
 +}
 +
 +/**
 +  * @brief  Enables or disables the PLLSAI. 
 +  * 
 +  * @note   This function can be used only for STM32F42xxx/43xxx devices 
 +  *       
 +  * @note   The PLLSAI is disabled by hardware when entering STOP and STANDBY modes.  
 +  * @param  NewState: new state of the PLLSAI. This parameter can be: ENABLE or DISABLE.
 +  * @retval None
 +  */
 +void RCC_PLLSAICmd(FunctionalState NewState)
 +{
 +  /* Check the parameters */
 +  assert_param(IS_FUNCTIONAL_STATE(NewState));
 +  *(__IO uint32_t *) CR_PLLSAION_BB = (uint32_t)NewState;
 +}
 +
 +/**
    * @brief  Enables or disables the Clock Security System.
    * @note   If a failure is detected on the HSE oscillator clock, this oscillator
    *         is automatically disabled and an interrupt is generated to inform the
 @@ -653,8 +750,33 @@ void RCC_MCO2Config(uint32_t RCC_MCO2Source, uint32_t RCC_MCO2Div)               to 48. This clock is derived of the main PLL through PLLQ divider.
          (+@) IWDG clock which is always the LSI clock.
 -      (#) The maximum frequency of the SYSCLK and HCLK is 168 MHz, PCLK2 84 MHz 
 -          and PCLK1 42 MHz. Depending on the device voltage range, the maximum 
 +      (#) For STM32F405xx/407xx and STM32F415xx/417xx devices, the maximum frequency 
 +         of the SYSCLK and HCLK is 168 MHz, PCLK2 84 MHz and PCLK1 42 MHz. Depending 
 +         on the device voltage range, the maximum frequency should be adapted accordingly:
 + +-------------------------------------------------------------------------------------+     
 + | Latency       |                HCLK clock frequency (MHz)                           |
 + |               |---------------------------------------------------------------------|     
 + |               | voltage range  | voltage range  | voltage range   | voltage range   |
 + |               | 2.7 V - 3.6 V  | 2.4 V - 2.7 V  | 2.1 V - 2.4 V   | 1.8 V - 2.1 V   |
 + |---------------|----------------|----------------|-----------------|-----------------|              
 + |0WS(1CPU cycle)|0 < HCLK <= 30  |0 < HCLK <= 24  |0 < HCLK <= 22   |0 < HCLK <= 20   |
 + |---------------|----------------|----------------|-----------------|-----------------|   
 + |1WS(2CPU cycle)|30 < HCLK <= 60 |24 < HCLK <= 48 |22 < HCLK <= 44  |20 < HCLK <= 40  | 
 + |---------------|----------------|----------------|-----------------|-----------------|   
 + |2WS(3CPU cycle)|60 < HCLK <= 90 |48 < HCLK <= 72 |44 < HCLK <= 66  |40 < HCLK <= 60  |
 + |---------------|----------------|----------------|-----------------|-----------------| 
 + |3WS(4CPU cycle)|90 < HCLK <= 120|72 < HCLK <= 96 |66 < HCLK <= 88  |60 < HCLK <= 80  |
 + |---------------|----------------|----------------|-----------------|-----------------| 
 + |4WS(5CPU cycle)|120< HCLK <= 150|96 < HCLK <= 120|88 < HCLK <= 110 |80 < HCLK <= 100 |
 + |---------------|----------------|----------------|-----------------|-----------------| 
 + |5WS(6CPU cycle)|150< HCLK <= 168|120< HCLK <= 144|110 < HCLK <= 132|100 < HCLK <= 120| 
 + |---------------|----------------|----------------|-----------------|-----------------| 
 + |6WS(7CPU cycle)|      NA        |144< HCLK <= 168|132 < HCLK <= 154|120 < HCLK <= 140| 
 + |---------------|----------------|----------------|-----------------|-----------------| 
 + |7WS(8CPU cycle)|      NA        |      NA        |154 < HCLK <= 168|140 < HCLK <= 160|
 + +---------------|----------------|----------------|-----------------|-----------------+ 
 +      (#) For STM32F42xxx/43xxx devices, the maximum frequency of the SYSCLK and HCLK is 180 MHz, 
 +          PCLK2 90 MHz and PCLK1 45 MHz. Depending on the device voltage range, the maximum 
            frequency should be adapted accordingly:
   +-------------------------------------------------------------------------------------+     
   | Latency       |                HCLK clock frequency (MHz)                           |
 @@ -662,24 +784,58 @@ void RCC_MCO2Config(uint32_t RCC_MCO2Source, uint32_t RCC_MCO2Div)   |               | voltage range  | voltage range  | voltage range   | voltage range   |
   |               | 2.7 V - 3.6 V  | 2.4 V - 2.7 V  | 2.1 V - 2.4 V   | 1.8 V - 2.1 V   |
   |---------------|----------------|----------------|-----------------|-----------------|              
 - |0WS(1CPU cycle)|0 < HCLK <= 30  |0 < HCLK <= 24  |0 < HCLK <= 18   |0 < HCLK <= 16   |
 + |0WS(1CPU cycle)|0 < HCLK <= 30  |0 < HCLK <= 24  |0 < HCLK <= 22   |0 < HCLK <= 20   |
   |---------------|----------------|----------------|-----------------|-----------------|   
 - |1WS(2CPU cycle)|30 < HCLK <= 60 |24 < HCLK <= 48 |18 < HCLK <= 36  |16 < HCLK <= 32  | 
 + |1WS(2CPU cycle)|30 < HCLK <= 60 |24 < HCLK <= 48 |22 < HCLK <= 44  |20 < HCLK <= 40  | 
   |---------------|----------------|----------------|-----------------|-----------------|   
 - |2WS(3CPU cycle)|60 < HCLK <= 90 |48 < HCLK <= 72 |36 < HCLK <= 54  |32 < HCLK <= 48  |
 + |2WS(3CPU cycle)|60 < HCLK <= 90 |48 < HCLK <= 72 |44 < HCLK <= 66  |40 < HCLK <= 60  |
   |---------------|----------------|----------------|-----------------|-----------------| 
 - |3WS(4CPU cycle)|90 < HCLK <= 120|72 < HCLK <= 96 |54 < HCLK <= 72  |48 < HCLK <= 64  |
 + |3WS(4CPU cycle)|90 < HCLK <= 120|72 < HCLK <= 96 |66 < HCLK <= 88  |60 < HCLK <= 80  |
   |---------------|----------------|----------------|-----------------|-----------------| 
 - |4WS(5CPU cycle)|120< HCLK <= 150|96 < HCLK <= 120|72 < HCLK <= 90  |64 < HCLK <= 80  |
 + |4WS(5CPU cycle)|120< HCLK <= 150|96 < HCLK <= 120|88 < HCLK <= 110 |80 < HCLK <= 100 |
   |---------------|----------------|----------------|-----------------|-----------------| 
 - |5WS(6CPU cycle)|120< HCLK <= 168|120< HCLK <= 144|90 < HCLK <= 108 |80 < HCLK <= 96  | 
 + |5WS(6CPU cycle)|120< HCLK <= 180|120< HCLK <= 144|110 < HCLK <= 132|100 < HCLK <= 120| 
   |---------------|----------------|----------------|-----------------|-----------------| 
 - |6WS(7CPU cycle)|      NA        |144< HCLK <= 168|108 < HCLK <= 120|96 < HCLK <= 112 | 
 + |6WS(7CPU cycle)|      NA        |144< HCLK <= 168|132 < HCLK <= 154|120 < HCLK <= 140| 
   |---------------|----------------|----------------|-----------------|-----------------| 
 - |7WS(8CPU cycle)|      NA        |      NA        |120 < HCLK <= 138|112 < HCLK <= 120| 
 - +-------------------------------------------------------------------------------------+    
 -      -@- When VOS bits (in PWR_CR register) is reset to 0 , the maximum value of HCLK is 144 MHz.
 -          You can use PWR_MainRegulatorModeConfig() function to set or reset this bit.
 + |7WS(8CPU cycle)|      NA        |168< HCLK <= 180|154 < HCLK <= 176|140 < HCLK <= 160|
 + |---------------|----------------|----------------|-----------------|-----------------| 
 + |8WS(9CPU cycle)|      NA        |      NA        |176 < HCLK <= 180|160 < HCLK <= 168|
 + +-------------------------------------------------------------------------------------+
 +   
 +      (#) For STM32F401xx devices, the maximum frequency of the SYSCLK and HCLK is 84 MHz, 
 +          PCLK2 84 MHz and PCLK1 42 MHz. Depending on the device voltage range, the maximum 
 +          frequency should be adapted accordingly:
 + +-------------------------------------------------------------------------------------+     
 + | Latency       |                HCLK clock frequency (MHz)                           |
 + |               |---------------------------------------------------------------------|     
 + |               | voltage range  | voltage range  | voltage range   | voltage range   |
 + |               | 2.7 V - 3.6 V  | 2.4 V - 2.7 V  | 2.1 V - 2.4 V   | 1.8 V - 2.1 V   |
 + |---------------|----------------|----------------|-----------------|-----------------|              
 + |0WS(1CPU cycle)|0 < HCLK <= 30  |0 < HCLK <= 24  |0 < HCLK <= 22   |0 < HCLK <= 20   |
 + |---------------|----------------|----------------|-----------------|-----------------|   
 + |1WS(2CPU cycle)|30 < HCLK <= 60 |24 < HCLK <= 48 |22 < HCLK <= 44  |20 < HCLK <= 40  | 
 + |---------------|----------------|----------------|-----------------|-----------------|   
 + |2WS(3CPU cycle)|60 < HCLK <= 84 |48 < HCLK <= 72 |44 < HCLK <= 66  |40 < HCLK <= 60  |
 + |---------------|----------------|----------------|-----------------|-----------------| 
 + |3WS(4CPU cycle)|      NA        |72 < HCLK <= 84 |66 < HCLK <= 84  |60 < HCLK <= 80  |
 + |---------------|----------------|----------------|-----------------|-----------------| 
 + |4WS(5CPU cycle)|      NA        |      NA        |      NA         |80 < HCLK <= 84  | 
 + +-------------------------------------------------------------------------------------+ 
 +  
 +      -@- On STM32F405xx/407xx and STM32F415xx/417xx devices: 
 +           (++) when VOS = '0', the maximum value of fHCLK = 144MHz. 
 +           (++) when VOS = '1', the maximum value of fHCLK = 168MHz. 
 +          [..] 
 +          On STM32F42xxx/43xxx devices:
 +           (++) when VOS[1:0] = '0x01', the maximum value of fHCLK is 120MHz.
 +           (++) when VOS[1:0] = '0x10', the maximum value of fHCLK is 144MHz.
 +           (++) when VOS[1:0] = '0x11', the maximum value of f  is 168MHz 
 +          [..]  
 +          On STM32F401x devices:
 +           (++) when VOS[1:0] = '0x01', the maximum value of fHCLK is 64MHz.
 +           (++) when VOS[1:0] = '0x10', the maximum value of fHCLK is 84MHz.
 +           You can use PWR_MainRegulatorModeConfig() function to control VOS bits.
  @endverbatim
    * @{
 @@ -1072,9 +1228,179 @@ void RCC_I2SCLKConfig(uint32_t RCC_I2SCLKSource)  }
  /**
 +  * @brief  Configures the SAI clock Divider coming from PLLI2S.
 +  * 
 +  * @note   This function can be used only for STM32F42xxx/43xxx devices.
 +  *   
 +  * @note   This function must be called before enabling the PLLI2S.
 +  *              
 +  * @param  RCC_PLLI2SDivQ: specifies the PLLI2S division factor for SAI1 clock .
 +  *          This parameter must be a number between 1 and 32.
 +  *          SAI1 clock frequency = f(PLLI2S_Q) / RCC_PLLI2SDivQ 
 +  *              
 +  * @retval None
 +  */
 +void RCC_SAIPLLI2SClkDivConfig(uint32_t RCC_PLLI2SDivQ)  
 +{
 +  uint32_t tmpreg = 0;
 +  
 +  /* Check the parameters */
 +  assert_param(IS_RCC_PLLI2S_DIVQ_VALUE(RCC_PLLI2SDivQ));
 +  
 +  tmpreg = RCC->DCKCFGR;
 +
 +  /* Clear PLLI2SDIVQ[4:0] bits */
 +  tmpreg &= ~(RCC_DCKCFGR_PLLI2SDIVQ);
 +
 +  /* Set PLLI2SDIVQ values */
 +  tmpreg |= (RCC_PLLI2SDivQ - 1);
 +
 +  /* Store the new value */
 +  RCC->DCKCFGR = tmpreg;
 +}
 +
 +/**
 +  * @brief  Configures the SAI clock Divider coming from PLLSAI.
 +  * 
 +  * @note   This function can be used only for STM32F42xxx/43xxx devices.
 +  *        
 +  * @note   This function must be called before enabling the PLLSAI.
 +  *   
 +  * @param  RCC_PLLSAIDivQ: specifies the PLLSAI division factor for SAI1 clock .
 +  *          This parameter must be a number between 1 and 32.
 +  *          SAI1 clock frequency = f(PLLSAI_Q) / RCC_PLLSAIDivQ  
 +  *              
 +  * @retval None
 +  */
 +void RCC_SAIPLLSAIClkDivConfig(uint32_t RCC_PLLSAIDivQ)  
 +{
 +  uint32_t tmpreg = 0;
 +  
 +  /* Check the parameters */
 +  assert_param(IS_RCC_PLLSAI_DIVQ_VALUE(RCC_PLLSAIDivQ));
 +  
 +  tmpreg = RCC->DCKCFGR;
 +
 +  /* Clear PLLI2SDIVQ[4:0] and PLLSAIDIVQ[4:0] bits */
 +  tmpreg &= ~(RCC_DCKCFGR_PLLSAIDIVQ);
 +
 +  /* Set PLLSAIDIVQ values */
 +  tmpreg |= ((RCC_PLLSAIDivQ - 1) << 8);
 +
 +  /* Store the new value */
 +  RCC->DCKCFGR = tmpreg;
 +}
 +
 +/**
 +  * @brief  Configures SAI1BlockA clock source selection.
 +  * 
 +  * @note   This function can be used only for STM32F42xxx/43xxx devices.
 +  *       
 +  * @note   This function must be called before enabling PLLSAI, PLLI2S and  
 +  *         the SAI clock.
 +  * @param  RCC_SAIBlockACLKSource: specifies the SAI Block A clock source.
 +  *          This parameter can be one of the following values:
 +  *            @arg RCC_SAIACLKSource_PLLI2S: PLLI2S_Q clock divided by PLLI2SDIVQ used 
 +  *                                           as SAI1 Block A clock 
 +  *            @arg RCC_SAIACLKSource_PLLSAI: PLLISAI_Q clock divided by PLLSAIDIVQ used 
 +  *                                           as SAI1 Block A clock 
 +  *            @arg RCC_SAIACLKSource_Ext: External clock mapped on the I2S_CKIN pin
 +  *                                        used as SAI1 Block A clock
 +  * @retval None
 +  */
 +void RCC_SAIBlockACLKConfig(uint32_t RCC_SAIBlockACLKSource)
 +{
 +  uint32_t tmpreg = 0;
 +  
 +  /* Check the parameters */
 +  assert_param(IS_RCC_SAIACLK_SOURCE(RCC_SAIBlockACLKSource));
 +  
 +  tmpreg = RCC->DCKCFGR;
 +
 +  /* Clear RCC_DCKCFGR_SAI1ASRC[1:0] bits */
 +  tmpreg &= ~RCC_DCKCFGR_SAI1ASRC;
 +
 +  /* Set SAI Block A source selection value */
 +  tmpreg |= RCC_SAIBlockACLKSource;
 +
 +  /* Store the new value */
 +  RCC->DCKCFGR = tmpreg;
 +}
 +
 +/**
 +  * @brief  Configures SAI1BlockB clock source selection.
 +  * 
 +  * @note   This function can be used only for STM32F42xxx/43xxx devices.
 +  *       
 +  * @note   This function must be called before enabling PLLSAI, PLLI2S and  
 +  *         the SAI clock.
 +  * @param  RCC_SAIBlockBCLKSource: specifies the SAI Block B clock source.
 +  *          This parameter can be one of the following values:
 +  *            @arg RCC_SAIBCLKSource_PLLI2S: PLLI2S_Q clock divided by PLLI2SDIVQ used 
 +  *                                           as SAI1 Block B clock 
 +  *            @arg RCC_SAIBCLKSource_PLLSAI: PLLISAI_Q clock divided by PLLSAIDIVQ used 
 +  *                                           as SAI1 Block B clock 
 +  *            @arg RCC_SAIBCLKSource_Ext: External clock mapped on the I2S_CKIN pin
 +  *                                        used as SAI1 Block B clock
 +  * @retval None
 +  */
 +void RCC_SAIBlockBCLKConfig(uint32_t RCC_SAIBlockBCLKSource)
 +{
 +  uint32_t tmpreg = 0;
 +  
 +  /* Check the parameters */
 +  assert_param(IS_RCC_SAIBCLK_SOURCE(RCC_SAIBlockBCLKSource));
 +  
 +  tmpreg = RCC->DCKCFGR;
 +
 +  /* Clear RCC_DCKCFGR_SAI1BSRC[1:0] bits */
 +  tmpreg &= ~RCC_DCKCFGR_SAI1BSRC;
 +
 +  /* Set SAI Block B source selection value */
 +  tmpreg |= RCC_SAIBlockBCLKSource;
 +
 +  /* Store the new value */
 +  RCC->DCKCFGR = tmpreg;
 +}
 +
 +
 +/**
 +  * @brief  Configures the LTDC clock Divider coming from PLLSAI.
 +  * 
 +  * @note   The LTDC peripheral is only available with STM32F429xx/439xx Devices.
 +  *      
 +  * @note   This function must be called before enabling the PLLSAI.
 +  *   
 +  * @param  RCC_PLLSAIDivR: specifies the PLLSAI division factor for LTDC clock .
 +  *          This parameter must be a number between 2 and 16.
 +  *          LTDC clock frequency = f(PLLSAI_R) / RCC_PLLSAIDivR  
 +  *            
 +  * @retval None
 +  */
 +void RCC_LTDCCLKDivConfig(uint32_t RCC_PLLSAIDivR)
 +{
 +  uint32_t tmpreg = 0;
 +  
 +  /* Check the parameters */
 +  assert_param(IS_RCC_PLLSAI_DIVR_VALUE(RCC_PLLSAIDivR));
 +  
 +  tmpreg = RCC->DCKCFGR;
 +
 +  /* Clear PLLSAIDIVR[2:0] bits */
 +  tmpreg &= ~RCC_DCKCFGR_PLLSAIDIVR;
 +
 +  /* Set PLLSAIDIVR values */
 +  tmpreg |= RCC_PLLSAIDivR;
 +
 +  /* Store the new value */
 +  RCC->DCKCFGR = tmpreg;
 +}
 +
 +/**
    * @brief  Configures the Timers clocks prescalers selection.
    * 
 -  * @note   This feature is only available with STM32F427x/437x Devices.  
 +  * @note   This function can be used only for STM32F42xxx/43xxx and STM32F401xx devices. 
 +  *   
    * @param  RCC_TIMCLKPrescaler : specifies the Timers clocks prescalers selection
    *         This parameter can be one of the following values:
    *            @arg RCC_TIMPrescDesactivated: The Timers kernels clocks prescaler is 
 @@ -1112,12 +1438,15 @@ void RCC_TIMCLKPresConfig(uint32_t RCC_TIMCLKPrescaler)    *            @arg RCC_AHB1Periph_GPIOF:       GPIOF clock
    *            @arg RCC_AHB1Periph_GPIOG:       GPIOG clock
    *            @arg RCC_AHB1Periph_GPIOG:       GPIOG clock
 -  *            @arg RCC_AHB1Periph_GPIOI:       GPIOI clock 
 +  *            @arg RCC_AHB1Periph_GPIOI:       GPIOI clock
 +  *            @arg RCC_AHB1Periph_GPIOJ:       GPIOJ clock (STM32F42xxx/43xxx devices) 
 +  *            @arg RCC_AHB1Periph_GPIOK:       GPIOK clock (STM32F42xxx/43xxx devices)  
    *            @arg RCC_AHB1Periph_CRC:         CRC clock
    *            @arg RCC_AHB1Periph_BKPSRAM:     BKPSRAM interface clock
    *            @arg RCC_AHB1Periph_CCMDATARAMEN CCM data RAM interface clock
    *            @arg RCC_AHB1Periph_DMA1:        DMA1 clock
 -  *            @arg RCC_AHB1Periph_DMA2:        DMA2 clock 
 +  *            @arg RCC_AHB1Periph_DMA2:        DMA2 clock
 +  *            @arg RCC_AHB1Periph_DMA2D:       DMA2D clock (STM32F429xx/439xx devices)  
    *            @arg RCC_AHB1Periph_ETH_MAC:     Ethernet MAC clock
    *            @arg RCC_AHB1Periph_ETH_MAC_Tx:  Ethernet Transmission clock
    *            @arg RCC_AHB1Periph_ETH_MAC_Rx:  Ethernet Reception clock
 @@ -1183,7 +1512,7 @@ void RCC_AHB2PeriphClockCmd(uint32_t RCC_AHB2Periph, FunctionalState NewState)    *         using it. 
    * @param  RCC_AHBPeriph: specifies the AHB3 peripheral to gates its clock.
    *          This parameter must be: RCC_AHB3Periph_FSMC
 -  *                                  
 +  *                                  or RCC_AHB3Periph_FMC (STM32F42xxx/43xxx devices)  
    * @param  NewState: new state of the specified peripheral clock.
    *          This parameter can be: ENABLE or DISABLE.
    * @retval None
 @@ -1279,6 +1608,8 @@ void RCC_APB1PeriphClockCmd(uint32_t RCC_APB1Periph, FunctionalState NewState)    *            @arg RCC_APB2Periph_TIM11:  TIM11 clock
    *            @arg RCC_APB2Periph_SPI5:   SPI5 clock
    *            @arg RCC_APB2Periph_SPI6:   SPI6 clock
 +  *            @arg RCC_APB2Periph_SAI1:   SAI1 clock (STM32F42xxx/43xxx devices) 
 +  *            @arg RCC_APB2Periph_LTDC:   LTDC clock (STM32F429xx/439xx devices) 
    * @param  NewState: new state of the specified peripheral clock.
    *          This parameter can be: ENABLE or DISABLE.
    * @retval None
 @@ -1311,10 +1642,13 @@ void RCC_APB2PeriphClockCmd(uint32_t RCC_APB2Periph, FunctionalState NewState)    *            @arg RCC_AHB1Periph_GPIOF:   GPIOF clock
    *            @arg RCC_AHB1Periph_GPIOG:   GPIOG clock
    *            @arg RCC_AHB1Periph_GPIOG:   GPIOG clock
 -  *            @arg RCC_AHB1Periph_GPIOI:   GPIOI clock  
 +  *            @arg RCC_AHB1Periph_GPIOI:   GPIOI clock
 +  *            @arg RCC_AHB1Periph_GPIOJ:   GPIOJ clock (STM32F42xxx/43xxx devices) 
 +  *            @arg RCC_AHB1Periph_GPIOK:   GPIOK clock (STM32F42xxx/43xxxdevices)   
    *            @arg RCC_AHB1Periph_CRC:     CRC clock
    *            @arg RCC_AHB1Periph_DMA1:    DMA1 clock
 -  *            @arg RCC_AHB1Periph_DMA2:    DMA2 clock 
 +  *            @arg RCC_AHB1Periph_DMA2:    DMA2 clock
 +  *            @arg RCC_AHB1Periph_DMA2D:   DMA2D clock (STM32F429xx/439xx devices)   
    *            @arg RCC_AHB1Periph_ETH_MAC: Ethernet MAC clock
    *            @arg RCC_AHB1Periph_OTG_HS:  USB OTG HS clock
    *                  
 @@ -1371,7 +1705,7 @@ void RCC_AHB2PeriphResetCmd(uint32_t RCC_AHB2Periph, FunctionalState NewState)    * @brief  Forces or releases AHB3 peripheral reset.
    * @param  RCC_AHB3Periph: specifies the AHB3 peripheral to reset.
    *          This parameter must be: RCC_AHB3Periph_FSMC
 -  *                                   
 +  *                                  or RCC_AHB3Periph_FMC (STM32F42xxx/43xxx devices)  
    * @param  NewState: new state of the specified peripheral reset.
    *          This parameter can be: ENABLE or DISABLE.
    * @retval None
 @@ -1459,7 +1793,9 @@ void RCC_APB1PeriphResetCmd(uint32_t RCC_APB1Periph, FunctionalState NewState)    *            @arg RCC_APB2Periph_TIM10:  TIM10 clock
    *            @arg RCC_APB2Periph_TIM11:  TIM11 clock
    *            @arg RCC_APB2Periph_SPI5:   SPI5 clock
 -  *            @arg RCC_APB2Periph_SPI6:   SPI6 clock 
 +  *            @arg RCC_APB2Periph_SPI6:   SPI6 clock
 +  *            @arg RCC_APB2Periph_SAI1:   SAI1 clock (STM32F42xxx/43xxx devices) 
 +  *            @arg RCC_APB2Periph_LTDC:   LTDC clock (STM32F429xx/439xx devices)   
    * @param  NewState: new state of the specified peripheral reset.
    *          This parameter can be: ENABLE or DISABLE.
    * @retval None
 @@ -1495,11 +1831,14 @@ void RCC_APB2PeriphResetCmd(uint32_t RCC_APB2Periph, FunctionalState NewState)    *            @arg RCC_AHB1Periph_GPIOF:       GPIOF clock
    *            @arg RCC_AHB1Periph_GPIOG:       GPIOG clock
    *            @arg RCC_AHB1Periph_GPIOG:       GPIOG clock
 -  *            @arg RCC_AHB1Periph_GPIOI:       GPIOI clock 
 +  *            @arg RCC_AHB1Periph_GPIOI:       GPIOI clock
 +  *            @arg RCC_AHB1Periph_GPIOJ:       GPIOJ clock (STM32F42xxx/43xxx devices) 
 +  *            @arg RCC_AHB1Periph_GPIOK:       GPIOK clock (STM32F42xxx/43xxx devices)   
    *            @arg RCC_AHB1Periph_CRC:         CRC clock
    *            @arg RCC_AHB1Periph_BKPSRAM:     BKPSRAM interface clock
    *            @arg RCC_AHB1Periph_DMA1:        DMA1 clock
    *            @arg RCC_AHB1Periph_DMA2:        DMA2 clock
 +  *            @arg RCC_AHB1Periph_DMA2D:       DMA2D clock (STM32F429xx/439xx devices) 
    *            @arg RCC_AHB1Periph_ETH_MAC:     Ethernet MAC clock
    *            @arg RCC_AHB1Periph_ETH_MAC_Tx:  Ethernet Transmission clock
    *            @arg RCC_AHB1Periph_ETH_MAC_Rx:  Ethernet Reception clock
 @@ -1565,7 +1904,7 @@ void RCC_AHB2PeriphClockLPModeCmd(uint32_t RCC_AHB2Periph, FunctionalState NewSt    * @note   By default, all peripheral clocks are enabled during SLEEP mode.
    * @param  RCC_AHBPeriph: specifies the AHB3 peripheral to gates its clock.
    *          This parameter must be: RCC_AHB3Periph_FSMC
 -  *                                  
 +  *                                  or RCC_AHB3Periph_FMC (STM32F429x/439x devices) 
    * @param  NewState: new state of the specified peripheral clock.
    *          This parameter can be: ENABLE or DISABLE.
    * @retval None
 @@ -1660,7 +1999,9 @@ void RCC_APB1PeriphClockLPModeCmd(uint32_t RCC_APB1Periph, FunctionalState NewSt    *            @arg RCC_APB2Periph_TIM10:  TIM10 clock
    *            @arg RCC_APB2Periph_TIM11:  TIM11 clock
    *            @arg RCC_APB2Periph_SPI5:   SPI5 clock
 -  *            @arg RCC_APB2Periph_SPI6:   SPI6 clock  
 +  *            @arg RCC_APB2Periph_SPI6:   SPI6 clock
 +  *            @arg RCC_APB2Periph_SAI1:   SAI1 clock (STM32F42xxx/43xxx devices) 
 +  *            @arg RCC_APB2Periph_LTDC:   LTDC clock (STM32F429xx/439xx devices)   
    * @param  NewState: new state of the specified peripheral clock.
    *          This parameter can be: ENABLE or DISABLE.
    * @retval None
 @@ -1706,7 +2047,7 @@ void RCC_APB2PeriphClockLPModeCmd(uint32_t RCC_APB2Periph, FunctionalState NewSt    *            @arg RCC_IT_HSERDY: HSE ready interrupt
    *            @arg RCC_IT_PLLRDY: main PLL ready interrupt
    *            @arg RCC_IT_PLLI2SRDY: PLLI2S ready interrupt
 -  *              
 +  *            @arg RCC_IT_PLLSAIRDY: PLLSAI ready interrupt (only for STM32F42xxx/43xxx devices)
    * @param  NewState: new state of the specified RCC interrupts.
    *          This parameter can be: ENABLE or DISABLE.
    * @retval None
 @@ -1736,6 +2077,7 @@ void RCC_ITConfig(uint8_t RCC_IT, FunctionalState NewState)    *            @arg RCC_FLAG_HSERDY: HSE oscillator clock ready
    *            @arg RCC_FLAG_PLLRDY: main PLL clock ready
    *            @arg RCC_FLAG_PLLI2SRDY: PLLI2S clock ready
 +  *            @arg RCC_FLAG_PLLSAIRDY: PLLSAI clock ready (only for STM32F42xxx/43xxx devices)
    *            @arg RCC_FLAG_LSERDY: LSE oscillator clock ready
    *            @arg RCC_FLAG_LSIRDY: LSI oscillator clock ready
    *            @arg RCC_FLAG_BORRST: POR/PDR or BOR reset
 @@ -1807,7 +2149,8 @@ void RCC_ClearFlag(void)    *            @arg RCC_IT_HSIRDY: HSI ready interrupt
    *            @arg RCC_IT_HSERDY: HSE ready interrupt
    *            @arg RCC_IT_PLLRDY: main PLL ready interrupt
 -  *            @arg RCC_IT_PLLI2SRDY: PLLI2S ready interrupt             
 +  *            @arg RCC_IT_PLLI2SRDY: PLLI2S ready interrupt           
 +  *            @arg RCC_IT_PLLSAIRDY: PLLSAI clock ready interrupt (only for STM32F42xxx/43xxx devices)    
    *            @arg RCC_IT_CSS: Clock Security System interrupt
    * @retval The new state of RCC_IT (SET or RESET).
    */
 @@ -1841,6 +2184,7 @@ ITStatus RCC_GetITStatus(uint8_t RCC_IT)    *            @arg RCC_IT_HSERDY: HSE ready interrupt
    *            @arg RCC_IT_PLLRDY: main PLL ready interrupt
    *            @arg RCC_IT_PLLI2SRDY: PLLI2S ready interrupt  
 +  *            @arg RCC_IT_PLLSAIRDY: PLLSAI ready interrupt (only for STM32F42xxx/43xxx devices)   
    *            @arg RCC_IT_CSS: Clock Security System interrupt
    * @retval None
    */
 diff --git a/stm/lib/stm32f4xx_rcc.h b/stm/lib/stm32f4xx_rcc.h index 0cbeab2fc..6abb55160 100644 --- a/stm/lib/stm32f4xx_rcc.h +++ b/stm/lib/stm32f4xx_rcc.h @@ -2,8 +2,8 @@    ******************************************************************************
    * @file    stm32f4xx_rcc.h
    * @author  MCD Application Team
 -  * @version V1.1.0
 -  * @date    11-January-2013
 +  * @version V1.3.0
 +  * @date    08-November-2013
    * @brief   This file contains all the functions prototypes for the RCC firmware library.  
    ******************************************************************************
    * @attention
 @@ -85,6 +85,23 @@ typedef struct  #define IS_RCC_PLLI2SN_VALUE(VALUE) ((192 <= (VALUE)) && ((VALUE) <= 432))
  #define IS_RCC_PLLI2SR_VALUE(VALUE) ((2 <= (VALUE)) && ((VALUE) <= 7))  
 +
 +#define IS_RCC_PLLI2SQ_VALUE(VALUE) ((2 <= (VALUE)) && ((VALUE) <= 15))
 +#define IS_RCC_PLLSAIN_VALUE(VALUE) ((192 <= (VALUE)) && ((VALUE) <= 432))
 +#define IS_RCC_PLLSAIQ_VALUE(VALUE) ((2 <= (VALUE)) && ((VALUE) <= 15))
 +#define IS_RCC_PLLSAIR_VALUE(VALUE) ((2 <= (VALUE)) && ((VALUE) <= 7))  
 +
 +#define IS_RCC_PLLSAI_DIVQ_VALUE(VALUE) ((1 <= (VALUE)) && ((VALUE) <= 32))
 +#define IS_RCC_PLLI2S_DIVQ_VALUE(VALUE) ((1 <= (VALUE)) && ((VALUE) <= 32))
 +
 +#define RCC_PLLSAIDivR_Div2                ((uint32_t)0x00000000)
 +#define RCC_PLLSAIDivR_Div4                ((uint32_t)0x00010000)
 +#define RCC_PLLSAIDivR_Div8                ((uint32_t)0x00020000)
 +#define RCC_PLLSAIDivR_Div16               ((uint32_t)0x00030000)
 +#define IS_RCC_PLLSAI_DIVR_VALUE(VALUE) (((VALUE) == RCC_PLLSAIDivR_Div2) ||\
 +                                        ((VALUE) == RCC_PLLSAIDivR_Div4)  ||\
 +                                        ((VALUE) == RCC_PLLSAIDivR_Div8)  ||\
 +                                        ((VALUE) == RCC_PLLSAIDivR_Div16))
  /**                                                                     
    * @}
 @@ -147,15 +164,16 @@ typedef struct  #define RCC_IT_HSIRDY                    ((uint8_t)0x04)
  #define RCC_IT_HSERDY                    ((uint8_t)0x08)
  #define RCC_IT_PLLRDY                    ((uint8_t)0x10)
 -#define RCC_IT_PLLI2SRDY                 ((uint8_t)0x20)
 +#define RCC_IT_PLLI2SRDY                 ((uint8_t)0x20) 
 +#define RCC_IT_PLLSAIRDY                 ((uint8_t)0x40)
  #define RCC_IT_CSS                       ((uint8_t)0x80)
 -#define IS_RCC_IT(IT) ((((IT) & (uint8_t)0xC0) == 0x00) && ((IT) != 0x00))
 +#define IS_RCC_IT(IT) ((((IT) & (uint8_t)0x80) == 0x00) && ((IT) != 0x00))
  #define IS_RCC_GET_IT(IT) (((IT) == RCC_IT_LSIRDY) || ((IT) == RCC_IT_LSERDY) || \
                             ((IT) == RCC_IT_HSIRDY) || ((IT) == RCC_IT_HSERDY) || \
                             ((IT) == RCC_IT_PLLRDY) || ((IT) == RCC_IT_CSS) || \
 -                           ((IT) == RCC_IT_PLLI2SRDY))
 -#define IS_RCC_CLEAR_IT(IT) ((((IT) & (uint8_t)0x40) == 0x00) && ((IT) != 0x00))
 +                           ((IT) == RCC_IT_PLLSAIRDY) || ((IT) == RCC_IT_PLLI2SRDY))
 +#define IS_RCC_CLEAR_IT(IT)((IT) != 0x00)
  /**
    * @}
 @@ -255,6 +273,34 @@ typedef struct    * @}
    */ 
 +/** @defgroup RCC_SAI_BlockA_Clock_Source
 +  * @{
 +  */
 +#define RCC_SAIACLKSource_PLLSAI             ((uint32_t)0x00000000)
 +#define RCC_SAIACLKSource_PLLI2S             ((uint32_t)0x00100000)
 +#define RCC_SAIACLKSource_Ext                ((uint32_t)0x00200000)
 +
 +#define IS_RCC_SAIACLK_SOURCE(SOURCE) (((SOURCE) == RCC_SAIACLKSource_PLLI2S) ||\
 +                                       ((SOURCE) == RCC_SAIACLKSource_PLLSAI) ||\
 +                                       ((SOURCE) == RCC_SAIACLKSource_Ext))
 +/**
 +  * @}
 +  */ 
 +
 +/** @defgroup RCC_SAI_BlockB_Clock_Source
 +  * @{
 +  */
 +#define RCC_SAIBCLKSource_PLLSAI             ((uint32_t)0x00000000)
 +#define RCC_SAIBCLKSource_PLLI2S             ((uint32_t)0x00400000)
 +#define RCC_SAIBCLKSource_Ext                ((uint32_t)0x00800000)
 +
 +#define IS_RCC_SAIBCLK_SOURCE(SOURCE) (((SOURCE) == RCC_SAIBCLKSource_PLLI2S) ||\
 +                                       ((SOURCE) == RCC_SAIBCLKSource_PLLSAI) ||\
 +                                       ((SOURCE) == RCC_SAIBCLKSource_Ext))
 +/**
 +  * @}
 +  */ 
 +
  /** @defgroup RCC_TIM_PRescaler_Selection
    * @{
    */
 @@ -277,7 +323,9 @@ typedef struct  #define RCC_AHB1Periph_GPIOF             ((uint32_t)0x00000020)
  #define RCC_AHB1Periph_GPIOG             ((uint32_t)0x00000040)
  #define RCC_AHB1Periph_GPIOH             ((uint32_t)0x00000080)
 -#define RCC_AHB1Periph_GPIOI             ((uint32_t)0x00000100)
 +#define RCC_AHB1Periph_GPIOI             ((uint32_t)0x00000100) 
 +#define RCC_AHB1Periph_GPIOJ             ((uint32_t)0x00000200)
 +#define RCC_AHB1Periph_GPIOK             ((uint32_t)0x00000400)
  #define RCC_AHB1Periph_CRC               ((uint32_t)0x00001000)
  #define RCC_AHB1Periph_FLITF             ((uint32_t)0x00008000)
  #define RCC_AHB1Periph_SRAM1             ((uint32_t)0x00010000)
 @@ -287,6 +335,7 @@ typedef struct  #define RCC_AHB1Periph_CCMDATARAMEN      ((uint32_t)0x00100000)
  #define RCC_AHB1Periph_DMA1              ((uint32_t)0x00200000)
  #define RCC_AHB1Periph_DMA2              ((uint32_t)0x00400000)
 +#define RCC_AHB1Periph_DMA2D             ((uint32_t)0x00800000)
  #define RCC_AHB1Periph_ETH_MAC           ((uint32_t)0x02000000)
  #define RCC_AHB1Periph_ETH_MAC_Tx        ((uint32_t)0x04000000)
  #define RCC_AHB1Periph_ETH_MAC_Rx        ((uint32_t)0x08000000)
 @@ -294,10 +343,9 @@ typedef struct  #define RCC_AHB1Periph_OTG_HS            ((uint32_t)0x20000000)
  #define RCC_AHB1Periph_OTG_HS_ULPI       ((uint32_t)0x40000000)
 -#define IS_RCC_AHB1_CLOCK_PERIPH(PERIPH) ((((PERIPH) & 0x818BEE00) == 0x00) && ((PERIPH) != 0x00))
 -#define IS_RCC_AHB1_RESET_PERIPH(PERIPH) ((((PERIPH) & 0xDD9FEE00) == 0x00) && ((PERIPH) != 0x00))
 -#define IS_RCC_AHB1_LPMODE_PERIPH(PERIPH) ((((PERIPH) & 0x81906E00) == 0x00) && ((PERIPH) != 0x00))
 -
 +#define IS_RCC_AHB1_CLOCK_PERIPH(PERIPH) ((((PERIPH) & 0x810BE800) == 0x00) && ((PERIPH) != 0x00))
 +#define IS_RCC_AHB1_RESET_PERIPH(PERIPH) ((((PERIPH) & 0xDD1FE800) == 0x00) && ((PERIPH) != 0x00))
 +#define IS_RCC_AHB1_LPMODE_PERIPH(PERIPH) ((((PERIPH) & 0x81106800) == 0x00) && ((PERIPH) != 0x00))
  /**
    * @}
 @@ -319,7 +367,13 @@ typedef struct  /** @defgroup RCC_AHB3_Peripherals 
    * @{
    */ 
 +#if defined (STM32F40_41xxx)
  #define RCC_AHB3Periph_FSMC                ((uint32_t)0x00000001)
 +#endif /* STM32F40_41xxx */
 +
 +#if defined (STM32F427_437xx) || defined (STM32F429_439xx) 
 +#define RCC_AHB3Periph_FMC                ((uint32_t)0x00000001)
 +#endif /* STM32F427_437xx ||  STM32F429_439xx */
  #define IS_RCC_AHB3_PERIPH(PERIPH) ((((PERIPH) & 0xFFFFFFFE) == 0x00) && ((PERIPH) != 0x00))
  /**
 @@ -379,10 +433,11 @@ typedef struct  #define RCC_APB2Periph_TIM11             ((uint32_t)0x00040000)
  #define RCC_APB2Periph_SPI5              ((uint32_t)0x00100000)
  #define RCC_APB2Periph_SPI6              ((uint32_t)0x00200000)
 +#define RCC_APB2Periph_SAI1              ((uint32_t)0x00400000)
 +#define RCC_APB2Periph_LTDC              ((uint32_t)0x04000000)
 -#define IS_RCC_APB2_PERIPH(PERIPH) ((((PERIPH) & 0xFFC880CC) == 0x00) && ((PERIPH) != 0x00))
 -#define IS_RCC_APB2_RESET_PERIPH(PERIPH) ((((PERIPH) & 0xFFC886CC) == 0x00) && ((PERIPH) != 0x00))
 -
 +#define IS_RCC_APB2_PERIPH(PERIPH) ((((PERIPH) & 0xFB8880CC) == 0x00) && ((PERIPH) != 0x00))
 +#define IS_RCC_APB2_RESET_PERIPH(PERIPH) ((((PERIPH) & 0xFB8886CC) == 0x00) && ((PERIPH) != 0x00))
  /**
    * @}
 @@ -439,6 +494,7 @@ typedef struct  #define RCC_FLAG_HSERDY                  ((uint8_t)0x31)
  #define RCC_FLAG_PLLRDY                  ((uint8_t)0x39)
  #define RCC_FLAG_PLLI2SRDY               ((uint8_t)0x3B)
 +#define RCC_FLAG_PLLSAIRDY               ((uint8_t)0x3D)
  #define RCC_FLAG_LSERDY                  ((uint8_t)0x41)
  #define RCC_FLAG_LSIRDY                  ((uint8_t)0x61)
  #define RCC_FLAG_BORRST                  ((uint8_t)0x79)
 @@ -449,13 +505,13 @@ typedef struct  #define RCC_FLAG_WWDGRST                 ((uint8_t)0x7E)
  #define RCC_FLAG_LPWRRST                 ((uint8_t)0x7F)
 -#define IS_RCC_FLAG(FLAG) (((FLAG) == RCC_FLAG_HSIRDY) || ((FLAG) == RCC_FLAG_HSERDY) || \
 -                           ((FLAG) == RCC_FLAG_PLLRDY) || ((FLAG) == RCC_FLAG_LSERDY) || \
 -                           ((FLAG) == RCC_FLAG_LSIRDY) || ((FLAG) == RCC_FLAG_BORRST) || \
 -                           ((FLAG) == RCC_FLAG_PINRST) || ((FLAG) == RCC_FLAG_PORRST) || \
 -                           ((FLAG) == RCC_FLAG_SFTRST) || ((FLAG) == RCC_FLAG_IWDGRST)|| \
 -                           ((FLAG) == RCC_FLAG_WWDGRST)|| ((FLAG) == RCC_FLAG_LPWRRST)|| \
 -                           ((FLAG) == RCC_FLAG_PLLI2SRDY))
 +#define IS_RCC_FLAG(FLAG) (((FLAG) == RCC_FLAG_HSIRDY)   || ((FLAG) == RCC_FLAG_HSERDY) || \
 +                           ((FLAG) == RCC_FLAG_PLLRDY)   || ((FLAG) == RCC_FLAG_LSERDY) || \
 +                           ((FLAG) == RCC_FLAG_LSIRDY)   || ((FLAG) == RCC_FLAG_BORRST) || \
 +                           ((FLAG) == RCC_FLAG_PINRST)   || ((FLAG) == RCC_FLAG_PORRST) || \
 +                           ((FLAG) == RCC_FLAG_SFTRST)   || ((FLAG) == RCC_FLAG_IWDGRST)|| \
 +                           ((FLAG) == RCC_FLAG_WWDGRST)  || ((FLAG) == RCC_FLAG_LPWRRST)|| \
 +                           ((FLAG) == RCC_FLAG_PLLI2SRDY)|| ((FLAG) == RCC_FLAG_PLLSAIRDY))
  #define IS_RCC_CALIBRATION_VALUE(VALUE) ((VALUE) <= 0x1F)
  /**
 @@ -479,54 +535,68 @@ void        RCC_AdjustHSICalibrationValue(uint8_t HSICalibrationValue);  void        RCC_HSICmd(FunctionalState NewState);
  void        RCC_LSEConfig(uint8_t RCC_LSE);
  void        RCC_LSICmd(FunctionalState NewState);
 -
  void        RCC_PLLConfig(uint32_t RCC_PLLSource, uint32_t PLLM, uint32_t PLLN, uint32_t PLLP, uint32_t PLLQ);
  void        RCC_PLLCmd(FunctionalState NewState);
 +
 +#if defined (STM32F40_41xxx) || defined (STM32F401xx)
  void        RCC_PLLI2SConfig(uint32_t PLLI2SN, uint32_t PLLI2SR);
 +#endif /* STM32F40_41xxx || STM32F401xx */
 +
 +#if defined (STM32F427_437xx) || defined (STM32F429_439xx)
 +void        RCC_PLLI2SConfig(uint32_t PLLI2SN, uint32_t PLLI2SQ, uint32_t PLLI2SR);
 +#endif /* STM32F41_43xxx */
 +
  void        RCC_PLLI2SCmd(FunctionalState NewState);
 +void        RCC_PLLSAIConfig(uint32_t PLLSAIN, uint32_t PLLSAIQ, uint32_t PLLSAIR);
 +void        RCC_PLLSAICmd(FunctionalState NewState);
  void        RCC_ClockSecuritySystemCmd(FunctionalState NewState);
  void        RCC_MCO1Config(uint32_t RCC_MCO1Source, uint32_t RCC_MCO1Div);
  void        RCC_MCO2Config(uint32_t RCC_MCO2Source, uint32_t RCC_MCO2Div);
  /* System, AHB and APB busses clocks configuration functions ******************/
 -void    RCC_SYSCLKConfig(uint32_t RCC_SYSCLKSource);
 -uint8_t RCC_GetSYSCLKSource(void);
 -void    RCC_HCLKConfig(uint32_t RCC_SYSCLK);
 -void    RCC_PCLK1Config(uint32_t RCC_HCLK);
 -void    RCC_PCLK2Config(uint32_t RCC_HCLK);
 -void    RCC_GetClocksFreq(RCC_ClocksTypeDef* RCC_Clocks);
 +void        RCC_SYSCLKConfig(uint32_t RCC_SYSCLKSource);
 +uint8_t     RCC_GetSYSCLKSource(void);
 +void        RCC_HCLKConfig(uint32_t RCC_SYSCLK);
 +void        RCC_PCLK1Config(uint32_t RCC_HCLK);
 +void        RCC_PCLK2Config(uint32_t RCC_HCLK);
 +void        RCC_GetClocksFreq(RCC_ClocksTypeDef* RCC_Clocks);
  /* Peripheral clocks configuration functions **********************************/
 -void RCC_RTCCLKConfig(uint32_t RCC_RTCCLKSource);
 -void RCC_RTCCLKCmd(FunctionalState NewState);
 -void RCC_BackupResetCmd(FunctionalState NewState);
 -void RCC_I2SCLKConfig(uint32_t RCC_I2SCLKSource); 
 -void RCC_TIMCLKPresConfig(uint32_t RCC_TIMCLKPrescaler);
 -
 -void RCC_AHB1PeriphClockCmd(uint32_t RCC_AHB1Periph, FunctionalState NewState);
 -void RCC_AHB2PeriphClockCmd(uint32_t RCC_AHB2Periph, FunctionalState NewState);
 -void RCC_AHB3PeriphClockCmd(uint32_t RCC_AHB3Periph, FunctionalState NewState);
 -void RCC_APB1PeriphClockCmd(uint32_t RCC_APB1Periph, FunctionalState NewState);
 -void RCC_APB2PeriphClockCmd(uint32_t RCC_APB2Periph, FunctionalState NewState);
 -
 -void RCC_AHB1PeriphResetCmd(uint32_t RCC_AHB1Periph, FunctionalState NewState);
 -void RCC_AHB2PeriphResetCmd(uint32_t RCC_AHB2Periph, FunctionalState NewState);
 -void RCC_AHB3PeriphResetCmd(uint32_t RCC_AHB3Periph, FunctionalState NewState);
 -void RCC_APB1PeriphResetCmd(uint32_t RCC_APB1Periph, FunctionalState NewState);
 -void RCC_APB2PeriphResetCmd(uint32_t RCC_APB2Periph, FunctionalState NewState);
 -
 -void RCC_AHB1PeriphClockLPModeCmd(uint32_t RCC_AHB1Periph, FunctionalState NewState);
 -void RCC_AHB2PeriphClockLPModeCmd(uint32_t RCC_AHB2Periph, FunctionalState NewState);
 -void RCC_AHB3PeriphClockLPModeCmd(uint32_t RCC_AHB3Periph, FunctionalState NewState);
 -void RCC_APB1PeriphClockLPModeCmd(uint32_t RCC_APB1Periph, FunctionalState NewState);
 -void RCC_APB2PeriphClockLPModeCmd(uint32_t RCC_APB2Periph, FunctionalState NewState);
 +void        RCC_RTCCLKConfig(uint32_t RCC_RTCCLKSource);
 +void        RCC_RTCCLKCmd(FunctionalState NewState);
 +void        RCC_BackupResetCmd(FunctionalState NewState);
 +void        RCC_I2SCLKConfig(uint32_t RCC_I2SCLKSource); 
 +void        RCC_SAIPLLI2SClkDivConfig(uint32_t RCC_PLLI2SDivQ);
 +void        RCC_SAIPLLSAIClkDivConfig(uint32_t RCC_PLLSAIDivQ);
 +void        RCC_SAIBlockACLKConfig(uint32_t RCC_SAIBlockACLKSource);
 +void        RCC_SAIBlockBCLKConfig(uint32_t RCC_SAIBlockBCLKSource);
 +void        RCC_LTDCCLKDivConfig(uint32_t RCC_PLLSAIDivR);
 +void        RCC_TIMCLKPresConfig(uint32_t RCC_TIMCLKPrescaler);
 +
 +void        RCC_AHB1PeriphClockCmd(uint32_t RCC_AHB1Periph, FunctionalState NewState);
 +void        RCC_AHB2PeriphClockCmd(uint32_t RCC_AHB2Periph, FunctionalState NewState);
 +void        RCC_AHB3PeriphClockCmd(uint32_t RCC_AHB3Periph, FunctionalState NewState);
 +void        RCC_APB1PeriphClockCmd(uint32_t RCC_APB1Periph, FunctionalState NewState);
 +void        RCC_APB2PeriphClockCmd(uint32_t RCC_APB2Periph, FunctionalState NewState);
 +
 +void        RCC_AHB1PeriphResetCmd(uint32_t RCC_AHB1Periph, FunctionalState NewState);
 +void        RCC_AHB2PeriphResetCmd(uint32_t RCC_AHB2Periph, FunctionalState NewState);
 +void        RCC_AHB3PeriphResetCmd(uint32_t RCC_AHB3Periph, FunctionalState NewState);
 +void        RCC_APB1PeriphResetCmd(uint32_t RCC_APB1Periph, FunctionalState NewState);
 +void        RCC_APB2PeriphResetCmd(uint32_t RCC_APB2Periph, FunctionalState NewState);
 +
 +void        RCC_AHB1PeriphClockLPModeCmd(uint32_t RCC_AHB1Periph, FunctionalState NewState);
 +void        RCC_AHB2PeriphClockLPModeCmd(uint32_t RCC_AHB2Periph, FunctionalState NewState);
 +void        RCC_AHB3PeriphClockLPModeCmd(uint32_t RCC_AHB3Periph, FunctionalState NewState);
 +void        RCC_APB1PeriphClockLPModeCmd(uint32_t RCC_APB1Periph, FunctionalState NewState);
 +void        RCC_APB2PeriphClockLPModeCmd(uint32_t RCC_APB2Periph, FunctionalState NewState);
  /* Interrupts and flags management functions **********************************/
 -void       RCC_ITConfig(uint8_t RCC_IT, FunctionalState NewState);
 -FlagStatus RCC_GetFlagStatus(uint8_t RCC_FLAG);
 -void       RCC_ClearFlag(void);
 -ITStatus   RCC_GetITStatus(uint8_t RCC_IT);
 -void       RCC_ClearITPendingBit(uint8_t RCC_IT);
 +void        RCC_ITConfig(uint8_t RCC_IT, FunctionalState NewState);
 +FlagStatus  RCC_GetFlagStatus(uint8_t RCC_FLAG);
 +void        RCC_ClearFlag(void);
 +ITStatus    RCC_GetITStatus(uint8_t RCC_IT);
 +void        RCC_ClearITPendingBit(uint8_t RCC_IT);
  #ifdef __cplusplus
  }
 diff --git a/stm/lib/stm32f4xx_rng.c b/stm/lib/stm32f4xx_rng.c index 3fb52f291..4746dd6bd 100644 --- a/stm/lib/stm32f4xx_rng.c +++ b/stm/lib/stm32f4xx_rng.c @@ -2,8 +2,8 @@    ******************************************************************************
    * @file    stm32f4xx_rng.c
    * @author  MCD Application Team
 -  * @version V1.1.0
 -  * @date    11-January-2013
 +  * @version V1.3.0
 +  * @date    08-November-2013
    * @brief This file provides firmware functions to manage the following 
    *          functionalities of the Random Number Generator (RNG) peripheral:           
    *           + Initialization and Configuration 
 @@ -53,7 +53,6 @@    */
  /* Includes ------------------------------------------------------------------*/
 -#include "stm32f4xx_conf.h"
  #include "stm32f4xx_rng.h"
  #include "stm32f4xx_rcc.h"
 diff --git a/stm/lib/stm32f4xx_rng.h b/stm/lib/stm32f4xx_rng.h index 6de413c86..874c9bab5 100644 --- a/stm/lib/stm32f4xx_rng.h +++ b/stm/lib/stm32f4xx_rng.h @@ -2,8 +2,8 @@    ******************************************************************************
    * @file    stm32f4xx_rng.h
    * @author  MCD Application Team
 -  * @version V1.1.0
 -  * @date    11-January-2013
 +  * @version V1.3.0
 +  * @date    08-November-2013
    * @brief   This file contains all the functions prototypes for the Random 
    *          Number Generator(RNG) firmware library.
    ******************************************************************************
 diff --git a/stm/lib/stm32f4xx_rtc.c b/stm/lib/stm32f4xx_rtc.c index 339ec9e4d..5d96db5a3 100644 --- a/stm/lib/stm32f4xx_rtc.c +++ b/stm/lib/stm32f4xx_rtc.c @@ -2,8 +2,8 @@    ******************************************************************************
    * @file    stm32f4xx_rtc.c
    * @author  MCD Application Team
 -  * @version V1.1.0
 -  * @date    11-January-2013
 +  * @version V1.3.0
 +  * @date    08-November-2013
    * @brief   This file provides firmware functions to manage the following 
    *          functionalities of the Real-Time Clock (RTC) peripheral:
    *           + Initialization
 @@ -282,7 +282,6 @@    */ 
  /* Includes ------------------------------------------------------------------*/
 -#include "stm32f4xx_conf.h"
  #include "stm32f4xx_rtc.h"
  /** @addtogroup STM32F4xx_StdPeriph_Driver
 diff --git a/stm/lib/stm32f4xx_rtc.h b/stm/lib/stm32f4xx_rtc.h index 51e2cfd63..a46227e53 100644 --- a/stm/lib/stm32f4xx_rtc.h +++ b/stm/lib/stm32f4xx_rtc.h @@ -2,8 +2,8 @@    ******************************************************************************
    * @file    stm32f4xx_rtc.h
    * @author  MCD Application Team
 -  * @version V1.1.0
 -  * @date    11-January-2013
 +  * @version V1.3.0
 +  * @date    08-November-2013
    * @brief   This file contains all the functions prototypes for the RTC firmware
    *          library.
    ******************************************************************************
 diff --git a/stm/lib/stm32f4xx_sdio.c b/stm/lib/stm32f4xx_sdio.c index 8ee5d55b8..aead846a1 100644 --- a/stm/lib/stm32f4xx_sdio.c +++ b/stm/lib/stm32f4xx_sdio.c @@ -2,8 +2,8 @@    ******************************************************************************
    * @file    stm32f4xx_sdio.c
    * @author  MCD Application Team
 -  * @version V1.1.0
 -  * @date    11-January-2013
 +  * @version V1.3.0
 +  * @date    08-November-2013
    * @brief   This file provides firmware functions to manage the following 
    *          functionalities of the Secure digital input/output interface (SDIO) 
    *          peripheral:
 @@ -153,7 +153,6 @@    */
  /* Includes ------------------------------------------------------------------*/
 -#include "stm32f4xx_conf.h"
  #include "stm32f4xx_sdio.h"
  #include "stm32f4xx_rcc.h"
 diff --git a/stm/lib/stm32f4xx_sdio.h b/stm/lib/stm32f4xx_sdio.h index 0765a09cc..05e0afa3c 100644 --- a/stm/lib/stm32f4xx_sdio.h +++ b/stm/lib/stm32f4xx_sdio.h @@ -2,8 +2,8 @@    ******************************************************************************
    * @file    stm32f4xx_sdio.h
    * @author  MCD Application Team
 -  * @version V1.1.0
 -  * @date    11-January-2013
 +  * @version V1.3.0
 +  * @date    08-November-2013
    * @brief   This file contains all the functions prototypes for the SDIO firmware
    *          library.
    ******************************************************************************
 @@ -459,8 +459,8 @@ typedef struct    * @{
    */
 -#define SDIO_ReadWaitMode_CLK               ((uint32_t)0x00000000)
 -#define SDIO_ReadWaitMode_DATA2             ((uint32_t)0x00000001)
 +#define SDIO_ReadWaitMode_DATA2             ((uint32_t)0x00000000)
 +#define SDIO_ReadWaitMode_CLK               ((uint32_t)0x00000001)
  #define IS_SDIO_READWAIT_MODE(MODE) (((MODE) == SDIO_ReadWaitMode_CLK) || \
                                       ((MODE) == SDIO_ReadWaitMode_DATA2))
  /**
 diff --git a/stm/lib/stm32f4xx_spi.c b/stm/lib/stm32f4xx_spi.c index ad4eb8ce0..eb725f46e 100644 --- a/stm/lib/stm32f4xx_spi.c +++ b/stm/lib/stm32f4xx_spi.c @@ -2,8 +2,8 @@    ******************************************************************************
    * @file    stm32f4xx_spi.c
    * @author  MCD Application Team
 -  * @version V1.1.0
 -  * @date    11-January-2013
 +  * @version V1.3.0
 +  * @date    08-November-2013
    * @brief   This file provides firmware functions to manage the following 
    *          functionalities of the Serial peripheral interface (SPI):
    *           + Initialization and Configuration
 @@ -156,7 +156,6 @@    */ 
  /* Includes ------------------------------------------------------------------*/
 -#include "stm32f4xx_conf.h"
  #include "stm32f4xx_spi.h"
  #include "stm32f4xx_rcc.h"
 diff --git a/stm/lib/stm32f4xx_spi.h b/stm/lib/stm32f4xx_spi.h index e7e2fc8f6..7f4834bfd 100644 --- a/stm/lib/stm32f4xx_spi.h +++ b/stm/lib/stm32f4xx_spi.h @@ -2,8 +2,8 @@    ******************************************************************************
    * @file    stm32f4xx_spi.h
    * @author  MCD Application Team
 -  * @version V1.1.0
 -  * @date    11-January-2013
 +  * @version V1.3.0
 +  * @date    08-November-2013
    * @brief   This file contains all the functions prototypes for the SPI 
    *          firmware library. 
    ******************************************************************************
 diff --git a/stm/lib/stm32f4xx_syscfg.c b/stm/lib/stm32f4xx_syscfg.c index 6b3ada053..638f76115 100644 --- a/stm/lib/stm32f4xx_syscfg.c +++ b/stm/lib/stm32f4xx_syscfg.c @@ -2,8 +2,8 @@    ******************************************************************************
    * @file    stm32f4xx_syscfg.c
    * @author  MCD Application Team
 -  * @version V1.1.0
 -  * @date    11-January-2013
 +  * @version V1.3.0
 +  * @date    08-November-2013
    * @brief   This file provides firmware functions to manage the SYSCFG peripheral.
    *
   @verbatim
 @@ -14,7 +14,10 @@      [..] This driver provides functions for:
         (#) Remapping the memory accessible in the code area using SYSCFG_MemoryRemapConfig()
 -                            
 +            
 +       (#) Swapping the internal flash Bank1 and Bank2 this features is only visible for 
 +           STM32F42xxx/43xxx devices Devices. 
 +                
         (#) Manage the EXTI lines connection to the GPIOs using SYSCFG_EXTILineConfig()
         (#) Select the ETHERNET media interface (RMII/RII) using SYSCFG_ETH_MediaInterfaceConfig()
 @@ -44,7 +47,6 @@    */
  /* Includes ------------------------------------------------------------------*/
 -#include "stm32f4xx_conf.h"
  #include "stm32f4xx_syscfg.h"
  #include "stm32f4xx_rcc.h"
 @@ -61,6 +63,12 @@  /* Private define ------------------------------------------------------------*/
  /* ------------ RCC registers bit address in the alias region ----------- */
  #define SYSCFG_OFFSET             (SYSCFG_BASE - PERIPH_BASE)
 +/* ---  MEMRMP Register ---*/ 
 +/* Alias word address of UFB_MODE bit */ 
 +#define MEMRMP_OFFSET             SYSCFG_OFFSET 
 +#define UFB_MODE_BitNumber        ((uint8_t)0x8) 
 +#define UFB_MODE_BB               (PERIPH_BB_BASE + (MEMRMP_OFFSET * 32) + (UFB_MODE_BitNumber * 4)) 
 +
  /* ---  PMC Register ---*/ 
  /* Alias word address of MII_RMII_SEL bit */ 
 @@ -101,8 +109,10 @@ void SYSCFG_DeInit(void)    *         This parameter can be one of the following values:
    *            @arg SYSCFG_MemoryRemap_Flash:       Main Flash memory mapped at 0x00000000  
    *            @arg SYSCFG_MemoryRemap_SystemFlash: System Flash memory mapped at 0x00000000
 -  *            @arg SYSCFG_MemoryRemap_FSMC:        FSMC (Bank1 (NOR/PSRAM 1 and 2) mapped at 0x00000000   
 -  *            @arg SYSCFG_MemoryRemap_SRAM:        Embedded SRAM (112kB) mapped at 0x00000000          
 +  *            @arg SYSCFG_MemoryRemap_FSMC:        FSMC (Bank1 (NOR/PSRAM 1 and 2) mapped at 0x00000000 for STM32F405xx/407xx and STM32F415xx/417xx devices. 
 +  *            @arg SYSCFG_MemoryRemap_FMC:         FMC (Bank1 (NOR/PSRAM 1 and 2) mapped at 0x00000000 for STM32F42xxx/43xxx devices.  
 +  *            @arg SYSCFG_MemoryRemap_SRAM:        Embedded SRAM (112kB) mapped at 0x00000000
 +  *            @arg SYSCFG_MemoryRemap_SDRAM:       FMC (External SDRAM)  mapped at 0x00000000 for STM32F42xxx/43xxx devices.            
    * @retval None
    */
  void SYSCFG_MemoryRemapConfig(uint8_t SYSCFG_MemoryRemap)
 @@ -114,15 +124,38 @@ void SYSCFG_MemoryRemapConfig(uint8_t SYSCFG_MemoryRemap)  }
  /**
 +  * @brief  Enables or disables the Interal FLASH Bank Swapping.
 +  *   
 +  * @note   This function can be used only for STM32F42xxx/43xxx devices. 
 +  *
 +  * @param  NewState: new state of Interal FLASH Bank swapping.
 +  *          This parameter can be one of the following values:
 +  *            @arg ENABLE: Flash Bank2 mapped at 0x08000000 (and aliased @0x00000000) 
 +  *                         and Flash Bank1 mapped at 0x08100000 (and aliased at 0x00100000)   
 +  *            @arg DISABLE:(the default state) Flash Bank1 mapped at 0x08000000 (and aliased @0x0000 0000) 
 +                            and Flash Bank2 mapped at 0x08100000 (and aliased at 0x00100000)  
 +  * @retval None
 +  */
 +void SYSCFG_MemorySwappingBank(FunctionalState NewState)
 +{
 +  /* Check the parameters */
 +  assert_param(IS_FUNCTIONAL_STATE(NewState));
 +
 +  *(__IO uint32_t *) UFB_MODE_BB = (uint32_t)NewState;
 +}
 +
 +/**
    * @brief  Selects the GPIO pin used as EXTI Line.
    * @param  EXTI_PortSourceGPIOx : selects the GPIO port to be used as source for
 -  *          EXTI lines where x can be (A..I)  for STM32F40xx/STM32F41xx 
 -  *         and STM32F427x/STM32F437x devices.
 +  *          EXTI lines where x can be (A..K) for STM32F42xxx/43xxx devices, (A..I) 
 +  *          for STM32F405xx/407xx and STM32F415xx/417xx devices or (A, B, C, D and H)
 +  *          for STM32401xx devices.  
    *            
    * @param  EXTI_PinSourcex: specifies the EXTI line to be configured.
    *           This parameter can be EXTI_PinSourcex where x can be (0..15, except
 -  *           for EXTI_PortSourceGPIOI x can be (0..11) for STM32F40xx/STM32F41xx 
 -  *           and STM32F427x/STM32F437x devices. 
 +  *           for EXTI_PortSourceGPIOI x can be (0..11) for STM32F405xx/407xx
 +  *           and STM32F405xx/407xx devices and for EXTI_PortSourceGPIOK x can   
 +  *           be (0..7) for STM32F42xxx/43xxx devices. 
    *             
    * @retval None
    */
 diff --git a/stm/lib/stm32f4xx_syscfg.h b/stm/lib/stm32f4xx_syscfg.h index 604c337a1..7d3cc4288 100644 --- a/stm/lib/stm32f4xx_syscfg.h +++ b/stm/lib/stm32f4xx_syscfg.h @@ -2,8 +2,8 @@    ******************************************************************************
    * @file    stm32f4xx_syscfg.h
    * @author  MCD Application Team
 -  * @version V1.1.0
 -  * @date    11-January-2013
 +  * @version V1.3.0
 +  * @date    08-November-2013
    * @brief   This file contains all the functions prototypes for the SYSCFG firmware
    *          library. 
    ******************************************************************************
 @@ -64,7 +64,9 @@  #define EXTI_PortSourceGPIOG       ((uint8_t)0x06)
  #define EXTI_PortSourceGPIOH       ((uint8_t)0x07)
  #define EXTI_PortSourceGPIOI       ((uint8_t)0x08)
 -  
 +#define EXTI_PortSourceGPIOJ       ((uint8_t)0x09)
 +#define EXTI_PortSourceGPIOK       ((uint8_t)0x0A)
 +
  #define IS_EXTI_PORT_SOURCE(PORTSOURCE) (((PORTSOURCE) == EXTI_PortSourceGPIOA) || \
                                           ((PORTSOURCE) == EXTI_PortSourceGPIOB) || \
                                           ((PORTSOURCE) == EXTI_PortSourceGPIOC) || \
 @@ -73,7 +75,9 @@                                           ((PORTSOURCE) == EXTI_PortSourceGPIOF) || \
                                           ((PORTSOURCE) == EXTI_PortSourceGPIOG) || \
                                           ((PORTSOURCE) == EXTI_PortSourceGPIOH) || \
 -                                         ((PORTSOURCE) == EXTI_PortSourceGPIOI))
 +                                         ((PORTSOURCE) == EXTI_PortSourceGPIOI) || \
 +                                         ((PORTSOURCE) == EXTI_PortSourceGPIOJ) || \
 +                                         ((PORTSOURCE) == EXTI_PortSourceGPIOK))
  /**
    * @}
 @@ -126,12 +130,36 @@  #define SYSCFG_MemoryRemap_Flash       ((uint8_t)0x00)
  #define SYSCFG_MemoryRemap_SystemFlash ((uint8_t)0x01)
  #define SYSCFG_MemoryRemap_SRAM        ((uint8_t)0x03)
 +#define SYSCFG_MemoryRemap_SDRAM       ((uint8_t)0x04)
 +
 +#if defined (STM32F40_41xxx)
  #define SYSCFG_MemoryRemap_FSMC        ((uint8_t)0x02) 
 +#endif /* STM32F40_41xxx */
 +#if defined (STM32F427_437xx) || defined (STM32F429_439xx)
 +#define SYSCFG_MemoryRemap_FMC         ((uint8_t)0x02) 
 +#endif /* STM32F427_437xx ||  STM32F429_439xx */  
 +
 +#if defined (STM32F40_41xxx) 
  #define IS_SYSCFG_MEMORY_REMAP_CONFING(REMAP) (((REMAP) == SYSCFG_MemoryRemap_Flash)       || \
                                                 ((REMAP) == SYSCFG_MemoryRemap_SystemFlash) || \
                                                 ((REMAP) == SYSCFG_MemoryRemap_SRAM)        || \
                                                 ((REMAP) == SYSCFG_MemoryRemap_FSMC))
 +#endif /* STM32F40_41xxx */
 +
 +#if defined (STM32F401xx) 
 +#define IS_SYSCFG_MEMORY_REMAP_CONFING(REMAP) (((REMAP) == SYSCFG_MemoryRemap_Flash)       || \
 +                                               ((REMAP) == SYSCFG_MemoryRemap_SystemFlash) || \
 +                                               ((REMAP) == SYSCFG_MemoryRemap_SRAM))
 +#endif /* STM32F401xx */
 +
 +#if defined (STM32F427_437xx) || defined (STM32F429_439xx)
 +#define IS_SYSCFG_MEMORY_REMAP_CONFING(REMAP) (((REMAP) == SYSCFG_MemoryRemap_Flash)       || \
 +                                               ((REMAP) == SYSCFG_MemoryRemap_SystemFlash) || \
 +                                               ((REMAP) == SYSCFG_MemoryRemap_SRAM)        || \
 +                                               ((REMAP) == SYSCFG_MemoryRemap_SDRAM)       || \
 +                                               ((REMAP) == SYSCFG_MemoryRemap_FMC))
 +#endif /* STM32F427_437xx ||  STM32F429_439xx */
  /**
    * @}
 @@ -157,8 +185,9 @@  /* Exported macro ------------------------------------------------------------*/
  /* Exported functions --------------------------------------------------------*/ 
 -void       SYSCFG_DeInit(void);
 +void SYSCFG_DeInit(void);
  void       SYSCFG_MemoryRemapConfig(uint8_t SYSCFG_MemoryRemap);
 +void       SYSCFG_MemorySwappingBank(FunctionalState NewState);
  void       SYSCFG_EXTILineConfig(uint8_t EXTI_PortSourceGPIOx, uint8_t EXTI_PinSourcex);
  void       SYSCFG_ETH_MediaInterfaceConfig(uint32_t SYSCFG_ETH_MediaInterface); 
  void       SYSCFG_CompensationCellCmd(FunctionalState NewState); 
 diff --git a/stm/lib/stm32f4xx_tim.c b/stm/lib/stm32f4xx_tim.c index e9c5655b9..9a17ac316 100644 --- a/stm/lib/stm32f4xx_tim.c +++ b/stm/lib/stm32f4xx_tim.c @@ -2,8 +2,8 @@    ******************************************************************************
    * @file    stm32f4xx_tim.c
    * @author  MCD Application Team
 -  * @version V1.1.0
 -  * @date    11-January-2013
 +  * @version V1.3.0
 +  * @date    08-November-2013
    * @brief   This file provides firmware functions to manage the following 
    *          functionalities of the TIM peripheral:
    *            + TimeBase management
 @@ -116,7 +116,6 @@    */
  /* Includes ------------------------------------------------------------------*/
 -#include "stm32f4xx_conf.h"
  #include "stm32f4xx_tim.h"
  #include "stm32f4xx_rcc.h"
 diff --git a/stm/lib/stm32f4xx_tim.h b/stm/lib/stm32f4xx_tim.h index 94c225619..7983cc024 100644 --- a/stm/lib/stm32f4xx_tim.h +++ b/stm/lib/stm32f4xx_tim.h @@ -2,8 +2,8 @@    ******************************************************************************
    * @file    stm32f4xx_tim.h
    * @author  MCD Application Team
 -  * @version V1.1.0
 -  * @date    11-January-2013
 +  * @version V1.3.0
 +  * @date    08-November-2013
    * @brief   This file contains all the functions prototypes for the TIM firmware 
    *          library.
    ******************************************************************************
 diff --git a/stm/lib/stm32f4xx_usart.c b/stm/lib/stm32f4xx_usart.c index bf9f4d737..f786c942c 100644 --- a/stm/lib/stm32f4xx_usart.c +++ b/stm/lib/stm32f4xx_usart.c @@ -2,8 +2,8 @@    ******************************************************************************
    * @file    stm32f4xx_usart.c
    * @author  MCD Application Team
 -  * @version V1.1.0
 -  * @date    11-January-2013
 +  * @version V1.3.0
 +  * @date    08-November-2013
    * @brief   This file provides firmware functions to manage the following 
    *          functionalities of the Universal synchronous asynchronous receiver
    *          transmitter (USART):           
 @@ -89,7 +89,6 @@    */ 
  /* Includes ------------------------------------------------------------------*/
 -#include "stm32f4xx_conf.h"
  #include "stm32f4xx_usart.h"
  #include "stm32f4xx_rcc.h"
 diff --git a/stm/lib/stm32f4xx_usart.h b/stm/lib/stm32f4xx_usart.h index 391fe769d..dc011da7b 100644 --- a/stm/lib/stm32f4xx_usart.h +++ b/stm/lib/stm32f4xx_usart.h @@ -2,8 +2,8 @@    ******************************************************************************
    * @file    stm32f4xx_usart.h
    * @author  MCD Application Team
 -  * @version V1.1.0
 -  * @date    11-January-2013
 +  * @version V1.3.0
 +  * @date    08-November-2013
    * @brief   This file contains all the functions prototypes for the USART 
    *          firmware library.    
    ******************************************************************************
 diff --git a/stm/lib/stm_misc.c b/stm/lib/stm_misc.c index 7f12a3724..875584a66 100644 --- a/stm/lib/stm_misc.c +++ b/stm/lib/stm_misc.c @@ -2,8 +2,8 @@    ******************************************************************************
    * @file    misc.c
    * @author  MCD Application Team
 -  * @version V1.1.0
 -  * @date    11-January-2013
 +  * @version V1.3.0
 +  * @date    08-November-2013
    * @brief   This file provides all the miscellaneous firmware functions (add-on
    *          to CMSIS functions).
    *          
 @@ -73,7 +73,6 @@    */
  /* Includes ------------------------------------------------------------------*/
 -#include "stm32f4xx_conf.h"
  #include "stm_misc.h"
  /** @addtogroup STM32F4xx_StdPeriph_Driver
 diff --git a/stm/lib/stm_misc.h b/stm/lib/stm_misc.h index dec96ec2a..2d08fdd63 100644 --- a/stm/lib/stm_misc.h +++ b/stm/lib/stm_misc.h @@ -2,8 +2,8 @@    ******************************************************************************
    * @file    misc.h
    * @author  MCD Application Team
 -  * @version V1.1.0
 -  * @date    11-January-2013
 +  * @version V1.3.0
 +  * @date    08-November-2013
    * @brief   This file contains all the functions prototypes for the miscellaneous
    *          firmware library functions (add-on to CMSIS functions).
    ******************************************************************************
 diff --git a/stm/lib/system_stm32f4xx.h b/stm/lib/system_stm32f4xx.h index 98da16c1e..675593a84 100644 --- a/stm/lib/system_stm32f4xx.h +++ b/stm/lib/system_stm32f4xx.h @@ -2,8 +2,8 @@    ******************************************************************************
    * @file    system_stm32f4xx.h
    * @author  MCD Application Team
 -  * @version V1.1.0
 -  * @date    11-January-2013
 +  * @version V1.3.0
 +  * @date    08-November-2013
    * @brief   CMSIS Cortex-M4 Device System Source File for STM32F4xx devices.       
    ******************************************************************************  
    * @attention
 | 
