mirror of
https://github.com/RT-Thread/rt-thread.git
synced 2025-01-19 05:43:31 +08:00
185 lines
7.9 KiB
C
185 lines
7.9 KiB
C
/*
|
|
* @brief Common IAP support functions
|
|
*
|
|
* @note
|
|
* Copyright(C) NXP Semiconductors, 2013
|
|
* All rights reserved.
|
|
*
|
|
* @par
|
|
* Software that is described herein is for illustrative purposes only
|
|
* which provides customers with programming information regarding the
|
|
* LPC products. This software is supplied "AS IS" without any warranties of
|
|
* any kind, and NXP Semiconductors and its licenser disclaim any and
|
|
* all warranties, express or implied, including all implied warranties of
|
|
* merchantability, fitness for a particular purpose and non-infringement of
|
|
* intellectual property rights. NXP Semiconductors assumes no responsibility
|
|
* or liability for the use of the software, conveys no license or rights under any
|
|
* patent, copyright, mask work right, or any other intellectual property rights in
|
|
* or to any products. NXP Semiconductors reserves the right to make changes
|
|
* in the software without notification. NXP Semiconductors also makes no
|
|
* representation or warranty that such application will be suitable for the
|
|
* specified use without further testing or modification.
|
|
*
|
|
* @par
|
|
* Permission to use, copy, modify, and distribute this software and its
|
|
* documentation is hereby granted, under NXP Semiconductors' and its
|
|
* licensor's relevant copyrights in the software, without fee, provided that it
|
|
* is used in conjunction with NXP Semiconductors microcontrollers. This
|
|
* copyright, permission, and disclaimer notice must appear in all copies of
|
|
* this code.
|
|
*/
|
|
|
|
#ifndef __IAP_H_
|
|
#define __IAP_H_
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
|
|
/** @defgroup COMMON_IAP CHIP: Common Chip ISP/IAP commands and return codes
|
|
* @ingroup CHIP_Common
|
|
* @{
|
|
*/
|
|
|
|
/* IAP command definitions */
|
|
#define IAP_PREWRRITE_CMD 50 /*!< Prepare sector for write operation command */
|
|
#define IAP_WRISECTOR_CMD 51 /*!< Write Sector command */
|
|
#define IAP_ERSSECTOR_CMD 52 /*!< Erase Sector command */
|
|
#define IAP_BLANK_CHECK_SECTOR_CMD 53 /*!< Blank check sector */
|
|
#define IAP_REPID_CMD 54 /*!< Read PartID command */
|
|
#define IAP_READ_BOOT_CODE_CMD 55 /*!< Read Boot code version */
|
|
#define IAP_COMPARE_CMD 56 /*!< Compare two RAM address locations */
|
|
#define IAP_REINVOKE_ISP_CMD 57 /*!< Reinvoke ISP */
|
|
#define IAP_READ_UID_CMD 58 /*!< Read UID */
|
|
#define IAP_ERASE_PAGE_CMD 59 /*!< Erase page */
|
|
#define IAP_EEPROM_WRITE 61 /*!< EEPROM Write command */
|
|
#define IAP_EEPROM_READ 62 /*!< EEPROM READ command */
|
|
|
|
/* IAP response definitions */
|
|
#define IAP_CMD_SUCCESS 0 /*!< Command is executed successfully */
|
|
#define IAP_INVALID_COMMAND 1 /*!< Invalid command */
|
|
#define IAP_SRC_ADDR_ERROR 2 /*!< Source address is not on word boundary */
|
|
#define IAP_DST_ADDR_ERROR 3 /*!< Destination address is not on a correct boundary */
|
|
#define IAP_SRC_ADDR_NOT_MAPPED 4 /*!< Source address is not mapped in the memory map */
|
|
#define IAP_DST_ADDR_NOT_MAPPED 5 /*!< Destination address is not mapped in the memory map */
|
|
#define IAP_COUNT_ERROR 6 /*!< Byte count is not multiple of 4 or is not a permitted value */
|
|
#define IAP_INVALID_SECTOR 7 /*!< Sector number is invalid or end sector number is greater than start sector number */
|
|
#define IAP_SECTOR_NOT_BLANK 8 /*!< Sector is not blank */
|
|
#define IAP_SECTOR_NOT_PREPARED 9 /*!< Command to prepare sector for write operation was not executed */
|
|
#define IAP_COMPARE_ERROR 10 /*!< Source and destination data not equal */
|
|
#define IAP_BUSY 11 /*!< Flash programming hardware interface is busy */
|
|
#define IAP_PARAM_ERROR 12 /*!< nsufficient number of parameters or invalid parameter */
|
|
#define IAP_ADDR_ERROR 13 /*!< Address is not on word boundary */
|
|
#define IAP_ADDR_NOT_MAPPED 14 /*!< Address is not mapped in the memory map */
|
|
#define IAP_CMD_LOCKED 15 /*!< Command is locked */
|
|
#define IAP_INVALID_CODE 16 /*!< Unlock code is invalid */
|
|
#define IAP_INVALID_BAUD_RATE 17 /*!< Invalid baud rate setting */
|
|
#define IAP_INVALID_STOP_BIT 18 /*!< Invalid stop bit setting */
|
|
#define IAP_CRP_ENABLED 19 /*!< Code read protection enabled */
|
|
|
|
/* IAP_ENTRY API function type */
|
|
typedef void (*IAP_ENTRY_T)(unsigned int[], unsigned int[]);
|
|
|
|
/**
|
|
* @brief Prepare sector for write operation
|
|
* @param strSector : Start sector number
|
|
* @param endSector : End sector number
|
|
* @return Status code to indicate the command is executed successfully or not
|
|
* @note This command must be executed before executing "Copy RAM to flash"
|
|
* or "Erase Sector" command.
|
|
* The end sector must be greater than or equal to start sector number
|
|
*/
|
|
uint8_t Chip_IAP_PreSectorForReadWrite(uint32_t strSector, uint32_t endSector);
|
|
|
|
/**
|
|
* @brief Copy RAM to flash
|
|
* @param dstAdd : Destination FLASH address where data bytes are to be written
|
|
* @param srcAdd : Source RAM address where data bytes are to be read
|
|
* @param byteswrt : Number of bytes to be written
|
|
* @return Status code to indicate the command is executed successfully or not
|
|
* @note The addresses should be a 256 byte boundary and the number of bytes
|
|
* should be 256 | 512 | 1024 | 4096
|
|
*/
|
|
uint8_t Chip_IAP_CopyRamToFlash(uint32_t dstAdd, uint32_t *srcAdd, uint32_t byteswrt);
|
|
|
|
/**
|
|
* @brief Erase sector
|
|
* @param strSector : Start sector number
|
|
* @param endSector : End sector number
|
|
* @return Status code to indicate the command is executed successfully or not
|
|
* @note The end sector must be greater than or equal to start sector number
|
|
*/
|
|
uint8_t Chip_IAP_EraseSector(uint32_t strSector, uint32_t endSector);
|
|
|
|
/**
|
|
* @brief Blank check a sector or multiples sector of on-chip flash memory
|
|
* @param strSector : Start sector number
|
|
* @param endSector : End sector number
|
|
* @return Offset of the first non blank word location if the status code is SECTOR_NOT_BLANK
|
|
* @note The end sector must be greater than or equal to start sector number
|
|
*/
|
|
// FIXME - There are two return value (result[0] & result[1]
|
|
// Result0:Offset of the first non blank word location if the Status Code is
|
|
// SECTOR_NOT_BLANK.
|
|
// Result1:Contents of non blank word location.
|
|
uint8_t Chip_IAP_BlankCheckSector(uint32_t strSector, uint32_t endSector);
|
|
|
|
/**
|
|
* @brief Read part identification number
|
|
* @return Part identification number
|
|
*/
|
|
uint32_t Chip_IAP_ReadPID(void);
|
|
|
|
/**
|
|
* @brief Read boot code version number
|
|
* @return Boot code version number
|
|
*/
|
|
uint32_t Chip_IAP_ReadBootCode(void);
|
|
|
|
/**
|
|
* @brief Compare the memory contents at two locations
|
|
* @param dstAdd : Destination of the RAM address of data bytes to be compared
|
|
* @param srcAdd : Source of the RAM address of data bytes to be compared
|
|
* @param bytescmp : Number of bytes to be compared
|
|
* @return Offset of the first mismatch of the status code is COMPARE_ERROR
|
|
* @note The addresses should be a word boundary and number of bytes should be
|
|
* a multiply of 4
|
|
*/
|
|
uint8_t Chip_IAP_Compare(uint32_t dstAdd, uint32_t srcAdd, uint32_t bytescmp);
|
|
|
|
/**
|
|
* @brief IAP reinvoke ISP to invoke the bootloader in ISP mode
|
|
* @return none
|
|
*/
|
|
uint8_t Chip_IAP_ReinvokeISP(void);
|
|
|
|
/**
|
|
* @brief Read the unique ID
|
|
* @return Status code to indicate the command is executed successfully or not
|
|
*/
|
|
uint32_t Chip_IAP_ReadUID(uint32_t* uid);
|
|
|
|
/**
|
|
* @brief Erase a page or multiple papers of on-chip flash memory
|
|
* @param strPage : Start page number
|
|
* @param endPage : End page number
|
|
* @return Status code to indicate the command is executed successfully or not
|
|
* @note The page number must be greater than or equal to start page number
|
|
*/
|
|
// FIXME - There are four return value
|
|
// Result0:The first 32-bit word (at the lowest address)
|
|
// Result1:The second 32-bit word.
|
|
// Result2:The third 32-bit word.
|
|
// Result3:The fourth 32-bit word.
|
|
uint8_t Chip_IAP_ErasePage(uint32_t strPage, uint32_t endPage);
|
|
|
|
/**
|
|
* @}
|
|
*/
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif
|
|
|
|
#endif /* __IAP_H_ */
|