1852|0

6807

帖子

0

TA的资源

五彩晶圆(高级)

楼主
 

TI C2000 MCU Boot过程分析-以TMS320F28069为例 [复制链接]

每一款MCU从上电复位到代码运行到main函数这之间的一段过程就是MCU的boot,其实不只是MCU,其他任何类型的processor都有这样的一个过程,这里以TI C2000 F28069为例,分析其Boot过程,以帮助对处理器的底层原理有一个比较清楚的了解。
芯片复位之后,首先会跳到一个固定的中断向量,成为RESET,其地址是0x3F FFC0,RESET指向存在于boot ROM里的InitBoot函数,InitBoot是厂家出厂就固化好的,这个函数用于开启Boot过程,检查特定的IO口以决定选择哪一种Boot模式

假设在仿真模式下需要将程序下载到片内的Flash里面去(程序掉电不会丢失),那么Boot会就根据RAM里面的EMU_KEY和EMU_BMODE里面的值来决定是什么样的boot模式。在Boot 到Flash模式下,会到0x3F 7FF6所在的位置开始取指令,在linker链接文件里有相关的定义
[cpp] view plain copy
MEMORY  
{  
PAGE 0 :  
   BEGIN       : origin = 0x3F7FF6, length = 0x000002/* Part of FLASHA.  Used for "boot to Flash" bootloader mode. */  
   RESET       : origin = 0x3FFFC0, length = 0x000002     /* part of boot ROM  */  
}  
SECTIONS  
{  
   codestart           : > BEGIN,      PAGE = 0  
   .reset                : > RESET,      PAGE = 0, TYPE = DSECT  
}  
而codestart段(Section)是在CodeStartBranch.asm里定义过的,这个汇编文件里有一个code_start函数,在这个函数里关闭看门狗,然后跳转到_c_int00函数,这个_c_int00是C语言运行环境的设置函数,只有经过_c_int00后,才能够跳转执行用C语言编写的main函数
如果代码烧写到RAM里运行(掉电程序会丢失,但是仿真调试情况下不用频繁擦写Flash),则需要将链接文件里的BEGIN的地址定义做一下修改:
[cpp] view plain copy
MEMORY  
{  
PAGE 0 :  
   BEGIN        : origin = 0x000000, length = 0x000002  
   RESET       : origin = 0x3FFFC0, length = 0x000002     /* part of boot ROM  */  
}  
SECTIONS  
{  
   codestart           : > BEGIN,      PAGE = 0  
   .reset                : > RESET,      PAGE = 0, TYPE = DSECT  
}  
当然除了以上BEGIN的地址修改,还需要对程序的存储地址等做相应的修改,这比较简单,官方都有相应的链接文件模板,这里不再介绍。

总体来看,整个Boot过程可以总结如下:
1. 复位,Reset(0x3F 7FF6)
2. 跳转到InitBoot函数,读取相关IO口的状态
3. 判断启动方式
4. 跳到codestart,执行code_start函数,关看门狗,跳到_c_int00,设置C语言函数的运行环境,准备执行main函数
5. 执行用户编写的main函数(入口函数)

 
点赞 关注(1)

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

随便看看
查找数据手册?

EEWorld Datasheet 技术支持

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

 
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
快速回复 返回顶部 返回列表