简介
MCU复位后从PROM的起始地址(0地址)开始运行,把执行代码烧录到PROM起始地址(0地址)开始的区域中即可;在一些特殊应用场景中用户希望把代码放到PROM的后半段(非起始地址),这个时候需要对启动代码(StartUp.S)和链接文件(gcc_xxx.ld)做一些更改。
一、CK80x系列内核,APT32F110x(CK802)为例
1、启动代码(StartUp.s)部分
在启动代码里加入一个段落,可以命名为por,段的起始位置定义一个变量,将系统代码的入口地址(__start)赋值给这个变量
2、链接文件(.ld)修改
1) 将64K的ROM分为两个区,ROM0区是PROM起始地址(0地址)开始大小为256Bytes区域,ROM区PROM 第32K开始,大小为32K的区域;PROM两个分区大小用户可根据实际情况来定,ROM0分区的第一个PAGE用户不能使用(存放por段),ROM分区的起始地址和大小用户可以根据实际应用来调整
2)将启动代码(StartUp.S)中的por段链接到ROM0分区中起始地址开始的区域(por段大小为256Bytes)
二、E90x系列内核,以APT32F103x(E902)系列为例
1、启动代码(StartUp.s)部分
在启动代码里加入一个段落,可以命名为por,段的起始位置放一条长跳转指令,跳转到系统代码的入口地址(Reset_Handler)
2、链接文件(.ld)修改
这部分和CK80x系列同样操作,请参阅第一章节中的具体说明。
三、CK80x系列和E90x系列内核实现差异
CK系列内核是在ROM0分区的起始地址(0地址)处放入代码的入口地址(__start),E90x系列是在ROM0分区的起始地址(0地址)处放一条跳转指令,跳转到代码的入口地址(Reset_Handler)。