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

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

3天内不再提示

FPGA的8大威廉希尔官方网站 要点,点进来看看?

电子设计 来源:电子设计 作者:电子设计 2020-10-30 12:16 次阅读

1. 面积与速度的平衡与互换

这里的面积指一个设计消耗 FPGA/CPLD 的逻辑资源的数量,对于 FPGA 可以用消耗的 FF(触发器)和 LUT(查找表)来衡量,更一般的衡量方式可以用设计所占的等价逻辑门数。

速度指设计在芯片上稳定运行所能达到的最高频率,这个频率由设计的时序状况来决定,以及设计满足的时钟要求:PAD to PAD time 、Clock Setup Time、Clock Hold Time、Clock-to-Output Delay 等众多时序特征量密切相关。

面积和速度这两个指标贯穿 FPGA/CPLD 设计的时钟,是设计质量的评价的终极标准 ——面积和速度是一对对立统一的矛盾体。

要求一个同时具备设计面积最小、运行频率最高是不现实的。更科学的设计目标应该是在满足设计时序要求(包括对设计频率的要求)的前提下,占用最小的芯片面积。或者在所规定的面积下,是设计的时序余量更大、频率跑的更高。这两种目标充分体现了面积和速度的平衡的思想。

作为矛盾的两个组成部分,面积和速度的地位是不一样的。相比之下,满足时序、工作频率的要求更重要一些,当两者冲突时,采用速度优先的准则。

从理论上讲,如果一个设计时序余量较大,所能跑的速度远远高于设计要求,那么就通过功能模块的复用来减少整个设计消耗的芯片面积,这就是用速度的优势换取面积的节约。反之,如果一个设计的时序要求很高,普通方法达不到设计频率,那么一般可以通过将数据流串并转换,并行复制多个操作模块,对整个设计采取乒乓操作和串并转换的思想运行。

2.硬件原则

硬件原则主要针对 HDL 代码编写而言:Verilog 是采用了 C 语言形式的硬件的抽象,它的本质作用在于描述硬件,它的最终实现结果是芯片内部的实际电路。所以评判一段 HDL 代码的优劣的最终标准是:其描述并实现的硬件电路的性能,包括面积和速度两个方面。

评价一个设计的代码水平较高,仅仅是说这个设计是由硬件想 HDL 代码这种表现形式的转换更加流畅、合理。而一个设计最终性能,在更大程度上取决于设计工程师所构想的硬件实现方案的效率以及合理性。(HDL 代码仅仅是硬件设计的表达形式之一)

初学者片面追求代码的整洁、简短,是错误的,是与 HDL 的标准背道而驰的。正确的编码方法,首先要做到对所需实现的硬件电路胸有成竹,对该部分的硬件的结构和连接十分清晰,然后再用适当的 HDL 语句表达出来即可。

另外,Verilog 作为一种 HDL 语言,是分层次的。系统级 -- 算法级 -- 寄存器传输级 -- 逻辑级 -- 门级 -- 开关级。构建优先级树会消耗大量的组合逻辑,所以如果能够使用 case 的地方,尽量使用 case 代替 if.....else......

3. 系统原则

系统原则包含两个层次的含义:更高层面上看,是一个硬件系统,一块单板如何进行模块花费和任务分配,什么样的算法和功能适合放在 FPGA 里面实现,什么样的算法和功能适合放在 DSP/CPU 里面实现,以及 FPGA 的规模估算数据接口设计等。具体到 FPGA 设计就要对设计的全局有个宏观上的合理安排,比如时钟域、模块复用、约束、面积、速度等问题,在系统上模块的优化最为重要。

一般来说实时性要求高,频率快的功能模块适合 FPGA 实现。而 FPGA 和 CPLD 相比,更适合实现规模较大、频率较高、寄存器较多的设计。使用 FPGA/CPLD 设计时,应该对芯片内部的各种底层硬件资源,和可用的设计资源有一个较深刻的认识。

比如 FPGA 一般触发器资源丰富,CPLD 的组合逻辑资源更加丰富。FPGA/CPLD 一般是由底层可编程硬件单元、BRAM、布线资源、可配置 IO 单元、时钟资源等构成。

