选择特殊符号

选择搜索类型

热门搜索

首页 > 百科 > 建设工程百科

FPGA/CPLD应用设计200例

《FPGA/CPLD应用设计200例》分上、下两册。上册主要介绍FPGA/CPLD可编程控制器在网络通信、仪器仪表、工业控制、遥感遥测、汽车工业、航天军工及家用电器等领域的典型应用设计实例;下册主要介绍产品设计开发技巧、方法与秘诀,常用设计、开发工具及软件特性,常用芯片的结构特点等内容。《FPGA/CPLD应用设计200例》共计典型应用设计实例287个。

FPGA/CPLD应用设计200例基本信息

FPGA/CPLD应用设计200例编辑推荐

《FPGA/CPLD应用设计200例》是应广大科学研究人员、工程技术人员的迫切需求,参照国内外1000余项FPGA/CPLD应用设计成果,从实用角度出发编写的。是一本具有实用性、启发性、信息性的综合工具书。《FPGA/CPLD应用设计200例》共计典型应用设计实例287个,可供科学研究人员、工程技术人员、维护修理人员及大专院校师生在解决现代科研和生产中的许多实际问题时参考、借鉴。

查看详情

FPGA/CPLD应用设计200例造价信息

  • 市场价
  • 信息价
  • 询价

总控应用服务器

  • DELLi7-97008G512GSSD+2T机械盘6G独显
  • 大峡谷
  • 13%
  • 大峡谷照明系统(苏州)股份有限公司
  • 2022-12-06
查看价格

龙骨

  • 天地B
  • 千年舟
  • 13%
  • 成都市大周方圆商贸有限公司
  • 2022-12-06
查看价格

球阀

  • 规格型号:15;成本类别:临建临电临水类;
  • 轩尔
  • 13%
  • 呼和浩特市轩尔商贸有限公司
  • 2022-12-06
查看价格

总控应用服务器

  • DELL i7-9700 8G 512GSSD+2T机械盘 6G独显
  • 江苏明朗
  • 13%
  • 江苏明朗照明科技有限公司
  • 2022-12-06
查看价格

总控应用服务器

  • DELL i7-9700 8G 512GSSD+2T机械盘 6G独显
  • 佛山银河照明
  • 13%
  • 佛山市银河兰晶科技股份有限公司
  • 2022-12-06
查看价格

火灾报警控制器集成应用编程接口

  • GST-OOM
  • 茂名市2009年9月信息价
  • 建筑工程
查看价格

火灾报警控制器集成应用编程接口

  • GST-API
  • 茂名市2009年8月信息价
  • 建筑工程
查看价格

火灾报警控制器集成应用编程接口

  • GST-API
  • 茂名市2009年5月信息价
  • 建筑工程
查看价格

火灾报警控制器集成应用编程接口

  • GST-API
  • 茂名市2009年4月信息价
  • 建筑工程
查看价格

火灾报警控制器集成应用编程接口

  • GST-OOM
  • 茂名市2009年3月信息价
  • 建筑工程
查看价格

单头汤炉

  • 700×800×800
  • 1.0台
  • 1
  • 中档
  • 不含税费 | 不含运费
  • 2016-08-22
查看价格

雕塑设计

  • 雕塑设计
  • 14.4m²
  • 3
  • 中高档
  • 不含税费 | 含运费
  • 2021-09-28
查看价格

UI设计

  • 品牌:GNG;型号:定制开发界面设计、交互设计
  • 1套
  • 1
  • 中档
  • 不含税费 | 不含运费
  • 2019-10-08
查看价格

UI设计

  • 品牌:GNG;型号:定制开发界面设计、交互设计
  • 1套
  • 1
  • GNG
  • 中高档
  • 不含税费 | 含运费
  • 2019-09-30
查看价格

视频应用软件

  • 视频应用软件
  • 1套
  • 1
  • 中档
  • 含税费 | 不含运费
  • 2016-11-09
查看价格

