|
|
|
data:image/s3,"s3://crabby-images/24f38/24f38e26af18495c41b98c594418dcbc76342e1d" alt="space.gif"
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/24f38/24f38e26af18495c41b98c594418dcbc76342e1d" alt="space.gif"
|
|
data:image/s3,"s3://crabby-images/f0800/f08005aa0ee9490f148277f99c6db1c747840c31" alt="../images/main/bullet_green_ball.gif" |
All About Reset
|
|
|
data:image/s3,"s3://crabby-images/24f38/24f38e26af18495c41b98c594418dcbc76342e1d" alt="space.gif"
|
|
|
Synchronous Reset : Reset is sampled with respect to clock |
|
|
Asynchronous Reset : Reset is sampled with no respect to clock. |
|
|
data:image/s3,"s3://crabby-images/24f38/24f38e26af18495c41b98c594418dcbc76342e1d" alt="space.gif"
|
|
|
Synchronous Reset
|
Asynchronous Reset
|
Synchronous reset requires more gates to implement (see the example below)
|
Asynchronous reset requires less gates to implement (see the example below)
|
Synchronous reset requires clock to be active always
|
Asynchronous reset does not require clock to be always active
|
Synchronous reset does not have metastability problems.
|
Asynchronous reset suffer from metastability problems.
|
Synchronous reset is slow.
|
Asynchronous reset is fast.
|
|
|
|
data:image/s3,"s3://crabby-images/24f38/24f38e26af18495c41b98c594418dcbc76342e1d" alt="space.gif"
|
|
data:image/s3,"s3://crabby-images/f0800/f08005aa0ee9490f148277f99c6db1c747840c31" alt="../images/main/bullet_green_ball.gif" |
Code Example
|
|
|
data:image/s3,"s3://crabby-images/24f38/24f38e26af18495c41b98c594418dcbc76342e1d" alt="space.gif"
|
|
|
Synchronous Reset |
|
|
1 module syn_reset (clk,reset,a,c);
2 input clk;
3 input reset;
4 input a;
5 output c;
6
7 wire clk;
8 wire reset;
9 wire a;
10 reg c;
11
12 always @ (posedge clk )
13 if ( reset == 1'b1) begin
14 c <= 0;
15 end else begin
16 c <= a;
17 end
18
19 endmodule
You could download file syn_reset.v here
|
|
|
data:image/s3,"s3://crabby-images/24f38/24f38e26af18495c41b98c594418dcbc76342e1d" alt="space.gif"
|
|
|
Asynchronous Reset |
|
|
1 module asyn_reset(clk,reset,a,c);
2 input clk;
3 input reset;
4 input a;
5 output c;
6
7 wire clk;
8 wire reset;
9 wire a;
10 reg c;
11
12 always @ (posedge clk or posedge reset)
13 if ( reset == 1'b1) begin
14 c <= 0;
15 end else begin
16 c <= a;
17 end
18 endmodule
You could download file asyn_reset.v here
|
|
|
data:image/s3,"s3://crabby-images/24f38/24f38e26af18495c41b98c594418dcbc76342e1d" alt="space.gif"
|
|
|
Synthesis Output |
|
|
data:image/s3,"s3://crabby-images/24f38/24f38e26af18495c41b98c594418dcbc76342e1d" alt="space.gif"
|
|
|
data:image/s3,"s3://crabby-images/a1779/a1779f69269c54bc73ef976cf514c6886c8b3fbc" alt="../images/tidbits/reset.12.gif" |
|
|
data:image/s3,"s3://crabby-images/24f38/24f38e26af18495c41b98c594418dcbc76342e1d" alt="space.gif"
|
|
|
Synchronize the asynchronous external reset signal, use this synchronous reset as input to all the asynchronous flip-flops inside the design, as shown in the figure below. We do this as an asynchronous reset flip-flop takes less logic to implement, is faster, consumes less power. |
|
|
data:image/s3,"s3://crabby-images/24f38/24f38e26af18495c41b98c594418dcbc76342e1d" alt="space.gif"
|
|
|
data:image/s3,"s3://crabby-images/82a36/82a3675631f6d8c9eae9221dfa579d70150728ca" alt="../images/tidbits/reset.13.gif" |
|
|
data:image/s3,"s3://crabby-images/24f38/24f38e26af18495c41b98c594418dcbc76342e1d" alt="space.gif"
|
|
|
data:image/s3,"s3://crabby-images/24f38/24f38e26af18495c41b98c594418dcbc76342e1d" alt="space.gif"
|
|
|
data:image/s3,"s3://crabby-images/24f38/24f38e26af18495c41b98c594418dcbc76342e1d" alt="space.gif"
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/24f38/24f38e26af18495c41b98c594418dcbc76342e1d" alt="space.gif"
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/726ff/726ff3b19415f2aff791975e94476916fe0130d2" alt=""
|
|
Copyright © 1998-2025 |
Deepak Kumar Tala - All rights reserved |
Do you have any Comment? mail me at:deepak@asic-world.com
|
|
|