底层可编程硬件单元一般由触发器和查找表组成。Xilinx 的底层可编程硬件资源较 SLICE,由两个 FF 和 2 个 LUT 构成。Altera 的底层硬件资源叫 LE,由 1 个 FF 和 1 个 LUT 构成。使用片内 RAN 可以实现单口 RAM、双口 RAM、同步 / 异步 FIFO、ROM、CAM 等常用单元模块。

一般的 FPGA 系统规划的简化流程

4. 同步设计原则

异步电路的逻辑核心是用组合逻辑电路实现,比如异步的 FIFO/RAM 读写信号,地址译码等电路。电路的主要信号、输出信号等并不依赖于任何一个时钟性信号,不是由时钟信号驱动 FF 产生的。异步时序电路的最大缺点是容易产生毛刺,在布局布线后仿真和用逻辑分析仪观测实际信号时,这种毛刺尤其明显。

同步时序电路的核心逻辑用各种各样的触发器实现,电路的主要信号、输出信号都是由某个时钟沿驱动触发器产生出来的。同步时序电路可以很好的避免毛刺,布局布线后仿真,和用逻辑分析仪采样实际工作信号都没有毛刺。

是否时序电路一定比异步电路使用更多的资源呢?从单纯的 ASCI 设计来看,大约需要 7 个门来实现一个 D 触发器,而一个门即可实现一个 2 输入与非门,所以一般来说,同步时序电路比异步电路占用更大的面积。(FPGA/CPLD 中不同,主要是因为单元块的计算方式)

如何实现同步时序电路的延时?异步电路产生延时的一般方法是插入一个 Buffer、两级与非门等,这种延时调整手段是不适用同步时序设计思想的。首先要明确一点 HDL 语法中的延时控制语法,是行为级的代码描述,常用于仿真测试激励,但是在电路综合是会被忽略,并不能启动延时作用。

同步时序电路的延时一般是通过时序控制完成的,换句话说,同步时序电路的延时被当做一个电路逻辑来设计。对于比较大的和特殊定时要求的延时,一般用高速时钟产生一个计数器,通过计数器的计数控制延迟;对于比较小的延时,可以用 D 触发器打一下,这种做法不仅仅使信号延时了一个时钟周期,而且完成了信号与时钟的初次同步,在输入信号采样和增加时序约束余量中使用。

同步时序电路的时钟如何产生?时钟的质量和稳定性直接决定着同步时序电路的性能。输入信号的同步时序电路要求对输入信号进行同步化,如果输入数据的节拍和本级芯片的处理时钟同频,并且建立保持时间匹配,可以直接用本级芯片的主时钟对输入数据寄存器采样,完成输入数据的同步化。如果输入数据和本级芯片的处理时钟是异步的,特别是频率不匹配的时候,则要用处理时钟对输入数据做两次寄存器采样,才能完成输入数据的同步化。

是不是定义为 Reg 型,就一定综合成寄存器,并且是同步时序电路呢?答案的否定的。Verilog 中最常用的两种数据类型 Wire 和 Reg,一般来说,Wire 型指定书数据和网线通过组合逻辑实现,而 reg 型指定的数据不一定就是用寄存器实现。

5. 乒乓操作

“ 乒乓操作 ” 是一个常常应用于数据流控制的处理技巧,乒乓操作的处理流程为:输入数据流通过 “ 输入数据选择单元 ” 将数据流等时分配到两个数据缓冲区,数据缓冲模块可以为任何存储模块,比较常用的存储单元为双口 RAM(DPRAM) 、单口 RAM(SPRAM) 、 FIFO 等。

在第一个缓冲周期,将输入的数据流缓存到 “ 数据缓冲模块 1” ;在第 2 个缓冲周期,通过 “ 输入数据选择单元 ” 的切换,将输入的数据流缓存到 “ 数据缓冲模块 2” ,同时将 “ 数据缓冲模块 1” 缓存的第 1 个周期数据通过 “ 输入数据选择单元 ” 的选择,送到 “ 数据流运算处理模块 ” 进行运算处理;在第 3 个缓冲周期通过 “ 输入数据选择单元 ” 的再次切换,将输入的数据流缓存到 “ 数据缓冲模块 1” ,同时将 “ 数据缓冲模块 2” 缓存的第 2 个周期的数据通过 “ 输入数据选择单元 ” 切换,送到 “ 数据流运算处理模块 ” 进行运算处理。如此循环。

