搞了一下午博客环境

我也是醉了

Cs450/timer

Question

Implement a timer that counts down for a given number of clock cycles, then asserts a signal to indicate that the given duration has elapsed. A good way to implement this is with a down-counter that asserts an output signal when the count becomes 0.

At each clock cycle:

  • If load = 1, load the internal counter with the 10-bit data, the number of clock cycles the timer should count before timing out. The counter can be loaded at any time, including when it is still counting and has not yet reached 0.
  • If load = 0, the internal counter should decrement by 1.

The output signal tc (“terminal count”) indicates whether the internal counter has reached 0. Once the internal counter has reached 0, it should stay 0 (stop counting) until the counter is loaded again.

Below is an example of what happens when asking the timer to count for 3 cycles:

Module Declaration

1
2
3
4
5
6
module top_module(
input clk,
input load,
input [9:0] data,
output tc
);

Solution

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
module top_module(
input clk,
input load,
input [9:0] data,
output tc
);

reg [9:0] cnt;

always @(posedge clk) begin
if (load)
cnt <= data;
else if (cnt != 0)
cnt <= cnt - 1'b1;
else
cnt <= cnt;
end

assign tc = (cnt == 0);

endmodule