



## D conversion.v /home/itzzinfinity/Cozy Drive/100daysofRTL/day 053/project 2/project 2.srcs/sources 1/new/D conversion.v 1 □ `timescale 1ns / 1ps // Engineer: Anjan Prasad // Create Date: 11/13/2024 05:44:45 AM // Module Name: D conversion module D conversion ( 9 input S, R, J, K, T, clk, reset, 10 output q sr, q jk, q t 12 // Instantiate SR, JK, and T Flip-Flops 13 SR flipflop sr ff (.S(S), .R(R), .clk(clk), .reset(reset), .Q(q sr));14 JK flipflop jk ff (.J(J), .K(K), .clk(clk), .reset(reset), .Q(q jk));15 T flipflop t ff (.T(T), .clk(clk), .reset(reset), .Q(q t));16 endmodule

## D conversion tb.v

/home/itzzinfinity/Cozy Drive/100daysofRTL/day\_053/project\_2/project\_2.srcs/sim\_1/new/D\_conversion\_tb.v

```
1 📥
        timescale 1ns / 1ps
2 🗇
        3 ¦
        // Engineer: Anjan Prasad
4
        // Create Date: 11/13/2024 05:52:13 AM
5
        '// Module Name: D conversion tb
6 🕁
        7
8
        module D conversion tb;
9
            reg S, R, J, K, T, clk, reset;
10
            wire q sr, q jk, q t;
11
12
            D conversion DUT (.S(S), R(R), J(J), K(K), T(T), clk(clk), reset(reset), q_sr(q_sr), q_jk(q_jk), q_t(q_t));
13
14
            initial begin
15
     \circ
               clk = 0;
     \circ
16
                forever #5 clk = ~clk;
17
            end
18
            initial begin
19
20
               S = 0; R = 0; J = 0; K = 0; T = 0; reset = 1;
     0
21
               #10 \text{ reset} = 0;
22
               // Test SR Flip-Flop
23
     \circ
               #10 S = 1; R = 0; // Set
24
     \circ
               #10 S = 0; R = 1; // Reset
25
     \circ
               #10 S = 0; R = 0; // Hold
26
     \circ
               #10 S = 1; R = 1; // Invalid (both set and reset)
     \circ
27
               #10 S = 0; R = 1;
28
            end
29
            initial begin
30
               // Test JK Flip-Flop
31
               #20 S = 0; R = 0; // Disable SR inputs
32
     \circ
               J = 1; K = 0; // Set
     \circ
33
               #10 J = 0; K = 1; // Reset
     \circ
34
               #10 J = 1; K = 1; // Toggle
35
     \circ
               #10 J = 0; K = 0; // Hold
     \bigcirc
36
               #50 $stop;
37
            end
38
            initial begin
39
               // Test T Flip-Flop
40
     0
               \#20 J = 0; K = 0; // Disable JK inputs
     \circ
41
               T = 1:
                               // Toggle
42
     \circ
               #10 T = 0;
                               // Hold
43
                               // Toggle again
               #10 T = 1:
44
            end
45
        endmodule
46
47
```



