官网就有XDS100V3的资料(官网链接我实在找不到,这里是eeworld论坛的链接),包括原理图、FPGA源代码、FPGA代码综合的方法、制作方法;
官网XDS100V3的资料如下
dtsa_a3p125.stp文件:是默认提供的FPGA编程文件。
Board_Design 目录: 下面有官方的原理图的PCB文件、BOM文件。
Documentation目录: 包含XDS100V3功能的介绍制作方法和接口定义。
FPGA目录:是FPAG的VHDL代码,默认使用A3P125VQ100,可以使用官方的Libero Soc开发套件对源代码进行修改、生成STP下载文件。
Utilities目录: 里面提供了通过FT223HL调试、烧录FPAG的工具,后面编程FPGA会用到。
我根据网上网友的资料还有TI官网的资料,自己画了一块XDS100V3的下载板,有些地方略有魔改,仅供参考;XDS100V3 主要使用了FT2232HL、A3P060VQ100(A3P060VQ100(可以使用A3P125VQ100替代,注意不要买带程序的IC,不然可能会无法编程FPGA,我第一次就遇到了),此外还使用了一颗E2PROM 93LC56BT来存储FT2232HL的配置信息;
整体结构如下(图片来源于官方文档)
FT2232HL及其外围电路:FT2232HL将USB协议转换为JTAG协议,如果不需要XDS100V3的全部功能,可以仅使用FT2232HL而不需要FPGA芯片就可以实现XDS100V2。外围电路需要给FT2232HL提供3V3的供电,FT2232HL内部自带一个1.8V LDO,将3.3V转换为1.8V为USB PLL供电。FT2232HL 的USB配置信息存储在外部E2PROM中(我使用了了两个E2配合FPGA实现XDS100V2和XDS100V3的切换,纯粹是为了折腾。。。,可以只用一个E2),FT2232HL 一上电就会读取E2中的信息用作USB枚举过程(如果没有则使用FT2232HL的默认枚举信息),E2PROM可以通过FTDI的官方软件FT_Prog配置。
A3P060VQ100及其外围电路:
FPGA 负责将JTAG 1149.1转换为1149.7,即将FTDI的1149.1标准的JTAG接口转换1149.7标准,此外还可以将其他外部1149.1标准的JTAG下载器接口转化为1149.7标准;
如果需要对官方的VHDL代码进行魔改就需要Re-Synthesizing FPGA工程然后生产STP下载文件进行下载,当然也可以使用现成的STP文件直接烧录到FPGA中。Re-Synthesizing FPGA工程要使用需要使用Microsemi 的Libero_SoC 开发工具,我使用的是Libero_SoC_v11.8,安装软件需要提供license,可以在官网申请免费的license,可以参考网友的教程。
使用Libero打开FPGA 目录下方的 v3_fpga_125.prjx工程,打开软件会报错这是正常的:编辑VHDL文件
在Libero Soc的Files导航栏下,可以编辑工程目录内包含的文件。
编辑完成后,在Libero Soc的Deisgn Hierarchy导航栏下可以右键检查VHDL文件是否有语法错误:
Re-Synthesizing FPGA工程
在Libero的Design Flow界面点击图示处的小齿轮图标
选择对于型号的器件,点击Save
设置IO为LVCMOS 3.3V
右键Synthesize选择Open Interactively唤出Synplify工具:
在Synplify界面设置频率为100MHz,取消勾选FSM Complier,然后点击RUN,未发生报错就可以退出Synplify界面
Complier 工程&生成下载文件
回到Libero的Design Flow界面,删除Complie下面生成的默认.sdc文件,添加FPGA/constraint目录下面.sdc和.pdc文件
右键Complie选择Open Interactively唤出Designer工具,然后点击Complie取消勾选Abort Compile if errors…,然后点击OK:
点击Layout使用默认选项,然后点击Programing File选项,使用默认选项点击Finish
设置生成文件的文件名和路径,勾选.stp文件,点击生成
生成用于烧录的文件就在FPGA\designer\impl2下方
待续。。。。。