119 lines
4.5 KiB
C
119 lines
4.5 KiB
C
/******************************************************************************
|
|
******************************************************************************
|
|
*
|
|
* @file flash.h
|
|
*
|
|
* @brief application entry point which performs application specific tasks.
|
|
*
|
|
*******************************************************************************
|
|
*
|
|
* provide a demo for how to initialize the NV32, output messages via SCI,
|
|
* flash operations, etc.
|
|
* NOTE:
|
|
* printf call may occupy a lot of memory (around 1924 bytes), so please
|
|
* consider your code size before using printf.
|
|
******************************************************************************
|
|
*
|
|
* provide FLASH driver
|
|
*
|
|
******************************************************************************/
|
|
|
|
|
|
|
|
#ifndef FLASH_H_
|
|
#define FLASH_H_
|
|
|
|
/******************************************************************************
|
|
* Includes
|
|
******************************************************************************/
|
|
#include "common.h"
|
|
/******************************************************************************
|
|
* Constants
|
|
******************************************************************************/
|
|
|
|
/******************************************************************************
|
|
* Macros
|
|
******************************************************************************/
|
|
/* Uncomment the following line to support programming flash while running code from flash */
|
|
// #define FLASH_ENABLE_STALLING_FLASH_CONTROLLER
|
|
|
|
#define ETMRH_FSTAT_MGSTAT0_MASK (1)
|
|
#define ETMRH_FSTAT_MGSTAT1_MASK (1<<1)
|
|
|
|
#define FLASH_SECTOR_SIZE 512 // in bytes
|
|
|
|
/* Flash driver errors */
|
|
#define FLASH_ERR_BASE 0x3000
|
|
#define FLASH_ERR_SUCCESS 0
|
|
#define FLASH_ERR_INVALID_PARAM (FLASH_ERR_BASE+1) // invalid parameter error code
|
|
#define EEPROM_ERR_SINGLE_BIT_FAULT (FLASH_ERR_BASE+2) // EEPROM single bit fault error code
|
|
#define EEPROM_ERR_DOUBLE_BIT_FAULT (FLASH_ERR_BASE+4) // EEPROM double bits fault error code
|
|
#define FLASH_ERR_ACCESS (FLASH_ERR_BASE+8) // flash access error code
|
|
#define FLASH_ERR_PROTECTION (FLASH_ERR_BASE+0x10) // flash protection error code
|
|
#define FLASH_ERR_MGSTAT0 (FLASH_ERR_BASE+0x11) // flash verification error code
|
|
#define FLASH_ERR_MGSTAT1 (FLASH_ERR_BASE+0x12) // flash non-correctable error code
|
|
#define FLASH_ERR_INIT_CCIF (FLASH_ERR_BASE+0x14) // flash driver init error with CCIF = 1
|
|
#define FLASH_ERR_INIT_FDIV (FLASH_ERR_BASE+0x18) // flash driver init error with wrong FDIV
|
|
|
|
/* Flash and EEPROM commands */
|
|
|
|
|
|
#define FLASH_CMD_PROGRAM 0x20000000
|
|
#define FLASH_CMD_CLEAR 0x00005000
|
|
#define FLASH_CMD_ERASE_ALL 0x41000000
|
|
#define FLASH_CMD_ERASE_SECTOR 0x40000000
|
|
#define FLASH_FACTORY_KEY 0x0065fe9a
|
|
|
|
#define EFM_DONE_MASK 0x00006000
|
|
#define EFM_STATUS_DONE 0x00006000
|
|
#define EFM_STATUS_READY 0x00002000
|
|
|
|
#define FLASH_ACCERR_MASK 0x10
|
|
|
|
#define M8(adr) (*((volatile unsigned char *) (adr)))
|
|
#define M16(adr) (*((volatile unsigned short *) (adr)))
|
|
#define M32(adr) (*((volatile unsigned long *) (adr)))
|
|
|
|
|
|
|
|
/******************************************************************************
|
|
* Types
|
|
******************************************************************************/
|
|
typedef uint16_t (*TFlash_Fun1)(uint32_t wNVMTargetAddress, uint8_t *pbData, uint8_t bByteCount);
|
|
typedef uint16_t (*TFlash_Fun2)(uint32_t wNVMTargetAddress, uint32_t dwData0, uint32_t dwData1);
|
|
typedef uint16_t (*TFlash_Fun3)(uint32_t wNVMTargetAddress, uint32_t dwData);
|
|
|
|
/******************************************************************************
|
|
* Global variables
|
|
******************************************************************************/
|
|
|
|
/******************************************************************************
|
|
* Global functions
|
|
******************************************************************************/
|
|
uint16_t Flash_Program(uint32_t wNVMTargetAddress, uint8_t *pData, uint16_t sizeBytes);
|
|
uint16_t Flash_Program1LongWord(uint32_t wNVMTargetAddress, uint32_t dwData);
|
|
uint16_t Flash_Program2LongWords(uint32_t wNVMTargetAddress, uint32_t dwData0, uint32_t dwData1);
|
|
|
|
uint16_t Flash_EraseSector(uint32_t wNVMTargetAddress);
|
|
|
|
uint16_t Flash_VerifyBackdoorKey(void);
|
|
|
|
uint16_t NVM_EraseAll(void);
|
|
|
|
uint16_t NVM_Unsecure(void);
|
|
|
|
uint16_t Flash_Init(void);
|
|
|
|
#ifdef IAR
|
|
void __ramfunc EFM_LaunchCMD(uint32_t EFM_CMD);
|
|
#else
|
|
void EFM_LaunchCMD(uint32_t EFM_CMD);
|
|
#endif
|
|
|
|
|
|
void Flash_CopyInRAM(void);
|
|
void Flash_CopyRouinte2RAM(char *func, uint16_t sizeFunc);
|
|
/********************************************************************/
|
|
|
|
#endif /* FLASH_H_ */
|