STM32091C_EVAL BSP User Manual: stm32091c_eval.h Source File

STM32091C EVAL BSP Drivers

stm32091c_eval.h
Go to the documentation of this file.
00001 /**
00002   ******************************************************************************
00003   * @file    stm32091c_eval.h
00004   * @author  MCD Application Team
00005   * @brief   This file contains definitions for STM32091C_EVAL's Leds, push-buttons
00006   *          and COM port hardware resources.
00007   ******************************************************************************
00008   * @attention
00009   *
00010   * <h2><center>&copy; COPYRIGHT(c) 2016 STMicroelectronics</center></h2>
00011   *
00012   * Redistribution and use in source and binary forms, with or without modification,
00013   * are permitted provided that the following conditions are met:
00014   *   1. Redistributions of source code must retain the above copyright notice,
00015   *      this list of conditions and the following disclaimer.
00016   *   2. Redistributions in binary form must reproduce the above copyright notice,
00017   *      this list of conditions and the following disclaimer in the documentation
00018   *      and/or other materials provided with the distribution.
00019   *   3. Neither the name of STMicroelectronics nor the names of its contributors
00020   *      may be used to endorse or promote products derived from this software
00021   *      without specific prior written permission.
00022   *
00023   * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
00024   * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
00025   * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
00026   * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
00027   * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
00028   * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
00029   * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
00030   * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
00031   * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
00032   * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
00033   *
00034   ******************************************************************************
00035   */
00036   
00037 /* Define to prevent recursive inclusion -------------------------------------*/
00038 #ifndef __STM32091C_EVAL_H
00039 #define __STM32091C_EVAL_H
00040 
00041 #ifdef __cplusplus
00042  extern "C" {
00043 #endif
00044 
00045 /** @addtogroup BSP
00046   * @{
00047   */
00048 
00049 /** @defgroup STM32091C_EVAL STM32091C-EVAL
00050   * @{
00051   */
00052 
00053 /* Includes ------------------------------------------------------------------*/
00054 #include "stm32f0xx_hal.h"
00055 
00056 /** @defgroup STM32091C_EVAL_Common STM32091C-EVAL Common
00057   * @{
00058   */ 
00059 
00060 /** @defgroup STM32091C_EVAL_Private_Constants Private Constants
00061  * @{
00062  */
00063 /**
00064 * @}
00065 */        
00066 
00067 /** @defgroup STM32091C_EVAL_Private_Variables Private Variables
00068  * @{
00069  */
00070 /**
00071 * @}
00072 */
00073 
00074 /** @defgroup STM32091C_EVAL_Exported_Types Exported Types
00075   * @{
00076   */ 
00077 
00078 /**
00079  * @brief LED Types Definition
00080  */
00081 typedef enum 
00082 {
00083   LED1 = 0,
00084   LED2 = 1,
00085   LED3 = 2,
00086   LED4 = 3,
00087   /* Color led aliases */
00088   LED_GREEN  = LED1,
00089   LED_ORANGE = LED2,
00090   LED_RED    = LED3,
00091   LED_BLUE   = LED4
00092 } Led_TypeDef;
00093 
00094 /**
00095  * @brief BUTTON Types Definition
00096  */
00097 typedef enum 
00098 {
00099   BUTTON_TAMPER = 0
00100 } Button_TypeDef;
00101 
00102 typedef enum 
00103 {  
00104   BUTTON_MODE_GPIO = 0,
00105   BUTTON_MODE_EXTI = 1
00106 } ButtonMode_TypeDef;
00107 
00108 /**
00109  * @brief JOYSTICK Types Definition
00110  */
00111 typedef enum 
00112 { 
00113   JOY_SEL = 0,
00114   JOY_DOWN = 1,
00115   JOY_LEFT = 2,
00116   JOY_RIGHT = 3,
00117   JOY_UP = 4,
00118   JOY_NONE = 5
00119 } JOYState_TypeDef;
00120 
00121 typedef enum 
00122 {  
00123   JOY_MODE_GPIO = 0,
00124   JOY_MODE_EXTI = 1
00125 } JOYMode_TypeDef;
00126 
00127 /**
00128  * @brief COM Types Definition
00129  */
00130 typedef enum 
00131 {
00132   COM1 = 0
00133 } COM_TypeDef;   
00134 
00135 /**
00136   * @}
00137   */ 
00138 
00139 /** @defgroup STM32091C_EVAL_Exported_Constants Exported Constants
00140   * @{
00141   */ 
00142 
00143 /** 
00144   * @brief  Define for STM32091C_EVAL board  
00145   */ 
00146 #if !defined (USE_STM32091C_EVAL)
00147  #define USE_STM32091C_EVAL
00148 #endif
00149 
00150 /** @defgroup STM32091C_EVAL_LED STM32091C-EVAL LED
00151   * @{
00152   */
00153 #define LEDn                             4
00154 
00155 #define LED1_PIN                         GPIO_PIN_0  /* PE.00 */
00156 #define LED1_GPIO_PORT                   GPIOE
00157 #define LED1_GPIO_CLK_ENABLE()           __HAL_RCC_GPIOE_CLK_ENABLE()
00158 #define LED1_GPIO_CLK_DISABLE()          __HAL_RCC_GPIOE_CLK_DISABLE()
00159   
00160 #define LED2_PIN                         GPIO_PIN_1  /* PE.01 */
00161 #define LED2_GPIO_PORT                   GPIOE
00162 #define LED2_GPIO_CLK_ENABLE()           __HAL_RCC_GPIOE_CLK_ENABLE()
00163 #define LED2_GPIO_CLK_DISABLE()          __HAL_RCC_GPIOE_CLK_DISABLE()
00164   
00165 #define LED3_PIN                         GPIO_PIN_7  /* PE.07 */
00166 #define LED3_GPIO_PORT                   GPIOE
00167 #define LED3_GPIO_CLK_ENABLE()           __HAL_RCC_GPIOE_CLK_ENABLE()
00168 #define LED3_GPIO_CLK_DISABLE()          __HAL_RCC_GPIOE_CLK_DISABLE()
00169   
00170 #define LED4_PIN                         GPIO_PIN_8  /* PE.08 */
00171 #define LED4_GPIO_PORT                   GPIOE
00172 #define LED4_GPIO_CLK_ENABLE()           __HAL_RCC_GPIOE_CLK_ENABLE()
00173 #define LED4_GPIO_CLK_DISABLE()          __HAL_RCC_GPIOE_CLK_DISABLE()
00174 
00175 #define LEDx_GPIO_CLK_ENABLE(__LED__)    do { if((__LED__) == LED1) LED1_GPIO_CLK_ENABLE(); else \
00176                                           if((__LED__) == LED2) LED2_GPIO_CLK_ENABLE(); else \
00177                                           if((__LED__) == LED3) LED3_GPIO_CLK_ENABLE(); else \
00178                                           if((__LED__) == LED4) LED4_GPIO_CLK_ENABLE();} while(0)
00179 
00180 #define LEDx_GPIO_CLK_DISABLE(__LED__)   (((__LED__) == LED1) ? LED1_GPIO_CLK_DISABLE() :\
00181                                           ((__LED__) == LED2) ? LED2_GPIO_CLK_DISABLE() :\
00182                                           ((__LED__) == LED3) ? LED3_GPIO_CLK_DISABLE() :\
00183                                           ((__LED__) == LED4) ? LED4_GPIO_CLK_DISABLE() : 0 )
00184 
00185 /**
00186   * @}
00187   */ 
00188 
00189 /** @defgroup STM32091C_EVAL_BUTTON STM32091C-EVAL BUTTON
00190   * @{
00191   */  
00192 #define JOYn                             5
00193 #define BUTTONn                          1
00194 
00195 /**
00196  * @brief Tamper push-button
00197  */
00198 #define TAMPER_BUTTON_PIN                   GPIO_PIN_13  /* PC.13 */
00199 #define TAMPER_BUTTON_GPIO_PORT             GPIOC
00200 #define TAMPER_BUTTON_GPIO_CLK_ENABLE()     __HAL_RCC_GPIOC_CLK_ENABLE()
00201 #define TAMPER_BUTTON_GPIO_CLK_DISABLE()    __HAL_RCC_GPIOC_CLK_DISABLE()
00202 #define TAMPER_BUTTON_EXTI_IRQn             EXTI4_15_IRQn
00203 
00204 #define TAMPERx_GPIO_CLK_ENABLE(__BUTTON__)    do { if((__BUTTON__) == BUTTON_TAMPER) TAMPER_BUTTON_GPIO_CLK_ENABLE();} while(0)
00205 
00206 #define TAMPERx_GPIO_CLK_DISABLE(__BUTTON__)   (((__BUTTON__) == BUTTON_TAMPER) ? TAMPER_BUTTON_GPIO_CLK_DISABLE(): 0 )
00207 
00208 /**
00209  * @brief Joystick Right push-button
00210  */
00211 #define RIGHT_JOY_PIN                 GPIO_PIN_3  /* PE.03 */
00212 #define RIGHT_JOY_GPIO_PORT           GPIOE
00213 #define RIGHT_JOY_GPIO_CLK_ENABLE()   __HAL_RCC_GPIOE_CLK_ENABLE()
00214 #define RIGHT_JOY_GPIO_CLK_DISABLE()  __HAL_RCC_GPIOE_CLK_DISABLE()
00215 #define RIGHT_JOY_EXTI_IRQn           EXTI2_3_IRQn
00216 
00217 /**
00218  * @brief Joystick Left push-button
00219  */
00220 #define LEFT_JOY_PIN                  GPIO_PIN_2  /* PE.02 */
00221 #define LEFT_JOY_GPIO_PORT            GPIOE
00222 #define LEFT_JOY_GPIO_CLK_ENABLE()    __HAL_RCC_GPIOE_CLK_ENABLE()
00223 #define LEFT_JOY_GPIO_CLK_DISABLE()   __HAL_RCC_GPIOE_CLK_DISABLE()
00224 #define LEFT_JOY_EXTI_IRQn            EXTI2_3_IRQn  
00225 
00226 /**
00227  * @brief Joystick Up push-button
00228  */
00229 #define UP_JOY_PIN                    GPIO_PIN_4  /* PE.04 */
00230 #define UP_JOY_GPIO_PORT              GPIOE
00231 #define UP_JOY_GPIO_CLK_ENABLE()      __HAL_RCC_GPIOE_CLK_ENABLE()
00232 #define UP_JOY_GPIO_CLK_DISABLE()     __HAL_RCC_GPIOE_CLK_DISABLE()
00233 #define UP_JOY_EXTI_IRQn              EXTI4_15_IRQn
00234 
00235 /**
00236  * @brief Joystick Down push-button
00237  */  
00238 #define DOWN_JOY_PIN                  GPIO_PIN_5   /* PE.05 */
00239 #define DOWN_JOY_GPIO_PORT            GPIOE
00240 #define DOWN_JOY_GPIO_CLK_ENABLE()    __HAL_RCC_GPIOE_CLK_ENABLE()
00241 #define DOWN_JOY_GPIO_CLK_DISABLE()   __HAL_RCC_GPIOE_CLK_DISABLE()
00242 #define DOWN_JOY_EXTI_IRQn            EXTI4_15_IRQn
00243 
00244 /**
00245  * @brief Joystick Sel push-button
00246  */
00247 #define SEL_JOY_PIN                   GPIO_PIN_0   /* PA.00 */
00248 #define SEL_JOY_GPIO_PORT             GPIOA
00249 #define SEL_JOY_GPIO_CLK_ENABLE()     __HAL_RCC_GPIOA_CLK_ENABLE()
00250 #define SEL_JOY_GPIO_CLK_DISABLE()    __HAL_RCC_GPIOA_CLK_DISABLE()
00251 #define SEL_JOY_EXTI_IRQn             EXTI0_1_IRQn 
00252 
00253 #define JOYx_GPIO_CLK_ENABLE(__JOY__)    do { if((__JOY__) == JOY_SEL) SEL_JOY_GPIO_CLK_ENABLE(); else \
00254                                           if((__JOY__) == JOY_DOWN) DOWN_JOY_GPIO_CLK_ENABLE(); else \
00255                                           if((__JOY__) == JOY_LEFT) LEFT_JOY_GPIO_CLK_ENABLE(); else \
00256                                           if((__JOY__) == JOY_RIGHT) RIGHT_JOY_GPIO_CLK_ENABLE(); else \
00257                                           if((__JOY__) == JOY_UP) UP_JOY_GPIO_CLK_ENABLE();} while(0)
00258 
00259 #define JOYx_GPIO_CLK_DISABLE(__JOY__)   (((__JOY__) == JOY_SEL) ? SEL_JOY_GPIO_CLK_DISABLE() :\
00260                                           ((__JOY__) == JOY_DOWN) ? DOWN_JOY_GPIO_CLK_DISABLE() :\
00261                                           ((__JOY__) == JOY_LEFT) ? LEFT_JOY_GPIO_CLK_DISABLE() :\
00262                                           ((__JOY__) == JOY_RIGHT) ? RIGHT_JOY_GPIO_CLK_DISABLE() :\
00263                                           ((__JOY__) == JOY_UP) ? UP_JOY_GPIO_CLK_DISABLE() : 0 )
00264 
00265 /**
00266   * @}
00267   */
00268 
00269 /** @defgroup STM32091C_EVAL_COM STM32091C-EVAL COM
00270   * @{
00271   */
00272 #define COMn                            1
00273 
00274 /**
00275  * @brief Definition for COM port1, connected to USART1
00276  */ 
00277 #define EVAL_COM1                       USART1
00278 #define EVAL_COM1_CLK_ENABLE()          __HAL_RCC_USART1_CLK_ENABLE()
00279 #define EVAL_COM1_CLK_DISABLE()         __HAL_RCC_USART1_CLK_DISABLE()
00280 
00281 #define EVAL_COM1_TX_PIN                GPIO_PIN_9 /* PA.09 */
00282 #define EVAL_COM1_TX_GPIO_PORT          GPIOA
00283 #define EVAL_COM1_TX_GPIO_CLK_ENABLE()  __HAL_RCC_GPIOA_CLK_ENABLE()
00284 #define EVAL_COM1_TX_GPIO_CLK_DISABLE() __HAL_RCC_GPIOA_CLK_DISABLE()
00285 #define EVAL_COM1_TX_AF                 GPIO_AF1_USART1
00286 
00287 #define EVAL_COM1_RX_PIN                GPIO_PIN_10 /* PA.10 */
00288 #define EVAL_COM1_RX_GPIO_PORT          GPIOA
00289 #define EVAL_COM1_RX_GPIO_CLK_ENABLE()  __HAL_RCC_GPIOA_CLK_ENABLE()
00290 #define EVAL_COM1_RX_GPIO_CLK_DISABLE() __HAL_RCC_GPIOA_CLK_DISABLE()
00291 #define EVAL_COM1_RX_AF                 GPIO_AF1_USART1
00292 
00293 #define EVAL_COM1_CTS_PIN               GPIO_PIN_11 /* PA.11 */
00294 #define EVAL_COM1_CTS_GPIO_PORT         GPIOA
00295 #define EVAL_COM1_CTS_GPIO_CLK_ENABLE() __HAL_RCC_GPIOA_CLK_ENABLE()
00296 #define EVAL_COM1_CTS_GPIO_CLK_DISABLE() __HAL_RCC_GPIOA_CLK_DISABLE()
00297 #define EVAL_COM1_CTS_AF                GPIO_AF1_USART1
00298 
00299 #define EVAL_COM1_RTS_PIN               GPIO_PIN_12 /* PA.12 */
00300 #define EVAL_COM1_RTS_GPIO_PORT         GPIOA
00301 #define EVAL_COM1_RTS_GPIO_CLK_ENABLE() __HAL_RCC_GPIOA_CLK_ENABLE()
00302 #define EVAL_COM1_RTS_GPIO_CLK_DISABLE() __HAL_RCC_GPIOA_CLK_DISABLE()
00303 #define EVAL_COM1_RTS_AF                GPIO_AF1_USART1
00304    
00305 #define EVAL_COM1_IRQn                  USART1_IRQn
00306 
00307 #define COMx_CLK_ENABLE(__COM__)        do { if((__COM__) == COM1) EVAL_COM1_CLK_ENABLE();} while(0)
00308 #define COMx_CLK_DISABLE(__COM__)       (((__COM__) == COM1) ? EVAL_COM1_CLK_DISABLE() : 0)
00309 
00310 #define COMx_TX_GPIO_CLK_ENABLE(__COM__) do { if((__COM__) == COM1) EVAL_COM1_TX_GPIO_CLK_ENABLE();} while(0)
00311 #define COMx_TX_GPIO_CLK_DISABLE(__COM__) (((__COM__) == COM1) ? EVAL_COM1_TX_GPIO_CLK_DISABLE() : 0)
00312 
00313 #define COMx_RX_GPIO_CLK_ENABLE(__COM__) do { if((__COM__) == COM1) EVAL_COM1_RX_GPIO_CLK_ENABLE();} while(0)
00314 #define COMx_RX_GPIO_CLK_DISABLE(__COM__) (((__COM__) == COM1) ? EVAL_COM1_RX_GPIO_CLK_DISABLE() : 0)
00315 
00316 #define COMx_CTS_GPIO_CLK_ENABLE(__COM__) do { if((__COM__) == COM1) EVAL_COM1_CTS_GPIO_CLK_ENABLE();} while(0)
00317 #define COMx_CTS_GPIO_CLK_DISABLE(__COM__) (((__COM__) == COM1) ? EVAL_COM1_CTS_GPIO_CLK_DISABLE() : 0)
00318 
00319 #define COMx_RTS_GPIO_CLK_ENABLE(__COM__) do { if((__COM__) == COM1) EVAL_COM1_RTS_GPIO_CLK_ENABLE();} while(0)
00320 #define COMx_RTS_GPIO_CLK_DISABLE(__COM__) (((__COM__) == COM1) ? EVAL_COM1_RTS_GPIO_CLK_DISABLE() : 0)
00321 
00322 #if defined(HAL_I2C_MODULE_ENABLED)
00323 /*##################### I2Cx ###################################*/
00324 /* User can use this section to tailor I2Cx instance used and associated resources */
00325 /* Definition for I2C1 Pins */
00326 #define EVAL_I2C1                        I2C1
00327 #define EVAL_I2C1_CLK_ENABLE()           __HAL_RCC_I2C1_CLK_ENABLE()
00328 #define EVAL_I2C1_CLK_DISABLE()          __HAL_RCC_I2C1_CLK_DISABLE()
00329 #define EVAL_I2C1_FORCE_RESET()          __HAL_RCC_I2C1_FORCE_RESET()
00330 #define EVAL_I2C1_RELEASE_RESET()        __HAL_RCC_I2C1_RELEASE_RESET()  
00331 
00332 #define EVAL_I2C1_SCL_PIN                GPIO_PIN_6             /* PB.6 */
00333 #define EVAL_I2C1_SDA_PIN                GPIO_PIN_7             /* PB.7 */
00334 
00335 #define EVAL_I2C1_GPIO_PORT              GPIOB                  /* GPIOB */
00336 #define EVAL_I2C1_GPIO_CLK_ENABLE()      __HAL_RCC_GPIOB_CLK_ENABLE()
00337 #define EVAL_I2C1_GPIO_CLK_DISABLE()     __HAL_RCC_GPIOB_CLK_DISABLE() 
00338 #define EVAL_I2C1_SCL_SDA_AF             GPIO_AF1_I2C1
00339 
00340 /* Definition for I2C2 Pins */
00341 #define EVAL_I2C2                       I2C2
00342 #define EVAL_I2C2_CLK_ENABLE()          __HAL_RCC_I2C2_CLK_ENABLE()
00343 #define EVAL_I2C2_CLK_DISABLE()         __HAL_RCC_I2C2_CLK_DISABLE()
00344 #define EVAL_I2C2_FORCE_RESET()         __HAL_RCC_I2C2_FORCE_RESET()
00345 #define EVAL_I2C2_RELEASE_RESET()       __HAL_RCC_I2C2_RELEASE_RESET()
00346 
00347 #define EVAL_I2C2_SCL_PIN               GPIO_PIN_13             /* PB.13 */
00348 #define EVAL_I2C2_SDA_PIN               GPIO_PIN_14             /* PB.14 */
00349 
00350 #define EVAL_I2C2_GPIO_PORT             GPIOB                   /* GPIOB */
00351 #define EVAL_I2C2_GPIO_CLK_ENABLE()     __HAL_RCC_GPIOB_CLK_ENABLE()
00352 #define EVAL_I2C2_GPIO_CLK_DISABLE()    __HAL_RCC_GPIOB_CLK_DISABLE()
00353 #define EVAL_I2C2_AF                    GPIO_AF5_I2C2
00354 
00355 /* Definition for I2C2 NVIC */
00356 #define EVAL_I2C2_IRQn                  I2C2_IRQn
00357   
00358 /* Maximum Timeout values for flags waiting loops. These timeouts are not based
00359    on accurate values, they just guarantee that the application will not remain
00360    stuck if the I2C communication is corrupted.
00361    You may modify these timeout values depending on CPU frequency and application
00362    conditions (interrupts routines ...). */   
00363 #define EVAL_I2C1_TIMEOUT_MAX            1000
00364 #define EVAL_I2C2_TIMEOUT_MAX            1000
00365 
00366 /* I2C TIMING is calculated in case of the I2C Clock source is the SYSCLK = 48 MHz */
00367 /* Set TIMING to 0x00E0D3FF to reach 100 KHz speed (Rise time = 50ns, Fall time = 10ns) */
00368 #define I2C2_TIMING                      0x00E0D3FF
00369 #define I2C1_TIMING                      0x00E0D3FF
00370 
00371 #endif /* HAL_I2C_MODULE_ENABLED */
00372 
00373 #if defined(HAL_SPI_MODULE_ENABLED)
00374 /**
00375   * @brief  Definition for SPI Interface pins (SPI1 used)
00376   */
00377 #define EVAL_SPIx                       SPI1
00378 #define EVAL_SPIx_CLK_ENABLE()          __HAL_RCC_SPI1_CLK_ENABLE()
00379 #define EVAL_SPIx_CLK_DISABLE()         __HAL_RCC_SPI1_CLK_DISABLE()
00380 #define EVAL_SPIx_FORCE_RESET()          __HAL_RCC_SPI1_FORCE_RESET()
00381 #define EVAL_SPIx_RELEASE_RESET()        __HAL_RCC_SPI1_RELEASE_RESET()
00382 
00383 #define EVAL_SPIx_SCK_PIN                 GPIO_PIN_13             /* PE.13 */
00384 #define EVAL_SPIx_SCK_GPIO_PORT           GPIOE                   /* GPIOE */
00385 #define EVAL_SPIx_SCK_GPIO_CLK_ENABLE()   __HAL_RCC_GPIOE_CLK_ENABLE()
00386 #define EVAL_SPIx_SCK_GPIO_CLK_DISABLE()  __HAL_RCC_GPIOE_CLK_DISABLE()
00387 #define EVAL_SPIx_SCK_AF                  GPIO_AF1_SPI1
00388 
00389 #define EVAL_SPIx_MISO_PIN              GPIO_PIN_14             /* PE.14 */
00390 #define EVAL_SPIx_MISO_GPIO_PORT        GPIOE                   /* GPIOE */
00391 #define EVAL_SPIx_MISO_GPIO_CLK_ENABLE() __HAL_RCC_GPIOE_CLK_ENABLE()
00392 #define EVAL_SPIx_MISO_GPIO_CLK_DISABLE() __HAL_RCC_GPIOE_CLK_DISABLE()
00393 #define EVAL_SPIx_MISO_AF               GPIO_AF1_SPI1
00394 
00395 #define EVAL_SPIx_MOSI_PIN              GPIO_PIN_15             /* PE.15 */
00396 #define EVAL_SPIx_MOSI_GPIO_PORT        GPIOE                   /* GPIOE */
00397 #define EVAL_SPIx_MOSI_GPIO_CLK_ENABLE() __HAL_RCC_GPIOE_CLK_ENABLE()
00398 #define EVAL_SPIx_MOSI_GPIO_CLK_DISABLE() __HAL_RCC_GPIOE_CLK_DISABLE()
00399 #define EVAL_SPIx_MOSI_AF               GPIO_AF1_SPI1
00400 
00401 #define EVAL_SPIx_MOSI_DIR_PIN            GPIO_PIN_9             /* PE.09 */
00402 #define EVAL_SPIx_MOSI_DIR_GPIO_PORT      GPIOE                  /* GPIOE */
00403 #define EVAL_SPIx_MOSI_DIR_GPIO_CLK_ENABLE()  __HAL_RCC_GPIOE_CLK_ENABLE()
00404 #define EVAL_SPIx_MOSI_DIR_GPIO_CLK_DISABLE() __HAL_RCC_GPIOE_CLK_DISABLE()
00405 
00406 /* Maximum Timeout values for flags waiting loops. These timeouts are not based
00407    on accurate values, they just guarantee that the application will not remain
00408    stuck if the SPI communication is corrupted.
00409    You may modify these timeout values depending on CPU frequency and application
00410    conditions (interrupts routines ...). */   
00411 #define EVAL_SPIx_TIMEOUT_MAX                 1000
00412 
00413 #endif /* HAL_SPI_MODULE_ENABLED */
00414 /**
00415   * @}
00416   */
00417 
00418 
00419 /** @defgroup STM32091C_EVAL_COMPONENT STM32091C-EVAL COMPONENT
00420   * @{
00421   */
00422 /*##################### LCD ###################################*/  
00423 /* Chip Select macro definition */
00424 #define LCD_CS_LOW()                    HAL_GPIO_WritePin(LCD_NCS_GPIO_PORT, LCD_NCS_PIN, GPIO_PIN_RESET)
00425 #define LCD_CS_HIGH()                   HAL_GPIO_WritePin(LCD_NCS_GPIO_PORT, LCD_NCS_PIN, GPIO_PIN_SET)
00426 /** 
00427   * @brief  LCD Control pins 
00428   */ 
00429 #define LCD_NCS_PIN                     GPIO_PIN_10             /* PE. 10*/
00430 #define LCD_NCS_GPIO_PORT               GPIOE                   /* GPIOE */
00431 #define LCD_NCS_GPIO_CLK_ENABLE()       __HAL_RCC_GPIOE_CLK_ENABLE()
00432 #define LCD_NCS_GPIO_CLK_DISABLE()      __HAL_RCC_GPIOE_CLK_DISABLE()  
00433 
00434 
00435 /*##################### SD ###################################*/  
00436 /* Chip Select macro definition */
00437 #define SD_CS_LOW()                     HAL_GPIO_WritePin(SD_CS_GPIO_PORT, SD_CS_PIN, GPIO_PIN_RESET)
00438 #define SD_CS_HIGH()                    HAL_GPIO_WritePin(SD_CS_GPIO_PORT, SD_CS_PIN, GPIO_PIN_SET)  
00439 /**
00440   * @brief SD card Control pin  
00441   */
00442 #define SD_CS_PIN                       GPIO_PIN_12             /* PE.12 */
00443 #define SD_CS_GPIO_PORT                 GPIOE                   /* GPIOE */
00444 #define SD_CS_GPIO_CLK_ENABLE()         __HAL_RCC_GPIOE_CLK_ENABLE()
00445 #define SD_CS_GPIO_CLK_DISABLE()        __HAL_RCC_GPIOE_CLK_DISABLE()
00446 
00447 /**
00448   * @brief  SD Detect Interface pins
00449   */
00450 #define SD_DETECT_PIN                   GPIO_PIN_11             /* PE.11 */
00451 #define SD_DETECT_GPIO_PORT             GPIOE                   /* GPIOE */
00452 #define SD_DETECT_GPIO_CLK_ENABLE()     __HAL_RCC_GPIOE_CLK_ENABLE()
00453 #define SD_DETECT_GPIO_CLK_DISABLE()    __HAL_RCC_GPIOE_CLK_DISABLE()
00454 #define SD_DETECT_EXTI_IRQn             EXTI4_15_IRQn
00455 
00456 
00457 /*##################### HDMI-CEC ###################################*/
00458 /**
00459   * @brief  I2C HDMI CEC Interface pins
00460   */
00461 #define HDMI_CEC_HPD_SINK_PIN             GPIO_PIN_11           /* PD.11*/
00462 #define HDMI_CEC_HPD_SINK_GPIO_PORT       GPIOD
00463 #define HDMI_CEC_HPD_SINK_CLK_ENABLE()    __HAL_RCC_GPIOD_CLK_ENABLE()
00464 #define HDMI_CEC_HPD_SINK_CLK_DISABLE()   __HAL_RCC_GPIOD_CLK_DISABLE()
00465   
00466 #define HDMI_CEC_HPD_SOURCE_PIN           GPIO_PIN_10  /* PD.10 */
00467 #define HDMI_CEC_HPD_SOURCE_GPIO_PORT     GPIOD        /* GPIOD */
00468 #define HDMI_CEC_HPD_SOURCE_CLK_ENABLE()  __HAL_RCC_GPIOD_CLK_ENABLE()
00469 #define HDMI_CEC_HPD_SOURCE_CLK_DISABLE() __HAL_RCC_GPIOD_CLK_DISABLE()
00470 
00471 #define HDMI_CEC_LINE_PIN                 GPIO_PIN_10           /* PB.10*/
00472 #define HDMI_CEC_LINE_GPIO_PORT           GPIOB
00473 #define HDMI_CEC_LINE_CLK_ENABLE()        __HAL_RCC_GPIOB_CLK_ENABLE()
00474 #define HDMI_CEC_LINE_CLK_DISABLE()       __HAL_RCC_GPIOB_CLK_DISABLE()
00475 #define HDMI_CEC_LINE_AF                  GPIO_AF0_CEC   
00476 #define HDMI_CEC_IRQn                     CEC_CAN_IRQn  
00477 
00478 /* HDMI-CEC hardware I2C address */ 
00479 #define HDMI_CEC_I2C_ADDRESS              0xA0 /* TBC */
00480 
00481 /**
00482   * @}
00483   */  
00484 
00485 /**
00486   * @}
00487   */  
00488  
00489 /** @defgroup STM32091C_EVAL_Exported_Functions Exported Functions
00490   * @{
00491   */
00492 uint32_t                BSP_GetVersion(void);
00493 void                    BSP_LED_Init(Led_TypeDef Led);
00494 void                    BSP_LED_On(Led_TypeDef Led);
00495 void                    BSP_LED_Off(Led_TypeDef Led);
00496 void                    BSP_LED_Toggle(Led_TypeDef Led);
00497 void                    BSP_PB_Init(Button_TypeDef Button, ButtonMode_TypeDef Button_Mode);
00498 uint32_t                BSP_PB_GetState(Button_TypeDef Button);
00499 uint8_t           BSP_JOY_Init(JOYMode_TypeDef Joy_Mode);
00500 JOYState_TypeDef  BSP_JOY_GetState(void);
00501 #if defined(HAL_UART_MODULE_ENABLED)
00502 void                    BSP_COM_Init(COM_TypeDef COM, UART_HandleTypeDef* huart); 
00503 #endif /* HAL_UART_MODULE_ENABLED */
00504 
00505 /**
00506   * @}
00507   */
00508 
00509 /**
00510   * @}
00511   */
00512   
00513 /**
00514   * @}
00515   */ 
00516 
00517 /**
00518   * @}
00519   */ 
00520 
00521 #ifdef __cplusplus
00522 }
00523 #endif
00524 
00525 #endif /* __STM32091C_EVAL_H */
00526 
00527 /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/
Generated on Wed Jul 5 2017 09:21:50 for STM32091C_EVAL BSP User Manual by   doxygen 1.7.6.1