典型的乒乓操作方法

乒乓操作的最大特点是,通过输入数据选择单元和输出数据选择单元、进行运算和处理。把乒乓操作模块当成一个整体,站在两端看数据,输入数据和输出数据流都是连续不断的,没有任何停顿,因此非常适合对数据流进行流水线式处理。所以乒乓操作常常应用于流水线式算法,完成数据的无缝缓冲和处理。

乒乓操作的第二个优点是可以节约缓冲区空间。比如在 WCDMA 基带应用中,1 帧是由 15 个时隙组成的,有时需要将 1 整帧的数据延时一个时隙后处理,比较直接的方法就是将这帧数据缓存起来,然后延时一个时隙,进行处理。这时缓冲区的长度为 1 帧的数据长,假设数据速率是 3.84Mb/s,1 帧 10ms,此时需要缓冲区的长度是 38400bit,如果采用乒乓操作,只需定义两个缓冲 1 时隙的数据 RAM,当向一个 RAM 写数据时,从另一块 RAM 读数据,然后送到处理单元处理,此时每块 RAM 的容量仅需 2560bit,2 块加起来 5120bit 的容量。

乒乓操作用低速模块处理高速数据流

另外,巧妙运用乒乓操作还可以达到用低速模块处理高速数据流的效果。数据缓冲模块采用了双口 RAM ,并在 DPRAM 后引入了一级数据预处理模块,这个数据预处理可以根据需要的各种数据运算,比如在 WCDMA 设计中,对输入数据流的解扩、解扰、去旋转等。假设端口 A 的输入数据流的速率为 100Mbps ,乒乓操作的缓冲周期是 10ms 。

6. 串并转换设计技巧

串并转换是 FPGA 设计的一个重要技巧,它是数据流处理的常用手段,也是面积与速度互换思想的直接体现。串并转换的实现方法多种多样,根据数据的排序和数量的要求,可以选用寄存器、 RAM 等实现。

前面在乒乓操作中就是通过 DPRAM 实现了数据流的串并转换,而且由于使用了 DPRAM ,数据的缓冲区可以开得很大,对于数量比较小的设计可以采用寄存器完成串并转换。如无特殊需求,应该用同步时序设计完成串并之间的转换。比如数据从串行到并行,数据排列顺序是高位在前,可以用下面的编码实现:prl_temp<={prl_temp,srl_in}。

其中, prl_temp 是并行输出缓存寄存器, srl_in 是串行数据输入。对于排列顺序有规定的串并转换,可以用 case 语句判断实现。对于复杂的串并转换,还可以用状态机实现。串并转换的方法比较简单,在此不必赘述。

7.流水线操作设计思想

首先需要声明的是,这里所讲述的流水线是指一种处理流程和顺序操作的设计思想,并非 FPGA 、 ASIC 设计中优化时序所用的 “Pipelining” 。

流水线处理是高速设计中的一个常用设计手段。如果某个设计的处理流程分为若干步骤,而且整个数据处理是 “ 单流向 ” 的,即没有反馈或者迭代运算,前一个步骤的输出是下一个步骤的输入,则可以考虑采用流水线设计方法来提高系统的工作频率。

流水线设计的结构

流水线设计的基本结构为:将适当划分的 n 个操作步骤单流向串联起来。流水线操作的最大特点和要求是,数据流在各个步骤的处理从时间上看是连续的,如果将每个操作步骤简化假设为通过一个 D 触发器 ( 就是用寄存器打一个节拍 ) ,那么流水线操作就类似一个移位寄存器组,数据流依次流经 D 触发器,完成每个步骤的操作。

流水线设计时序

流水线设计的一个关键在于整个设计时序的合理安排,要求每个操作步骤的划分合理。如果前级操作时间恰好等于后级的操作时间,设计最为简单,前级的输出直接汇入后级的输入即可;如果前级操作时间大于后级的操作时间,则需要对前级的输出数据适当缓存才能汇入到后级输入端;如果前级操作时间恰好小于后级的操作时间,则必须通过复制逻辑,将数据流分流,或者在前级对数据采用存储、后处理方式,否则会造成后级数据溢出。

