1265|0

2014

帖子

0

TA的资源

纯净的硅(中级)

楼主
 

关于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

 
点赞 关注

回复
举报
您需要登录后才可以回帖 登录 | 注册

查找数据手册?

EEWorld Datasheet 技术支持

相关文章 更多>>
关闭
站长推荐上一条 1/10 下一条

 
EEWorld订阅号

 
EEWorld服务号

 
汽车开发圈

About Us 关于我们 客户服务 联系方式 器件索引 网站地图 最新更新 手机版

站点相关: 国产芯 安防电子 汽车电子 手机便携 工业控制 家用电子 医疗电子 测试测量 网络通信 物联网

北京市海淀区中关村大街18号B座15层1530室 电话:(010)82350740 邮编:100190

电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2025 EEWORLD.com.cn, Inc. All rights reserved
快速回复 返回顶部 返回列表