0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

超全使用串口对DSP进行应用可编程的方法

电子工程师 来源:马玲 孟庆新 作者:马玲 孟庆新 2021-04-02 16:13 次阅读

1引言

通过串口总线可以对TMS320LF2407A FLASH进行编程。串口编程可以对DSP系统编程,同时本文给出了一种可编程的应用方法。

该DSP拥有一个片内串口,可以通过一个外部的电平转换器件与标准RS232器件通讯。该串口不仅仅用于编程,在编程结束后可以配置成标准的串口使用。

Bootloader是一个让用户方便对片内FLASH或RAM进行重新编程升级的工具。Bootloader本身不包含某些编程算法,嵌入在片内的Bootloader只具有一些基本的代码下载指令,并在片内RAM运行。Bootloader一般都提供一些编程片内程序存储器的ISP和IAP的接口

ISP(In-System Programming):使用片内的Bootloader软件和通讯接口,对片内存储器进行编程和重编程。IAP(In Application Programming):IAP对片内存储器执行擦除和写操作,可以由用户代码来执行。

2工作过程

2.1DSP初始化

上电以后,程序首先从地址0x0000开始执行,然后立即跳转到bootloade程序。

.sect vectors

RESET: B _bootloader ; 地址0x0000

……。。

_bootloader :

Bootloade首先对串口进行配置,8位数据位,一位停止位,无校验位,建立与 计算 机的通讯。在此过程中,计算机始终向DSP发送检测字符,0x0D. Bootloade一直通过串口监听计算机通讯,如果连续接受到三个字符与0X0D不相符合,则改为下一个波特率进行监听。当波特率匹配成功后,Bootloade就准备接收9个相同的字符。一旦9个字符接收成功后,Bootloade将发送一个应答信号0XAA,表示通讯建立,从此开始,Bootloade接收到的每一个字符都将发送给计算机,以验证通讯是否正确。

2.2内核传输

内核通过通讯接口,以字节为单位进行传输。首先发送的是低字节,后面是高字节。数据包格式如下:

计算机发送:

①启动地址:一个字(16 bits),每次传输一个字节,低字节优先。

②数据包容量(要传输的字的数目):一个字(16 bits),每次传输一个字节,低字节优先。

③内核代码:每次传输一个字节,低字节优先。一旦内核传输到Ram,内核会发送状态字节来表示初始化的状态。0X0表示发送成功,其它 内容 表示发送失败,计算机会终止传输。

2.3内核操作

内核只要成功传输,则内核程序将接管控制功能。对于TMS320LF2407A,内核程序算法必须满足以下要求:

①内核必须小于0X100字,并且必须在程序空间0Xfe00-0Xfeff安装和执行,程序起始点必须是0Xfe00。

②内核必须返回程序的状态。

③内核程序必须能够将控制功能返回,不会破坏程序使用的变量。

④内核等待擦除,置1和编程的算法。

⑤内核必须装载到有效的地址内存空间内。

2.4擦除算法

擦除算法是第一个被下载到目标芯片内的算法。它将FLASH第一扇区和第二扇区的内容清0,为FLASH置位作准备。成功擦除后,返回0x0,不然就返回一个非零值。

2.5置位

下载置位算法,它可以置位FLASH。成功置位后,返回0x0,不然就返回一个非零值。

2.6编程

下载编程算法,但编程算法并不立即执行,而是下载第一组编程数据。一旦得到编程数据,将会调用编程算法,将下载的编程数据烧写到FLASH里。图2是编程步骤的流程图。

对FLASH第一扇区的编程操作结束以后,编程算法将向 计算 机返回状态。并一直等待下一组编程数据,一直到接收到最后一组数据标志为止。将编程数据烧写到FLASH后,编程算法将控制权交给工作程序。

3使用 方法

为了使用该软件将程序下载到FLASH里,首先要通过编译器将程序编译、调试通过,一般编译器生成的文件格式为COFF格式,该文件包含程序二进制代码,但不包含要烧写到FLASH里的二进制文件。需要使用工具将该文件格式转换为可下载的文件格式。

在芯片内有四个字的密码,在下载程序时要注意。如果下载程序里的密码是0X0000 或0X0FFFF,则不用关心,但如果其它的密码,则需要记录下来,以备下次下载时使用,将密码设置到要下载的程序里,解密原来的芯片。

Password1:set 0000h ;在地址0x0040中的密码

Password2:set 0000h ;在地址0x0041中的密码

Password3:set 0000h ;在地址0x0042中的密码

Password4:set 0000h ;在地址0x0043中的密码

4结果

使用该方法可以方便的对芯片进行程序下载,成本低、操作方便。本方法已经在北京瑞泰公司的DSP开发板上调试通过,稳定可靠。

参考文献

[1]刘和平。 TMS320LF240x DSP结构原理及 应用 。 北京:北京航空航天大学出版社,2002.

[2]张雄伟等。 DSP芯片的原理与开发应用(第3版)[M]。 北京:北京 电子 工业 出版社,2003.

[3]TMS320LF2407A DSP controller. TI 2000.

[4]潭浩强。 C 程序设计[M]。 北京:清华大学出版社,2003.

编辑:jq

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • dsp
    dsp
    +关注

    关注

    544

    文章

    7682

    浏览量

    344362
  • FlaSh
    +关注

    关注

    10

    文章

    1550

    浏览量

    146646
  • 串口
    +关注

    关注

    14

    文章

    1483

    浏览量

    74511
