Tuesday, 26 July 2016

5.LATCHES

Now we are discuss about Latches.It is Level Sensitive.

Here they are.

D LATCH:

module D_latch ( enable ,din ,reset ,dout );
output dout ;
reg dout ;
input enable ;
wire enable ;
input din ;
wire din ;
input reset ;
wire reset ;
always @ (enable or din or reset)
begin
if (reset)
dout = 0;
else
begin
if (enable)
dout = din;
end
end
endmodule


SR LATCH:

module SR_Latch ( s ,r ,enable ,reset ,q ,qb );
output q ;
reg q ;
output qb ;
reg qb ;
input s ;
wire s ;
input r ;
wire r ;
input enable ;
wire enable ;
input reset ;
wire reset ;
always @ (enable or s or r or reset)
begin
if (reset)
begin
q = 0;
qb = 1;
end
else
if (enable)
begin
if (s!=r)
begin
q = s;
qb = r;
end
else
if (s==1 && r==1)
begin
q = 1'bZ;
qb = 1'bZ;
end
end
end
endmodule


Tuesday, 26 August 2014

4.FLIP FLOPS




The storage elements used in clocked sequential circuits are called flip flops. A flip flop is a binary storage device capable of storing one bit of information.
The types of flip flops are

  •  D Flip Flop
  • T Flip Flop
  • JK Flip Flop
  • SR Flip Flop
  • Master-Slave Flip Flop
4.1 D FLIP FLOP:

SYMBOL:


EQUATION:

Q (t + 1) = D

EXCITATION TABLE:

Q(t)
Q(t+1)
D
0
0
0
0
1
1
1
0
0
1
1
1


PROGRAM:

module DFF ( Q, D ,CLK);
output Q ;
reg Q ;
input D,CLK ;
always @ (posedge CLK)
Q = D;
endmodule

4.2 T FLIP FLOP:

SYMBOL:


EQUATION:

Q (t + 1) = TQ’ + T’Q
EXCITATION TABLE:

Q(t)
Q(t+1)
T
0
0
0
0
1
1
1
0
1
1
1
0

PROGRAM:

module t_flip_flop ( t ,clk ,reset ,dout );
output dout ;
reg dout ;
input t ;
wire t ;
input clk ;
wire clk ;
input reset ;
wire reset ;
initial dout = 0;
 always @ (posedge (clk))
begin
if (reset)
dout <= 0;
else
begin
if (t)
dout <= ~dout;
end
end
endmodule

4.3 JK FLIP FLOP:

SYMBOL:
 

EQUATION:

Q (t + 1) = JQ’ + J’Q

EXCITATION TABLE:

Q(t)
Q(t+1)
J
K
0
0
0
X
0
1
1
X
1
0
X
1
1
1
X
0

PROGRAM:

module JK_flip_flop ( j ,k ,clk ,reset ,q ,qb );
output q ;
reg q ;
output qb ;
reg qb ;
input j ;
wire j ;
input k ;
wire k ;
input clk ;
wire clk ;
input reset ;
wire reset ;
always @ (posedge (clk))
begin
if (reset)
begin
q <= 0;
qb <= 1;
end
else
begin
if (j!=k)
begin
q <= j;
qb <= k;
end
else
if (j==1 && k==1)
begin q <= ~q;
qb <= ~qb;
end
end
end
endmodule

4.4 SR FLIPFLOP:

SYMBOL:
 
EQUATION:

Q(t + 1) = S + R’Q

EXCITATION TABLE:

Q(t)
Q(t+1)
S
R
0
0
0
X
0
1
1
0
1
0
0
1
1
1
X
0

PROGRAM:

module sr_flip_flop ( s ,r ,clk ,reset ,q ,qb );
output q ;
reg q ;
output qb ;
reg qb ;
input s ;
wire s ;
input r ;
wire r ;
input clk ;
wire clk ;
input reset ;
wire reset ;
always @ (posedge (clk))
begin
if (reset)
begin
q <= 0;
qb <= 1;
end
else
begin
if (s!=r)
begin
q <= s;
qb <= r;
end
else
if (s==1 && r==1)
begin
q <= 1'bZ;
qb <= 1'bZ;
end
end
end
endmodule

4.5 MASTER SLAVE FLIP FLOP:

We can use any type of flip flop. For example  i have taken D flip flop. A D flip flop takes only a single input, the D (data) input. The master-slave configuration has the advantage of being edge-triggered, making it easier to use in larger circuits, since the inputs to a flip-flop often depend on the state of its output.

The circuit consists of two D flip-flops connected together. When the clock is high, the D input is stored in the first latch, but the second latch cannot change state. When the clock is low, the first latch's output is stored in the second latch, but the first latch cannot change state.

The result is that output can only change state when the clock makes a transition from high to low.
 

DIAGRAM:

PROGRAM:

module master_slave_ff ( din ,clk ,reset ,dout );
output dout ;
input din ;
input clk ;
input reset ;
wire s;
wire in_clk;
assign in_clk = ~clk ;
 d_flip_flop u0 (.din(din),.clk(clk),.reset(reset),.dout(s));
d_flip_flop u1 (.din(s),.clk(in_clk),.reset(reset),.dout(dout));
endmodule 

In next session we are going to see about latches.