关于C6000的引导过程的一点认识
2007-08-07 21:38
323 查看
关于C6000的引导过程的一点认识
我是这样认为的(有不对的希望大家指正):
CPU复位后首先把系统程序加载到内部RAM或者外部高速RAM中,然后在RAM中运行,
bootloader就是完成加载的过程。
C6000有3钟引导方式(1)无引导(2)ROM引导 (3)主机引导
我只用过ROM引导。
ROM引导加载过程:
(1)当CPU的Reset引脚处于低电平状态时,BOOTMODE的引脚状态根据预设设定(我的目标版
上面有这几个开关可设置),RESET信号处于上升沿的时候,相应加载方式启动。
(2)ROM加载方式是通过DMA控制器,将外部ROM的一段固定大小的代码复制到内部RAM中(加
载时CPU处于stall状态),对于不同型号芯片,复制的代码大小不同。67X的应该是1KB
(3)加载完毕后,CPU开始从0地址执行。
想象一下,有的程序都很大,1K是不能解决问题的,所以,一般在0地址处建立一个叫做
“bootloader”的段(代码小于1KB),这一小段程序也叫“引导程序”,上电或者重启后首
先执行它,完成将其余程序(真正完成用户要求算法的程序)加载,然后跳转到主程序入口
地址运行。
举例:
我的目标版FLASH地址为0x9000 0000, 在完成源代码编写,编译,连接后生成*.out文件,通
过hex6x.exe工具转换成*.hex文件(16进制数据文件),然后使用Flashburn工具烧写到外部
Flash Rom中。
程序boot.asm ,功能:完成数据大小为FLASH_SIZE 的数据搬移,源地址FLASH_START,目的
地址RAM_START,搬移结束后跳转的主程序入口点_c_int00运行
FLASH_START .set 0x90000400 ;DMA已经加载可1KB(400H),所以地址从0x90000400开
始
RAM_START .set 0x400
FLASH_SIZE .set 0x40000
.ref _c_int00
.def start
.sect ".bootload"
start:
mvkl FLASH_START,A4
mvkh FLASH_START,A4
mvkl RAM_START,B4
mvkh RAM_START,B4
mvkl FLASH_SIZE,B5
mvkh FLASH_SIZE,B5
zero A1
loop
ldw *A4++,B0
nop 5
stw B0,*B4++
add 1,A1,A1
cmplt A1,B5,B0
nop
[B0] b loop
nop 5
b _c_int00
nop 5
我是这样认为的(有不对的希望大家指正):
CPU复位后首先把系统程序加载到内部RAM或者外部高速RAM中,然后在RAM中运行,
bootloader就是完成加载的过程。
C6000有3钟引导方式(1)无引导(2)ROM引导 (3)主机引导
我只用过ROM引导。
ROM引导加载过程:
(1)当CPU的Reset引脚处于低电平状态时,BOOTMODE的引脚状态根据预设设定(我的目标版
上面有这几个开关可设置),RESET信号处于上升沿的时候,相应加载方式启动。
(2)ROM加载方式是通过DMA控制器,将外部ROM的一段固定大小的代码复制到内部RAM中(加
载时CPU处于stall状态),对于不同型号芯片,复制的代码大小不同。67X的应该是1KB
(3)加载完毕后,CPU开始从0地址执行。
想象一下,有的程序都很大,1K是不能解决问题的,所以,一般在0地址处建立一个叫做
“bootloader”的段(代码小于1KB),这一小段程序也叫“引导程序”,上电或者重启后首
先执行它,完成将其余程序(真正完成用户要求算法的程序)加载,然后跳转到主程序入口
地址运行。
举例:
我的目标版FLASH地址为0x9000 0000, 在完成源代码编写,编译,连接后生成*.out文件,通
过hex6x.exe工具转换成*.hex文件(16进制数据文件),然后使用Flashburn工具烧写到外部
Flash Rom中。
程序boot.asm ,功能:完成数据大小为FLASH_SIZE 的数据搬移,源地址FLASH_START,目的
地址RAM_START,搬移结束后跳转的主程序入口点_c_int00运行
FLASH_START .set 0x90000400 ;DMA已经加载可1KB(400H),所以地址从0x90000400开
始
RAM_START .set 0x400
FLASH_SIZE .set 0x40000
.ref _c_int00
.def start
.sect ".bootload"
start:
mvkl FLASH_START,A4
mvkh FLASH_START,A4
mvkl RAM_START,B4
mvkh RAM_START,B4
mvkl FLASH_SIZE,B5
mvkh FLASH_SIZE,B5
zero A1
loop
ldw *A4++,B0
nop 5
stw B0,*B4++
add 1,A1,A1
cmplt A1,B5,B0
nop
[B0] b loop
nop 5
b _c_int00
nop 5
相关文章推荐
- (每日心得)关于面向对象与面向过程的一点认识
- 关于C#的索引一点认识
- 关于DropDownList绑定数据的一点认识
- 关于java匿名内部类的一点认识
- 关于C#多态性的一点认识
- 关于云的一点认识。
- 关于synchronized与volatile的一点认识
- 关于深搜具体的过程一点理解
- 关于C#委托的一点认识
- 关于Java 数组内存分配一点认识
- 关于商城系统购物车的一点认识
- 关于感知学习模型机中空间任一点到超平面的距离公式的推导过程
- 关于感知学习模型机中空间任一点到超平面的距离公式的推导过程
- 关于OOM和内存回收的一点浅显的认识
- 关于rst_n_async到rst_n_sync的认识过程
- 关于ActivityGroup使用过程中遇到的一点问题
- 关于strtok的一点简单认识
- 关于Oracle索引的一点认识
- 关于printf参数与栈的问题的一点认识
- 关于设计的度的一点小认识