mirror of
https://github.com/RT-Thread/rt-thread.git
synced 2025-01-14 17:49:27 +08:00
154 lines
5.1 KiB
C
154 lines
5.1 KiB
C
|
/**********************************************************************
|
||
|
* $Id$ lpc_iap.h 2011-11-21
|
||
|
*//**
|
||
|
* @file lpc_iap.h
|
||
|
* @brief Contains all functions support for IAP
|
||
|
* on LPC
|
||
|
* @version 1.0
|
||
|
* @date 21. November. 2011
|
||
|
* @author NXP MCU SW Application Team
|
||
|
*
|
||
|
* Copyright(C) 2011, NXP Semiconductor
|
||
|
* All rights reserved.
|
||
|
*
|
||
|
***********************************************************************
|
||
|
* Software that is described herein is for illustrative purposes only
|
||
|
* which provides customers with programming information regarding the
|
||
|
* products. This software is supplied "AS IS" without any warranties.
|
||
|
* NXP Semiconductors assumes no responsibility or liability for the
|
||
|
* use of the software, conveys no license or title under any patent,
|
||
|
* copyright, or mask work right to the product. NXP Semiconductors
|
||
|
* reserves the right to make changes in the software without
|
||
|
* notification. NXP Semiconductors also make no representation or
|
||
|
* warranty that such application will be suitable for the specified
|
||
|
* use without further testing or modification.
|
||
|
* Permission to use, copy, modify, and distribute this software and its
|
||
|
* documentation is hereby granted, under NXP Semiconductors'
|
||
|
* relevant copyright 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 _LPC_IAP_H
|
||
|
#define _LPC_IAP_H
|
||
|
#include "lpc_types.h"
|
||
|
|
||
|
/** @defgroup IAP IAP (In Application Programming)
|
||
|
* @ingroup LPC_CMSIS_FwLib_Drivers
|
||
|
* @{
|
||
|
*/
|
||
|
|
||
|
/** @defgroup IAP_Public_Macros IAP Public Macros
|
||
|
* @{
|
||
|
*/
|
||
|
|
||
|
/** IAP entry location */
|
||
|
#define IAP_LOCATION (0x1FFF1FF1UL)
|
||
|
|
||
|
/**
|
||
|
* @}
|
||
|
*/
|
||
|
|
||
|
/** @defgroup IAP_Public_Types IAP Public Types
|
||
|
* @{
|
||
|
*/
|
||
|
|
||
|
/**
|
||
|
* @brief IAP command code definitions
|
||
|
*/
|
||
|
typedef enum
|
||
|
{
|
||
|
IAP_PREPARE = 50, // Prepare sector(s) for write operation
|
||
|
IAP_COPY_RAM2FLASH = 51, // Copy RAM to Flash
|
||
|
IAP_ERASE = 52, // Erase sector(s)
|
||
|
IAP_BLANK_CHECK = 53, // Blank check sector(s)
|
||
|
IAP_READ_PART_ID = 54, // Read chip part ID
|
||
|
IAP_READ_BOOT_VER = 55, // Read chip boot code version
|
||
|
IAP_COMPARE = 56, // Compare memory areas
|
||
|
IAP_REINVOKE_ISP = 57, // Reinvoke ISP
|
||
|
IAP_READ_SERIAL_NUMBER = 58, // Read serial number
|
||
|
} IAP_COMMAND_CODE;
|
||
|
|
||
|
/**
|
||
|
* @brief IAP status code definitions
|
||
|
*/
|
||
|
typedef enum
|
||
|
{
|
||
|
CMD_SUCCESS, // Command is executed successfully.
|
||
|
INVALID_COMMAND, // Invalid command.
|
||
|
SRC_ADDR_ERROR, // Source address is not on a word boundary.
|
||
|
DST_ADDR_ERROR, // Destination address is not on a correct boundary.
|
||
|
SRC_ADDR_NOT_MAPPED, // Source address is not mapped in the memory map.
|
||
|
DST_ADDR_NOT_MAPPED, // Destination address is not mapped in the memory map.
|
||
|
COUNT_ERROR, // Byte count is not multiple of 4 or is not a permitted value.
|
||
|
INVALID_SECTOR, // Sector number is invalid.
|
||
|
SECTOR_NOT_BLANK, // Sector is not blank.
|
||
|
SECTOR_NOT_PREPARED_FOR_WRITE_OPERATION, // Command to prepare sector for write operation was not executed.
|
||
|
COMPARE_ERROR, // Source and destination data is not same.
|
||
|
BUSY, // Flash programming hardware interface is busy.
|
||
|
} IAP_STATUS_CODE;
|
||
|
|
||
|
/**
|
||
|
* @brief IAP write length definitions
|
||
|
*/
|
||
|
typedef enum {
|
||
|
IAP_WRITE_256 = 256,
|
||
|
IAP_WRITE_512 = 512,
|
||
|
IAP_WRITE_1024 = 1024,
|
||
|
IAP_WRITE_4096 = 4096,
|
||
|
} IAP_WRITE_SIZE;
|
||
|
|
||
|
/**
|
||
|
* @brief IAP command structure
|
||
|
*/
|
||
|
typedef struct {
|
||
|
uint32_t cmd; // Command
|
||
|
uint32_t param[4]; // Parameters
|
||
|
uint32_t status; // status code
|
||
|
uint32_t result[4]; // Result
|
||
|
} IAP_COMMAND_Type;
|
||
|
|
||
|
/**
|
||
|
* @}
|
||
|
*/
|
||
|
|
||
|
/* Public Functions ----------------------------------------------------------- */
|
||
|
/** @defgroup IAP_Public_Functions IAP Public Functions
|
||
|
* @{
|
||
|
*/
|
||
|
|
||
|
/** Get sector number of an address */
|
||
|
uint32_t GetSecNum (uint32_t adr);
|
||
|
/** Prepare sector(s) for write operation */
|
||
|
IAP_STATUS_CODE PrepareSector(uint32_t start_sec, uint32_t end_sec);
|
||
|
/** Copy RAM to Flash */
|
||
|
IAP_STATUS_CODE CopyRAM2Flash(uint8_t * dest, uint8_t* source, IAP_WRITE_SIZE size);
|
||
|
/** Prepare sector(s) for write operation */
|
||
|
IAP_STATUS_CODE EraseSector(uint32_t start_sec, uint32_t end_sec);
|
||
|
/** Blank check sectors */
|
||
|
IAP_STATUS_CODE BlankCheckSector(uint32_t start_sec, uint32_t end_sec,
|
||
|
uint32_t *first_nblank_loc,
|
||
|
uint32_t *first_nblank_val);
|
||
|
/** Read part identification number */
|
||
|
IAP_STATUS_CODE ReadPartID(uint32_t *partID);
|
||
|
/** Read boot code version */
|
||
|
IAP_STATUS_CODE ReadBootCodeVer(uint8_t *major, uint8_t* minor);
|
||
|
/** Read Device serial number */
|
||
|
IAP_STATUS_CODE ReadDeviceSerialNum(uint32_t *uid);
|
||
|
/** Compare memory */
|
||
|
IAP_STATUS_CODE Compare(uint8_t *addr1, uint8_t *addr2, uint32_t size);
|
||
|
/** Invoke ISP */
|
||
|
void InvokeISP(void);
|
||
|
|
||
|
/**
|
||
|
* @}
|
||
|
*/
|
||
|
|
||
|
/**
|
||
|
* @}
|
||
|
*/
|
||
|
|
||
|
#endif /*_LPC_IAP_H*/
|
||
|
|