FPGA/CPLD应用设计200例目录

上册

第1篇FPGA/CPLD典型应用设计实例

1.1FFT(快速傅里叶变换)的FPGA设计与实现

1.2数字式存储示波器

1.3汽车尾灯控制电路设计

1.4数字钟电路设计

1.5数字调制(FSK)信号发生器

1.6电子数字闹钟

1.7函数发生器设计

1.8伪随机序列发生器

1.9多功能点阵牌电路设计

1.10光通信PDH的标准伪随机图案发生器设计

1.11数字秒表

1.12电子密码锁

1.13数字电压表

1.14自动交通控制系统

1.15交通信号灯控制器

1.16交通控制灯逻辑电路系统设计

1.17十字路口交通管理信号灯系统设计

1.18交通灯控制程序设计

1.19交通灯电路设计

1.20无线通信中的全数字调制器设计

1.21无线通信中的全数字解调器设计

1.22采用VHDL语言设计的数字频率计

1.23数字显示频率计

1.24简易数字频率计设计

1.254位数字频率计

1.26采用VerilogHDL语言设计的频率计

1.27简易频率计电路设计

1.28简易频率计设计

1.29电子数字钟

1.30采用VerilogHDL语言设计的电子数字钟

1.31采用VHDL语言设计的电子数字钟

1.32电子时钟电路设计

1.33计时器

1.34波形发生器电路设计

1.35LED数码管动态显示设计

1.36流水灯电路设计

1.37直流步进电机控制电路设计

1.38ADC电压测量电路设计

1.39简易电子钟设计

1.40数字抢答器

1.41序列检测器

1.42UART通用异步串行口设计

1.43简易周期信号测试仪

1.44序列信号发生器

1.45通信、雷达和遥测用序列检测器的设计

1.46数字密码锁

1.47伪随机序列信号发生器设计

1.48FIFO存储器的VHDL描述

1.49采用VerilogHDL语言设计的UART通用异步收发器.

1.50倍频电路

1.51双向数据转换器

1.52键盘电路

1.53数码LED显示器

1.54多位加法器电路

1.556位数码管动态扫描及译码电路

1.56非2的幂次分频电路

1.57非整数分频电路

1.58常用电路的VHDL描述

1.59同步一百进制计数器的设计

1.60门电路设计

1.61时序电路设计

1.62组合逻辑电路设计

1.63频率合成技术--基于FPGA的直接数字合成器(DDS)设计

1.64串行通信MAX232接口电路设计

1.652的幂次分频电路

1.66环形计数器与扭环形计数器

1.678位可逆计数器和三角波发生器

1.68并/串转换器

1.694选1数据选择器

1.704位二进制数/8421BCD码

1.71移位寄存器设计

1.72三进制计数器设计

1.73移位型控制器的设计与实现

1.74存储器接口电路设计

1.754位加法器设计

1.76乘法器设计

1.77译码器设计

1.78可变模计数器设计

1.79整数增益放大器设计与测试

1.80滤波器的设计与测试

1.81比较器的设计与测试

1.82带阻有源滤波器设计

1.83线性反馈移位寄存器LFSR的FPGA设计与实现

1.84线性分析、循环码编码译码器的FPGA设计与实现

1.85数据传输与I/O接口标准

1.86异步收发器

1.87有限脉冲响应(FIR)数字滤波器的FPGA设计与实现

1.88逐次逼近型ADC

1.89乘法器的FPGA设计与实现

1.90总线仲裁电路的设计

1.91ALU(算术逻辑部件)设计

1.92脉冲分配器设计

1.93二进制码/格雷码的转换

1.94直接序列扩频通信系统设计

1.95并/串转换模块设计

1.96移位相加模块设计

1.97时延环节模块设计

1.98多波形发生器设计

1.99三位乘法器设计

1.100小信号测量系统

1.101单片电路设计

1.102简易数字锁

1.103交通灯控制器

