Xilinx文档的数量非常多。即使全职从事FPGA相关工作,没有几年时间不可能对器件特性、应用、注意事项等等有较为全面的了解。本文记录了我自使用Xilinx系列FPGA以来或精读、或翻阅、或查询过的文档,及其主要内容。如果有新的会随时补录进来。以下按照个人理解对文档进行了分类,不一定恰当,也会有重叠的情况,欢迎提出意见。
ds180:7系列器件概述,介绍不同器件的资源、IO分布、工作频率、收发器数量、DSP类型、IO电压等等。
ds190:Zynq-7000系列器件概述。
ug471:7系列器件SelectIO的技术手册,内容包括SelectIIO资源(电平标准、DCI、匹配等)、IDELAY、IDELAYCTRL、ISERDESE2、OSERDESE2等等。
ug472:该手册详细描述了7系列器件的时钟资源,如时钟架构、时钟布线资源、时钟管理等等。
ug473:详细介绍7系列器件的Block RAM资源。
ug474:详细介绍7系列器件的可配置逻辑块(CLB)的结构、特点、应用、分布等等。
ug475:详细介绍7系列器件的封装、尺寸、管脚分布、热特性等等。
ug479:7系列器件中DSP单元的架构、使用方法、应用等。
ug480:7系列器件内置XADC的详细介绍。
ug953:7系列器件设计库,包含7系列器件几乎所有的Macro和Primitive。
ds890:ultrascale系列器件概述。
ds891:UltraScale+ Zynq器件概述。
ds892:KU器件概述。
ds893:VU器件概述。
ds923:VU+器件概述。
pg188:High Speed SelectIO Wizard,UltraScale和UltraScale+系列器件SelectIO使用向导,其实就是ISERDES和OSERDES的使用向导。
ug571:UltraScale系列器件SelectIO的技术手册,内容包括SelectIO资源(电平标准、DCI、匹配等)、IDELAY、IDELAYCTRL、ISERDESE2、OSERDESE2等等。
ug572:该手册详细描述了UltraScale系列器件的时钟资源,如时钟架构、时钟布线资源、时钟管理等等。
ug573:详细介绍UltraScale系列器件的Block RAM资源。
ug574:详细介绍UltraScale系列器件的可配置逻辑块(CLB)的结构、特点、应用、分布等等。和7系列的区别挺大。
ug575:详细介绍UltraScale系列器件的封装、尺寸、管脚分布、热特性等等。
ug580:UltraScale Architecture System Monitor,其实和ug480讲的内容差不多,主要是内置XADC的详细介绍。
ug974:UltraScale系列器件设计库,包含7系列器件几乎所有的Macro和Primitive。
ds181、ds182、ds183、ds187:分别详细介绍A7、K7、V7和Zynq-7000系列器件的电气特性,如直流电平、交流特性、上电顺序、收发器电气特性、eFUSE编程等等。
ug470:详细介绍7系列器件的多种配置方法和电路。
xapp520:如何将7系列器件HP IO与2.5V/3.3V的I/O标准互连。
7_Series_Schematic_Review_Recommendations_xart_040714.xls:7系列器件原理图设计自查/复查建议表,做设计时可以对着检查,130多条。
XTP031:FPGA System Design Checklist,与上面的excel文档作用相似。
xapp583:介绍使用微处理器,通过Slave Serial或Slave Select MAP方式配置7系列FPGA的方法。
xapp586:介绍如何使用SPI Flash配置7系列FPGA。
ug483:7系列FPGA PCB设计指南。
ug583:UltraScale系列FPGA PCB设计指南。
ds892、ds893、ds923:分别介绍Kintex UltraScale、Virtex UltraScale和Virtex UltraScale+系列器件的电气特性。
ug570:详细介绍UltraScale系列器件的多种配置方法和电路。
pg116:MicroBlaze Micro Controller System,介绍MicroBlaze Micro Controller System(MCS)。
pg201:Zynq UltraScale+ MPSoC Processing System产品手册。
ug898:Vivado Design Suite User Guide: Embedded Processor Hardware Design,介绍Zynq-7000类SoC和MicroBlaze的设计和使用,包含硬件设计和软件设计。
ug984:MicroBlaze Processor Reference Guide。
ug1043:Embedded System Tools Reference Manual。基于Cortex A9 arm处理器和MicroBlaze介绍嵌入式系统工具和嵌入式设计流程的框架。
ug1209:Zynq UltraScale+ MPSoC: Embedded Design Tutorial,是MPSoC比较重要的上手指南,入门可以用这个。
ug129:PicoBlaze 8-bit Embedded Microcontroller User Guide,非常轻量级的一个8bit嵌入式微控制器,省资源,挺好用。
ug908:Vivado Design Suite User Guide,Programming and Debugging。介绍基于Vivado的编程和调试步骤和方法。
ug835:Vivado Design Suite Tcl Command Reference Guide,Vivado使用的Tcl脚本指令参考手册。
ug871:Vivado HLS的帮助文档。
ug892:Vivado设计流程概述。
ug893:Vivado IDE环境帮助文档。
ug894:Vivado Design Suite User Guide: Using Tcl Scripting,介绍Tcl脚本语言的作用和使用方法。
ug896:介绍Vivado中IP的使用,以及基于IP的设计方法。
ug899:介绍在Vivado中如何进行IO和时钟planning。
ug900:介绍在Vivado中如何进行逻辑仿真。
ug908:介绍在Vivado中如何进行编程和调试,主要讲Vivado IDE的使用。
ug909:主要将partial reconfiguration,就是PR,目前挺火的,我只是有很肤浅的了解。
ug910:Vivado Getting Started。
ug911:介绍如何将设计向Vivado迁移。
ug912:属性参考手册,这里的属性包括BEL/CELL/NET/PIN/PORT/SITE这样的对象,也包括ASYNC_REG/BEL/CLOCK_ROOT/DC-_CASCADE/DIFF_TERM/DONT_TOUCH/PBLOCK/VCCAUX_IO这一类的属性,非常有用。
7series_hdl:7系列器件HDL设计库,包括所有可用的Macros和Primitives。比如BRAM_SINGLE_macro、ADDSUB_MACRO、BUFG、CARRY4、FDRE、GTHE2_CHANNEL、IBUF、LUT4、MMCME2_ADV、PHASER_IN、RAMB36E1等等。
ug936:一个使用Vivado进行编程和调试的手把手的教程。
ug947:一个使用Vivado进行PR设计的手把手的教程。
ug949:UltraFast设计方法指南。这是一个非常全面的文档,部分内容比较深入,部分内容只是介绍。主要是一些方法、流程、工具、概念的介绍。比如HLS设计、基于IP的设计方法、仿真、Project和Non-Project比较、板级设计、PCB设计、编码风格等等。
ug975:Vivado Quick Reference。非常非常有用的一个速查手册,涉及各个方面,主要包括Tcl介绍(索引)和文档介绍。随便列几个大的条目:Getting Help、Simulation Commands、Main Reporting Commands、Design Object Query Commands、Timing-based Query Commands、Filtering、Tcl Examples、Batch Mode Script Examples、Timing Constraints。
ug994:Designing IP Subsystems Using IP Integrator。
ug908:Vivado Design Suite User Guide,Programming and Debugging。介绍基于Vivado的编程和调试步骤和方法。
pg172:ILA,介绍如何应用Integrated Logic Analyzer进行调试。
ug904:Vivado Design Suite User Guide,Implementation。
ug905:Hierarchical Design设计方法。Hierarchical设计要用好不容易,对FPGA器件、设计方法学、架构要有非常深入的了解。曾经用过,但是对我参与的项目不适用(主要是没见过世面),所以放弃。
ug901:介绍如何进行设计综合,内容包括综合策略选择、综合技巧、设计原则等等。
ug903:介绍如何使用约束,包括IO位置约束、延时约束、时序约束、物理约束、CDC约束等等。
ug906:介绍如何对自己的工程进行分析和改进,进而实现时序收敛。
ug1292:UltraFast Design Methodology Timing Closure Quick Reference Guide,实现Ultra器件时序收敛的快速参考,非常有用。
pg021:AXI DMA手册,用于实现AXI4 memory map和AXI4-Stream接口之间的高带宽传输。可应用于基于处理器(CPU)的系统中。
pg022:AXI DataMover手册,用于实现AXI4 memory map和AXI4-Stream的高带宽数据传输,主要包含S2MM和MM2S两个接口。
pg034:AXI CDMA手册,使用AXI4协议实现memory map地址之间的DMA。
pg059:AXI Interconnect手册,AXI系统设计中最常用的IP,用于实现任何AXI Master和Slave之间的智能互联,可自动实现协议转换(AXI4, AXI3, or AXI4-Lite)和时钟域转换。
pg067:AXI Chip2Chip手册。AXI Chip2Chip可以通过AXI接口实现两个器件之间的无缝互联。
pg078:AXI Block RAM Controller手册,可以实现AXI系统与器件内部BRAM的互联,支持单次读写和突发读写。
pg144:AXI GPIO手册。
pg164:Processor System Reset Module手册,实现整个系统(包括processor、interconnect和peripheral)的复位。
pg247:SmartConnect手册,实现类似多个memory map master和多个memory map slave之间的互联,我还没有用过。
pg288:AXI Multichannel Direct Memory Access手册,我还没有用过。
ug761:AXI Reference Guide用户手册,介绍AXI协议的关键概念、概述AXI的使用、如何将现有设计迁移到AXI下。
ug1037:Vivado Design Suite: AXI Reference Guide,与ug761相似,增加了UltraScale器件以及在Vivado中的使用介绍。
pg066:JESD204接口IP。
pg198:JESD204物理层IP。
pg057:Fifo Generator。
pg058:Block Memory Generator。
ug586:7 Series FPGAs Memory Interface Solutions,介绍存储器接口使用,包含例化、使用方法、PCB设计等等,存储器类型包括DDR3、DDR2、QDRII+、RLDRAM II/III、LPDDR2等。
xtp359-memory-ip-ultrascale-design-checklist.xlsm:UltraScale器件存储器接口设计自查表。
pg054:7系列FPGA的PCIe接口IP说明文档,内容包括PCIe接口概述、电气特性、使用方法、设计步骤、仿真调试等等。
pg023:Virtex7器件PCIe Gen3接口的产品手册。
pg054:7系列器件PCIe接口产品手册。
pg195:DMA/Bridge Subsystem for PCI Express,就是XDMA的产品手册。
AR# 58495:Xilinx PCI Express Interrupt Debugging Guide,调试PCIe中断用得上。
AR# 65444:XDMA驱动和软件使用。(数字签名真烦人)。
xapp888:7系列器件中MMCM和PLL的动态重配置。
ug476:7系列器件收发器的用户手册,内容涵盖收发器内部资源的详细描述和使用方法,硬件电路设计注意事项,收发器应用等等。
ug576:UltraScale系列器件GTH收发器的用户手册。
ug578:UltraScale系列器件GTY收发器的用户手册。
pg074:Aurora接口产品手册。
pg196:UltraScale系列GTY Ibert的产品手册,在收发器调试中非常有用,值得拥有!
pg173:UltraScale系列GTH Ibert的产品手册。
其他
ug429:介绍如何将设计从Virtex6移植到7系列器件。
ug953:Vivado Design Suite 7 Series FPGA and Zynq-7000 SoC Libraries Guide原语对应的使用手册
引自:https://blog.csdn.net/yinyeyy/article/details/104566824
matlab打开matlab,用最简单的imread方法读取一个图像clcclearimg_h=imread('hua.jpg');返回一个数组(矩阵),往往是a*b*cunit8类型解释一下这个三维数组的意思,行数、数和层数,unit8:指数据类型,无符号八位整形,可理解为0~2^8的数三个层数分别代表RGB三个通道图像rgb最常用的是24-位实现方法,即RGB每个通道有256色阶(2^8)。基于这样的24-位RGB模型的色彩空间可以表现256×256×256≈1670万色当imshow传入了一个二维数组,它将以灰度方式绘制;可以把图像拆分为rgb三层,可以以灰度的方式观察它figure(1
我发现自己需要这个。假设cart是一个包含用户列表的模型。defindex_of_itemcart.users.each_with_indexdo|u,i|ifu==current_userreturniendend获取此类关联索引的更简单方法是什么? 最佳答案 indexArray上的方法与您的index_of_item方法相同,例如cart.users.index(current_user)返回数组中第一个对象的索引==给obj。如果未找到匹配项,则返回nil。 关于ruby-on-
因此,当我遵循MichaelHartl的RubyonRails教程时,我注意到在用户表中,我们为:email属性添加了一个唯一索引,以提高find的效率方法,因此它不会逐行搜索。到目前为止,我们一直在根据情况使用find_by_email和find_by_id进行搜索。然而,我们从未为:id属性设置索引。:id是否自动索引,因为它在默认情况下是唯一的并且本质上是顺序的?或者情况并非如此,我应该为:id搜索添加索引吗? 最佳答案 大多数数据库(包括sqlite,这是RoR中的默认数据库)会自动索引主键,对于RailsMigration
Ruby有一些不错的文档生成器,例如Yard、rDoc,甚至Glyph。问题是Sphinx可以做网站、PDF、epub、LaTex等。它在重组文本中完成所有这些事情。在Ruby世界中有替代方案吗?也许是程序的组合?如果我也能使用Markdown就更好了。 最佳答案 自1.0版以来,Sphinx有了“域”的概念,它是从Python和/或C以外的语言标记代码实体(如方法调用、对象、函数等)的方法。有一个rubydomain,所以你可以只使用Sphinx本身。您唯一会缺少的(我认为)是Sphinx使用autodoc从源代码自动创建文档
假设我有一个可枚举对象enum,现在我想获取第三个项目。我知道一种通用方法是转换成数组,然后使用索引访问,如:enum.to_a[2]但这种方式会创建一个临时数组,效率可能很低。现在我使用:enum.each_with_index{|v,i|breakvifi==2}但这非常丑陋和多余。执行此操作最有效的方法是什么? 最佳答案 你可以使用take剥离前三个元素,然后剥离last从take给你的数组中获取第三个元素:third=enum.take(3).last如果您根本不想生成任何数组,那么也许:#Ifenumisn'tanEnum
在我的场景中,Logstash收到的系统日志行的“时间戳”是UTC,我们在Elasticsearch输出中使用事件“时间戳”:output{elasticsearch{embedded=>falsehost=>localhostport=>9200protocol=>httpcluster=>'elasticsearch'index=>"syslog-%{+YYYY.MM.dd}"}}我的问题是,在UTC午夜,Logstash在外时区(GMT-4=>America/Montreal)结束前将日志发送到不同的索引,并且索引在20小时(晚上8点)之后没有日志,因为“时间戳”是UTC。我们已
我怀念ipython的一件事是它有一个?为特定功能挖掘文档的运算符。我知道ruby有一个类似的命令行工具,但是我在irb中调用它非常不方便。ruby/irb有类似的东西吗? 最佳答案 Pry是IPython的Ruby版本,它支持?命令来查找有关方法的文档,但语法略有不同:pry(main)>?File.dirnameFrom:file.cinRubyCore(CMethod):Numberoflines:6visibility:publicsignature:dirname()Returnsallcomponentsofthef
我正在尝试使用nokogirigem提取页面上的所有url及其链接文本,并将链接文本和url存储在散列中。FooBar我想回去{"Foo"=>"#foo","Bar"=>"#bar"} 最佳答案 这是一个单行:Hash[doc.xpath('//a[@href]').map{|link|[link.text.strip,link["href"]]}]#=>{"Foo"=>"#foo","Bar"=>"#bar"}拆分一点可以说更具可读性:h={}doc.xpath('//a[@href]').eachdo|link|h[link.t
我想从特定索引开始遍历数组。我该怎么做?myj.eachdo|temp|...end 最佳答案 执行以下操作:your_array[your_index..-1].eachdo|temp|###end 关于ruby-从特定索引开始迭代数组,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/44151758/
我一直在努力学习如何处理由数组组成的数组。假设我有这个数组:my_array=[['ORANGE',1],['APPLE',2],['PEACH',3]我将如何找到包含'apple'的my_array索引并删除该索引(删除子数组['APPLE',2]因为'apple'包含在该索引的数组中)?谢谢-我非常感谢这里的帮助。 最佳答案 您可以使用Array.select过滤掉项目:>>a=[['ORANGE',1],['APPLE',2],['PEACH',3]]=>[["ORANGE",1],["APPLE",2],["PEACH",3