fix LPC812 PWM

Dependents:   IR_LED_Send

Fork of mbed-dev by mbed official

Committer:
nameless129
Date:
Mon May 16 16:50:30 2016 +0000
Revision:
129:2e517c56bcfb
Parent:
0:9b334a45a8ff
PWM Fix:Duty 0%??H???????????????

Who changed what in which revision?

UserRevisionLine numberNew contents of line
bogdanm 0:9b334a45a8ff 1 /**
bogdanm 0:9b334a45a8ff 2 ******************************************************************************
bogdanm 0:9b334a45a8ff 3 * @file stm32f3xx_hal_flash.h
bogdanm 0:9b334a45a8ff 4 * @author MCD Application Team
bogdanm 0:9b334a45a8ff 5 * @version V1.1.0
bogdanm 0:9b334a45a8ff 6 * @date 12-Sept-2014
bogdanm 0:9b334a45a8ff 7 * @brief Header file of Flash HAL module.
bogdanm 0:9b334a45a8ff 8 ******************************************************************************
bogdanm 0:9b334a45a8ff 9 * @attention
bogdanm 0:9b334a45a8ff 10 *
bogdanm 0:9b334a45a8ff 11 * <h2><center>&copy; COPYRIGHT(c) 2014 STMicroelectronics</center></h2>
bogdanm 0:9b334a45a8ff 12 *
bogdanm 0:9b334a45a8ff 13 * Redistribution and use in source and binary forms, with or without modification,
bogdanm 0:9b334a45a8ff 14 * are permitted provided that the following conditions are met:
bogdanm 0:9b334a45a8ff 15 * 1. Redistributions of source code must retain the above copyright notice,
bogdanm 0:9b334a45a8ff 16 * this list of conditions and the following disclaimer.
bogdanm 0:9b334a45a8ff 17 * 2. Redistributions in binary form must reproduce the above copyright notice,
bogdanm 0:9b334a45a8ff 18 * this list of conditions and the following disclaimer in the documentation
bogdanm 0:9b334a45a8ff 19 * and/or other materials provided with the distribution.
bogdanm 0:9b334a45a8ff 20 * 3. Neither the name of STMicroelectronics nor the names of its contributors
bogdanm 0:9b334a45a8ff 21 * may be used to endorse or promote products derived from this software
bogdanm 0:9b334a45a8ff 22 * without specific prior written permission.
bogdanm 0:9b334a45a8ff 23 *
bogdanm 0:9b334a45a8ff 24 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
bogdanm 0:9b334a45a8ff 25 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
bogdanm 0:9b334a45a8ff 26 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
bogdanm 0:9b334a45a8ff 27 * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
bogdanm 0:9b334a45a8ff 28 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
bogdanm 0:9b334a45a8ff 29 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
bogdanm 0:9b334a45a8ff 30 * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
bogdanm 0:9b334a45a8ff 31 * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
bogdanm 0:9b334a45a8ff 32 * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
bogdanm 0:9b334a45a8ff 33 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
bogdanm 0:9b334a45a8ff 34 *
bogdanm 0:9b334a45a8ff 35 ******************************************************************************
bogdanm 0:9b334a45a8ff 36 */
bogdanm 0:9b334a45a8ff 37
bogdanm 0:9b334a45a8ff 38 /* Define to prevent recursive inclusion -------------------------------------*/
bogdanm 0:9b334a45a8ff 39 #ifndef __STM32F3xx_HAL_FLASH_H
bogdanm 0:9b334a45a8ff 40 #define __STM32F3xx_HAL_FLASH_H
bogdanm 0:9b334a45a8ff 41
bogdanm 0:9b334a45a8ff 42 #ifdef __cplusplus
bogdanm 0:9b334a45a8ff 43 extern "C" {
bogdanm 0:9b334a45a8ff 44 #endif
bogdanm 0:9b334a45a8ff 45
bogdanm 0:9b334a45a8ff 46 /* Includes ------------------------------------------------------------------*/
bogdanm 0:9b334a45a8ff 47 #include "stm32f3xx_hal_def.h"
bogdanm 0:9b334a45a8ff 48
bogdanm 0:9b334a45a8ff 49 /** @addtogroup STM32F3xx_HAL_Driver
bogdanm 0:9b334a45a8ff 50 * @{
bogdanm 0:9b334a45a8ff 51 */
bogdanm 0:9b334a45a8ff 52
bogdanm 0:9b334a45a8ff 53 /** @addtogroup FLASH FLASH HAL module driver
bogdanm 0:9b334a45a8ff 54 * @{
bogdanm 0:9b334a45a8ff 55 */
bogdanm 0:9b334a45a8ff 56
bogdanm 0:9b334a45a8ff 57 /* Exported types ------------------------------------------------------------*/
bogdanm 0:9b334a45a8ff 58 /** @defgroup FLASH_Exported_Types FLASH Exported Types
bogdanm 0:9b334a45a8ff 59 * @{
bogdanm 0:9b334a45a8ff 60 */
bogdanm 0:9b334a45a8ff 61
bogdanm 0:9b334a45a8ff 62 /**
bogdanm 0:9b334a45a8ff 63 * @brief FLASH Error source
bogdanm 0:9b334a45a8ff 64 */
bogdanm 0:9b334a45a8ff 65 typedef enum
bogdanm 0:9b334a45a8ff 66 {
bogdanm 0:9b334a45a8ff 67 FLASH_ERROR_PG = 0x01,
bogdanm 0:9b334a45a8ff 68 FLASH_ERROR_WRP = 0x02
bogdanm 0:9b334a45a8ff 69 } FLASH_ErrorTypeDef;
bogdanm 0:9b334a45a8ff 70
bogdanm 0:9b334a45a8ff 71 /**
bogdanm 0:9b334a45a8ff 72 * @brief FLASH Erase structure definition
bogdanm 0:9b334a45a8ff 73 */
bogdanm 0:9b334a45a8ff 74 typedef struct
bogdanm 0:9b334a45a8ff 75 {
bogdanm 0:9b334a45a8ff 76 uint32_t TypeErase; /*!< TypeErase: Mass erase or page erase.
bogdanm 0:9b334a45a8ff 77 This parameter can be a value of @ref FLASH_Type_Erase */
bogdanm 0:9b334a45a8ff 78
bogdanm 0:9b334a45a8ff 79 uint32_t PageAddress; /*!< PageAdress: Initial FLASH page address to erase when mass erase is disabled
bogdanm 0:9b334a45a8ff 80 This parameter must be a value of @ref FLASHEx_Address */
bogdanm 0:9b334a45a8ff 81
bogdanm 0:9b334a45a8ff 82 uint32_t NbPages; /*!< NbPages: Number of pagess to be erased.
bogdanm 0:9b334a45a8ff 83 This parameter must be a value between 1 and (max number of pages - value of initial page)*/
bogdanm 0:9b334a45a8ff 84
bogdanm 0:9b334a45a8ff 85 } FLASH_EraseInitTypeDef;
bogdanm 0:9b334a45a8ff 86
bogdanm 0:9b334a45a8ff 87 /**
bogdanm 0:9b334a45a8ff 88 * @brief FLASH Options bytes program structure definition
bogdanm 0:9b334a45a8ff 89 */
bogdanm 0:9b334a45a8ff 90 typedef struct
bogdanm 0:9b334a45a8ff 91 {
bogdanm 0:9b334a45a8ff 92 uint32_t OptionType; /*!< OptionType: Option byte to be configured.
bogdanm 0:9b334a45a8ff 93 This parameter can be a value of @ref FLASH_OB_Type */
bogdanm 0:9b334a45a8ff 94
bogdanm 0:9b334a45a8ff 95 uint32_t WRPState; /*!< WRPState: Write protection activation or deactivation.
bogdanm 0:9b334a45a8ff 96 This parameter can be a value of @ref FLASH_OB_WRP_State */
bogdanm 0:9b334a45a8ff 97
bogdanm 0:9b334a45a8ff 98 uint32_t WRPPage; /*!< WRPSector: specifies the page(s) to be write protected
bogdanm 0:9b334a45a8ff 99 This parameter can be a value of @ref FLASHEx_OB_Write_Protection */
bogdanm 0:9b334a45a8ff 100
bogdanm 0:9b334a45a8ff 101 uint8_t RDPLevel; /*!< RDPLevel: Set the read protection level..
bogdanm 0:9b334a45a8ff 102 This parameter can be a value of @ref FLASH_OB_Read_Protection */
bogdanm 0:9b334a45a8ff 103
bogdanm 0:9b334a45a8ff 104 uint8_t USERConfig; /*!< USERConfig: Program the FLASH User Option Byte:
bogdanm 0:9b334a45a8ff 105 IWDG / STOP / STDBY / BOOT1 / VDDA_ANALOG / SRAM_PARITY / SDADC12_VDD_MONITOR
bogdanm 0:9b334a45a8ff 106 This parameter can be a combination of @ref FLASH_OB_IWatchdog, @ref FLASH_OB_nRST_STOP,
bogdanm 0:9b334a45a8ff 107 @ref FLASH_OB_nRST_STDBY, @ref FLASH_OB_BOOT1, @ref FLASH_OB_VDDA_Analog_Monitoring,
bogdanm 0:9b334a45a8ff 108 @ref FLASH_OB_SRAM_Parity_Enable and @ref FLASH_OB_SDADC12_VDD_MONITOR */
bogdanm 0:9b334a45a8ff 109
bogdanm 0:9b334a45a8ff 110 uint32_t DATAAddress; /*!< DATAAddress: Address of the option byte DATA to be prgrammed
bogdanm 0:9b334a45a8ff 111 This parameter can be a value of @ref FLASH_OB_Data_Address */
bogdanm 0:9b334a45a8ff 112
bogdanm 0:9b334a45a8ff 113 uint8_t DATAData; /*!< DATAData: Data to be stored in the option byte DATA
bogdanm 0:9b334a45a8ff 114 This parameter can have any value */
bogdanm 0:9b334a45a8ff 115
bogdanm 0:9b334a45a8ff 116 } FLASH_OBProgramInitTypeDef;
bogdanm 0:9b334a45a8ff 117
bogdanm 0:9b334a45a8ff 118 /**
bogdanm 0:9b334a45a8ff 119 * @brief FLASH Procedure structure definition
bogdanm 0:9b334a45a8ff 120 */
bogdanm 0:9b334a45a8ff 121 typedef enum
bogdanm 0:9b334a45a8ff 122 {
bogdanm 0:9b334a45a8ff 123 FLASH_PROC_NONE = 0,
bogdanm 0:9b334a45a8ff 124 FLASH_PROC_PAGEERASE = 1,
bogdanm 0:9b334a45a8ff 125 FLASH_PROC_MASSERASE = 2,
bogdanm 0:9b334a45a8ff 126 FLASH_PROC_PROGRAMHALFWORD = 3,
bogdanm 0:9b334a45a8ff 127 FLASH_PROC_PROGRAMWORD = 4,
bogdanm 0:9b334a45a8ff 128 FLASH_PROC_PROGRAMDOUBLEWORD = 5
bogdanm 0:9b334a45a8ff 129 } FLASH_ProcedureTypeDef;
bogdanm 0:9b334a45a8ff 130
bogdanm 0:9b334a45a8ff 131 /**
bogdanm 0:9b334a45a8ff 132 * @brief FLASH handle Structure definition
bogdanm 0:9b334a45a8ff 133 */
bogdanm 0:9b334a45a8ff 134 typedef struct
bogdanm 0:9b334a45a8ff 135 {
bogdanm 0:9b334a45a8ff 136 __IO FLASH_ProcedureTypeDef ProcedureOnGoing; /* Internal variable to indicate which procedure is ongoing or not in IT context */
bogdanm 0:9b334a45a8ff 137
bogdanm 0:9b334a45a8ff 138 __IO uint32_t DataRemaining; /* Internal variable to save the remaining pages to erase or half-word to program in IT context */
bogdanm 0:9b334a45a8ff 139
bogdanm 0:9b334a45a8ff 140 __IO uint32_t Address; /* Internal variable to save address selected for program or erase */
bogdanm 0:9b334a45a8ff 141
bogdanm 0:9b334a45a8ff 142 __IO uint64_t Data; /* Internal variable to save data to be programmed */
bogdanm 0:9b334a45a8ff 143
bogdanm 0:9b334a45a8ff 144 HAL_LockTypeDef Lock; /* FLASH locking object */
bogdanm 0:9b334a45a8ff 145
bogdanm 0:9b334a45a8ff 146 __IO FLASH_ErrorTypeDef ErrorCode; /* FLASH error code */
bogdanm 0:9b334a45a8ff 147
bogdanm 0:9b334a45a8ff 148 } FLASH_ProcessTypeDef;
bogdanm 0:9b334a45a8ff 149
bogdanm 0:9b334a45a8ff 150 /**
bogdanm 0:9b334a45a8ff 151 * @}
bogdanm 0:9b334a45a8ff 152 */
bogdanm 0:9b334a45a8ff 153
bogdanm 0:9b334a45a8ff 154 /* Exported constants --------------------------------------------------------*/
bogdanm 0:9b334a45a8ff 155 /** @defgroup FLASH_Exported_Constants FLASH Exported Constants
bogdanm 0:9b334a45a8ff 156 * @{
bogdanm 0:9b334a45a8ff 157 */
bogdanm 0:9b334a45a8ff 158
bogdanm 0:9b334a45a8ff 159 /** @defgroup FLASH_Type_Erase FLASH Type Erase
bogdanm 0:9b334a45a8ff 160 * @{
bogdanm 0:9b334a45a8ff 161 */
bogdanm 0:9b334a45a8ff 162 #define TYPEERASE_PAGES ((uint32_t)0x00) /*!<Pages erase only*/
bogdanm 0:9b334a45a8ff 163 #define TYPEERASE_MASSERASE ((uint32_t)0x01) /*!<Flash mass erase activation*/
bogdanm 0:9b334a45a8ff 164
bogdanm 0:9b334a45a8ff 165 #define IS_TYPEERASE(VALUE) (((VALUE) == TYPEERASE_PAGES) || \
bogdanm 0:9b334a45a8ff 166 ((VALUE) == TYPEERASE_MASSERASE))
bogdanm 0:9b334a45a8ff 167 /**
bogdanm 0:9b334a45a8ff 168 * @}
bogdanm 0:9b334a45a8ff 169 */
bogdanm 0:9b334a45a8ff 170
bogdanm 0:9b334a45a8ff 171 /** @defgroup FLASH_Type_Program FLASH Type Program
bogdanm 0:9b334a45a8ff 172 * @{
bogdanm 0:9b334a45a8ff 173 */
bogdanm 0:9b334a45a8ff 174 #define TYPEPROGRAM_HALFWORD ((uint32_t)0x01) /*!<Program a half-word (16-bit) at a specified address.*/
bogdanm 0:9b334a45a8ff 175 #define TYPEPROGRAM_WORD ((uint32_t)0x02) /*!<Program a word (32-bit) at a specified address.*/
bogdanm 0:9b334a45a8ff 176 #define TYPEPROGRAM_DOUBLEWORD ((uint32_t)0x03) /*!<Program a double word (64-bit) at a specified address*/
bogdanm 0:9b334a45a8ff 177
bogdanm 0:9b334a45a8ff 178 #define IS_TYPEPROGRAM(VALUE) (((VALUE) == TYPEPROGRAM_HALFWORD) || \
bogdanm 0:9b334a45a8ff 179 ((VALUE) == TYPEPROGRAM_WORD) || \
bogdanm 0:9b334a45a8ff 180 ((VALUE) == TYPEPROGRAM_DOUBLEWORD))
bogdanm 0:9b334a45a8ff 181 /**
bogdanm 0:9b334a45a8ff 182 * @}
bogdanm 0:9b334a45a8ff 183 */
bogdanm 0:9b334a45a8ff 184
bogdanm 0:9b334a45a8ff 185 /** @defgroup FLASH_OB_WRP_State FLASH WRP State
bogdanm 0:9b334a45a8ff 186 * @{
bogdanm 0:9b334a45a8ff 187 */
bogdanm 0:9b334a45a8ff 188 #define WRPSTATE_DISABLE ((uint32_t)0x00) /*!<Disable the write protection of the desired pages*/
bogdanm 0:9b334a45a8ff 189 #define WRPSTATE_ENABLE ((uint32_t)0x01) /*!<Enable the write protection of the desired pagess*/
bogdanm 0:9b334a45a8ff 190
bogdanm 0:9b334a45a8ff 191 #define IS_WRPSTATE(VALUE) (((VALUE) == WRPSTATE_DISABLE) || \
bogdanm 0:9b334a45a8ff 192 ((VALUE) == WRPSTATE_ENABLE))
bogdanm 0:9b334a45a8ff 193 /**
bogdanm 0:9b334a45a8ff 194 * @}
bogdanm 0:9b334a45a8ff 195 */
bogdanm 0:9b334a45a8ff 196
bogdanm 0:9b334a45a8ff 197 /** @defgroup FLASH_OB_Type FLASH Option Bytes Type
bogdanm 0:9b334a45a8ff 198 * @{
bogdanm 0:9b334a45a8ff 199 */
bogdanm 0:9b334a45a8ff 200 #define OPTIONBYTE_WRP ((uint32_t)0x01) /*!<WRP option byte configuration*/
bogdanm 0:9b334a45a8ff 201 #define OPTIONBYTE_RDP ((uint32_t)0x02) /*!<RDP option byte configuration*/
bogdanm 0:9b334a45a8ff 202 #define OPTIONBYTE_USER ((uint32_t)0x04) /*!<USER option byte configuration*/
bogdanm 0:9b334a45a8ff 203 #define OPTIONBYTE_DATA ((uint32_t)0x08) /*!<DATA option byte configuration*/
bogdanm 0:9b334a45a8ff 204
bogdanm 0:9b334a45a8ff 205 #define IS_OPTIONBYTE(VALUE) (((VALUE) < (OPTIONBYTE_WRP | OPTIONBYTE_RDP | OPTIONBYTE_USER | OPTIONBYTE_DATA)))
bogdanm 0:9b334a45a8ff 206 /**
bogdanm 0:9b334a45a8ff 207 * @}
bogdanm 0:9b334a45a8ff 208 */
bogdanm 0:9b334a45a8ff 209
bogdanm 0:9b334a45a8ff 210 /** @defgroup FLASH_Latency FLASH Latency
bogdanm 0:9b334a45a8ff 211 * @{
bogdanm 0:9b334a45a8ff 212 */
bogdanm 0:9b334a45a8ff 213 #define FLASH_LATENCY_0 ((uint8_t)0x0000) /*!< FLASH Zero Latency cycle */
bogdanm 0:9b334a45a8ff 214 #define FLASH_LATENCY_1 FLASH_ACR_LATENCY_0 /*!< FLASH One Latency cycle */
bogdanm 0:9b334a45a8ff 215 #define FLASH_LATENCY_2 FLASH_ACR_LATENCY_1 /*!< FLASH Two Latency cycles */
bogdanm 0:9b334a45a8ff 216
bogdanm 0:9b334a45a8ff 217 #define IS_FLASH_LATENCY(LATENCY) (((LATENCY) == FLASH_LATENCY_0) || \
bogdanm 0:9b334a45a8ff 218 ((LATENCY) == FLASH_LATENCY_1) || \
bogdanm 0:9b334a45a8ff 219 ((LATENCY) == FLASH_LATENCY_2))
bogdanm 0:9b334a45a8ff 220 /**
bogdanm 0:9b334a45a8ff 221 * @}
bogdanm 0:9b334a45a8ff 222 */
bogdanm 0:9b334a45a8ff 223
bogdanm 0:9b334a45a8ff 224 /** @defgroup FLASH_OB_Data_Address FLASH Option Byte Data Address
bogdanm 0:9b334a45a8ff 225 * @{
bogdanm 0:9b334a45a8ff 226 */
bogdanm 0:9b334a45a8ff 227 #define IS_OB_DATA_ADDRESS(ADDRESS) (((ADDRESS) == 0x1FFFF804) || ((ADDRESS) == 0x1FFFF806))
bogdanm 0:9b334a45a8ff 228 /**
bogdanm 0:9b334a45a8ff 229 * @}
bogdanm 0:9b334a45a8ff 230 */
bogdanm 0:9b334a45a8ff 231
bogdanm 0:9b334a45a8ff 232 /** @defgroup FLASH_OB_Read_Protection FLASH Option Byte Read Protection
bogdanm 0:9b334a45a8ff 233 * @{
bogdanm 0:9b334a45a8ff 234 */
bogdanm 0:9b334a45a8ff 235 #define OB_RDP_LEVEL_0 ((uint8_t)0xAA)
bogdanm 0:9b334a45a8ff 236 #define OB_RDP_LEVEL_1 ((uint8_t)0xBB)
bogdanm 0:9b334a45a8ff 237 #define OB_RDP_LEVEL_2 ((uint8_t)0xCC) /*!< Warning: When enabling read protection level 2
bogdanm 0:9b334a45a8ff 238 it's no more possible to go back to level 1 or 0 */
bogdanm 0:9b334a45a8ff 239 #define IS_OB_RDP_LEVEL(LEVEL) (((LEVEL) == OB_RDP_LEVEL_0) ||\
bogdanm 0:9b334a45a8ff 240 ((LEVEL) == OB_RDP_LEVEL_1))/*||\
bogdanm 0:9b334a45a8ff 241 ((LEVEL) == OB_RDP_LEVEL_2))*/
bogdanm 0:9b334a45a8ff 242 /**
bogdanm 0:9b334a45a8ff 243 * @}
bogdanm 0:9b334a45a8ff 244 */
bogdanm 0:9b334a45a8ff 245
bogdanm 0:9b334a45a8ff 246 /** @defgroup FLASH_OB_IWatchdog FLASH Option Byte IWatchdog
bogdanm 0:9b334a45a8ff 247 * @{
bogdanm 0:9b334a45a8ff 248 */
bogdanm 0:9b334a45a8ff 249 #define OB_IWDG_SW ((uint8_t)0x01) /*!< Software IWDG selected */
bogdanm 0:9b334a45a8ff 250 #define OB_IWDG_HW ((uint8_t)0x00) /*!< Hardware IWDG selected */
bogdanm 0:9b334a45a8ff 251 #define IS_OB_IWDG_SOURCE(SOURCE) (((SOURCE) == OB_IWDG_SW) || ((SOURCE) == OB_IWDG_HW))
bogdanm 0:9b334a45a8ff 252 /**
bogdanm 0:9b334a45a8ff 253 * @}
bogdanm 0:9b334a45a8ff 254 */
bogdanm 0:9b334a45a8ff 255
bogdanm 0:9b334a45a8ff 256 /** @defgroup FLASH_OB_nRST_STOP FLASH Option Byte nRST STOP
bogdanm 0:9b334a45a8ff 257 * @{
bogdanm 0:9b334a45a8ff 258 */
bogdanm 0:9b334a45a8ff 259 #define OB_STOP_NO_RST ((uint8_t)0x02) /*!< No reset generated when entering in STOP */
bogdanm 0:9b334a45a8ff 260 #define OB_STOP_RST ((uint8_t)0x00) /*!< Reset generated when entering in STOP */
bogdanm 0:9b334a45a8ff 261 #define IS_OB_STOP_SOURCE(SOURCE) (((SOURCE) == OB_STOP_NO_RST) || ((SOURCE) == OB_STOP_RST))
bogdanm 0:9b334a45a8ff 262 /**
bogdanm 0:9b334a45a8ff 263 * @}
bogdanm 0:9b334a45a8ff 264 */
bogdanm 0:9b334a45a8ff 265
bogdanm 0:9b334a45a8ff 266 /** @defgroup FLASH_OB_nRST_STDBY FLASH Option Byte nRST STDBY
bogdanm 0:9b334a45a8ff 267 * @{
bogdanm 0:9b334a45a8ff 268 */
bogdanm 0:9b334a45a8ff 269 #define OB_STDBY_NO_RST ((uint8_t)0x04) /*!< No reset generated when entering in STANDBY */
bogdanm 0:9b334a45a8ff 270 #define OB_STDBY_RST ((uint8_t)0x00) /*!< Reset generated when entering in STANDBY */
bogdanm 0:9b334a45a8ff 271 #define IS_OB_STDBY_SOURCE(SOURCE) (((SOURCE) == OB_STDBY_NO_RST) || ((SOURCE) == OB_STDBY_RST))
bogdanm 0:9b334a45a8ff 272 /**
bogdanm 0:9b334a45a8ff 273 * @}
bogdanm 0:9b334a45a8ff 274 */
bogdanm 0:9b334a45a8ff 275
bogdanm 0:9b334a45a8ff 276 /** @defgroup FLASH_OB_BOOT1 FLASH Option Byte BOOT1
bogdanm 0:9b334a45a8ff 277 * @{
bogdanm 0:9b334a45a8ff 278 */
bogdanm 0:9b334a45a8ff 279 #define OB_BOOT1_RESET ((uint8_t)0x00) /*!< BOOT1 Reset */
bogdanm 0:9b334a45a8ff 280 #define OB_BOOT1_SET ((uint8_t)0x10) /*!< BOOT1 Set */
bogdanm 0:9b334a45a8ff 281 #define IS_OB_BOOT1(BOOT1) (((BOOT1) == OB_BOOT1_RESET) || ((BOOT1) == OB_BOOT1_SET))
bogdanm 0:9b334a45a8ff 282 /**
bogdanm 0:9b334a45a8ff 283 * @}
bogdanm 0:9b334a45a8ff 284 */
bogdanm 0:9b334a45a8ff 285
bogdanm 0:9b334a45a8ff 286 /** @defgroup FLASH_OB_VDDA_Analog_Monitoring FLASH Option Byte VDDA Analog Monitoring
bogdanm 0:9b334a45a8ff 287 * @{
bogdanm 0:9b334a45a8ff 288 */
bogdanm 0:9b334a45a8ff 289 #define OB_VDDA_ANALOG_ON ((uint8_t)0x20) /*!< Analog monitoring on VDDA Power source ON */
bogdanm 0:9b334a45a8ff 290 #define OB_VDDA_ANALOG_OFF ((uint8_t)0x00) /*!< Analog monitoring on VDDA Power source OFF */
bogdanm 0:9b334a45a8ff 291 #define IS_OB_VDDA_ANALOG(ANALOG) (((ANALOG) == OB_VDDA_ANALOG_ON) || ((ANALOG) == OB_VDDA_ANALOG_OFF))
bogdanm 0:9b334a45a8ff 292 /**
bogdanm 0:9b334a45a8ff 293 * @}
bogdanm 0:9b334a45a8ff 294 */
bogdanm 0:9b334a45a8ff 295
bogdanm 0:9b334a45a8ff 296 /** @defgroup FLASH_OB_SRAM_Parity_Enable FLASH Option Byte SRAM Parity Enable
bogdanm 0:9b334a45a8ff 297 * @{
bogdanm 0:9b334a45a8ff 298 */
bogdanm 0:9b334a45a8ff 299 #define OB_SRAM_PARITY_SET ((uint8_t)0x00) /*!< SRAM parity enable set */
bogdanm 0:9b334a45a8ff 300 #define OB_SRAM_PARITY_RESET ((uint8_t)0x40) /*!< SRAM parity enable reset */
bogdanm 0:9b334a45a8ff 301 #define IS_OB_SRAM_PARITY(PARITY) (((PARITY) == OB_SRAM_PARITY_SET) || ((PARITY) == OB_SRAM_PARITY_RESET))
bogdanm 0:9b334a45a8ff 302 /**
bogdanm 0:9b334a45a8ff 303 * @}
bogdanm 0:9b334a45a8ff 304 */
bogdanm 0:9b334a45a8ff 305
bogdanm 0:9b334a45a8ff 306 /** @defgroup FLASH_OB_SDADC12_VDD_MONITOR FLASH Option Byte SDADC12 VDD MONITOR
bogdanm 0:9b334a45a8ff 307 * @{
bogdanm 0:9b334a45a8ff 308 */
bogdanm 0:9b334a45a8ff 309 #define OB_SDADC12_VDD_MONITOR_SET ((uint8_t)0x80) /*!< SDADC12_VDD power supply supervisor set */
bogdanm 0:9b334a45a8ff 310 #define OB_SDADC12_VDD_MONITOR_RESET ((uint8_t)0x00) /*!< SDADC12_VDD power supply supervisor reset */
bogdanm 0:9b334a45a8ff 311 #define IS_OB_SDADC12_VDD_MONITOR(MONITOR) (((MONITOR) == OB_SDADC12_VDD_MONITOR_SET) || ((MONITOR) == OB_SDADC12_VDD_MONITOR_RESET))
bogdanm 0:9b334a45a8ff 312 /**
bogdanm 0:9b334a45a8ff 313 * @}
bogdanm 0:9b334a45a8ff 314 */
bogdanm 0:9b334a45a8ff 315
bogdanm 0:9b334a45a8ff 316 /** @defgroup FLASH_Flag_definition FLASH Flag definition
bogdanm 0:9b334a45a8ff 317 * @brief Flag definition
bogdanm 0:9b334a45a8ff 318 * @{
bogdanm 0:9b334a45a8ff 319 */
bogdanm 0:9b334a45a8ff 320 #define FLASH_FLAG_BSY FLASH_SR_BSY /*!< FLASH Busy flag */
bogdanm 0:9b334a45a8ff 321 #define FLASH_FLAG_PGERR FLASH_SR_PGERR /*!< FLASH Programming error flag */
bogdanm 0:9b334a45a8ff 322 #define FLASH_FLAG_WRPERR FLASH_SR_WRPERR /*!< FLASH Write protected error flag */
bogdanm 0:9b334a45a8ff 323 #define FLASH_FLAG_EOP FLASH_SR_EOP /*!< FLASH End of Operation flag */
bogdanm 0:9b334a45a8ff 324
bogdanm 0:9b334a45a8ff 325 #define IS_FLASH_CLEAR_FLAG(FLAG) ((((FLAG) & (uint32_t)0xFFFFFFC3) == 0x00000000) && ((FLAG) != 0x00000000))
bogdanm 0:9b334a45a8ff 326 #define IS_FLASH_GET_FLAG(FLAG) (((FLAG) == FLASH_FLAG_BSY) || ((FLAG) == FLASH_FLAG_PGERR) || \
bogdanm 0:9b334a45a8ff 327 ((FLAG) == FLASH_FLAG_WRPERR) || ((FLAG) == FLASH_FLAG_EOP))
bogdanm 0:9b334a45a8ff 328 /**
bogdanm 0:9b334a45a8ff 329 * @}
bogdanm 0:9b334a45a8ff 330 */
bogdanm 0:9b334a45a8ff 331
bogdanm 0:9b334a45a8ff 332 /** @defgroup FLASH_Interrupt_definition FLASH Interrupt definition
bogdanm 0:9b334a45a8ff 333 * @brief FLASH Interrupt definition
bogdanm 0:9b334a45a8ff 334 * @{
bogdanm 0:9b334a45a8ff 335 */
bogdanm 0:9b334a45a8ff 336 #define FLASH_IT_EOP FLASH_CR_EOPIE /*!< End of FLASH Operation Interrupt source */
bogdanm 0:9b334a45a8ff 337 #define FLASH_IT_ERR FLASH_CR_ERRIE /*!< Error Interrupt source */
bogdanm 0:9b334a45a8ff 338 #define IS_FLASH_IT(IT) ((((IT) & (uint32_t)0xFFFFEBFF) == 0x00000000) && ((IT) != 0x00000000))
bogdanm 0:9b334a45a8ff 339 /**
bogdanm 0:9b334a45a8ff 340 * @}
bogdanm 0:9b334a45a8ff 341 */
bogdanm 0:9b334a45a8ff 342
bogdanm 0:9b334a45a8ff 343 /** @defgroup FLASH_Timeout_definition FLASH Timeout definition
bogdanm 0:9b334a45a8ff 344 * @brief FLASH Timeout definition
bogdanm 0:9b334a45a8ff 345 * @{
bogdanm 0:9b334a45a8ff 346 */
bogdanm 0:9b334a45a8ff 347 #define HAL_FLASH_TIMEOUT_VALUE ((uint32_t)50000)/* 50 s */
bogdanm 0:9b334a45a8ff 348 /**
bogdanm 0:9b334a45a8ff 349 * @}
bogdanm 0:9b334a45a8ff 350 */
bogdanm 0:9b334a45a8ff 351
bogdanm 0:9b334a45a8ff 352 /**
bogdanm 0:9b334a45a8ff 353 * @}
bogdanm 0:9b334a45a8ff 354 */
bogdanm 0:9b334a45a8ff 355
bogdanm 0:9b334a45a8ff 356 /* Exported macro ------------------------------------------------------------*/
bogdanm 0:9b334a45a8ff 357
bogdanm 0:9b334a45a8ff 358 /** @defgroup FLASH_Exported_Macros FLASH Exported Macros
bogdanm 0:9b334a45a8ff 359 * @brief macros to control FLASH features
bogdanm 0:9b334a45a8ff 360 * @{
bogdanm 0:9b334a45a8ff 361 */
bogdanm 0:9b334a45a8ff 362
bogdanm 0:9b334a45a8ff 363 /**
bogdanm 0:9b334a45a8ff 364 * @brief Set the FLASH Latency.
bogdanm 0:9b334a45a8ff 365 * @param __LATENCY__: FLASH Latency
bogdanm 0:9b334a45a8ff 366 * The value of this parameter depend on device used within the same series
bogdanm 0:9b334a45a8ff 367 * @retval None
bogdanm 0:9b334a45a8ff 368 */
bogdanm 0:9b334a45a8ff 369 #define __HAL_FLASH_SET_LATENCY(__LATENCY__) (FLASH->ACR = (FLASH->ACR&(~FLASH_ACR_LATENCY)) | (__LATENCY__))
bogdanm 0:9b334a45a8ff 370
bogdanm 0:9b334a45a8ff 371 /**
bogdanm 0:9b334a45a8ff 372 * @brief Enable the FLASH prefetch buffer.
bogdanm 0:9b334a45a8ff 373 * @retval None
bogdanm 0:9b334a45a8ff 374 */
bogdanm 0:9b334a45a8ff 375 #define __HAL_FLASH_PREFETCH_BUFFER_ENABLE() (FLASH->ACR |= FLASH_ACR_PRFTBE)
bogdanm 0:9b334a45a8ff 376
bogdanm 0:9b334a45a8ff 377 /**
bogdanm 0:9b334a45a8ff 378 * @brief Disable the FLASH prefetch buffer.
bogdanm 0:9b334a45a8ff 379 * @retval None
bogdanm 0:9b334a45a8ff 380 */
bogdanm 0:9b334a45a8ff 381 #define __HAL_FLASH_PREFETCH_BUFFER_DISABLE() (FLASH->ACR &= (~FLASH_ACR_PRFTBE))
bogdanm 0:9b334a45a8ff 382
bogdanm 0:9b334a45a8ff 383 /**
bogdanm 0:9b334a45a8ff 384 * @brief Enable the FLASH half cycle access.
bogdanm 0:9b334a45a8ff 385 * @retval None
bogdanm 0:9b334a45a8ff 386 */
bogdanm 0:9b334a45a8ff 387 #define __HAL_FLASH_HALF_CYCLE_ACCESS_ENABLE() (FLASH->ACR |= FLASH_ACR_HLFCYA)
bogdanm 0:9b334a45a8ff 388
bogdanm 0:9b334a45a8ff 389 /**
bogdanm 0:9b334a45a8ff 390 * @brief Disable the FLASH half cycle access.
bogdanm 0:9b334a45a8ff 391 * @retval None
bogdanm 0:9b334a45a8ff 392 */
bogdanm 0:9b334a45a8ff 393 #define __HAL_FLASH_HALF_CYCLE_ACCESS_DISABLE() (FLASH->ACR &= (~FLASH_ACR_HLFCYA))
bogdanm 0:9b334a45a8ff 394
bogdanm 0:9b334a45a8ff 395 /** @defgroup FLASH_Interrupt FLASH Interrupt
bogdanm 0:9b334a45a8ff 396 * @brief macros to handle FLASH interrupts
bogdanm 0:9b334a45a8ff 397 * @{
bogdanm 0:9b334a45a8ff 398 */
bogdanm 0:9b334a45a8ff 399
bogdanm 0:9b334a45a8ff 400 /**
bogdanm 0:9b334a45a8ff 401 * @brief Enable the specified FLASH interrupt.
bogdanm 0:9b334a45a8ff 402 * @param __INTERRUPT__ : FLASH interrupt
bogdanm 0:9b334a45a8ff 403 * This parameter can be any combination of the following values:
bogdanm 0:9b334a45a8ff 404 * @arg FLASH_IT_EOP: End of FLASH Operation Interrupt
bogdanm 0:9b334a45a8ff 405 * @arg FLASH_IT_ERR: Error Interrupt
bogdanm 0:9b334a45a8ff 406 * @retval none
bogdanm 0:9b334a45a8ff 407 */
bogdanm 0:9b334a45a8ff 408 #define __HAL_FLASH_ENABLE_IT(__INTERRUPT__) (FLASH->CR |= (__INTERRUPT__))
bogdanm 0:9b334a45a8ff 409
bogdanm 0:9b334a45a8ff 410 /**
bogdanm 0:9b334a45a8ff 411 * @brief Disable the specified FLASH interrupt.
bogdanm 0:9b334a45a8ff 412 * @param __INTERRUPT__ : FLASH interrupt
bogdanm 0:9b334a45a8ff 413 * This parameter can be any combination of the following values:
bogdanm 0:9b334a45a8ff 414 * @arg FLASH_IT_EOP: End of FLASH Operation Interrupt
bogdanm 0:9b334a45a8ff 415 * @arg FLASH_IT_ERR: Error Interrupt
bogdanm 0:9b334a45a8ff 416 * @retval none
bogdanm 0:9b334a45a8ff 417 */
bogdanm 0:9b334a45a8ff 418 #define __HAL_FLASH_DISABLE_IT(__INTERRUPT__) (FLASH->CR &= ~(uint32_t)(__INTERRUPT__))
bogdanm 0:9b334a45a8ff 419
bogdanm 0:9b334a45a8ff 420 /**
bogdanm 0:9b334a45a8ff 421 * @brief Get the specified FLASH flag status.
bogdanm 0:9b334a45a8ff 422 * @param __FLAG__: specifies the FLASH flag to check.
bogdanm 0:9b334a45a8ff 423 * This parameter can be one of the following values:
bogdanm 0:9b334a45a8ff 424 * @arg FLASH_FLAG_EOP : FLASH End of Operation flag
bogdanm 0:9b334a45a8ff 425 * @arg FLASH_FLAG_WRPERR: FLASH Write protected error flag
bogdanm 0:9b334a45a8ff 426 * @arg FLASH_FLAG_PGERR : FLASH Programming error flag
bogdanm 0:9b334a45a8ff 427 * @arg FLASH_FLAG_BSY : FLASH Busy flag
bogdanm 0:9b334a45a8ff 428 * @retval The new state of __FLAG__ (SET or RESET).
bogdanm 0:9b334a45a8ff 429 */
bogdanm 0:9b334a45a8ff 430 #define __HAL_FLASH_GET_FLAG(__FLAG__) ((FLASH->SR & (__FLAG__)) == (__FLAG__))
bogdanm 0:9b334a45a8ff 431
bogdanm 0:9b334a45a8ff 432 /**
bogdanm 0:9b334a45a8ff 433 * @brief Clear the specified FLASH flag.
bogdanm 0:9b334a45a8ff 434 * @param __FLAG__: specifies the FLASH flags to clear.
bogdanm 0:9b334a45a8ff 435 * This parameter can be any combination of the following values:
bogdanm 0:9b334a45a8ff 436 * @arg FLASH_FLAG_EOP : FLASH End of Operation flag
bogdanm 0:9b334a45a8ff 437 * @arg FLASH_FLAG_WRPERR: FLASH Write protected error flag
bogdanm 0:9b334a45a8ff 438 * @arg FLASH_FLAG_PGERR : FLASH Programming error flag
bogdanm 0:9b334a45a8ff 439 * @retval none
bogdanm 0:9b334a45a8ff 440 */
bogdanm 0:9b334a45a8ff 441 #define __HAL_FLASH_CLEAR_FLAG(__FLAG__) (FLASH->SR = (__FLAG__))
bogdanm 0:9b334a45a8ff 442
bogdanm 0:9b334a45a8ff 443 /**
bogdanm 0:9b334a45a8ff 444 * @}
bogdanm 0:9b334a45a8ff 445 */
bogdanm 0:9b334a45a8ff 446
bogdanm 0:9b334a45a8ff 447 /**
bogdanm 0:9b334a45a8ff 448 * @}
bogdanm 0:9b334a45a8ff 449 */
bogdanm 0:9b334a45a8ff 450
bogdanm 0:9b334a45a8ff 451 /* Include FLASH HAL Extended module */
bogdanm 0:9b334a45a8ff 452 #include "stm32f3xx_hal_flash_ex.h"
bogdanm 0:9b334a45a8ff 453
bogdanm 0:9b334a45a8ff 454 /* Exported functions --------------------------------------------------------*/
bogdanm 0:9b334a45a8ff 455 /** @addtogroup FLASH_Exported_Functions FLASH Exported Functions
bogdanm 0:9b334a45a8ff 456 * @{
bogdanm 0:9b334a45a8ff 457 */
bogdanm 0:9b334a45a8ff 458
bogdanm 0:9b334a45a8ff 459 /** @addtogroup FLASH_Exported_Functions_Group1 Input and Output operation functions
bogdanm 0:9b334a45a8ff 460 * @{
bogdanm 0:9b334a45a8ff 461 */
bogdanm 0:9b334a45a8ff 462 /* IO operation functions *****************************************************/
bogdanm 0:9b334a45a8ff 463 HAL_StatusTypeDef HAL_FLASH_Program(uint32_t TypeProgram, uint32_t Address, uint64_t Data);
bogdanm 0:9b334a45a8ff 464 HAL_StatusTypeDef HAL_FLASH_Program_IT(uint32_t TypeProgram, uint32_t Address, uint64_t Data);
bogdanm 0:9b334a45a8ff 465
bogdanm 0:9b334a45a8ff 466 /* FLASH IRQ handler method */
bogdanm 0:9b334a45a8ff 467 void HAL_FLASH_IRQHandler(void);
bogdanm 0:9b334a45a8ff 468 /* Callbacks in non blocking modes */
bogdanm 0:9b334a45a8ff 469 void HAL_FLASH_EndOfOperationCallback(uint32_t ReturnValue);
bogdanm 0:9b334a45a8ff 470 void HAL_FLASH_OperationErrorCallback(uint32_t ReturnValue);
bogdanm 0:9b334a45a8ff 471
bogdanm 0:9b334a45a8ff 472 /**
bogdanm 0:9b334a45a8ff 473 * @}
bogdanm 0:9b334a45a8ff 474 */
bogdanm 0:9b334a45a8ff 475
bogdanm 0:9b334a45a8ff 476 /** @addtogroup FLASH_Exported_Functions_Group2 Peripheral Control functions
bogdanm 0:9b334a45a8ff 477 * @{
bogdanm 0:9b334a45a8ff 478 */
bogdanm 0:9b334a45a8ff 479 /* Peripheral Control functions ***********************************************/
bogdanm 0:9b334a45a8ff 480 HAL_StatusTypeDef HAL_FLASH_Unlock(void);
bogdanm 0:9b334a45a8ff 481 HAL_StatusTypeDef HAL_FLASH_Lock(void);
bogdanm 0:9b334a45a8ff 482 HAL_StatusTypeDef HAL_FLASH_OB_Unlock(void);
bogdanm 0:9b334a45a8ff 483 HAL_StatusTypeDef HAL_FLASH_OB_Lock(void);
bogdanm 0:9b334a45a8ff 484 /* Option bytes control */
bogdanm 0:9b334a45a8ff 485 HAL_StatusTypeDef HAL_FLASH_OB_Launch(void);
bogdanm 0:9b334a45a8ff 486
bogdanm 0:9b334a45a8ff 487 /**
bogdanm 0:9b334a45a8ff 488 * @}
bogdanm 0:9b334a45a8ff 489 */
bogdanm 0:9b334a45a8ff 490
bogdanm 0:9b334a45a8ff 491 /** @addtogroup FLASH_Exported_Functions_Group3 Peripheral State functions
bogdanm 0:9b334a45a8ff 492 * @{
bogdanm 0:9b334a45a8ff 493 */
bogdanm 0:9b334a45a8ff 494 /* Peripheral State and Error functions ***************************************/
bogdanm 0:9b334a45a8ff 495 FLASH_ErrorTypeDef HAL_FLASH_GetError(void);
bogdanm 0:9b334a45a8ff 496
bogdanm 0:9b334a45a8ff 497 /**
bogdanm 0:9b334a45a8ff 498 * @}
bogdanm 0:9b334a45a8ff 499 */
bogdanm 0:9b334a45a8ff 500
bogdanm 0:9b334a45a8ff 501 /**
bogdanm 0:9b334a45a8ff 502 * @}
bogdanm 0:9b334a45a8ff 503 */
bogdanm 0:9b334a45a8ff 504
bogdanm 0:9b334a45a8ff 505 /* Exported Private function -------------------------------------------------*/
bogdanm 0:9b334a45a8ff 506 /** @addtogroup FLASH_Exported_Private_Functions FLASH Exported Private Functions
bogdanm 0:9b334a45a8ff 507 * @{
bogdanm 0:9b334a45a8ff 508 */
bogdanm 0:9b334a45a8ff 509 /* Erase operations */
bogdanm 0:9b334a45a8ff 510 void FLASH_PageErase(uint32_t PageAddress);
bogdanm 0:9b334a45a8ff 511 HAL_StatusTypeDef FLASH_WaitForLastOperation(uint32_t Timeout);
bogdanm 0:9b334a45a8ff 512
bogdanm 0:9b334a45a8ff 513 /* Program operations */
bogdanm 0:9b334a45a8ff 514 /**
bogdanm 0:9b334a45a8ff 515 * @}
bogdanm 0:9b334a45a8ff 516 */
bogdanm 0:9b334a45a8ff 517
bogdanm 0:9b334a45a8ff 518 /**
bogdanm 0:9b334a45a8ff 519 * @}
bogdanm 0:9b334a45a8ff 520 */
bogdanm 0:9b334a45a8ff 521
bogdanm 0:9b334a45a8ff 522 /**
bogdanm 0:9b334a45a8ff 523 * @}
bogdanm 0:9b334a45a8ff 524 */
bogdanm 0:9b334a45a8ff 525
bogdanm 0:9b334a45a8ff 526 #ifdef __cplusplus
bogdanm 0:9b334a45a8ff 527 }
bogdanm 0:9b334a45a8ff 528 #endif
bogdanm 0:9b334a45a8ff 529
bogdanm 0:9b334a45a8ff 530 #endif /* __STM32F3xx_HAL_FLASH_H */
bogdanm 0:9b334a45a8ff 531
bogdanm 0:9b334a45a8ff 532 /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/