1.104闪烁灯和流水灯设计与仿真

1.1053DES算法的FPGA实现及其在3DES-PCI安全卡中的应用

1.106边界扫描测试

1.107交通信号灯

1.108交通灯监视电路设计

1.109汉字显示

1.110汉字显示电路设计

1.111洗衣机控制电路设计

1.112篮球30s可控计时器设计

1.113悦耳的音响设计

1.114乐曲演奏电路设计

1.115多音阶电子琴电路设计

1.116《友谊地久天长》乐曲演奏电路设计

1.117软件无线电内插滤波器设计

1.118量程自动转换的数字式频率计

1.119游戏电路设计

1.120全自动电梯控制电路

1.1218位二进制乘法电路

1.122自动售邮票机

参考文献

下册

第2篇FPGA/CPLD产品设计、开发技巧与秘诀

2.1如何根据项目选择器件

2.2可编程器件的选择原则

2.3确定初步方案的方法与技巧

2.4基于可编程逻辑器件的数字系统的设计流程

2.5掌握常用FPGA/CPLD

2.6EDA技术的基本设计方法

2.7数字系统设计中的低功耗设计方法

2.8动态可编程重构技术

2.9多级逻辑的设计技巧

2.10VerilogHDL设计方法与技巧

2.11FPGA设计的稳定性探讨

2.12同步电路设计技巧

2.13图形设计法的实用技术

2.14状态机设计技巧

2.15存储器的VHDL实现方法与技巧

2.16存储器设计典型实例

2.17只读存储器

2.18比较器

2.19多路选择器

2.20三态总线

2.21m序列的产生和性质

2.22对具体某一信号的连续存储

2.23典型的时序逻辑电路分析与描述

2.24用VerilogHDL的时序逻辑电路设计

2.25时序逻辑电路的设计方法与技巧

2.26FPGA/CPLD的设计和优化

2.27CPLD典型器件ispPAC20的扩展应用技巧

2.28CPLD典型器件ispPAC的基本应用技巧

2.29VerilogHDL设计组合逻辑电路技巧

2.30VHDL设计组合逻辑电路技巧

2.31LED七段译码器的分析与设计

2.32电路的仿真技巧

2.33宏器件及其调用

2.34ispPAC的增益调整方法

2.35数字系统的描述方法

2.36FPGA系统设计与调试技巧

2.37典型的下载/配置方式

2.38Xilinx器件的下载

2.39ByteBlaster并口下载电缆

2.40单个FLEX系列器件的PS配置(下载电缆连接与下载操作)

2.41多个FLEX器件的PS配置(下载电路连接与下载操作)

2.42单个MAX器件的JTAG方式编程(POF文件连接与编程)

2.43单个FLEX器件的JTAG方式配置(SOF文件连接与编程)

2.44多个MAX/FLEX器件的JTAG方式编程/配置(连接与编程)

2.45主动串行与被动串行配置模式

2.46门禁系统设计技巧

2.47两种实际应用的计数器电路设计

2.48常用触发器及其应用设计技巧

2.49加法器设计

2.50ispPAC的接口电路设计

2.51编程接口和编程--ISP方式和JTAG方式

2.52利用VerilogHDL设计状态机的技巧

2.53系统级层次式设计

2.54边界扫描测试技术

2.55在系统下载电缆与评估板

2.56用CPLD和单片机设计电子系统

2.57怎样优化程序

2.58怎样才能避免潜在的危险

2.59毛刺的产生及其消除技巧

2.60计数器设计与FPGA资源

2.61组合逻辑电路的竞争冒险及其消除技巧

2.62选择器设计和FPGA资源

2.63基于FPGA/CPLD应用设计的23点经验总结

第3篇FPGA/CPLD常用工具及软件特性

3.1常用的FPGA开发工具

3.2常用EDA设计工具

3.3FPGA/CPLD数字逻辑实验平台

3.4软件资源

3.5典型常用的VerilogHDL语言(应用设计举例)

