EDK=Embedded Development Kit,嵌入式开发套件。EDK是xilinx公司开发嵌入式系统的工具。比起xilinx的
xilinx ise,二者不同在于,如果仅仅是使用xilinx的fpga做逻辑设计,只需要ISE
开发环境。但是如果要使用powerpc或者microblaze处理器,从硬件到软件设计的整个嵌入式系统设计,就需要EDK。
EDK介绍
EDK工具中硬件平台部分的描述包含在MHS(Microprocessor Hardware Specification)文件中,这个文件是用
高级语言格式描述处器器系统的硬件平台。它是可编辑的
文本文件,是用于综合生成HDL网表的输入文件,为后续的布局布线(Netgen)做准备。
在
xps的项目信息区【Project Information Area】中打开【Project Tab】选项卡,双击
File∶system mhs文件,打开该文件,可以仔细研究其中的内容。
嵌入式系统经历了从单片计算机、工业控制计算机、集中分布式控制系统,发展到嵌入式的平台的几个阶段:从独立单机使用发展到联网设备;从以
模拟电路为主发展到以
数字电路为主、数/模混合型,进而进入全数字时代。总的来说,嵌入式系统向着更高性能、更小体积、更低功耗、更廉价、无处不在的方向发展。嵌入式系统的设计和实现朝着基于芯片,特别是片上可编程系统(
SOPC)的方向发展。
嵌入式开发套件(EDK)是用于设计嵌入式可编程系统的全面解决方案。该套件包括嵌入式软件工具(PlatformStudio)以及嵌入式IBMPowerPC硬件处理器核和/或XilinxMicroBlaze软处理器核进行Xilinx平台FPGA设计时所需的技术文档和IP。注意,这里的
嵌入式软件工具指用来产生、编辑、编译、链接、加载和调试高级
编程语言(通常是C或
C++)代码的工具,以便在处理器引擎上执行。
由于
嵌入式系统涉及了软件和硬件的开发以及两者的综合设计,因此其开发是较为复杂的。Xilinx为了简化基于FPGA的嵌入式开发流程,提供了功能强大、操作简单的工具集:集成软件环境——ISE;嵌入式开发套件——EDK。(注释:
xilinx ise是Xilinx公司FPGA逻辑设计的基础。在这个环境中,设计者可以进行约束文件的编写,时序分析,逻辑布局布线以及器件编程等。)
EDK自带了许多工具和IP,可以用来设计完整的嵌入式处理器系统,主要包括Xilinx平台工作室
xps和软件开发套件SDK。需要注意的是:只有安装了ISE软件,才能正常运行EDK,且二者的版本要一致。
EDK的组成模块有:
1.Xilinx平台工作室(XilinxPlatformStudio,XPS)
XPS是用来设计嵌入式处理器系统硬件部分的
开发环境或GUI,是系统设计者构建Xilinx嵌入式系统时必用的工具套件。在XPS中,可以完成嵌入式系统架构的创建、软件代码的编写、设计的编译以及FPGA芯片的硬件配置。
2.软件开发套件(SoftwareDevelopmentKit,SDK)
sdk是集成的开发环境,基于
Eclipse。它支持C/
C++,用于嵌入式软件应用的开发和验证。
3.其它EDK部分
EDK还包括其它的一些部分,如:用于Xilinx嵌入式处理器的硬IP;用于嵌入式软件开发的驱动和库;在MicroBlaze和PowerPC处理器上用于C/C++软件开发的GNU编译器和调试器;有关文档以及一些工程样例等。
Xilinx的嵌入式开发套件EDK带有许多的工具和IP,可以用来设计完整的嵌入式处理器系统,并在XilinxFPGA芯片上运行。EDK中包含了开发硬件和软件所必须的全部工具,可以很方便的添加系统自带的IP核和用户自定义的IP核,可以通过调用ISE等其他工具实现布局布线,时序优化等等。可以调用
GNU侦错器对应用程序进行板上调试及虚拟平台调试。
实现流程
2.1、基于EDK的开发流程
一个完整的嵌入式设计流程包括硬件设计和调试、软件设计与调试,各个步骤相对独立但又相辅相成。由于嵌入式应用场合多样,且软、硬件都可裁剪,因此并不是每个设计都要完成所有的步骤。图中为基于EDK的嵌入式设计的简化流程图。
通常,
xilinx iseFPGA开发软件在后台运行,
xps工具调用ISE软件提供的功能。XPS主要用来嵌入式处理器
硬件系统的开发。微处理器、外围设备以及这些组件之间的连接问题,另外还有它们各自的属性设置都在XPS里进行。简单的软件开发可以在XPS里完成,而对于更复杂的应用开发和调试,Xilinx则推荐使用SDK工具。硬件平台的功能验证可以通过硬件描述语言HDL仿真器完成。XPS提供了行为级、结构级以及定时精确级等三种类型的仿真。验证过程结构由XPS自动产生,其中包括了仿真的HDL文件。设计者只需要输入时钟时序、重配置信息以及一些应用代码即可。仿真细节将在下面的内容中进行相关讲述。完成设计后,在
xps中将FPGA比特流和可执行可链接格式文件下载,就可以进行目标器件的配置。
完整的EDK开发流程如右图所示,其主要步骤有:1.创建硬件平台:利用XPS的板级开发包向导(BSBWizard)快速构建设计的硬件平台,是EDK设计的第一步。
2.添加IPCore以及用户定制外设:在XPS中添加所需的IPCore,对于XPS库中缺少的模块,需要用户自行设计。同样,XPS提供了建立用户自定义外设的向导,可简化该过程。
3.生成仿真文件并测试
硬件系统:生成硬件系统的仿真文件,可选择行为级、结构级以及时序级仿真,利用ModelSim等工具测试系统,特别是用户自定义的外设;如果测试失败,需要返回上一步修改。
4.生成硬件比特流:生成硬件网表和比特流文件,这个步骤类似于传统FPGA设计的综合、布局布线、生成编程文件这3个操作。
5.开发软件系统:针对软件需求编写硬件代码,确定软件的操作系统、库、外设驱动等属性,针对每个应用软件工程,设置编译器、优化级别、使用的连接文件等信息。等设置完成后,编译生成.elf格式的可执行代码。
6.合并软、硬件比特流:编译软件后,需要将软、硬件可执行文件合并在一起,生成最终的二进制比特文件。
7.下载:使用JTAG编程电缆或编程器将更新后的最终比特流烧写到FPGA、PROM、FLASH以及CF卡。
8.在线调试:可利用XMD工具或ChipScope工具调试,通过JTAG编程电缆在线调试,下载可执行软件代码、控制执行,并监控相关信息。
2.2、EDK设计比特文件的组成
如前所述,最终下载到FPGA的嵌入式比特流文件是软、硬件比特流合并在一起的,详细的组成部分如右图所示。硬件部分比特流包括MHS文件、用户自定义HDL代码,二者经过综合实现后,产生.ngc网表,生成
硬件系统的比特流文件;软件系统包括MSS文件、用户.c/cpp/asm文件,通过
GCC编译器,生成目标文件.obj,再经过连接合成软件系统的比特流文件;最后通过Data2MEM过程,将软、硬件比特流合成完整系统比特流文件,通过JTAG链路下载到FPGA芯片中。
添加IP
安装时候需要版本搭配,如ISE8.1搭配EDK8.1。首先,说说使用EDK加入用户设计的IP。
1、启动
xps(xilinx
Platform studio),生成一个processor system,其中可以选择处理器,硬IP(powerpc)或软IP(microblaze),以及可选的IP(BRAM、UART)等。如果这个阶段拿不定不要什么IP,以后添加删除都可以。
2、启动Create and Import Peripheral Wizard,创建IPIF,选择需要的属性,如是否包括FIFO、DMA等,系统会自动创建HDL文档模板,用户只需要添加用户程序部分。同coreconnect
总线连接部分不用用户操心。
3、使用
xilinx ise的Project Navigator,打开第二步生成的.npl文件,添加入自己的代码,在ISE里进行编译。
4、如果需要,进行BFM(总线功能模型)仿真
5、若在第三步里,用户对接口有修改,需要重新启用Create and Import Peripheral Wizard,来生成EDK接口(.pao/.mpd文件)
6、使用XPS - Add/Edit Core Dialog,添加用户IP到第一步的工程中
8、编译、下载bit文件到开发板。