使用器件 ti dsp c2000 2837x

1、dsp的上电过程和boot mode以及boot loader

1)dsp的上电顺序,

对于双核系统而言 , 他的上电启动顺序如下所示:

系统复位或者重新上电之后:

cpu2系统重新上电之后,一直处于复位状态

cpu1系统会自动跳转到地址0x3fffc0中获取复位向量,福为向量的目的就是为了使得系统自动跳转到0X3F8000地址上,开始执行boot ROM 段中存储的boot loader代码段;

对于cpu1而言,cpu1的boot ROM段中的boot loader程序首先会从TI - OTP内存段中获取设备的配置自,并配置好器件。

完成之后,boot loader 开始执行DCSM 和OTP JTAGLOCK流程:DCSM流程:1)读取OTP中的Zx_poinyer;2)解码指针值;3)度去除TI-OTP中的SECDC;4)读取Zx BOOT模式;5)读取ZX DCSM模块

完成之后,boot loader检测FUSEERR寄存器中是否存在错误标志位,并采取错误处理机制

之后初始化RAM和内存端的ECC/PARITY

完成之后cpu1将引导CPU2系统跳出复位操作,之后便不管cpu2的运行状态

之后CPU1系统的boot loader将会根据外部的GPIO 和XRST(一般链接下载器才会有) 来确定程序的启动方式是从flash启动还是ram启动,或者是在XRST为低的情况下,更具PIE向量表(地址为0xd00)的第一个32位的值来确定启动方式(一般是链接了下载器的情况);

确定完之后,CPU1的boot loader代码段会将各种信息都更新到指定的RAM段中,以便于CPU1的程序去读取这些状态字。

此时按照启动方式开始跳转程序,如果是flash启动则将程序指针跳转到0x80000(flash的其实地址),如果是ram启动则将程序指针跳转到0x00000(ram段的起始地址),同时结束boot loader并进入CPU1的主程序。

如果此时的启动方式是外设启动,那么boot loader则会等待外部程序按照一定的格式将程序加载到ram中,程序代码传输完成之后,跳转到运行指针开始运行程序代码段。

此时cpu1的boot loader 完成使命,已退出,并开始执行CPU1中的用户程序。

此时的CPU2系统知识退出了复位状态,任然在等待启动模式确定,需要cpu1的用户程序来引导cpu2的引导,如果是cpu2也要从flash启动,则通过ipc command即可触发,但是如果cpu2也需要从外设启动,那么需要cpu1的应用首先设置好外设的引脚,之后在触发cpu2开始接受程序。

关于链接下载器的xrst为低是的系统启动过程参考手册

关于外设启动的代码输入格式也可以参考手册

//--------------------------------------------------------------------------------------------

2、实现在线升级的个些方案 :

次方案是用 : 升级代码 + 用户应用程序的方式来实现

升级代码的用途是下载到DSP中上电就开始运行的代码段,主要功能是上电之后首先监测是否有升级指令发出,如果有则进入升级流程,如果没有则通过(LB )的跳转指令跳转到指定的程序运行其实处。

假设 : 将用户应用程序的其实地址定义为0XC0000;当监测到需要升级的指令,则升级代码通过外设将上位机输送过来的代码通过DSP的flash API写入到以0XC0000为起始地址的FLASH sector中,当所有的数据全部书写完成之后,通过跳转指令,将程序指针跳转到0XC0000上,便开始执行用户程序。

数据格式 : 上位机输送给升级代码的格式就是bin文件当中的内容,dsp将.out文件转化为bin文件,然后dsp接受到这个文件直接写入到flash中就可以,原因是 :将同一个程序的.out文件下载到dsp中,然后通过uniflsh去查看内部代码段的内容和bin文件的内容是一样的。

至于为什么bin文件和.out文件的格式和datasheet上的数据流内容不一样,我还没找到原因