3.6VerilogHDL的一般结构

3.719种常用电路的VerilogHDL描述

3.8典型常用的VHDL语言(应用设计举例)

3.910种常用电路的VHDL描述.

第4篇FPGA/CPLD常用芯片结构及特点

4.1FPGA和CPLD的结构性能对照

4.2FPGA/CPLD的基本结构和原理

4.3Xilinx系列CPLD

4.4Altera系列CPLD

4.5现场可编程系统芯片FPSC

4.6无限可重构可编程门阵列ispXPGA

4.7ispXPLD器件

4.8在系统可编程通用数字开关ispGDS和互连器件ispGDX/V

4.9在系统可编程模拟器件的原理

4.10各种在系统可编程模拟器件的结构

4.11ispLSI系列器件的性能参数

4.12ispLSI系列器件的主要技术特性

4.13ispLSI系列器件的编程方法

4.14成熟器件与新型器件

4.15FPGA/CPLD器件的编程

附录l现场可编程逻辑器件主流产品一览

附录2各种器件的下载电路(在系统可编程ispJTAGTM芯片设计指导)

附录3Lattice系统宏(器件库)

附录4国内外常用二进制逻辑元件图形符号对照表

附录5世界著名的FPGA厂商及商标符号

附录6实验开发板电路原理图

附录7常用FPGA的端口资源

附录8两种CPLD实验仪器面板图及电路图

附录9CPLD主要器件引脚图

附录10缩略语词汇表

参考文献

……

查看详情

FPGA/CPLD应用设计200例版权信息

书名:FPGA/CPLD应用设计200例

ISBN:9787811243154

开本:16

定价:72.00 元

查看详情

FPGA/CPLD应用设计200例常见问题

查看详情

FPGA/CPLD应用设计200例文献

基于CPLD_FPGA器件参数化开方电路的设计及应用 基于CPLD_FPGA器件参数化开方电路的设计及应用

基于CPLD_FPGA器件参数化开方电路的设计及应用

格式:pdf

大小:382KB

页数: 4页

Ξ 基于 CPLD/ FPGA 器件参数化开方电路的设计及应用 魏佩敏  赵伟强 (绍兴文理学院  工学院 ,浙江  绍兴 312000) 摘  要 :讨论二进制开方运算的过程以及利用 CPLD/ FPGA 进行开方运算硬件电路的设计思想和实现方案 . 关键词 :二进制码 ;开方 ;CPLD/ FPGA ;H DL 语言 中图分类号 :TN702   文献标识码 :A    文章编号 :1008 - 293X (2005) 10 - 0058 - 04                      目前在模拟信号数字化处理过程中 ,数字可编程器件以其性能稳定 、处理速度快而得到广泛应用 ,特 别是 EDA 软件及在线可编程技术的使用 ,使设计的灵活性和设计速度大幅度提高 .在 CPLD/ FPGA 的开发 应用中 ,大多数 EDA 软件都提供加法 、减法 、乘法的设计向导 ,或提供 LPM宏函

应用CPLD的数字光端机的设计与实现 应用CPLD的数字光端机的设计与实现

应用CPLD的数字光端机的设计与实现

格式:pdf

大小:382KB

页数: 3页

针对模拟光端机传输质量低、信号易受环境干扰而失真、系统性能不稳定和电路设计复杂等缺点,采用CPLD对四路数字光端机进行设计。考虑到四路采样频率在满足以上要求的同时,还要通过一路光纤传输四路采样数据的情况,提出了并串转换频率为采样频率四倍的策略,实现了分时复用光纤通道。通过实验和时序仿真,验证了该系统的正确性和可行性。该系统结构简单、成本低、性能稳定,是未来数字光端机行业发展的方向。

FPGA/CPLD设计工作中常用四大技巧

导读: 本文讨论的四种常用FPGA/CPLD设计思想与技巧:乒乓操作、串并转换、流水线操作、数据接口同步化,都是FPGA/CPLD逻辑设计的内在规律的体现,合理地采用这些设计思想能在FPGA/CPLD设计工作中取得事半功倍的效果。