在 WCDMA 设计中经常使用到流水线处理的方法,如 RAKE 接收机、搜索器、前导捕获等。流水线处理方式之所以频率较高,是因为复制了处理模块,它是面积换取速度思想的又一种具体体现。

8. 数据接口的同步方法

数据接口的同步是 FPGA/CPLD 设计的一个常见问题,也是一个重点和难点,很多设计不稳定都是源于数据接口的同步有问题。在电路图设计阶段,一些工程师手工加入 BUFT 或者非门调整数据延迟,从而保证本级模块的时钟对上级模块数据的建立、保持时间要求。

还有一些工程师为了有稳定的采样,生成了很多相差 90 度的时钟信号,时而用正沿打一下数据,时而用负沿打一下数据,用以调整数据的采样位置。这两种做法都十分不可取,因为一旦芯片更新换代或者移植到其它芯片 组的芯片上,采样实现必须重新设计。而且,这两种做法造成电路实现的余量不够,一旦外界条件变换 ( 比如温度升高 ) ,采样时序就有可能完全紊乱,造成电路瘫痪。

输入、输出的延时 ( 芯片间、 PCB 布线、一些驱动接口元件的延时等 ) 不可测,或者有可能变动的条件下,如何完成数据同步?对于数据的延迟不可测或变动,就需要建立同步机制,可以用一个同步使能或同步指示信号。另外,使数据通过 RAM 或者 FIFO 的存取,也可以达到数据同步目的。

设计数据接口同步是否需要添加约束?建议最好添加适当的约束,特别是对于高速设计,一定要对周期、建立、保持时间等添加相应的约束。这里附加约束的作用有两点:提高设计的工作频率,满足接口数据同步要求;获得正确的时序分析报告。

审核编辑 黄昊宇

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

    关注

    1629

    文章

    21736

    浏览量

    603353
收藏 人收藏

    评论

    相关推荐

    不需要点表的边缘网关对网方案:实现设备远程监控与维护,PLC程序的便捷异地下载与更新,以及数据的实

    您是否正在为设备异地运维而烦恼?是否希望实现PLC程序的异地快速下载与更新?是否渴望实现异地数据的高效共享与同步?或是正在寻找稳定可靠的异地组网方案? 我们的不需要点表的边缘网关对网方案,正是为
    的头像 发表于 12-03 10:20 146次阅读
    不需<b class='flag-5'>要点</b>表的边缘网关<b class='flag-5'>点</b>对网方案:实现设备远程监控与维护,PLC程序的便捷异地下载与更新,以及数据的实

    4G模组PWM接口:威廉希尔官方网站 实操要点

    今天我们讲解的是4G模组PWM接口的威廉希尔官方网站 实操要点,以我常用的模组Air724UG为例分享出来。
    的头像 发表于 11-20 23:29 262次阅读
    4G模组PWM接口:<b class='flag-5'>威廉希尔官方网站
</b>实操<b class='flag-5'>要点</b>

    基于深控威廉希尔官方网站 “不需要点表的边缘计算网关” 的物联网解决方案

    深控威廉希尔官方网站 研发的 “不需要点表的边缘计算网关” 物联网解决方案凭借其无需表配置、强大的边缘计算能力、高度安全可靠以及广泛的设备兼容性等优势,能够在多个行业的物联网应用场景中发挥重要作用,帮助企业高效实现物联网项目的部署与运营,提
    的头像 发表于 11-15 11:51 264次阅读
    基于深控<b class='flag-5'>威廉希尔官方网站
</b> “不需<b class='flag-5'>要点</b>表的边缘计算网关” 的物联网解决方案

    深控威廉希尔官方网站 “不需要点表的工业网关” 在机械加工中的解决方案及实施案例

    设备之间的数据采集、传输与协同工作变得愈发重要。深控威廉希尔官方网站 研发的 “不需要点表的工业网关” 为机械加工企业提供了一种创新的解决方案,有效解决了传统工业网关在使用过程中面临的诸多痛,极大地提升了生产效率和管理效能。
    的头像 发表于 11-07 10:25 203次阅读
    深控<b class='flag-5'>威廉希尔官方网站
