STM32091C_EVAL BSP User Manual
|
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>© 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