FPGA(Field-Programmable Gate Array),即现场可编程门阵列,它是在PAL、GAL、CPLD等可编程器件的基础上进一步发展的产物。它是作为专用集成电路(ASIC)领域中的一种半定制电路而出现的,既解决了定制电路的不足,又克服了原有可编程器件门电路数有限的缺点。

FPGA/CPLD的设计思想与技巧是一个非常大的话题,由于篇幅所限,本文仅介绍一些常用的设计思想与技巧,希望本文能引起工程师们的注意,如果能有意识地利用这些原则指导日后的设计工作,将取得事半功倍的效果!

1、乒乓操作

“乒乓操作”是一个常常应用于数据流控制的处理技巧,典型的乒乓操作方法如图1所示。

乒乓操作的处理流程为:输入数据流通过“输入数据选择单元”将数据流等时分配到两个数据缓冲区,数据缓冲模块可以为任何存储模块,比较常用的存储单元为双口RAM(DPRAM)、单口RAM(SPRAM)、FIFO等。在第一个缓冲周期,将输入的数据流缓存到“数据缓冲模块1”;在第2个缓冲周期,通过“输入数据选择单元”的切换,将输入的数据流缓存到“数据缓冲模块2”,同时将“数据缓冲模块1”缓存的第1个周期数据通过“输入数据选择单元”的选择,送到“数据流运算处理模块”进行运算处理;在第3个缓冲周期通过“输入数据选择单元”的再次切换,将输入的数据流缓存到“数据缓冲模块1”,同时将“数据缓冲模块2”缓存的第2个周期的数据通过“输入数据选择单元”切换,送到“数据流运算处理模块”进行运算处理。如此循环。

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

乒乓操作的第二个优点是可以节约缓冲区空间。比如在WCDMA基带应用中,1个帧是由15个时隙组成的,有时需要将1整帧的数据延时一个时隙后处理,比较直接的办法是将这帧数据缓存起来,然后延时1个时隙进行处理。这时缓冲区的长度是1整帧数据长,假设数据速率是3.84Mbps,1帧长10ms,则此时需要缓冲区长度是38400位。如果采用乒乓操作,只需定义两个能缓冲1个时隙数据的RAM(单口RAM即可)。

当向一块RAM写数据的时候,从另一块RAM读数据,然后送到处理单元处理,此时每块RAM的容量仅需2560位即可,2块RAM加起来也只有5120位的容量。

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

A端口处输入数据流速率为100Mbps,在第1个缓冲周期10ms内,通过“输入数据选择单元”,从B1到达DPRAM1。B1的数据速率也是100Mbps,DPRAM1要在10ms内写入1Mb数据。同理,在第2个10ms,数据流被切换到DPRAM2,端口B2的数据速率也是100Mbps,DPRAM2在第2个10ms被写入1Mb数据。在第3个10ms,数据流又切换到DPRAM1,DPRAM1被写入1Mb数据。

仔细分析就会发现到第3个缓冲周期时,留给DPRAM1读取数据并送到“数据预处理模块1”的时间一共是20ms。有的工程师困惑于DPRAM1的读数时间为什么是20ms,这个时间是这样得来的:首先,在在第2个缓冲周期向DPRAM2写数据的10ms内,DPRAM1可以进行读操作;

