LPC43xx系列使用IAP的注意事项
LPC43xx系列使用IAP的注意事项
Tags: LPC43xx IAP 单片机
LPC43xx IAP函数的调用
一般MCU的IAP是,厂商固化一段代码在芯片的某个区域,然后告诉你这个代码的入口地址。
我们一般可以这么做:
typedef void (*IAP_ENTRY_T)(参数列表)
#define IAP_ADDR (0xdeadbeef) // 假设的地址
IAP_ENTRY_T const iap_entry = (IAP_ENTRY_T)IAP_ADDR;
这样我们便可以通过iap_entry来调用芯片里的固化代码了。
然而,LPC43xx系列内部的布局却不是这样。
LPC43xx ROM API结构
上面是LPC43xx内部固化代码的结构,可以看出:NXP把固化的函数的入口地址放到了一个数组里,然后告诉我们数组的起始地址,IAP函数排在第0位。
那么我们可以这样调用IAP函数:
/* 定义IAP入口函数的类型别名 */
typedef void (*IAP_ENTRY_T)(unsigned int[5], unsigned int[4]);
// ROM Driver Table的起始地址
#define LPC_ROM_API_BASE_LOC (0x10400100)
// 因为Cortex-M4是32位的,所以用uint32_t类型把IAP入口函数的地址提取出来
#define IAP_ENTRY_LOCATION (*((uint32_t *)LPC_ROM_API_BASE_LOC))
static inline void iap_entry(unsigned int cmd_param[5], unsigned int status_result[4])
{ // 强制转换为函数指针,然后调用
((IAP_ENTRY_T)IAP_ENTRY_LOCATION)(cmd_param, status_result);
}
内部FLASH操作是的注意事项
- 关全局中断
- 一定要先调用 Init 命令,再调用其他命令
- 擦除或写FLASH区块前,要先调用Prepare sectors for write operation命令
LPC43xx命令总览