问题如下:
疑问一:仿真调试下载程序或把程序已烧写至flash后脱机上电运行程序时,程序是不是必须要执行“从0x3f ffc0处复位→执行0x3f fc00地址处的初始化引导函数(initboot) →根据gpio选择引导模式→确定用户程序入口地址→从入口处开始执行用户程序”这一系列过程吗?对于用c语言编程时,通常在复位地址向量处(对于f240而言,复位地址在0x0000地址处?),常需要放置指令:“b _c_int0”来规定初始化入口地址,意即c语言函数“_c_int0”完成的功能就是初始化引导函数(initboot)的功能吗?但对f2812来说,复位向量地址为0x3f ffc0,处于rom区,是一次性编程rom,怎么把_c_int0这个入口地址放在0x3f ffc0处呢?
疑问二:由于引导模式由gpio引脚状态决定,那对于一个已经设计好的dsp最小系统,引脚状态在硬件上已经固定好了,意即是不是此时只能局限于一种引导模式了?不能同时进行仿真调试和烧写至flash内进行硬件调试吗?(因为仿真调试时,用户程序入口地址一般在saramh0处,烧写至flash内进行允许时,用户程序入口地址在flash处。)
解答如下:
1:上电运行时根据mp/mc引脚的状态决定是从片外的3fffc0处读取复位向量或者时从片内的rom的3fffc0处读取复位向量。mc方式下从片内读取,mp方式下从片外读取。
2:一般我们用的是mc方式,即从片内读取复位向量,在片内的rom 3fffc0处有一个地址为3ffc00。
3:复位后处理器从3fffc0处读取3ffc00这个地址,所以程序从3ffc00处开始执行
4:3ffc00处开始的就是initboot过程吧,根据io管教的状态判断该进入那一种引导方式
5:在scitxa{即gpiof4脚}引脚为高电平时就是flash boot方式,此时置pc=3f7ff6
6:在片内flash的3f7ff6和3f7ff7处有一个跳转指令,该跳转指令就是lb _c_int00
7:执行这个跳转指令后程序就开始运行c_int00这个函数了
8:这个函数就是建立一个c程序的运行环境,等建立完c运行环境后c_int00调用main函数
9:main函数开始就是我们自己编写的应用程序了。
以上是2812上电(复位)后运行过程的描述
如果你选择了mp方式,那么3fffc0处的复位向量可以自己设置,因为此时处理器从片外的zone7区的ram中读取复位向量的,当然初始化引导过程也可以自己编写。
lhfnjj 2005-12-6 14:29
在第5步中,为选择片内flash,则使scitxa为高电平。如果scitxa还用作串口通讯,那怎么办?
haomaru 2005-12-7 08:13
scitxa引脚有内部上拉,所以只要没有强制下拉的话,dsp检测的都是高电平。
对于通讯不影响。
scitxa不用在外部上拉。不能直接接到高电平上。
我自己理解的是,即 :.reset段表示跳转到_c_int00处的一个程序段
首先: .reset段区别于处于复位向量3fffc0(即复位指针,即dsp复位时pc所装的地址,在这个地址中存放了初始化boot的程序地址3ffc00,其事先已固化在bootrom的程序)
即系统复位以后首先跳转到复位向量3fffc0处,然后从此处跳转到初始化intboot (3ffc00)处,执行完初始化boot.并根据gpiof口选择启动模式,例如选择从flash启动,则退出初始化boot程序时,程序则会跳到0x3f7ff6处执行,此处距0x3f7ff8(密码设置区)只有两个字的距离,故在此也就只能放一个跳转指令,即跳转到c语言程序入口,即_c_int00处,个人认为当cmd文件将.reset段配置到0x3f7ff6时,起到的作用就是:即在0x3f7ff6处使程序跳转到_c_int00处。
memory
{
page 0 :
。。。
begin : origin = 0x3f7ff6, length = 0x000002
。。。
page 1 :
。。。
}
sections
{
.reset : > begin page = 0
}
同理当仿真模式时,初始化boot时完成时,程序会跳到h0ram起始地址0x3f8000处,则此时按如下方式配置cmd文件:即把跳转到_c_int00处的程序段.reset配置到0x3f8000。
memory
{
page 0 :
pramh0 : origin = 0x3f8000, length = 0x001000
。。。
}
sections
{
/* allocate program areas: */
.reset : > pramh0, page = 0
。。。
}