欢迎来到天天文库
浏览记录
ID:21736504
大小:116.45 KB
页数:6页
时间:2018-10-24
《基于tms320c6678的多核dsp加载模式研究》由会员上传分享,免费在线阅读,更多相关内容在应用文档-天天文库。
1、基于TMS320C6678的多核DSP加载模式研究摘要:德州仪器TI推出的八核DSP芯片TMS320C6678是目前基于Keystone架构的最高性能的DSP器件,是市场上应用广泛的C6455高端处理平台升级的理想选择。本文主要研究了C6678DSP程序的各种单核加栽和多核加载的几种模式,主要用到多核boot技术,对EMIF16FLASHboot引导模式、主机(PCIe接口)引导模式、I2C引导模式、SRIO引导模式、网络引导boot引导模式的方法做了研究,对TI的高性能多核架构DSP芯片的程序加载提供
2、了有效的参考帮助。近年来,以数字信号处理器(DSP)为基础的通用信号处理模块的研制受到人们的重视,DSP技术广泛应用于雷达、通信、图像处理等领域。随着声纳、雷达、高清视频以及嵌入式机器视觉等需求不断攀升,多核DSP的应用已成为满足发展的重要途径。由于DSP系统稳定运行起来后,在实际的应用中都要脱离仿真器件,实现系统的自动加载,尤其是多核DSP加载过程中,不同于多芯片间的加载方式,需要实现核间的调度,数据协同处理,因此多核启动的加载方式需要做具体研究。TMS320C6678DSP是TI最新发布的一款基于K
3、eyStone架构高性能的超长指令字(VLIW)架构芯片,片内有8个内核,每个核频率为1.25GHz,单核每秒高达40GBMAC定点运算和20GBFLOP浮点运算能力,工作速度可达10GHz。与目前应用较为广泛的TMS320C6455 DSP,为单核1.2GHz工作,定点处理能力为9600MMAC。可见C6678的处理能力要远强于C6455。针对C6678多核协同处理特性,本文以自定义的双6678板卡平台为基础,深入研究C6678的多种加载方式,对EMIF16FLASHboot引导模式、I2C引导模式、
4、SRIO引导模式、网络引导boot模式做了分析和说明,主机(PCIe接口)引导模式、HYPERLINK引导模式和SPI引导模式的使用,本文不做说明。1多核加载方式论述在C6678的片内地址空间0x20800000到0x20B1FFFF间集成了一块128K的内部ROM程序,又叫做RBL(ROMBootLoader),Romcode是C6678出厂时固化在Rom中的,用户不能改变,在DSP复位或上电时实现将DSP代码从外部接口读入到内部高速ram。启动过程可以大致分为主机引导和内存引导启动,在内存引导启动过
5、程代码从一个外部内存的加载初始应用程序到内部的内存来执行。如果主机模式,启动程序配置DSP在被动状态,等待代码将DSP应用程序程序由外部主机写入ram开始执行。为适应不同的系统要求,RBL提供了几种启动的执行方式。不同的引导方式如表1所示。2多核boot预处理C6678有8个核,采用基于KeyStone架构的中断控制器、核间通信寄存器以及合适的通信拓扑结构实现多核间的通信,core0为主核,其它7个核可以统一执行相同的Romcode代码,也可以不同,或者根据核号(即DNUM)进行不同程序的分支。对于co
6、re0来说,它主要是读取DEVSTAT寄存器的加载模式,并根据当前加载模式进行一些接口的初始化和PLL的配置,还要根据加载模式决定是否搬移数据。对于其它的7个核来说,它们主要是挂载IPC中断,然后进入IDLE状态等待core0发过来的中断。中断一到,就跳到入口地址开始执行程序,待加载工程总体流程如图1所示。代码读入前要根据不同的boot方式进行转换格式,转换工具是将各核的.out文件转换成.dat或.bin文件,也有网络boot时要转换成.eth格式的文件来传送,不同的转化方式在各自的boot说明中详细
7、阐述。无论哪一种启动方式,首先要boot起来core0之后再引导其他的从核,重点是从核在boot启动时通过host向DSP写了MAGIC_ADDRESS并触发IPC中断,DSP跳转到BOOT_MAIGC_ADDRESS所指向的地址执行程序。3C6678EMIFflashboot3.1core0加载C6678的EMIF16加载是一种直接从NorFlash(必须挂在CE2空间:0x70000000)加载core0的模式,不需要I2CEEPROM的参与,由Romcode初始化EMIF16接口,由于EMIF16
8、外接NorFlash是一种XIP器件,因此直接跳到NorFlash的起始地址处开始执行。为了将NorFlash中的代码搬移到C6678的core0的L2SRAM中,需要在core0的待加载工程中编写引导代码,此引导代码的作用就是将core0的代码按段加载到内存中,最后跳到入口地址处开始执行。引导代码放在L2SRAM的前1KB空间,并烧写到NorFlash的前1KB空间,应用代码放到1KB后面,生成.out文件编写转化工具生成.dat文件,如
此文档下载收益归作者所有