在第1个缓冲周期的第5ms起(绝对时间为5ms时刻),DPRAM1就可以一边向500K以后的地址写数据,一边从地址0读数,到达10ms时,DPRAM1刚好写完了1Mb数据,并且读了500K数据,这个缓冲时间内DPRAM1读了5ms;在第3个缓冲周期的第5ms起(绝对时间为35ms时刻),同理可以一边向500K以后的地址写数据一边从地址0读数,又读取了5个ms,所以截止DPRAM1第一个周期存入的数据被完全覆盖以前,DPRAM1最多可以读取20ms时间,而所需读取的数据为1Mb,所以端口C1的数据速率为:1Mb/20ms=50Mbps。因此,“数据预处理模块1”的最低数据吞吐能力也仅仅要求为50Mbps。同理,“数据预处理模块2”的最低数据吞吐能力也仅仅要求为50Mbps。换言之,通过乒乓操作,“数据预处理模块”的时序压力减轻了,所要求的数据处理速率仅仅为输入数据速率的1/2。

通过乒乓操作实现低速模块处理高速数据的实质是:通过DPRAM这种缓存单元实现了数据流的串并转换,并行用“数据预处理模块1”和“数据预处理模块2”处理分流的数据,是面积与速度互换原则的体现!

2、串并转换设计技巧

串并转换是FPGA设计的一个重要技巧,它是数据流处理的常用手段,也是面积与速度互换思想的直接体现。

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

prl_temp《={prl_temp,srl_in};

其中,prl_temp是并行输出缓存寄存器,srl_in是串行数据输入。

对于排列顺序有规定的串并转换,可以用case语句判断实现。对于复杂的串并转换,还可以用状态机实现。串并转换的方法比较简单,在此不必赘述。

3、流水线操作设计思想

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

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

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

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

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

4、数据接口的同步方法

数据接口的同步是FPGA/CPLD设计的一个常见问题,也是一个重点和难点,很多设计不稳定都是源于数据接口的同步有问题。

在电路图设计阶段,一些工程师手工加入BUFT或者非门调整数据延迟,从而保证本级模块的时钟对上级模块数据的建立、保持时间要求。还有一些工程师为了有稳定的采样,生成了很多相差90度的时钟信号,时而用正沿打一下数据,时而用负沿打一下数据,用以调整数据的采样位置。这两种做法都十分不可取,因为一旦芯片更新换代或者移植到其它芯片组的芯片上,采样实现必须从新设计。而且,这两种做法造成电路实现的余量不够,一旦外界条件变换(比如温度升高),采样时序就有可能完全紊乱,造成电路瘫痪。

下面简单介绍几种不同情况下数据接口的同步方法:

1. 输入、输出的延时(芯片间、PCB布线、一些驱动接口元件的延时等)不可测,或者有可能变动的条件下,如何完成数据同步?

对于数据的延迟不可测或变动,就需要建立同步机制,可以用一个同步使能或同步指示信号。另外,使数据通过RAM或者FIFO的存取,也可以达到数据同步目的。

把数据存放在RAM或FIFO的方法如下:将上级芯片提供的数据随路时钟作为写信号,将数据写入RAM或者FIFO,然后使用本级的采样时钟(一般是数据处理的主时钟)将数据读出来即可。这种做法的关键是数据写入RAM或者FIFO要可靠,如果使用同步RAM或者FIFO,就要求应该有一个与数据相对延迟关系固定的随路指示信号,这个信号可以是数据的有效指示,也可以是上级模块将数据打出来的时钟。对于慢速数据,也可以采样异步RAM或者FIFO,但是不推荐这种做法。

数据是有固定格式安排的,很多重要信息在数据的起始位置,这种情况在通信系统中非常普遍。通讯系统中,很多数据是按照“帧”组织的。而由于整个系统对时钟要求很高,常常专门设计一块时钟板完成高精度时钟的产生与驱动。而数据又是有起始位置的,如何完成数据的同步,并发现数据的“头”呢?

数据的同步方法完全可以采用上面的方法,采用同步指示信号,或者使用RAM、FIFO缓存一下。

找到数据头的方法有两种,第一种很简单,随路传输一个数据起始位置的指示信号即可,对于有些系统,特别是异步系统,则常常在数据中插入一段同步码(比如训练序列),接收端通过状态机检测到同步码后就能发现数据的“头”了,这种做法叫做“盲检测”。

