STM32F1xx_Nucleo BSP User Manual
|
stm32f1xx_nucleo.h
Go to the documentation of this file.
00001 /** 00002 ****************************************************************************** 00003 * @file stm32f1xx_nucleo.h 00004 * @author MCD Application Team 00005 * @version V1.0.3 00006 * @date 29-April-2016 00007 * @brief This file contains definitions for: 00008 * - LEDs and push-button available on STM32F1XX-Nucleo Kit 00009 * from STMicroelectronics 00010 * - LCD, joystick and microSD available on Adafruit 1.8" TFT LCD 00011 * shield (reference ID 802) 00012 ****************************************************************************** 00013 * @attention 00014 * 00015 * <h2><center>© COPYRIGHT(c) 2016 STMicroelectronics</center></h2> 00016 * 00017 * Redistribution and use in source and binary forms, with or without modification, 00018 * are permitted provided that the following conditions are met: 00019 * 1. Redistributions of source code must retain the above copyright notice, 00020 * this list of conditions and the following disclaimer. 00021 * 2. Redistributions in binary form must reproduce the above copyright notice, 00022 * this list of conditions and the following disclaimer in the documentation 00023 * and/or other materials provided with the distribution. 00024 * 3. Neither the name of STMicroelectronics nor the names of its contributors 00025 * may be used to endorse or promote products derived from this software 00026 * without specific prior written permission. 00027 * 00028 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" 00029 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 00030 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE 00031 * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE 00032 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 00033 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR 00034 * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER 00035 * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, 00036 * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE 00037 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 00038 * 00039 ****************************************************************************** 00040 */ 00041 00042 /* Define to prevent recursive inclusion -------------------------------------*/ 00043 #ifndef __STM32F1XX_NUCLEO_H 00044 #define __STM32F1XX_NUCLEO_H 00045 00046 #ifdef __cplusplus 00047 extern "C" { 00048 #endif 00049 00050 /** @addtogroup BSP 00051 * @{ 00052 */ 00053 00054 /** @addtogroup STM32F1XX_NUCLEO 00055 * @{ 00056 */ 00057 00058 /* Includes ------------------------------------------------------------------*/ 00059 #include "stm32f1xx_hal.h" 00060 00061 00062 /** @defgroup STM32F1XX_NUCLEO_Exported_Types Exported Types 00063 * @{ 00064 */ 00065 typedef enum 00066 { 00067 LED2 = 0, 00068 LED_GREEN = LED2 00069 } Led_TypeDef; 00070 00071 typedef enum 00072 { 00073 BUTTON_USER = 0, 00074 /* Alias */ 00075 BUTTON_KEY = BUTTON_USER 00076 } Button_TypeDef; 00077 00078 typedef enum 00079 { 00080 BUTTON_MODE_GPIO = 0, 00081 BUTTON_MODE_EXTI = 1 00082 } ButtonMode_TypeDef; 00083 00084 typedef enum 00085 { 00086 JOY_NONE = 0, 00087 JOY_SEL = 1, 00088 JOY_DOWN = 2, 00089 JOY_LEFT = 3, 00090 JOY_RIGHT = 4, 00091 JOY_UP = 5 00092 } JOYState_TypeDef; 00093 00094 /** 00095 * @} 00096 */ 00097 00098 /** @defgroup STM32F1XX_NUCLEO_Exported_Constants Exported Constants 00099 * @{ 00100 */ 00101 00102 /** 00103 * @brief Define for STM32F1xx_NUCLEO board 00104 */ 00105 #if !defined (USE_STM32F1xx_NUCLEO) 00106 #define USE_STM32F1xx_NUCLEO 00107 #endif 00108 00109 /** @defgroup STM32F1XX_NUCLEO_LED LED Constants 00110 * @{ 00111 */ 00112 #define LEDn 1 00113 00114 #define LED2_PIN GPIO_PIN_5 00115 #define LED2_GPIO_PORT GPIOA 00116 #define LED2_GPIO_CLK_ENABLE() __HAL_RCC_GPIOA_CLK_ENABLE() 00117 #define LED2_GPIO_CLK_DISABLE() __HAL_RCC_GPIOA_CLK_DISABLE() 00118 00119 #define LEDx_GPIO_CLK_ENABLE(__INDEX__) do { if((__INDEX__) == 0) LED2_GPIO_CLK_ENABLE();} while(0) 00120 #define LEDx_GPIO_CLK_DISABLE(__INDEX__) (((__INDEX__) == 0) ? LED2_GPIO_CLK_DISABLE() : 0) 00121 00122 /** 00123 * @} 00124 */ 00125 00126 /** @defgroup STM32F1XX_NUCLEO_BUTTON BUTTON Constants 00127 * @{ 00128 */ 00129 #define BUTTONn 1 00130 00131 /** 00132 * @brief User push-button 00133 */ 00134 #define USER_BUTTON_PIN GPIO_PIN_13 00135 #define USER_BUTTON_GPIO_PORT GPIOC 00136 #define USER_BUTTON_GPIO_CLK_ENABLE() __HAL_RCC_GPIOC_CLK_ENABLE() 00137 #define USER_BUTTON_GPIO_CLK_DISABLE() __HAL_RCC_GPIOC_CLK_DISABLE() 00138 #define USER_BUTTON_EXTI_IRQn EXTI15_10_IRQn 00139 /* Aliases */ 00140 #define KEY_BUTTON_PIN USER_BUTTON_PIN 00141 #define KEY_BUTTON_GPIO_PORT USER_BUTTON_GPIO_PORT 00142 #define KEY_BUTTON_GPIO_CLK_ENABLE() USER_BUTTON_GPIO_CLK_ENABLE() 00143 #define KEY_BUTTON_GPIO_CLK_DISABLE() USER_BUTTON_GPIO_CLK_DISABLE() 00144 #define KEY_BUTTON_EXTI_IRQn USER_BUTTON_EXTI_IRQn 00145 00146 #define BUTTONx_GPIO_CLK_ENABLE(__INDEX__) do { if((__INDEX__) == 0) USER_BUTTON_GPIO_CLK_ENABLE();} while(0) 00147 #define BUTTONx_GPIO_CLK_DISABLE(__INDEX__) (((__INDEX__) == 0) ? USER_BUTTON_GPIO_CLK_DISABLE() : 0) 00148 /** 00149 * @} 00150 */ 00151 00152 /** @addtogroup STM32F1XX_NUCLEO_BUS BUS Constants 00153 * @{ 00154 */ 00155 /*###################### SPI1 ###################################*/ 00156 #define NUCLEO_SPIx SPI1 00157 #define NUCLEO_SPIx_CLK_ENABLE() __HAL_RCC_SPI1_CLK_ENABLE() 00158 00159 #define NUCLEO_SPIx_SCK_GPIO_PORT GPIOA 00160 #define NUCLEO_SPIx_SCK_PIN GPIO_PIN_5 00161 #define NUCLEO_SPIx_SCK_GPIO_CLK_ENABLE() __HAL_RCC_GPIOA_CLK_ENABLE() 00162 #define NUCLEO_SPIx_SCK_GPIO_CLK_DISABLE() __HAL_RCC_GPIOA_CLK_DISABLE() 00163 00164 #define NUCLEO_SPIx_MISO_MOSI_GPIO_PORT GPIOA 00165 #define NUCLEO_SPIx_MISO_MOSI_GPIO_CLK_ENABLE() __HAL_RCC_GPIOA_CLK_ENABLE() 00166 #define NUCLEO_SPIx_MISO_MOSI_GPIO_CLK_DISABLE() __HAL_RCC_GPIOA_CLK_DISABLE() 00167 #define NUCLEO_SPIx_MISO_PIN GPIO_PIN_6 00168 #define NUCLEO_SPIx_MOSI_PIN GPIO_PIN_7 00169 /* Maximum Timeout values for flags waiting loops. These timeouts are not based 00170 on accurate values, they just guarantee that the application will not remain 00171 stuck if the SPI communication is corrupted. 00172 You may modify these timeout values depending on CPU frequency and application 00173 conditions (interrupts routines ...). */ 00174 #define NUCLEO_SPIx_TIMEOUT_MAX 1000 00175 00176 00177 /** 00178 * @brief SD Control Lines management 00179 */ 00180 #define SD_CS_LOW() HAL_GPIO_WritePin(SD_CS_GPIO_PORT, SD_CS_PIN, GPIO_PIN_RESET) 00181 #define SD_CS_HIGH() HAL_GPIO_WritePin(SD_CS_GPIO_PORT, SD_CS_PIN, GPIO_PIN_SET) 00182 00183 /** 00184 * @brief LCD Control Lines management 00185 */ 00186 #define LCD_CS_LOW() HAL_GPIO_WritePin(LCD_CS_GPIO_PORT, LCD_CS_PIN, GPIO_PIN_RESET) 00187 #define LCD_CS_HIGH() HAL_GPIO_WritePin(LCD_CS_GPIO_PORT, LCD_CS_PIN, GPIO_PIN_SET) 00188 #define LCD_DC_LOW() HAL_GPIO_WritePin(LCD_DC_GPIO_PORT, LCD_DC_PIN, GPIO_PIN_RESET) 00189 #define LCD_DC_HIGH() HAL_GPIO_WritePin(LCD_DC_GPIO_PORT, LCD_DC_PIN, GPIO_PIN_SET) 00190 00191 /** 00192 * @brief SD Control Interface pins (shield D4) 00193 */ 00194 #define SD_CS_PIN GPIO_PIN_5 00195 #define SD_CS_GPIO_PORT GPIOB 00196 #define SD_CS_GPIO_CLK_ENABLE() __HAL_RCC_GPIOB_CLK_ENABLE() 00197 #define SD_CS_GPIO_CLK_DISABLE() __HAL_RCC_GPIOB_CLK_DISABLE() 00198 00199 /** 00200 * @brief LCD Control Interface pins (shield D10) 00201 */ 00202 #define LCD_CS_PIN GPIO_PIN_6 00203 #define LCD_CS_GPIO_PORT GPIOB 00204 #define LCD_CS_GPIO_CLK_ENABLE() __HAL_RCC_GPIOB_CLK_ENABLE() 00205 #define LCD_CS_GPIO_CLK_DISABLE() __HAL_RCC_GPIOB_CLK_DISABLE() 00206 00207 /** 00208 * @brief LCD Data/Command Interface pins 00209 */ 00210 #define LCD_DC_PIN GPIO_PIN_9 00211 #define LCD_DC_GPIO_PORT GPIOA 00212 #define LCD_DC_GPIO_CLK_ENABLE() __HAL_RCC_GPIOA_CLK_ENABLE() 00213 #define LCD_DC_GPIO_CLK_DISABLE() __HAL_RCC_GPIOA_CLK_DISABLE() 00214 00215 /*##################### ADC1 ###################################*/ 00216 /** 00217 * @brief ADC Interface pins 00218 * used to detect motion of Joystick available on Adafruit 1.8" TFT shield 00219 */ 00220 #define NUCLEO_ADCx ADC1 00221 #define NUCLEO_ADCx_CLK_ENABLE() __HAL_RCC_ADC1_CLK_ENABLE() 00222 #define NUCLEO_ADCx_CLK_DISABLE() __HAL_RCC_ADC1_CLK_DISABLE() 00223 00224 #define NUCLEO_ADCx_GPIO_PORT GPIOB 00225 #define NUCLEO_ADCx_GPIO_PIN GPIO_PIN_0 00226 #define NUCLEO_ADCx_GPIO_CLK_ENABLE() __HAL_RCC_GPIOB_CLK_ENABLE() 00227 #define NUCLEO_ADCx_GPIO_CLK_DISABLE() __HAL_RCC_GPIOB_CLK_DISABLE() 00228 00229 /** 00230 * @} 00231 */ 00232 00233 00234 /** 00235 * @} 00236 */ 00237 00238 /** @addtogroup STM32F1XX_NUCLEO_Exported_Functions 00239 * @{ 00240 */ 00241 uint32_t BSP_GetVersion(void); 00242 /** @addtogroup STM32F1XX_NUCLEO_LED_Functions 00243 * @{ 00244 */ 00245 00246 void BSP_LED_Init(Led_TypeDef Led); 00247 void BSP_LED_DeInit(Led_TypeDef Led); 00248 void BSP_LED_On(Led_TypeDef Led); 00249 void BSP_LED_Off(Led_TypeDef Led); 00250 void BSP_LED_Toggle(Led_TypeDef Led); 00251 00252 /** 00253 * @} 00254 */ 00255 00256 /** @addtogroup STM32F1XX_NUCLEO_BUTTON_Functions 00257 * @{ 00258 */ 00259 00260 void BSP_PB_Init(Button_TypeDef Button, ButtonMode_TypeDef ButtonMode); 00261 void BSP_PB_DeInit(Button_TypeDef Button); 00262 uint32_t BSP_PB_GetState(Button_TypeDef Button); 00263 #if defined(HAL_ADC_MODULE_ENABLED) 00264 uint8_t BSP_JOY_Init(void); 00265 JOYState_TypeDef BSP_JOY_GetState(void); 00266 void BSP_JOY_DeInit(void); 00267 #endif /* HAL_ADC_MODULE_ENABLED */ 00268 00269 00270 /** 00271 * @} 00272 */ 00273 00274 /** 00275 * @} 00276 */ 00277 00278 /** 00279 * @} 00280 */ 00281 00282 /** 00283 * @} 00284 */ 00285 00286 #ifdef __cplusplus 00287 } 00288 #endif 00289 00290 #endif /* __STM32F1XX_NUCLEO_H */ 00291 00292 00293 /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/
Generated on Fri Mar 3 2017 19:17:51 for STM32F1xx_Nucleo BSP User Manual by 1.7.6.1