今天看了篇博客,

是拿altera的芯片和软件作例子的,讲同步异步复位的:

http://blog.sina.com.cn/s/blog_bff0927b0101aaii.html

还有一个博客,

http://bbs.ednchina.com/BLOG_ARTICLE_201656_2.HTM

想起<设计与验证>这本书也讲过,

顺便说一下,这是一本非常好的书!

拿 ISE实验了一下,器件选了ZC702,发现看到的RTL级电路,都不一样,

个人觉得现在的FPGA与综合工具都很智能了,

很多小问题都不用太在意,比如下面这几个例子中,ISE会自动选择不同的D触发器去适应...

then why bother...

同事也常说,好的时序是设计出来的,不是约束出来的...好像和这个没多大关系,

嗯...比如常用的"打一拍",时钟相位修改,合理的乒乓,缓存RAM,FIFO的使用...

在大多数情况下都可以解决问题;

同步异步复位的优缺点,书中有讲,大概在80页左右;

如下:

[同步复位]

优点,有效去毛刺,因为只有在时钟沿到来时,复位才能生效;

缺点,多消耗了组合逻辑资源,复位时间不能太短,否则复位不完全;

如代码段,

module reset(
input clk,
input reset,
input in,
output out
); reg test;
always @( posedge clk )
if(reset)
test <= 'b0;
else
test <= in; assign out = test; endmodule

博客和书中说,大多数FPGA中的触发器没有同步复位端,所以会多出一些组合逻辑,如

盗个图,

这就是多出来的资源,另外FPGA中DFF资源多一些,组合逻辑少一些;

而我用ISE出来的是,并没有额外多出组合逻辑,

查了fdr的源语,

// FDRE: Single Data Rate D Flip-Flop with Synchronous Reset and
// Clock Enable (posedge clk).
// Artix-7
// Xilinx HDL Language Template, version 14.4 FDRE #(
.INIT('b0) // Initial value of register (1'b0 or 'b1)
) FDRE_inst (
.Q(Q), // 1-bit Data output
.C(C), // 1-bit Clock input
.CE(CE), // 1-bit Clock enable input
.R(R), // 1-bit Synchronous reset input
.D(D) // 1-bit Data input
); // End of FDRE_inst instantiation

既然是源语,所以我觉得这个片子里是有,带同步复位的D-FF的,

也许现在大多数FPGA都有了...

如果有同学说,再底层是不是还是普通的D-FF+组合逻辑,那就不清楚了...

所以个人觉得使用类似FPGA用同步复位时也不必再担心浪费资源了;

[异步复位]

优点,快速复位,消耗资源少;

缺点,不利于时序约束,复位也容易受到毛刺影响,从而造成不稳定;

如代码段,

module reset(
input clk,
input reset,
input in,
output out
); reg test;
always @( posedge clk or posedge reset )
if(reset)
test <= 'b0;
else
test <= in; assign out = test; endmodule

书中说,大多数FPGA,CPLD都有异步复位端,所以RTL级图如下,

异步清零的DFF

// FDCE: Single Data Rate D Flip-Flop with Asynchronous Clear and
// Clock Enable (posedge clk).
// Artix-7
// Xilinx HDL Language Template, version 14.4 FDCE #(
.INIT('b0) // Initial value of register (1'b0 or 'b1)
) FDCE_inst (
.Q(Q), // 1-bit Data output
.C(C), // 1-bit Clock input
.CE(CE), // 1-bit Clock enable input
.CLR(CLR), // 1-bit Asynchronous clear input
.D(D) // 1-bit Data input
); // End of FDCE_inst instantiation

[另外]

书中和博客中给出了解决方法,就是把异步复位信号,"打一拍"再使用,

叫同步释放,异步复位,代码段

module reset(
input clk,
input reset,
input in,
output out
); reg test;
reg reset_r;
always @( posedge clk )
begin
reset_r <= reset;
end always @( posedge clk or posedge reset_r)
if(reset_r)
test <= 'b0;
else
test <= in; assign out = test; endmodule

ISE下RTL图,如下,

即书中的图,

这样做肯定更好,更容易去掉毛刺;

但如果时序没那么差,而且FPGA内部有了同步复位的DFF,能省则省了;

另外复位的重要性与同步复位的复位时间要求,书中有介绍;

