testbench.v 794 Bytes
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19
module testbench;
    reg clk;

    initial begin
        // $dumpfile("testbench.vcd");
        // $dumpvars(0, testbench);

        #5 clk = 0;
        repeat (10000) begin
            #5 clk = 1;
            #5 clk = 0;
        end

        $display("OKAY");
    end


    reg dinA = 0;
    wire doutB;
SergeyDegtyar committed
20 21
    wire pre,clr;
    reg q = 0;
22 23 24 25 26 27 28 29 30 31 32 33 34 35

    top uut (
        .clk (clk ),
        .clr (1'b0 ),
        .pre (1'b0 ),
        .a (dinA ),
        .b (doutB )
    );

    always @(negedge clk) begin
    #3;
    dinA <= !dinA;
    end

SergeyDegtyar committed
36 37 38 39 40 41 42 43 44 45 46 47
    assign pre = 1'b0;
    assign clr = 1'b0;

    	always @( negedge clk, posedge pre, negedge clr )
		if ( pre )
			q <= 1'b1;
		else if ( clr )
			q <= 1'b0;
		else
            q <= dinA;

	assert_dff ff_test(.clk(~clk), .test(doutB), .pat(q));
48 49

endmodule