191 lines
8.2 KiB
C
191 lines
8.2 KiB
C
/* CH592 Flash-ROM & Data-Flash */
|
||
/* Website: http://wch.cn */
|
||
/* Email: tech@wch.cn */
|
||
/* Author: W.ch 2020.06 */
|
||
/* V1.0 FlashROM library for USER/BOOT */
|
||
/* for the target in USER code area on the chip divided into USER code area and BOOT area */
|
||
/* 用于具有用户代码区和引导区的芯片、操作目标为用户代码区的情况,
|
||
可以在用户代码中被调用(IAP,擦写自身),也可以在引导代码中被调用(更新用户代码) */
|
||
|
||
/* Flash-ROM feature:
|
||
for store program code, support block erasing, dword and page writing, dword verifying, unit for Length is byte,
|
||
minimal quantity for write or verify is one dword (4-bytes),
|
||
256 bytes/page for writing, FLASH_ROM_WRITE support one dword or more dword writing, but multiple of 256 is the best,
|
||
4KB (4096 bytes) bytes/block for erasing, so multiple of 4096 is the best */
|
||
|
||
/* Data-Flash(EEPROM) feature:
|
||
for store data, support block erasing, byte and page writing, byte reading,
|
||
minimal quantity for write or read is one byte,
|
||
256 bytes/page for writing, EEPROM_WRITE support one byte or more byte writing, but multiple of 256 is the best,
|
||
0.25KB/4KB (256/4096 bytes) bytes/block for erasing, so multiple of 256 or 4096 is the best */
|
||
|
||
|
||
#ifndef EEPROM_PAGE_SIZE
|
||
#define EEPROM_PAGE_SIZE 256 // Flash-ROM & Data-Flash page size for writing
|
||
#define EEPROM_BLOCK_SIZE 4096 // Flash-ROM & Data-Flash block size for erasing
|
||
#define EEPROM_MIN_ER_SIZE EEPROM_PAGE_SIZE // Data-Flash minimal size for erasing
|
||
//#define EEPROM_MIN_ER_SIZE EEPROM_BLOCK_SIZE // Flash-ROM minimal size for erasing
|
||
#define EEPROM_MIN_WR_SIZE 1 // Data-Flash minimal size for writing
|
||
#define EEPROM_MAX_SIZE 0x8000 // Data-Flash maximum size, 32KB
|
||
#endif
|
||
#ifndef FLASH_MIN_WR_SIZE
|
||
#define FLASH_MIN_WR_SIZE 4 // Flash-ROM minimal size for writing
|
||
#endif
|
||
#ifndef FLASH_ROM_MAX_SIZE
|
||
#define FLASH_ROM_MAX_SIZE 0x070000 // Flash-ROM maximum program size, 448KB
|
||
#endif
|
||
|
||
#ifndef CMD_FLASH_ROM_SW_RESET
|
||
// CMD_* for caller from FlashROM or RAM, auto execute CMD_FLASH_ROM_SW_RESET before command
|
||
|
||
#define CMD_FLASH_ROM_START_IO 0x00 // start FlashROM I/O, without parameter
|
||
#define CMD_FLASH_ROM_SW_RESET 0x04 // software reset FlashROM, without parameter
|
||
#define CMD_GET_ROM_INFO 0x06 // get information from FlashROM, parameter @Address,Buffer
|
||
#define CMD_GET_UNIQUE_ID 0x07 // get 64 bit unique ID, parameter @Buffer
|
||
#define CMD_FLASH_ROM_PWR_DOWN 0x0D // power-down FlashROM, without parameter
|
||
#define CMD_FLASH_ROM_PWR_UP 0x0C // power-up FlashROM, without parameter
|
||
#define CMD_FLASH_ROM_LOCK 0x08 // lock(protect)/unlock FlashROM data block, return 0 if success, parameter @StartAddr
|
||
// StartAddr: 0=unlock all, 1=lock boot code, 3=lock all code and data
|
||
|
||
#define CMD_EEPROM_ERASE 0x09 // erase Data-Flash block, return 0 if success, parameter @StartAddr,Length
|
||
#define CMD_EEPROM_WRITE 0x0A // write Data-Flash data block, return 0 if success, parameter @StartAddr,Buffer,Length
|
||
#define CMD_EEPROM_READ 0x0B // read Data-Flash data block, parameter @StartAddr,Buffer,Length
|
||
#define CMD_FLASH_ROM_ERASE 0x01 // erase FlashROM block, return 0 if success, parameter @StartAddr,Length
|
||
#define CMD_FLASH_ROM_WRITE 0x02 // write FlashROM data block, minimal block is dword, return 0 if success, parameter @StartAddr,Buffer,Length
|
||
#define CMD_FLASH_ROM_VERIFY 0x03 // read FlashROM data block, minimal block is dword, return 0 if success, parameter @StartAddr,Buffer,Length
|
||
#endif
|
||
|
||
#define ROM_CFG_MAC_ADDR 0x7F018 // address for MAC address information
|
||
#define ROM_CFG_BOOT_INFO 0x7DFF8 // address for BOOT information
|
||
|
||
/**
|
||
* @brief execute Flash/EEPROM command, caller from FlashROM or RAM
|
||
*
|
||
* @param cmd - CMD_* for caller from FlashROM or RAM.
|
||
* @param StartAddr - Address of the data to be process.
|
||
* @param Buffer - Pointer to the buffer where data should be process, Must be aligned to 4 bytes.
|
||
* @param Length - Size of data to be process, in bytes.
|
||
*
|
||
* @return 0-SUCCESS (!0)-FAILURE
|
||
*/
|
||
extern uint32_t FLASH_EEPROM_CMD( uint8_t cmd, uint32_t StartAddr, void *Buffer, uint32_t Length );
|
||
|
||
/**
|
||
* @brief start FlashROM I/O
|
||
*
|
||
* @return 0-SUCCESS (!0)-FAILURE
|
||
*/
|
||
#define FLASH_ROM_START_IO( ) FLASH_EEPROM_CMD( CMD_FLASH_ROM_START_IO, 0, NULL, 0 )
|
||
|
||
/**
|
||
* @brief software reset FlashROM
|
||
*
|
||
* @return 0-SUCCESS (!0)-FAILURE
|
||
*/
|
||
#define FLASH_ROM_SW_RESET( ) FLASH_EEPROM_CMD( CMD_FLASH_ROM_SW_RESET, 0, NULL, 0 )
|
||
|
||
/**
|
||
* @brief get 6 bytes MAC address
|
||
*
|
||
* @param Buffer - Pointer to the buffer where data should be stored, Must be aligned to 4 bytes.
|
||
*
|
||
* @return 0-SUCCESS (!0)-FAILURE
|
||
*/
|
||
#define GetMACAddress(Buffer) FLASH_EEPROM_CMD( CMD_GET_ROM_INFO, ROM_CFG_MAC_ADDR, Buffer, 0 )
|
||
|
||
/**
|
||
* @brief get 8 bytes BOOT information
|
||
*
|
||
* @param Buffer - Pointer to the buffer where data should be stored, Must be aligned to 4 bytes.
|
||
*
|
||
* @return 0-SUCCESS (!0)-FAILURE
|
||
*/
|
||
#define GET_BOOT_INFO(Buffer) FLASH_EEPROM_CMD( CMD_GET_ROM_INFO, ROM_CFG_BOOT_INFO, Buffer, 0 )
|
||
|
||
/**
|
||
* @brief get 64 bit unique ID
|
||
*
|
||
* @param Buffer - Pointer to the buffer where data should be stored, Must be aligned to 4 bytes.
|
||
*
|
||
* @return 0-SUCCESS (!0)-FAILURE
|
||
*/
|
||
#define GET_UNIQUE_ID(Buffer) FLASH_EEPROM_CMD( CMD_GET_UNIQUE_ID, 0, Buffer, 0 )
|
||
|
||
/**
|
||
* @brief power-down FlashROM
|
||
*
|
||
* @return 0-SUCCESS (!0)-FAILURE
|
||
*/
|
||
#define FLASH_ROM_PWR_DOWN( ) FLASH_EEPROM_CMD( CMD_FLASH_ROM_PWR_DOWN, 0, NULL, 0 )
|
||
|
||
/**
|
||
* @brief power-up FlashROM
|
||
*
|
||
* @return 0-SUCCESS (!0)-FAILURE
|
||
*/
|
||
#define FLASH_ROM_PWR_UP( ) FLASH_EEPROM_CMD( CMD_FLASH_ROM_PWR_UP, 0, NULL, 0 )
|
||
|
||
/**
|
||
* @brief read Data-Flash data block
|
||
*
|
||
* @param StartAddr - Address of the data to be read.
|
||
* @param Buffer - Pointer to the buffer where data should be stored, Must be aligned to 4 bytes.
|
||
* @param Length - Size of data to be read, in bytes.
|
||
*
|
||
* @return 0-SUCCESS (!0)-FAILURE
|
||
*/
|
||
#define EEPROM_READ(StartAddr,Buffer,Length) FLASH_EEPROM_CMD( CMD_EEPROM_READ, StartAddr, Buffer, Length )
|
||
|
||
/**
|
||
*
|
||
* @param StartAddr - Address of the data to be erased.
|
||
* @param Length - Size of data to be erased, in bytes.
|
||
*
|
||
* @return 0-SUCCESS (!0)-FAILURE
|
||
*/
|
||
#define EEPROM_ERASE(StartAddr,Length) FLASH_EEPROM_CMD( CMD_EEPROM_ERASE, StartAddr, NULL, Length )
|
||
|
||
/**
|
||
* @brief write Data-Flash data block
|
||
*
|
||
* @param StartAddr - Address of the data to be written.
|
||
* @param Buffer - Pointer to the source buffer, Must be aligned to 4 bytes.
|
||
* @param Length - Size of data to be written, in bytes.
|
||
*
|
||
* @return 0-SUCCESS (!0)-FAILURE
|
||
*/
|
||
#define EEPROM_WRITE(StartAddr,Buffer,Length) FLASH_EEPROM_CMD( CMD_EEPROM_WRITE, StartAddr, Buffer, Length )
|
||
|
||
/**
|
||
* @brief erase FlashROM block
|
||
*
|
||
* @param StartAddr - Address of the data to be erased.
|
||
* @param Length - Size of data to be erased, in bytes.
|
||
*
|
||
* @return 0-SUCCESS (!0)-FAILURE
|
||
*/
|
||
#define FLASH_ROM_ERASE(StartAddr,Length) FLASH_EEPROM_CMD( CMD_FLASH_ROM_ERASE, StartAddr, NULL, Length )
|
||
|
||
/**
|
||
* @brief write FlashROM data block, minimal block is dword.
|
||
*
|
||
* @param StartAddr - Address of the data to be written.
|
||
* @param Buffer - Pointer to the source buffer, Must be aligned to 4 bytes.
|
||
* @param Length - Size of data to be written, in bytes.
|
||
*
|
||
* @return 0-SUCCESS (!0)-FAILURE
|
||
*/
|
||
#define FLASH_ROM_WRITE(StartAddr,Buffer,Length) FLASH_EEPROM_CMD( CMD_FLASH_ROM_WRITE, StartAddr, Buffer, Length )
|
||
|
||
/**
|
||
* @brief verify FlashROM data block, minimal block is dword.
|
||
*
|
||
* @param StartAddr - Address of the data to verify.
|
||
* @param Buffer - Pointer to the source buffer, Must be aligned to 4 bytes.
|
||
* @param Length - Size of data to verify, in bytes.
|
||
*
|
||
* @return 0-SUCCESS (!0)-FAILURE
|
||
*/
|
||
#define FLASH_ROM_VERIFY(StartAddr,Buffer,Length) FLASH_EEPROM_CMD( CMD_FLASH_ROM_VERIFY, StartAddr, Buffer, Length )
|
||
|