</b> “不需<b class='flag-5'>要点</b>表的工业网关” 在机械加工中的解决方案及实施案例

    iLight混合光源 激光与LED威廉希尔官方网站 的结合

    51camera机器视觉产品资料查询平台的光源种类比较丰富,今天我们一起来看看其合作厂商iCore的明星产品iLight混合光源,该产品提供了比LED更高的亮度,作为传统LED和氙气灯的替代品
    的头像 发表于 08-10 08:35 723次阅读
    iLight混合<b class='flag-5'>点</b>光源  激光与LED<b class='flag-5'>威廉希尔官方网站
</b>的结合

    LED显示屏各大组成部件及安装要点

    LED显示屏主要的组成部件是:单元板、电源、控制卡、连线单元板背面、单元板正面、开关电源和LED条屏控制卡。下面我们分别来看看各个组成部分及其安装要点:1... LED显示屏主要的组成部件是:单元板
    的头像 发表于 07-29 09:33 542次阅读

    大咖解析:LED显示屏各大组成部件及安装要点

    LED显示屏主要的组成部件是:单元板、电源、控制卡、连线单元板背面、单元板正面、开关电源和LED条屏控制卡。下面我们分别来看看各个组成部分及其安装要点:1... LED显示屏主要的组成部件是:单元板
    的头像 发表于 07-19 08:38 1021次阅读

    基于FPGA的CCD工业相机系统设计

    基于FPGA的CCD工业相机系统设计是一个综合性的项目,它结合了硬件电路设计、FPGA编程以及图像处理威廉希尔官方网站 。以下是一个详细的系统设计方案,包括设计概述、硬件架构、FPGA编程
    的头像 发表于 07-17 11:24 1189次阅读

    FPGA的学习笔记---FPGA的开发流程

    与通常的单片机应用开发不同,FPGA有自己的开发流程。但具体上怎样操作,作为初学者,没有一经验。网站奖励的清华FPGA需要的开发软件,到目前还没有安装成功。暂且先看看相关学习,慢慢积
    发表于 06-23 14:47

    M8连接器5芯关键要点与注意事项有哪些

      德索工程师说道M8连接器5芯,作为一种广泛应用于工业自动化、通信、汽车等领域的电气连接器,其性能的稳定性和可靠性对于整个系统的运行至关重要。以下将详细探讨M8连接器5芯的关键要点与注意事项,以确保其在实际应用中的高效、安全运
    的头像 发表于 04-30 17:29 723次阅读
    M<b class='flag-5'>8</b>连接器5芯关键<b class='flag-5'>要点</b>与注意事项有哪些

    TSMaster 2024.04 最新版已上线,来看看新增了哪些实用功能

    ,其中期待已久的DoIP诊断功能终于在最新升级版本里可以实现!同时对仿真模块、API接口、工具箱模块等进行了更新。一起来看看吧!软件更新方式1.直接在已有的软件中点击
    的头像 发表于 04-29 08:21 1765次阅读
    TSMaster 2024.04 最新版已上线,<b class='flag-5'>来看看</b>新增了哪些实用功能

    fpga封装威廉希尔官方网站 有哪些应用领域

    总的来说,FPGA封装威廉希尔官方网站 凭借其高性能、灵活性和可靠性,在多个领域发挥着重要作用。随着威廉希尔官方网站 的不断进步和应用需求的增长,FPGA封装威廉希尔官方网站 的应用
    的头像 发表于 03-26 15:49 605次阅读

    科普 | 一文了解FPGA威廉希尔官方网站 知识

    架构 FPGA 硬件三大指标:制程、门级数及 SERDES 速率,配套 EDA 软件工具同样重要。比较 FPGA 产品可以从威廉希尔官方网站 指标入手。从 FPGA 内部结构
    发表于 03-08 14:57

    【2023电子工程师大会】国产FPGA威廉希尔官方网站 及国内FPGA发展pp

    【2023电子工程师大会】国产FPGA威廉希尔官方网站 及国内FPGA发展ppt
    发表于 01-03 16:31 28次下载

    值得多看的FPGA 学习路线

    这个语言做验证 。 FPGA入门学习第二部分:基础知识 说完了编程语言,我们再来看看入门FPGA的第二部分内容:基础知识。这里主要有专业基础课和FPGA相关的专业知识两部分。 专业基础
    发表于 01-02 23:03