上级数据和本级时钟是异步的,也就是说上级芯片或模块和本级芯片或模块的时钟是异步时钟域的。

前面在输入数据同步化中已经简单介绍了一个原则:如果输入数据的节拍和本级芯片的处理时钟同频,可以直接用本级芯片的主时钟对输入数据寄存器采样,完成输入数据的同步化;如果输入数据和本级芯片的处理时钟是异步的,特别是频率不匹配的时候,则只有用处理时钟对输入数据做两次寄存器采样,才能完成输入数据的同步化。需要说明的是,用寄存器对异步时钟域的数据进行两次采样,其作用是有效防止亚稳态(数据状态不稳定)的传播,使后级电路处理的数据都是有效电平。但是这种做法并不能保证两级寄存器采样后的数据是正确的电平,这种方式处理一般都会产生一定数量的错误电平数据。所以仅仅适用于对少量错误不敏感的功能单元。

为了避免异步时钟域产生错误的采样电平,一般使用RAM、FIFO缓存的方法完成异步时钟域的数据转换。最常用的缓存单元是DPRAM,在输入端口使用上级时钟写数据,在输出端口使用本级时钟读数据,这样就非常方便的完成了异步时钟域之间的数据交换。

2. 设计数据接口同步是否需要添加约束?

建议最好添加适当的约束,特别是对于高速设计,一定要对周期、建立、保持时间等添加相应的约束。

这里附加约束的作用有两点:

a. 提高设计的工作频率,满足接口数据同步要求。通过附加周期、建立时间、保持时间等约束可以控制逻辑的综合、映射、布局和布线,以减小逻辑和布线延时,从而提高工作频率,满足接口数据同步要求。

b. 获得正确的时序分析报告。几乎所有的FPGA设计平台都包含静态时序分析工具,利用这类工具可以获得映射或布局布线后的时序分析报告,从而对设计的性能做出评估。静态时序分析工具以约束作为判断时序是否满足设计要求的标准,因此要求设计者正确输入约束,以便静态时序分析工具输出正确的时序分析报告。

Xilinx和数据接口相关的常用约束有Period、OFFSET_IN_BEFORE、OFFSET_IN_AFTER、OFFSET_OUT_BEFORE和OFFSET_OUT_AFTER等;Altera与数据接口相关的常用约束有Period、tsu、tH、tco等。

查看详情

下载 | 《CPLD/FPGA的开发与应用》

内容简介

CPLD/FPGA是目前应用最为广泛的两种可编程专用集成电路(ASIC),特别适合于产品的样品开发与小批量生产。本书从现代电子系统设计的角度出发,以全球著名的可编程逻辑器件供应商Xilinx公司的产品为背景,系统全面地介绍该公司的CPLD/FPGA产品的结构原理、性能特点、设计方法以及相应的EDA工具软件,重点介绍CPLD/FPGA在数字系统设计、数字通信与数字信号处理等领域中的应用。本书内容新颖

目录

第1章 可编程ASIC与EDA技术

第2章 Xilinx CPLD系列器件

第3章 Xilinx FPGA系列器件

第4章 CPLD/FPGA的边界扫描测试

第5章 Xilinx Foundation应用基础

第6章 Foundation高级应用

第7章 VHDL语言简介

第8章 CPLD/FPGA在数字系统设计中的应用

第9章 CPLD/FPGA在通信领域的应用

第10章 CPLD/FPGA在DSP领域的应用

第11章 CPLD/FPGA在微机系统领域的应用

附录 GW48型EDA实验开发系统使用介绍

参考文献

下载链接:

查看详情

CPLD/FPGA常用模块与综合系统设计实例精讲内容提要

本书配有光盘一张,包含了全书所有实例的硬件原理图和程序源代码,方便读者学习和使用。本书适合计算机、自动化、电子及硬件等相关专业的学生,以及从事CPLD/FPGA开发的科研人员使用。

查看详情

相关推荐

立即注册
免费服务热线: 400-888-9639