Prev Problem
Next Problem

74. Gated SR Latch

Back To All Submissions
Previous Submission
Next Submission

Solving Approach

How do you plan to solve it?

 

Code

module sr_latch_enable (
    input  EN,
    input  S,
    input  R,
    output reg Q,
    output reg Qn
); 
    always @(*)
    begin
        if(EN == 1'b1)
        begin
            case({S,R})
                2'b01 : begin
                    Q <= 1'b0;
                    Qn <= 1'b1;
                end
                2'b10 : begin
                    Q <= 1'b1;
                    Qn <= 1'b0;
                end
                2'b00 : begin
                    Q <= Q;
                    Qn <= ~Q;
                end
                2'b11 : begin
                    Q <= 1'b0;
                    Qn <= 1'b1;
                end
            endcase
        end
        else
        begin
            Q <= Q;
            Qn <= ~Q;
        end
    end
endmodule

 

Was this helpful?
Upvote
Downvote