1
votes

I have written a module in verilog implementing D flip-flop, like following:-

module d_flip_flop(q,d,clk,reset);

Now, I want to implement 4-bit shift register using this module. So I have to execute four d flip flops in parallel inside always @(negedge clk) block. I don't know how to parallel execute four user defined modules inside always(or how to instantiate). I don't want a direct behavioral implementation of 4-bit shift register.

1

1 Answers

3
votes

One way is to create 4 instances, connecting the q output of one to the d input of the next:

wire [3:0] q;
d_flip_flop i0 (q[0], din , clk,reset);
d_flip_flop i1 (q[1], q[0], clk,reset);
d_flip_flop i2 (q[2], q[1], clk,reset);
d_flip_flop i3 (q[3], q[2], clk,reset);

There is no need to use an always block.