收藏 人收藏

    评论

    相关推荐

    爱普生的低抖动温补可编程晶振

    爱普生发布最新可编程晶体 SG-8200/8201CJ.封装为2.0 x1.6(mm)还有SG-8201CJA 符合汽车应用AEC-0100可为可编程?就是输出频率可以根据客户需求编辑的晶体振荡器
    发表于 04-08 14:27 0次下载

    可编程片上系统的基本特征和主要应用

    可编程片上系统是一种特殊的嵌入式系统:首先它是片上系统,即由单个芯片完成整个系统的主要逻辑功能;其次,它是可编程系统,具有灵活的设计方式,可裁减、可扩充、可升级,并具备软硬件在系统可编程的功能。
    的头像 发表于 03-28 15:13 176次阅读

    可编程片上系统是什么意思

    可编程片上系统(Programmable System-on-Chip,PSoC)是一种特殊的嵌入式系统。它首先是一个片上系统,这意味着整个系统的主要逻辑功能由单个芯片完成。其次,它具有可编程的特性,设计方式灵活,可裁减、可扩充、可升级,并具备软硬件在系统
    的头像 发表于 03-28 15:09 192次阅读

    可编程片上系统是什么

    可编程片上系统(Programmable System-on-Chip,PSoC)是一种特殊的嵌入式系统,它集成了数字逻辑、模拟电路和可配置模块,将传统的微处理器、微控制器和可编程逻辑器件等功能融合
    的头像 发表于 03-28 14:55 170次阅读

    现场可编程门阵列的原理和应用

    可以根据用户的设计进行配置,形成所需的逻辑功能。互连资源则是一组可编程的连接通道,用于将PLU连接在一起,以实现用户定义的电路拓扑结构。此外,FPGA还包括输入输出模块(IOB),用于与外部设备或电路进行连接。
    的头像 发表于 03-27 14:49 166次阅读

    现场可编程门阵列是什么

    现场可编程门阵列(Field Programmable Gate Array,简称FPGA)是一种超大规模可编程逻辑器件,由可编程逻辑资源、可编程互连资源和
    的头像 发表于 03-16 16:38 1695次阅读

    可编程逻辑器件的特征及优势科普

    可编程逻辑器件是一种集成电路,具有可编程功能的特性。它们可以根据用户的需求进行编程,从而实现不同的逻辑功能。
    的头像 发表于 02-26 18:24 637次阅读

    分享 | 可编程晶振芯片几个知识点

    什么是可编程晶振?可编程晶振多为有源晶振,由两个芯片组成;一个是全硅MEMS谐振器,一个是具有温补功能的芯片,可以启动电路锁相环CMOS
    的头像 发表于 01-09 17:51 554次阅读
    分享 | <b class='flag-5'>可编程</b>晶振芯片几个知识点

    可编程器件的特点和发展历程

    )和读写存储器(ROM)。 可编程器件的特点主要包括以下几个方面: 可编程性:可编程器件可以根据需求进行编程,改变其功能和行为。它们通常具有
    的头像 发表于 12-21 17:19 369次阅读

    基于FPGA和TMS320C40 DSP可编程通用信号处理背板设计

    电子发烧友网站提供《基于FPGA和TMS320C40 DSP可编程通用信号处理背板设计.pdf》资料免费下载
    发表于 11-08 14:54 0次下载
    基于FPGA和TMS320C40 <b class='flag-5'>DSP</b>的<b class='flag-5'>可编程</b>通用信号处理背板设计

    可编程晶振详解「工作原理、结构、特点、应用」

    主要部分组成。其工作原理为:当加电压时,石英晶体就会产生振动,并产生电信号,此信号被检测并数字化后,再通过处理器进行解调,最后输出所需的频率信号。 二、可编程晶振的结构主要有以下几个部分: 晶体:晶体
    发表于 10-14 17:38

    什么叫可编程逻辑器件 可编程逻辑器件有哪些特征和优势?

    可编程逻辑器件(Programmable Logic Device,PLD)是一类集成电路器件,可以根据用户的需求进行编程和配置,以实现特定的逻辑功能。它们具有可编程的逻辑门、时钟资源
    发表于 09-14 15:25 1431次阅读

    什么是可编程片上系统?PSOC和FPGA的区别

    可编程片上系统(Programmable System-on-Chip,PSoC)是一种集成了数字逻辑、模拟电路和可配置模块的片上系统。它将传统的微处理器、微控制器和可编程逻辑器件等功能融合到一个芯片中,并提供了可编程的硬件资源
    发表于 07-06 15:15 2641次阅读

    可编程逻辑器件测试

    可编程逻辑器件 (Programmable Loeie Device,PLD)是一种用户编程实现某种逻辑功能的逻辑器件,主要由可编程的与阵列、或阵列、门阵列等组成,可通过编程来实现一定
    发表于 06-06 15:37 443次阅读
    <b class='flag-5'>可编程</b>逻辑器件测试

    可编程逻辑器件测试方法

    门阵列 ( Field Programmable Gate Array, FPGA)器件等。随着可编程器件的发展,可以将 CPU、DSP、ADC/DAC、存储器等集成到一个可编程器件上,从而构成
    的头像 发表于 06-06 15:35 758次阅读
    <b class='flag-5'>可编程</b>逻辑器件测试<b class='flag-5'>方法</b>