DSP28335学习笔记(2):启动原理详解

1.前言
通常了解一款芯片,我们最开始从它的电特性描述出发,随后看其外设、存储、时钟等系统基本框架。我相信大家拿到一款芯片之后第一件事就是去查阅其数据手册,对芯片特性有个初步了解。
很多芯片开发者在了解芯片特性之后,会直接拷贝官方提供的例程进行调试,之后慢慢熟悉芯片,变成开发者模式。在这过程中,很多开发者往往忽略了一个重要的步骤,那就是熟悉芯片启动原理,所以我们今天将dsp28335这款芯片的启动原理与大家分享。
2.上电复位
颠覆我们感性认识的是,芯片上电过程不是一个瞬时过程,而是 爬坡过程 ,也就是说芯片上电也是需要时间的。
在了解芯片基本特性之后,我们清晰的知道一般芯片都有上电复位模块(por),也可以称为上电延时复位,其作用是通过延时器件在上电电压爬坡过程中把芯片锁定在复位状态,保证芯片模拟模块和数字模块初始化至已知状态再启动芯片。
当电压逐渐增大,直到达到阈值电压时,上电复位电路会释放内部复位信号。在其他必要条件充足的情况下,芯片开始启动。
3.boot rom
boot rom是芯片内部存储器中固化好的一块只读存储区,用来存放引导程序。
boot rom在芯片内部存储器中地址0x3fe000-x3fffff如上图所示。
上图是boot rom中按功能分类的段地址存储区。
cpu vector table,此功能区在vmap = 1 ,enpie = 0的情况下使用。
再完成芯片引导程序后,此功能区其他部分被用来存放中断向量表。
4.启动过程
芯片上电完成后,开始运行程序。首先pc指针指向cpu vector table中的reset(地址:0xfffc0)。
通过观察cmd文件中的reset地址,我们发现此地址存放着.reset,通过访问存储区中翻译成汇编语言的代码,这里存放着一条跳转指令。芯片复位后第二步,跳转到initboot函数入口地址,执行initboot函数。
在initboot函数中,对器件模式、地址进行选择,还对某些功能进行初始化。最关键的是调用了selectbootmode这个函数,这个函数通过boot引脚状态来决定通过哪种方式引导程序,接下来我们一起走进selectbootmode。
dsp28335initboot中的selectbootmode是通过读取4个io引脚的状态决定程序引导方式。
如上图所示定义16种状态。
在引导方式上可以分为两大类,一类是进行adc校准,一类是不进行adc校准。
selectbootmode首先依据读取到的引脚状态判断是否是不进行adc校准,不校准直接跳过后续程序,将读取到的引导模式的引导函数入口地址返回。
若需要adc校准,则往下执行adc校准。
校准后再判断以哪种方式引导,并将引导函数入口地址返回。
返回后在initboot中将引导函数入口地址存入acc,再将acc赋予pc退出initboot,开始运行用户程序。
一般我们将程序引导至flash(地址:0x33fff6)。
通过工程下的cmd文件可发现0x33fff6中存放着codestart函数,所以紧接着运行codestart函数。
codestart函数中禁止看门狗,再调用rts中的c_int00函数。
c_int00函数中为c语言的运行搭建运行环境,然后跳转至main函数,来到c语言的世界。
5.总结
以上是dsp28335芯片上电到运行至main函数的基本过程,其基本流程可查阅芯片技术参考手册第二章,流程图如下图所示。
以上是本期全部内容,那么现在芯片就可以正常运行、万事大吉了吗?
当然不是,芯片启动后还需对芯片进行一系列初始化配置,那么这又是怎样一个过程呢?

蒋尚义会给武汉弘芯带来什么?
控制耦变压器降压线路设计和工作原理及其原理图
Qorvo的RF Fusion将应用于多项新款智能手机设计
Labview设计中的常见问题以及解答汇总
华为携手合作伙伴发布L3.5数据中心自动驾驶网络白皮书
DSP28335学习笔记(2):启动原理详解
华为p10最新消息:华为mate9卖了700万华为p10也不错 高端机华为领先
焕新出发,利尔智达天下
四层pcb打样需要注意什么
中国正在研发可载弹掠海飞行的地效无人机,成海防一大利器
神奇的“小芯片”设计,可在一颗芯片上使用不同工艺进行制造
Imagination与飞桨合作提出“软硬一体赋能芯片设计”理念
为什么说FB收购Oculus是个错误的决定?
蚂蚁回应被约谈:成立整改工作组
安卓8.0+高通骁龙835,配置不是一般的强悍,诺基亚9搞事情!
4G蓝牙网关具备哪些功能_SKYLAB
基于ZYNQ LCD显示OV5640图像测试方法
2018年彩电市场整体延续低迷走势 激光电视却逆势高速前行
2008年中国电池行业百强企业排名揭晓
MOS场效应管的基础知识