STM8S/A Standard Peripherals Firmware Library: stm8s_flash.h Source File

STM8S/A

stm8s_flash.h
Go to the documentation of this file.
00001 /**
00002   ******************************************************************************
00003   * @file    stm8s_flash.h
00004   * @author  MCD Application Team
00005   * @version V2.2.0
00006   * @date    30-September-2014
00007   * @brief   This file contains all functions prototype and macros for the FLASH peripheral.
00008    ******************************************************************************
00009   * @attention
00010   *
00011   * <h2><center>&copy; COPYRIGHT 2014 STMicroelectronics</center></h2>
00012   *
00013   * Licensed under MCD-ST Liberty SW License Agreement V2, (the "License");
00014   * You may not use this file except in compliance with the License.
00015   * You may obtain a copy of the License at:
00016   *
00017   *        http://www.st.com/software_license_agreement_liberty_v2
00018   *
00019   * Unless required by applicable law or agreed to in writing, software 
00020   * distributed under the License is distributed on an "AS IS" BASIS, 
00021   * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
00022   * See the License for the specific language governing permissions and
00023   * limitations under the License.
00024   *
00025   ******************************************************************************
00026   */
00027 
00028 /* Define to prevent recursive inclusion -------------------------------------*/
00029 #ifndef __STM8S_FLASH_H
00030 #define __STM8S_FLASH_H
00031 
00032 /* Includes ------------------------------------------------------------------*/
00033 #include "stm8s.h"
00034 
00035 /* Exported constants --------------------------------------------------------*/
00036 
00037 /** @addtogroup FLASH_Exported_Constants
00038   * @{
00039   */
00040 
00041 #define FLASH_PROG_START_PHYSICAL_ADDRESS ((uint32_t)0x008000) /*!< Program memory: start address */
00042 
00043 #if defined (STM8S208) || defined(STM8S207) || defined(STM8S007) || defined (STM8AF52Ax) || defined (STM8AF62Ax)
00044  #define FLASH_PROG_END_PHYSICAL_ADDRESS   ((uint32_t)0x027FFF) /*!< Program memory: end address */
00045  #define FLASH_PROG_BLOCKS_NUMBER          ((uint16_t)1024)     /*!< Program memory: total number of blocks */
00046  #define FLASH_DATA_START_PHYSICAL_ADDRESS ((uint32_t)0x004000) /*!< Data EEPROM memory: start address */
00047  #define FLASH_DATA_END_PHYSICAL_ADDRESS   ((uint32_t)0x0047FF) /*!< Data EEPROM memory: end address */
00048  #define FLASH_DATA_BLOCKS_NUMBER          ((uint16_t)16)       /*!< Data EEPROM memory: total number of blocks */
00049  #define FLASH_BLOCK_SIZE                  ((uint8_t)128)       /*!< Number of bytes in a block (common for Program and Data memories) */
00050 #endif /* STM8S208, STM8S207, STM8S007, STM8AF52Ax, STM8AF62Ax */
00051 
00052 #if defined(STM8S105) || defined(STM8S005) || defined(STM8AF626x)
00053  #define FLASH_PROG_END_PHYSICAL_ADDRESS   ((uint32_t)0xFFFF)   /*!< Program memory: end address */
00054  #define FLASH_PROG_BLOCKS_NUMBER          ((uint16_t)256)      /*!< Program memory: total number of blocks */
00055  #define FLASH_DATA_START_PHYSICAL_ADDRESS ((uint32_t)0x004000) /*!< Data EEPROM memory: start address */
00056  #define FLASH_DATA_END_PHYSICAL_ADDRESS   ((uint32_t)0x0043FF) /*!< Data EEPROM memory: end address */
00057  #define FLASH_DATA_BLOCKS_NUMBER          ((uint16_t)8)        /*!< Data EEPROM memory: total number of blocks */
00058  #define FLASH_BLOCK_SIZE                  ((uint8_t)128)       /*!< Number of bytes in a block (common for Program and Data memories) */
00059 #endif /* STM8S105 or STM8AF626x */
00060 
00061 #if defined(STM8S103) || defined(STM8S003) || defined(STM8S903) || defined(STM8AF622x)
00062  #define FLASH_PROG_END_PHYSICAL_ADDRESS   ((uint32_t)0x9FFF)   /*!< Program memory: end address */
00063  #define FLASH_PROG_BLOCKS_NUMBER          ((uint16_t)128)      /*!< Program memory: total number of blocks */
00064  #define FLASH_DATA_START_PHYSICAL_ADDRESS ((uint32_t)0x004000) /*!< Data EEPROM memory: start address */
00065  #define FLASH_DATA_END_PHYSICAL_ADDRESS   ((uint32_t)0x00427F) /*!< Data EEPROM memory: end address */
00066  #define FLASH_DATA_BLOCKS_NUMBER          ((uint16_t)10)       /*!< Data EEPROM memory: total number of blocks */
00067  #define FLASH_BLOCK_SIZE                  ((uint8_t)64)        /*!< Number of bytes in a block (common for Program and Data memories) */
00068 #endif /* STM8S103 or STM8S003 or STM8S903 or STM8AF622x*/
00069 
00070 #define FLASH_RASS_KEY1 ((uint8_t)0x56) /*!< First RASS key */
00071 #define FLASH_RASS_KEY2 ((uint8_t)0xAE) /*!< Second RASS key */
00072 
00073 #define OPTION_BYTE_START_PHYSICAL_ADDRESS  ((uint16_t)0x4800)
00074 #define OPTION_BYTE_END_PHYSICAL_ADDRESS    ((uint16_t)0x487F)
00075 #define FLASH_OPTIONBYTE_ERROR              ((uint16_t)0x5555) /*!< Error code option byte 
00076                                                                    (if value read is not equal to complement value read) */
00077 /**
00078   * @}
00079   */
00080 
00081 /* Exported types ------------------------------------------------------------*/
00082 
00083 /** @addtogroup FLASH_Exported_Types
00084   * @{
00085   */
00086 
00087 /**
00088   * @brief  FLASH Memory types
00089   */
00090 typedef enum {
00091     FLASH_MEMTYPE_PROG      = (uint8_t)0xFD, /*!< Program memory */
00092     FLASH_MEMTYPE_DATA      = (uint8_t)0xF7  /*!< Data EEPROM memory */
00093 } FLASH_MemType_TypeDef;
00094 
00095 /**
00096   * @brief  FLASH programming modes
00097   */
00098 typedef enum {
00099     FLASH_PROGRAMMODE_STANDARD = (uint8_t)0x00, /*!< Standard programming mode */
00100     FLASH_PROGRAMMODE_FAST     = (uint8_t)0x10  /*!< Fast programming mode */
00101 } FLASH_ProgramMode_TypeDef;
00102 
00103 /**
00104   * @brief  FLASH fixed programming time
00105   */
00106 typedef enum {
00107     FLASH_PROGRAMTIME_STANDARD = (uint8_t)0x00, /*!< Standard programming time fixed at 1/2 tprog */
00108     FLASH_PROGRAMTIME_TPROG    = (uint8_t)0x01  /*!< Programming time fixed at tprog */
00109 } FLASH_ProgramTime_TypeDef;
00110 
00111 /**
00112   * @brief  FLASH Low Power mode select
00113   */
00114 typedef enum {
00115     FLASH_LPMODE_POWERDOWN         = (uint8_t)0x04, /*!< HALT: Power-Down / ACTIVE-HALT: Power-Down */
00116     FLASH_LPMODE_STANDBY           = (uint8_t)0x08, /*!< HALT: Standby    / ACTIVE-HALT: Standby */
00117     FLASH_LPMODE_POWERDOWN_STANDBY = (uint8_t)0x00, /*!< HALT: Power-Down / ACTIVE-HALT: Standby */
00118     FLASH_LPMODE_STANDBY_POWERDOWN = (uint8_t)0x0C  /*!< HALT: Standby    / ACTIVE-HALT: Power-Down */
00119 }
00120 FLASH_LPMode_TypeDef;
00121 
00122 /**
00123   * @brief  FLASH status of the last operation
00124   */
00125 typedef enum {
00126 #if defined (STM8S208) || defined(STM8S207) || defined(STM8S007) || defined(STM8S105) || \
00127     defined(STM8S005) || defined (STM8AF52Ax) || defined (STM8AF62Ax) || defined(STM8AF626x)            
00128                 FLASH_STATUS_END_HIGH_VOLTAGE           = (uint8_t)0x40, /*!< End of high voltage */
00129 #endif /* STM8S208, STM8S207, STM8S105, STM8AF62Ax, STM8AF52Ax, STM8AF626x */
00130                 FLASH_STATUS_SUCCESSFUL_OPERATION       = (uint8_t)0x04, /*!< End of operation flag */
00131                 FLASH_STATUS_TIMEOUT = (uint8_t)0x02, /*!< Time out error */
00132     FLASH_STATUS_WRITE_PROTECTION_ERROR     = (uint8_t)0x01 /*!< Write attempted to protected page */
00133 } FLASH_Status_TypeDef;
00134 
00135 /**
00136   * @brief  FLASH flags definition
00137  * - Warning : FLAG value = mapping position register
00138   */
00139 typedef enum {
00140 #if defined (STM8S208) || defined(STM8S207) || defined(STM8S007) || defined(STM8S105) || \
00141     defined(STM8S005) || defined (STM8AF52Ax) || defined (STM8AF62Ax) || defined(STM8AF626x)
00142     FLASH_FLAG_HVOFF     = (uint8_t)0x40,     /*!< End of high voltage flag */
00143 #endif /* STM8S208, STM8S207, STM8S105, STM8AF62Ax, STM8AF52Ax, STM8AF626x */
00144     FLASH_FLAG_DUL       = (uint8_t)0x08,     /*!< Data EEPROM unlocked flag */
00145     FLASH_FLAG_EOP       = (uint8_t)0x04,     /*!< End of programming (write or erase operation) flag */
00146     FLASH_FLAG_PUL       = (uint8_t)0x02,     /*!< Flash Program memory unlocked flag */
00147     FLASH_FLAG_WR_PG_DIS = (uint8_t)0x01      /*!< Write attempted to protected page flag */
00148 } FLASH_Flag_TypeDef;
00149 
00150 /**
00151   * @}
00152   */
00153 
00154 /* Private macros ------------------------------------------------------------*/
00155 
00156 /**
00157   * @brief  Macros used by the assert function in order to check the different functions parameters.
00158   * @addtogroup FLASH_Private_Macros
00159   * @{
00160   */
00161 
00162 /**
00163   * @brief  Macro used by the assert function in order to check the different sensitivity values for the flash program Address
00164   */
00165 
00166 #define IS_FLASH_PROG_ADDRESS_OK(ADDRESS) (((ADDRESS) >= FLASH_PROG_START_PHYSICAL_ADDRESS) && \
00167     ((ADDRESS) <= FLASH_PROG_END_PHYSICAL_ADDRESS))
00168 
00169 /**
00170   * @brief  Macro used by the assert function in order to check the different sensitivity values for the data eeprom Address
00171   */
00172 
00173 #define IS_FLASH_DATA_ADDRESS_OK(ADDRESS) (((ADDRESS) >= FLASH_DATA_START_PHYSICAL_ADDRESS) && \
00174     ((ADDRESS) <= FLASH_DATA_END_PHYSICAL_ADDRESS))
00175 
00176 /**
00177   * @brief  Macro used by the assert function in order to check the different sensitivity values for the data eeprom and flash program Address
00178   */
00179 #define IS_FLASH_ADDRESS_OK(ADDRESS)((((ADDRESS) >= FLASH_PROG_START_PHYSICAL_ADDRESS) && ((ADDRESS) <= FLASH_PROG_END_PHYSICAL_ADDRESS)) || \
00180                                      (((ADDRESS) >= FLASH_DATA_START_PHYSICAL_ADDRESS) && ((ADDRESS) <= FLASH_DATA_END_PHYSICAL_ADDRESS)))
00181 
00182 /**
00183   * @brief  Macro used by the assert function in order to check the different sensitivity values for the flash program Block number
00184   */
00185 #define IS_FLASH_PROG_BLOCK_NUMBER_OK(BLOCKNUM) ((BLOCKNUM) < FLASH_PROG_BLOCKS_NUMBER)
00186 
00187 /**
00188   * @brief  Macro used by the assert function in order to check the different sensitivity values for the data eeprom Block number
00189   */
00190 #define IS_FLASH_DATA_BLOCK_NUMBER_OK(BLOCKNUM) ((BLOCKNUM) < FLASH_DATA_BLOCKS_NUMBER)
00191 
00192 /**
00193   * @brief  Macro used by the assert function in order to check the different sensitivity values for the flash memory type
00194   */
00195 
00196 #define IS_MEMORY_TYPE_OK(MEMTYPE) (((MEMTYPE) == FLASH_MEMTYPE_PROG) || \
00197                                     ((MEMTYPE) == FLASH_MEMTYPE_DATA))
00198 
00199 /**
00200   * @brief  Macro used by the assert function in order to check the different sensitivity values for the flash program mode
00201   */
00202 
00203 #define IS_FLASH_PROGRAM_MODE_OK(MODE) (((MODE) == FLASH_PROGRAMMODE_STANDARD) || \
00204                                         ((MODE) == FLASH_PROGRAMMODE_FAST))
00205 
00206 /**
00207   * @brief  Macro used by the assert function in order to check the program time mode
00208   */
00209 
00210 #define IS_FLASH_PROGRAM_TIME_OK(TIME) (((TIME) == FLASH_PROGRAMTIME_STANDARD) || \
00211                                         ((TIME) == FLASH_PROGRAMTIME_TPROG))
00212 
00213 /**
00214   * @brief  Macro used by the assert function in order to check the different 
00215   *         sensitivity values for the low power mode
00216   */
00217 
00218 #define IS_FLASH_LOW_POWER_MODE_OK(LPMODE) (((LPMODE) == FLASH_LPMODE_POWERDOWN) || \
00219     ((LPMODE) == FLASH_LPMODE_STANDBY) || \
00220     ((LPMODE) == FLASH_LPMODE_POWERDOWN_STANDBY) || \
00221     ((LPMODE) == FLASH_LPMODE_STANDBY_POWERDOWN))
00222 
00223 /**
00224   * @brief  Macro used by the assert function in order to check the different 
00225   *         sensitivity values for the option bytes Address
00226   */
00227 #define IS_OPTION_BYTE_ADDRESS_OK(ADDRESS) (((ADDRESS) >= OPTION_BYTE_START_PHYSICAL_ADDRESS) && \
00228     ((ADDRESS) <= OPTION_BYTE_END_PHYSICAL_ADDRESS))
00229 
00230 
00231 /**
00232   * @brief  Macro used by the assert function in order to check the different flags values
00233   */
00234 #if defined (STM8S208) || defined(STM8S207) || defined(STM8S007) || defined(STM8S105) || \
00235     defined(STM8S005) || defined (STM8AF52Ax) || defined (STM8AF62Ax) || defined(STM8AF626x)
00236  #define IS_FLASH_FLAGS_OK(FLAG) (((FLAG) == FLASH_FLAG_HVOFF) || \
00237                                  ((FLAG) == FLASH_FLAG_DUL) || \
00238                                  ((FLAG) == FLASH_FLAG_EOP) || \
00239                                  ((FLAG) == FLASH_FLAG_PUL) || \
00240                                  ((FLAG) == FLASH_FLAG_WR_PG_DIS))
00241 #else /* STM8S103, STM8S903, STM8AF622x */
00242  #define IS_FLASH_FLAGS_OK(FLAG) (((FLAG) == FLASH_FLAG_DUL) || \
00243                                  ((FLAG) == FLASH_FLAG_EOP) || \
00244                                  ((FLAG) == FLASH_FLAG_PUL) || \
00245                                  ((FLAG) == FLASH_FLAG_WR_PG_DIS))
00246 #endif /* STM8S208, STM8S207, STM8S105, STM8AF62Ax, STM8AF52Ax, STM8AF626x */
00247 /**
00248   * @}
00249   */
00250 
00251 /* Exported functions ------------------------------------------------------- */
00252 
00253 /** @addtogroup FLASH_Exported_Functions
00254   * @{
00255   */
00256 void FLASH_Unlock(FLASH_MemType_TypeDef FLASH_MemType);
00257 void FLASH_Lock(FLASH_MemType_TypeDef FLASH_MemType);
00258 void FLASH_DeInit(void);
00259 void FLASH_ITConfig(FunctionalState NewState);
00260 void FLASH_EraseByte(uint32_t Address);
00261 void FLASH_ProgramByte(uint32_t Address, uint8_t Data);
00262 uint8_t FLASH_ReadByte(uint32_t Address);
00263 void FLASH_ProgramWord(uint32_t Address, uint32_t Data);
00264 uint16_t FLASH_ReadOptionByte(uint16_t Address);
00265 void FLASH_ProgramOptionByte(uint16_t Address, uint8_t Data);
00266 void FLASH_EraseOptionByte(uint16_t Address);
00267 void FLASH_SetLowPowerMode(FLASH_LPMode_TypeDef FLASH_LPMode);
00268 void FLASH_SetProgrammingTime(FLASH_ProgramTime_TypeDef FLASH_ProgTime);
00269 FLASH_LPMode_TypeDef FLASH_GetLowPowerMode(void);
00270 FLASH_ProgramTime_TypeDef FLASH_GetProgrammingTime(void);
00271 uint32_t FLASH_GetBootSize(void);
00272 FlagStatus FLASH_GetFlagStatus(FLASH_Flag_TypeDef FLASH_FLAG);
00273 
00274 /**
00275 @code
00276  All the functions declared below must be executed from RAM exclusively, except 
00277  for the FLASH_WaitForLastOperation function which can be executed from Flash.
00278  
00279  Steps of the execution from RAM differs from one toolchain to another.
00280  for more details refer to stm8s_flash.c file.
00281  
00282  To enable execution from RAM you can either uncomment the following define 
00283  in the stm8s.h file or define it in your toolchain compiler preprocessor
00284  - #define RAM_EXECUTION  (1) 
00285 
00286 @endcode
00287 */
00288 IN_RAM(void FLASH_EraseBlock(uint16_t BlockNum, FLASH_MemType_TypeDef FLASH_MemType));
00289 IN_RAM(void FLASH_ProgramBlock(uint16_t BlockNum, FLASH_MemType_TypeDef FLASH_MemType, 
00290                         FLASH_ProgramMode_TypeDef FLASH_ProgMode, uint8_t *Buffer));
00291 IN_RAM(FLASH_Status_TypeDef FLASH_WaitForLastOperation(FLASH_MemType_TypeDef FLASH_MemType));
00292 
00293 /**
00294   * @}
00295   */
00296 
00297 #endif /*__STM8S_FLASH_H */
00298 
00299 
00300 /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/
STM8 Standard Peripherals Library: Footer

 

 

 

      For complete documentation on STM8 8-bit Microcontrollers platform visit www.st.com