关于DSP的boot mode / boot loader /上电顺序 /在线升级等问题的总结的更多相关文章

  1. spring boot / cloud (三) 集成springfox-swagger2构建在线API文档

    spring boot / cloud (三) 集成springfox-swagger2构建在线API文档 前言 不能同步更新API文档会有什么问题? 理想情况下,为所开发的服务编写接口文档,能提高与 ...

  2. Spring Boot的属性加载顺序

        伴随着团队的不断壮大,往往不需要开发人员知道测试或者生产环境的全部配置细节,比如数据库密码,帐号信息等.而是希望由运维或者指定的人员去维护配置信息,那么如果要修改某项配置信息,就不得不去修改项 ...

  3. dsp 28377在线升级 实例总结

    使用dsp品台28377d来实现在线升级的功能. 方案 : 升级程序  +  应用程序 升级程序 : 主要的目的是将上位机发送过来的应用程序数据(ccs编译生成的.bin文件)烧写到指定位置,之后在跳 ...

  4. 痞子衡嵌入式:飞思卡尔i.MX RT系列MCU启动那些事(2)- Boot配置(BOOT Pin/eFUSE)

    大家好,我是痞子衡,是正经搞技术的痞子.今天痞子衡给大家介绍的是飞思卡尔i.MX RT系列MCU的Boot配置. 在上一篇文章 Boot简介 里痞子衡为大家介绍了Boot基本原理以及i.MXRT Bo ...

  5. 痞子衡嵌入式:飞思卡尔i.MX RTyyyy系列MCU启动那些事(2)- Boot配置(BOOT Pin/eFUSE)

    大家好,我是痞子衡,是正经搞技术的痞子.今天痞子衡给大家介绍的是飞思卡尔i.MX RTyyyy系列MCU的Boot配置. 在上一篇文章 Boot简介 里痞子衡为大家介绍了Boot基本原理以及i.MXR ...

  6. spring boot ----> spring boot 和spring的联系

    1.自动配置的实现是基于spring 4.0的条件化配置,这是spring 4.0的新特性.比如,定义一个类A,它实现Condition接口,覆盖condition接口的match()方法,那么该类变 ...

  7. [Spring Boot] Spring Boot启动过程源码分析

    关于Spring Boot,已经有很多介绍其如何使用的文章了,本文从源代码(基于Spring-boot 1.5.6)的角度来看看Spring Boot的启动过程到底是怎么样的,为何以往纷繁复杂的配置到 ...

  8. Spring Boot -- Spring Boot之@Async异步调用、Mybatis、事务管理等

    这一节将在上一节的基础上,继续深入学习Spring Boot相关知识,其中主要包括@Async异步调用,@Value自定义参数.Mybatis.事务管理等. 本节所使用的代码是在上一节项目代码中,继续 ...

  9. spring boot 使用属性加载顺序

    1.命令行中传入的参数 2.SPRING_APPLICATION_JSON中的属性.SPRING_APPLICATION_JSON是以JSON格式配置再系统环境变量中的内容 3.java:comp/e ...

随机推荐

  1. Java 泛型约束

    类型约束: import java.util.List; import java.util.ArrayList; import java.util.LinkedList; /** * Created ...

  2. My Baits入门(一)mybaits环境搭建

    1)在工程下引入mybatis-3.4.1.jar包,再引入数据库(mysql,mssql..)包. 2)在src下新建一个配置文件conf.xml <?xml version="1. ...

  3. Lua屏蔽对象方法和恢复的方法

    背景 对于OO思想实现的类, 对于某些场景需要屏蔽某些方法, 不让调用.过了这段场景, 就恢复这些类的方法, 可以调用. 例如: 工厂具有开工方法, 但是在晚上不允许开工, 所有在晚上这段时间, 见开 ...

  4. 深入了解DSP与ARM的区别与联系

    http://www.eeboard.com/bbs/thread-25219-1-1.html ARM微处理器的体系结构 了解DSP的体系结构 深入了解DSP与ARM的区别与联系 2011-09-3 ...

  5. Url通配符映射

    原文:http://www.cnblogs.com/liukemng/p/3726897.ht 1.URL路径映射 1.1.对一个action配置多个URL映射: 我们把上一篇中的HelloWorld ...

  6. poj 2393 Yogurt factory

    http://poj.org/problem?id=2393 Yogurt factory Time Limit: 1000MS   Memory Limit: 65536K Total Submis ...

  7. csuoj 1394: Virus Replication

    http://acm.csu.edu.cn/OnlineJudge/problem.php?id=1394 1394: Virus Replication Time Limit: 1 Sec  Mem ...

  8. svg gradient

    SVG和canvas中是一样的,都是使用标准的HTML/CSS中的颜色表示方法,这些颜色都可以用于fill和stroke属性. 基本有下面这些定义颜色的方式: 1. 颜色名字: 直接使用颜色名字red ...

  9. HDU-1257 导弹拦截系统 http://acm.hdu.edu.cn/showproblem.php?pid=1257

    Problem Description 某国为了防御敌国的导弹袭击,发展出一种导弹拦截系统.但是这种导弹拦截系统有一个缺陷:虽然它的第一发炮弹能够到达任意的高度,但是以后每一发炮弹都不能超过前一发的高 ...

  10. .NET组件控件实例编程系列——5.DataGridView数值列和日期列

    在使用DataGridView编辑数据的时候,编辑的单元格一般会显示为文本框,逻辑值和图片会自动显示对应类型的列.当然我们自己可以手工选择列的类型,例如ComboBox列.Button列.Link列. ...