FPGA同步复位异步复位的更多相关文章

  1. FPGA设计中的复位

    (1)异步复位与同步复位的写法 1.异步复位与同步复位的区别? 同步复位:若复位信号在时钟有效边沿到来时刻为有效,则执行一次复位操作. 优点: 1)同步复位是离散的,所以非常有利于仿真器的仿真: 2) ...

  2. 7.FPGA中的同步复位与异步复位

    1.异步复位 always @ ( posedge sclk or negedge s_rst_n ) if ( !s_rst_n ) d_out <= 1'b0; else d_out < ...

  3. FPGA设计中的异步复位、同步释放思想

    1.一个简单的异步复位例子: module test( input clk, input rst_n, input data_in, output reg out ); always@(posedge ...

  4. 用4bit的counter看同步复位与异步复位

    先看看这个同步复位 //date: 2013/8/20 //designer :pengxiaoen module counter_4 ( clock,reset, out ); input rese ...

  5. FPGA基础学习(9) -- 复位设计

    目录 1. 常见问题 2. 常见的复位方式 3. 合理的复位设计 3.1 复位电平 3.2 异步复位同步化 3.3 恰到好处的复位 4. 补充 4.1 所谓的上电初始化 参考文献 一开始接触到FPGA ...

  6. ALTERA器件中复位电路实现之-异步复位同步化

    所谓异步复位同步化,就是我们通常说的异步复位同步撤除. 为了避免纯粹的同步复位和纯粹异步复位的问题,可以使用一种叫做同步化的异步复位,我们称其为第三类复位.这种复位完全结合了异步复位和同步复位的优势, ...

  7. 关于FIFO异步复位的问题

    关于FIFO异步复位的问题 FIFO异步复位的宽度,需要保证至少3个较慢时钟的时钟周期长度. 怎样对一个脉冲加宽呢? `timescale 1ns / 1ps //////////////////// ...

  8. Verilog笔记.5.同步、异步

    在数字电路中经常有同步synchronism.异步asynchronism的概念.异步指输入信号和时钟无关:同步指输入信号和时钟信号有关,实际上就是输入信号和时钟信号进行了与运算或者与非运算.实际开发 ...

  9. .NET同步与异步之相关背景知识(六)

    在之前的五篇随笔中,已经介绍了.NET 类库中实现并行的常见方式及其基本用法,当然.这些基本用法远远不能覆盖所有,也只能作为一个引子出现在这里.以下是前五篇随笔的目录: .NET 同步与异步之封装成T ...

随机推荐

  1. 谋哥:App自推广这个概念就由我来创立了!

    [谋哥每天一干货,第六十四篇] 昨天谋天团新增加了一名90后会员崔崔(微信号cuinianyyyy9),之前请教过我关于怎样从.Net到移动IOS开发然后创业的问题.我说你转到IOS,你须要自己学新语 ...

  2. java编译期优化与执行期优化技术浅析

    java语言的"编译期"是一段不确定的过程.由于它可能指的是前端编译器把java文件转变成class字节码文件的过程,也可能指的是虚拟机后端执行期间编译器(JIT)把字节码转变成机 ...

  3. HDU-1053-Entropy(Huffman编码)

    Problem Description An entropy encoder is a data encoding method that achieves lossless data compres ...

  4. jsp页面禁用缓存

    问题:为什么禁用JSP页面缓存 就是为了得到实时信息 怎样禁用JSP页面缓存 1.在JSP页面设置 <meta http-equiv="pragma" content=&qu ...

  5. 1_Linux_目录简介

    1. Linux中所以内容以文件形式保存,包括硬件,所以在用命令行配置文件时,该配置仅仅是临时生效.   2. Linux不靠扩展名区分类型,而是靠文件权限.之所以有扩展名是为了便于管理. .rpm二 ...

  6. HDU 5105 Math Problem

    让求  f(x)=|a∗x3+b∗x2+c∗x+d|(L≤x≤R)的最大值 这个题目讨论a和b的值,如果a==0的话,那么这个方程就变成了一个一元二次方程,直接找端点和对称轴(如果对称轴在给定的区间内 ...

  7. Python之路,Day26-----暂无正在更新中

    Python之路,Day26-----暂无正在更新中

  8. Tips--怎么使用谷歌搜索

    修改hosts即可: hosts在哪? windows下:C:\Windows\System32\drivers\etc 管理员身份打开,并将下载好的hosts文件内容,添加到原有的hosts文件末尾 ...

  9. ASP.NET-FineUI开发实践-14

    以前写过一个表格自动补全,改下,就出现了部分级联修改.测试版本4.1.1 共享下JS,ext-part2.js       后台再来个得到数据的方法就可以了.   1.方法还是删除+插入,主要在  i ...

  10. js正则表达式验证大全

    /判断输入内容是否为空    function IsNull(){        var str = document.getElementById('str').value.trim();      ...