STM32Cube BSP FW for STM32F769I-Discovery

Dependents:   mbed-os-example-blinky-5 DISCO-F769NI_TOUCHSCREEN_demo_custom_1 Datarecorder2 DISCO-F769NI_TOUCHSCREEN_demo ... more

Revision:
0:c0f3bbab73d2
Child:
1:3e58f8a39705
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/Drivers/BSP/STM32F769I-Discovery/stm32f769i_discovery.h	Fri Feb 10 13:08:21 2017 +0100
@@ -0,0 +1,339 @@
+/**
+  ******************************************************************************
+  * @file    stm32f769i_discovery.h
+  * @author  MCD Application Team
+  * @version V1.1.0
+  * @date    29-August-2016
+  * @brief   This file contains definitions for STM32F769I-Discovery LEDs,
+  *          push-buttons hardware resources.
+  ******************************************************************************
+  * @attention
+  *
+  * <h2><center>&copy; COPYRIGHT(c) 2016 STMicroelectronics</center></h2>
+  *
+  * Redistribution and use in source and binary forms, with or without modification,
+  * are permitted provided that the following conditions are met:
+  *   1. Redistributions of source code must retain the above copyright notice,
+  *      this list of conditions and the following disclaimer.
+  *   2. Redistributions in binary form must reproduce the above copyright notice,
+  *      this list of conditions and the following disclaimer in the documentation
+  *      and/or other materials provided with the distribution.
+  *   3. Neither the name of STMicroelectronics nor the names of its contributors
+  *      may be used to endorse or promote products derived from this software
+  *      without specific prior written permission.
+  *
+  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
+  * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
+  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
+  * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
+  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
+  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
+  * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
+  * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
+  * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
+  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+  *
+  ******************************************************************************
+  */
+
+/* Define to prevent recursive inclusion -------------------------------------*/
+#ifndef __STM32F769I_DISCOVERY_H
+#define __STM32F769I_DISCOVERY_H
+
+#ifdef __cplusplus
+ extern "C" {
+#endif
+
+
+ /* Includes ------------------------------------------------------------------*/
+#include "stm32f7xx_hal.h"
+
+/** @addtogroup BSP
+  * @{
+  */
+
+/** @addtogroup STM32F769I_Discovery
+  * @{
+  */
+
+/** @defgroup STM32F769I_Discovery_LOW_LEVEL STM32F769I-Discovery LOW LEVEL
+  * @{
+  */
+
+/** @defgroup STM32F769I_Discovery_LOW_LEVEL_Exported_Types STM32F769I Discovery Low Level Exported Types
+ * @{
+ */
+
+/** 
+  * @brief  Define for STM32F769I_DISCOVERY board
+  */ 
+#if !defined (USE_STM32F769I_DISCO)
+ #define USE_STM32F769I_DISCO
+#endif
+
+/** @brief Led_TypeDef
+  *  STM32F769I_Discovery board leds definitions.
+  */
+typedef enum
+{
+ DISCO_LED1 = 0, // patch for MBED
+ LED_RED = DISCO_LED1, // patch for MBED
+ DISCO_LED2 = 1, // patch for MBED
+ LED_GREEN = DISCO_LED2 // patch for MBED
+} Led_TypeDef;
+
+/** @brief Button_TypeDef
+  *  STM32F769I_Discovery board Buttons definitions.
+  */
+typedef enum
+{
+  BUTTON_WAKEUP = 0,
+} Button_TypeDef;
+
+#define BUTTON_USER BUTTON_WAKEUP
+
+/** @brief ButtonMode_TypeDef
+  *  STM32F769I_Discovery board Buttons Modes definitions.
+  */
+typedef enum
+{
+ BUTTON_MODE_GPIO = 0,
+ BUTTON_MODE_EXTI = 1
+
+} ButtonMode_TypeDef;
+
+/** @addtogroup Exported_types
+  * @{
+  */ 
+typedef enum 
+{
+  PB_SET = 0, 
+  PB_RESET = !PB_SET
+} ButtonValue_TypeDef;
+
+
+/** @brief DISCO_Status_TypeDef
+  *  STM32F769I_DISCO board Status return possible values.
+  */
+typedef enum
+{
+ DISCO_OK    = 0,
+ DISCO_ERROR = 1
+
+} DISCO_Status_TypeDef;
+
+/**
+  * @}
+  */
+
+/** @defgroup STM32F769I_Discovery_LOW_LEVEL_Exported_Constants STM32F769I Discovery Low Level Exported Constants
+  * @{
+  */
+
+
+/** @addtogroup STM32F769I_Discovery_LOW_LEVEL_LED STM32F769I Discovery Low Level Led
+  * @{
+  */
+/* Always four leds for all revisions of Discovery boards */
+#define LEDn                             ((uint8_t)2)
+
+
+/* 2 Leds are connected to MCU directly on PJ13 and PJ5 */
+#define LED1_GPIO_PORT                   ((GPIO_TypeDef*)GPIOJ)
+#define LED2_GPIO_PORT                   ((GPIO_TypeDef*)GPIOJ)
+
+#define LEDx_GPIO_CLK_ENABLE()           __HAL_RCC_GPIOJ_CLK_ENABLE()
+#define LEDx_GPIO_CLK_DISABLE()          __HAL_RCC_GPIOJ_CLK_DISABLE()
+
+#define LED1_PIN                         ((uint32_t)GPIO_PIN_13)
+#define LED2_PIN                         ((uint32_t)GPIO_PIN_5)
+
+/**
+  * @}
+  */
+
+/** @addtogroup STM32F769I_Discovery_LOW_LEVEL_BUTTON STM32F769I Discovery Low Level Button
+  * @{
+  */
+/* Only one User/Wakeup button */
+#define BUTTONn                             ((uint8_t)1)
+
+/**
+  * @brief Wakeup push-button
+  */
+#define WAKEUP_BUTTON_PIN                   GPIO_PIN_0
+#define WAKEUP_BUTTON_GPIO_PORT             GPIOA
+#define WAKEUP_BUTTON_GPIO_CLK_ENABLE()     __HAL_RCC_GPIOA_CLK_ENABLE()
+#define WAKEUP_BUTTON_GPIO_CLK_DISABLE()    __HAL_RCC_GPIOA_CLK_DISABLE()
+#define WAKEUP_BUTTON_EXTI_IRQn             EXTI0_IRQn
+
+/* Define the USER button as an alias of the Wakeup button */
+#define USER_BUTTON_PIN                   WAKEUP_BUTTON_PIN
+#define USER_BUTTON_GPIO_PORT             WAKEUP_BUTTON_GPIO_PORT
+#define USER_BUTTON_GPIO_CLK_ENABLE()     WAKEUP_BUTTON_GPIO_CLK_ENABLE()
+#define USER_BUTTON_GPIO_CLK_DISABLE()    WAKEUP_BUTTON_GPIO_CLK_DISABLE()
+#define USER_BUTTON_EXTI_IRQn             WAKEUP_BUTTON_EXTI_IRQn
+
+#define BUTTON_GPIO_CLK_ENABLE()            __HAL_RCC_GPIOA_CLK_ENABLE()
+
+/**
+  * @}
+  */
+
+/**
+  * @brief USB OTG HS Over Current signal
+  */
+#define OTG_HS_OVER_CURRENT_PIN                  GPIO_PIN_4
+#define OTG_HS_OVER_CURRENT_PORT                 GPIOD
+#define OTG_HS_OVER_CURRENT_PORT_CLK_ENABLE()    __HAL_RCC_GPIOD_CLK_ENABLE()
+
+/**
+  * @brief SD-detect signal
+  */
+#define SD_DETECT_PIN                        ((uint32_t)GPIO_PIN_15)
+#define SD_DETECT_GPIO_PORT                  ((GPIO_TypeDef*)GPIOI)
+#define SD_DETECT_GPIO_CLK_ENABLE()          __HAL_RCC_GPIOI_CLK_ENABLE()
+#define SD_DETECT_GPIO_CLK_DISABLE()         __HAL_RCC_GPIOI_CLK_DISABLE()
+#define SD_DETECT_EXTI_IRQn                  EXTI15_10_IRQn
+
+/**
+  * @brief Touch screen interrupt signal
+  */
+#define TS_INT_PIN                        ((uint32_t)GPIO_PIN_13)
+#define TS_INT_GPIO_PORT                  ((GPIO_TypeDef*)GPIOI)
+#define TS_INT_GPIO_CLK_ENABLE()          __HAL_RCC_GPIOI_CLK_ENABLE()
+#define TS_INT_GPIO_CLK_DISABLE()         __HAL_RCC_GPIOI_CLK_DISABLE()
+#define TS_INT_EXTI_IRQn                  EXTI15_10_IRQn
+
+/**
+  * @brief TouchScreen FT6206 Slave I2C address
+  */
+#define TS_I2C_ADDRESS                   ((uint16_t)0x54)
+
+/**
+  * @brief Audio I2C Slave address
+  */
+#define AUDIO_I2C_ADDRESS                ((uint16_t)0x34)
+
+/**
+  * @brief EEPROM I2C Slave address 1
+  */
+#define EEPROM_I2C_ADDRESS_A01           ((uint16_t)0xA0)
+
+/**
+  * @brief EEPROM I2C Slave address 2
+  */
+#define EEPROM_I2C_ADDRESS_A02           ((uint16_t)0xA6)
+
+/**
+  * @brief User can use this section to tailor I2C4/I2C4 instance used and associated
+  * resources (audio codec).
+  * Definition for I2C4 clock resources
+  */
+#define DISCOVERY_AUDIO_I2Cx                             I2C4
+#define DISCOVERY_AUDIO_I2Cx_CLK_ENABLE()                __HAL_RCC_I2C4_CLK_ENABLE()
+#define DISCOVERY_AUDIO_I2Cx_SCL_GPIO_CLK_ENABLE()       __HAL_RCC_GPIOD_CLK_ENABLE()
+#define DISCOVERY_AUDIO_I2Cx_SDA_GPIO_CLK_ENABLE()       __HAL_RCC_GPIOB_CLK_ENABLE()
+
+#define DISCOVERY_AUDIO_I2Cx_FORCE_RESET()               __HAL_RCC_I2C4_FORCE_RESET()
+#define DISCOVERY_AUDIO_I2Cx_RELEASE_RESET()             __HAL_RCC_I2C4_RELEASE_RESET()
+
+/** @brief Definition for I2C4 Pins
+  */
+#define DISCOVERY_AUDIO_I2Cx_SCL_PIN                     GPIO_PIN_12 /*!< PD12 */
+#define DISCOVERY_AUDIO_I2Cx_SCL_AF                      GPIO_AF4_I2C4
+#define DISCOVERY_AUDIO_I2Cx_SCL_GPIO_PORT               GPIOD
+#define DISCOVERY_AUDIO_I2Cx_SDA_PIN                     GPIO_PIN_7 /*!< PB7 */
+#define DISCOVERY_AUDIO_I2Cx_SDA_AF                      GPIO_AF11_I2C4
+#define DISCOVERY_AUDIO_I2Cx_SDA_GPIO_PORT               GPIOB
+/** @brief Definition of I2C4 interrupt requests
+  */
+#define DISCOVERY_AUDIO_I2Cx_EV_IRQn                     I2C4_EV_IRQn
+#define DISCOVERY_AUDIO_I2Cx_ER_IRQn                     I2C4_ER_IRQn
+
+/**
+  * @brief User can use this section to tailor I2C1/I2C1 instance used and associated
+  * resources.
+  * Definition for I2C1 clock resources
+  */
+#define DISCOVERY_EXT_I2Cx                             I2C1
+#define DISCOVERY_EXT_I2Cx_CLK_ENABLE()                __HAL_RCC_I2C1_CLK_ENABLE()
+#define DISCOVERY_DMAx_CLK_ENABLE()                __HAL_RCC_DMA1_CLK_ENABLE()
+#define DISCOVERY_EXT_I2Cx_SCL_SDA_GPIO_CLK_ENABLE()   __HAL_RCC_GPIOB_CLK_ENABLE()
+
+#define DISCOVERY_EXT_I2Cx_FORCE_RESET()               __HAL_RCC_I2C1_FORCE_RESET()
+#define DISCOVERY_EXT_I2Cx_RELEASE_RESET()             __HAL_RCC_I2C1_RELEASE_RESET()
+
+/** @brief Definition for I2C1 Pins
+  */
+#define DISCOVERY_EXT_I2Cx_SCL_PIN                     GPIO_PIN_8 /*!< PB8 */
+#define DISCOVERY_EXT_I2Cx_SCL_SDA_GPIO_PORT           GPIOB
+#define DISCOVERY_EXT_I2Cx_SCL_SDA_AF                  GPIO_AF4_I2C1
+#define DISCOVERY_EXT_I2Cx_SDA_PIN                     GPIO_PIN_9 /*!< PB9 */
+
+/** @brief Definition of I2C interrupt requests
+  */
+#define DISCOVERY_EXT_I2Cx_EV_IRQn                     I2C1_EV_IRQn
+#define DISCOVERY_EXT_I2Cx_ER_IRQn                     I2C1_ER_IRQn
+
+/* I2C TIMING Register define when I2C clock source is SYSCLK */
+/* I2C TIMING is calculated from APB1 source clock = 50 MHz */
+/* Due to the big MOFSET capacity for adapting the camera level the rising time is very large (>1us) */
+/* 0x40912732 takes in account the big rising and aims a clock of 100khz */
+#ifndef DISCOVERY_I2Cx_TIMING  
+#define DISCOVERY_I2Cx_TIMING                      ((uint32_t)0x40912732)
+#endif /* DISCOVERY_I2Cx_TIMING */
+
+
+/**
+  * @}
+  */
+
+/** @defgroup STM32F769I_Discovery_LOW_LEVEL_Exported_Macros STM32F769I Discovery Low Level Exported Macros
+  * @{
+  */
+/**
+  * @}
+  */
+
+/** @defgroup STM32F769I_Discovery_LOW_LEVEL_Exported_Functions STM32F769I Discovery Low Level Exported Functions
+  * @{
+  */
+uint32_t         BSP_GetVersion(void);
+void             BSP_LED_Init(Led_TypeDef Led);
+void             BSP_LED_DeInit(Led_TypeDef Led);
+void             BSP_LED_On(Led_TypeDef Led);
+void             BSP_LED_Off(Led_TypeDef Led);
+void             BSP_LED_Toggle(Led_TypeDef Led);
+void             BSP_PB_Init(Button_TypeDef Button, ButtonMode_TypeDef Button_Mode);
+void             BSP_PB_DeInit(Button_TypeDef Button);
+uint32_t         BSP_PB_GetState(Button_TypeDef Button);
+
+/**
+  * @}
+  */
+
+/**
+  * @}
+  */
+
+/**
+  * @}
+  */
+
+/**
+  * @}
+  */
+
+/**
+  * @}
+  */
+
+
+#ifdef __cplusplus
+}
+#endif
+
+#endif /* __STM32F769I_DISCOVERY_H */
+
+/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/