# **Lab 6 - Electronic Clock**

106033233 資工大四 周聖諺 (Sheng-Yen Chou)

2022-04-15

# **Contents**

| Lab 6 - Electronic Clock Report |      | 4 |
|---------------------------------|------|---|
| Block Diagram                   | <br> | 4 |
| Finite State Machine            | <br> | 4 |
| Design Specification            | <br> | 4 |
| Design Implementation           | <br> | 4 |
| Time Display Module             | <br> | 5 |
| Design Specification            | <br> | 5 |
| Design Implementation           | <br> | 5 |
| Unit Setting Module             | <br> | 6 |
| Design Specification            | <br> | 6 |
| Design Implementation           | <br> | 6 |
| Alarm Module                    | <br> | 6 |
| Design Specification            | <br> | 6 |
| Design Implementation           | <br> | 6 |
| Stopwatch Module                | <br> | 7 |
| Design Specification            | <br> | 7 |
| Design Implementation           | <br> | 7 |
| Switch Controller Module        | <br> | 7 |
| Design Specification            | <br> | 7 |
| Design Implementation           | <br> | 7 |
| Display Controller Module       | <br> | 7 |
| Design Specification            | <br> | 7 |
| Design Implementation           | <br> | 8 |
| Clock Generator Module          | <br> | 8 |
| Design Specification            | <br> | 8 |
| Design Implementation           | <br> | 8 |
| Extract Module                  | <br> | 8 |
| Design Specification            | <br> | 8 |
| Design Implementation           | <br> | 9 |
| Scan Controller Module          | <br> | 9 |
| Design Specification            | <br> | 9 |
| Design Implementation           | <br> | 9 |
| Display Module                  | <br> | 9 |
| Design Specification            | <br> | 9 |
| Design Implementation           | <br> | 9 |

| Debounce              | .0 |
|-----------------------|----|
| Design Specification  | .0 |
| Design Implementation | .0 |
| Onepule Module        | .0 |
| Design Specification  | LO |
| Design Implementation | .0 |
| Counterx Module       | .0 |
| Design Specification  | .0 |
| Design Implementation | .1 |
| Datetime Limit Module | .1 |
| Design Specification  | .1 |
| Design Implementation | .1 |
| Design Implementatio  | .1 |
| I/O Pin Assignment    | .1 |
| Conclusion            | 2  |

# **Lab 6 - Electronic Clock Report**

106033233 資工大四 周聖諺 (Sheng-Yen Chou)

# **Block Diagram**



## **Finite State Machine**

## **Design Specification**

fsm.v Source Code

Output: [15:0] state\_led, [1:0] display\_slide, load\_to\_disp\_alarm, load\_to\_unitset, time\_enable, alarm\_enable, stopwatch\_enable, stopwatch\_restart, stopwatch\_lap, [1:0] set\_u1\_u0, [4:0] state
Input: btn\_l, btn\_m, btn\_r, switch\_0, switch\_1, switch\_alarm, clk, rst\_n

## **Design Implementation**

#### **State Control**

Use 3 DIP switches to control the states and the activation of the alarm and some variables only depend on the state, including state, load\_to\_disp\_alarm, load\_to\_unitset, time\_enable, and alarm\_enable. The variable load\_to\_disp\_alarm decides whether to load the output of the module unitset and load\_to\_unitset determine whether to load current digits of the alarm and the time components to module unitset. load\_to\_disp\_alarm is on in the state TIME and SET.

#### **Time Display and Alarm**

The variables time\_enable and alarm\_enable control whether to enable counting of the modules. Absolutely, time\_enable is enabled in state TIME and alarm\_enable is enabled in state ALARM.

#### Stopwatch

The variables stopwatch\_enable, stopwatch\_restart, and stopwatch\_lap control the behavior of the stopwatch module. The implementation is totally the same as the Lab 5-2. The finite state machine controls 2 signals: stopwatch\_enable and stopwatch\_restart. The down counter will pause while the signal stopwatch\_enable is at low voltage and resume to count while the signal is at low voltage. It is controlled independently, so I only need to inverse the signal whenever the right button btn\_r is pressed.

On the other hand, the down counter will reset to 0 when the signal stopwatch\_restart raises. It only depends on btn\_l button, so we only need to inverse the signal whenever the button is clicked.

#### **Others**

The variable state\_led controls the LED display of the board and it can simply implemented by switch and if-else condition control.

display\_slide controls the digits that would be displayed in the 7-segment display.

## **Time Display Module**

#### **Design Specification**

timedisplay.v Source Code

Output: year, month, day, hour, min, sec

Input: count\_enable, load\_value\_enable, load\_value\_year, load\_value\_month, load\_value\_day, load\_value\_hour, load\_value\_min, load\_value\_sec, clk, rst\_n

#### **Design Implementation**

The module is implemented with a series of counterx module. We can simply cascade the counterx from the second to the year. Use the carry bit to trigger the next counter.

For leap year, I design a module called datetime\_limit to count the length of a month. The module will set the length of February in the leap year as 29, otherwise, as 28.

# **Unit Setting Module**

## **Design Specification**

unitset.v Source Code

Output: [8:0] alarm\_hour, [8:0] alarm\_min, [8:0] year, [8:0] month, [8:0] day, [8:0] hour, [8:0] min, [8:0] sec

Input: count\_enable, load\_value\_enable, [8:0] load\_alarm\_hour, [8:0] load\_alarm\_min, [8:0] load\_year, [8:0] load\_month, [8:0] load\_day, [8:0] load\_hour, [8:0] load\_min, [8:0] load\_sec, display\_slide, clk, rst\_n

## **Design Implementation**

The display\_slide will control the variable enabled\_counting\_digits to decide which unit to set up. While display\_slide is 3, 2, 1, 0, the unitset will set the (alarm hour, alarm minute), (year, month), (day, hour) and, (minute, second) individually. The module also support leap years.

The module is implemented by a series of cascaded counters counterx. The counting of a digit would be enabled while the digit is selected by the enabled\_counting\_digits.

#### **Alarm Module**

#### **Design Specification**

alarm.v Source Code

Output: [6:0] alarm\_led, [8:0] alarm\_min, [8:0] alarm\_hour

Input: alarm\_enable, load\_value\_enable, [8:0] current\_min, [8:0] current\_hour, [8:0] load\_value\_alarm\_min, [8:0] load\_value\_alarm\_hour

## **Design Implementation**

If load\_value\_enable is enabled, the module will load the argument load\_value\_alarm\_hour to the register alarm\_hour and load the argument load\_value\_alarm\_min to the register alarm\_min. In addition, while alarm\_enable is enabled, the alarm will be active. If the current hour and minute is the same as the hours and the minute, alarm\_led will be lighted up.

# **Stopwatch Module**

## **Design Specification**

stopwatch.v Source Code

Output: stopwatch\_led, [8:0] sec, [8:0] min,

Input: count\_enable, lap\_enable, clk, rst\_n

## **Design Implementation**

The stopwatch module is implemented by 2 counterx modules. The counter will be activated while the argument count\_enable is true. It will be reset while the argument rst\_n is raised. In addition, while the argument lap\_enable is true, the variable sec and min will be freezed and stopped to synchronize with the argument counting\_sec and counting\_min.

#### **Switch Controller Module**

#### **Design Specification**

switch\_controller.v Source Code

Output: [8:0] sel\_d1, [8:0] sel\_d0

Input: [8:0] alarm\_hour, [8:0] alarm\_min, [8:0] year, [8:0] month, [8:0] day, [8:0] hour, [8:0] min, [8:0]

sec, [1:0] display\_slide

#### **Design Implementation**

The module will select the corresponding unit as output according to the display\_slide argument. When display\_slide is equal to 0, 1, 2, 3, the module will output (sel\_d1, sel\_d0) = (alarm\_hour, alarm\_min), (year, month), (day, hour), (min, sec) respectively.

## **Display Controller Module**

#### **Design Specification**

display\_controller.v Source Code

Output: [8:0] ssd\_reg0, [8:0] ssd\_reg1

Input: [4:0]state, [1:0]display\_slide, [8:0] alarm\_hour, [8:0] alarm\_min, [8:0] time\_year, [8:0] time\_month, [8:0] time\_day, [8:0] time\_hour, [8:0] time\_min, [8:0] time\_sec, [8:0] stopwatch\_min, [8:0] stopwatch\_sec, [8:0] set\_alarm\_hour, [8:0] set\_alarm\_min, [8:0] set\_year, [8:0] set\_month, [8:0] set\_day, [8:0] set\_hour, [8:0] set\_min, [8:0] set\_sec

## **Design Implementation**

The module will select corresponding inputs as the output according to the argument state and display\_slide. First, the module will call switch\_controller module to select the corresponding numbers according to the argument display\_slide. Then, The module will choose the numbers that will be shown in the 7-segment display ssd\_reg0 and ssd\_reg1 from the selected numbers. While the state[4:3] is equal to 2'b00(Time), 2'b11(SET), and 2'b01(STW), the module will choose the selected number of timedisplay, unitset, and stopwatch respectively.

#### **Clock Generator Module**

## **Design Specification**

clock\_generator.v Source Code

Output: reg clk\_1, reg clk\_100, reg clk\_2k,

Input: clk, rst\_n

#### **Design Implementation**

The clock generator provides 1 Hz clock and 100 Hz clock. The module is implemented by a counter. Whenever the counter hit the limit, the module would invert the output signal.

#### **Extract Module**

# **Design Specification**

extract.v Source Code

Output: [3:0] d0, [3:0] d1

Input: [8:0] x

# **Design Implementation**

The extract module will separate the tens digit d1 and unit digits d0 from the input number x.

#### **Scan Controller Module**

## **Design Specification**

scan\_ctl.v Source Code

Output: [3:0] ssd\_in, [3:0] ssd\_ctl

Input: [3:0] in0, [3:0] in1, [3:0] in2, [3:0] in3, ssd\_ctl\_en, rst\_n

## **Design Implementation**

Since we can only control one digit of the 7-segment display each time, I design a module that takes the 4-digit patterns as input and shows the 1 digit on the display when the clock raises. Whenever the clock raises, the module will switch the control  $ssd_ctl$  to different digit and shows the corresponding digit. Take an example, when the first clock raise occur, the module will  $set_ssd_ctl = 4' \ b1110$  and  $ssd_in = in0$ . As for second clock pulse, the module will output  $ssd_ctl = 4' \ b1101$  and  $ssd_in = in1$  and soon.

## **Display Module**

## **Design Specification**

display.v Source Code

Output: [7:0] segs

Input: [3:0] bin

## **Design Implementation**

The module will convert the 4-bits binary number to 7-segment display patters from 0~16.

#### **Debounce**

# **Design Specification**

debounce.v Source Code

Output: push\_debounced

Input: rst, clk, push

## **Design Implementation**

For each click, the module will delay 4 clock cycle and then raise the debounce pulse. I use 4 registers to represent the delay state and send a pulse while 4 registers are all 1s

# **Onepule Module**

# **Design Specification**

onepulse.v Source Code

Output: push\_onepulse, push\_onepulse\_long, push\_debounced, push\_debounced\_long

Input: clk, rst, push

#### **Design Implementation**

The one-pulse module raise a pulse while the debounce module raises a pulse. As a result, it will produce high voltage while the previous debounce signal is higher than the current debounce signal.

#### **Counterx Module**

# **Design Specification**

counterx.v Source Code

 $Output: \ [8:0] \ q, time\_carry, count\_enable, load\_value\_enable, [8:0] \ load\_value, [8:0] \ count\_limit\_u, \\$ 

[8:0] count\_limit\_l, [8:0] count\_init

Input: clk, rst\_n

# **Design Implementation**

The counterx module is a binary-up counter that counts from count\_limit\_l to count\_limit\_u. The argument count\_init set the initial value of the counter.

## **Datetime Limit Module**

## **Design Specification**

datetime\_limit.v Source Code

Output: [8:0] year\_limit, [8:0] month\_limit, [8:0] day\_limit, [8:0] hour\_limit, [8:0] min\_limit, [8:0] sec\_limit, [8:0] year\_init, [8:0] month\_init, [8:0] day\_init, [8:0] hour\_init, [8:0] min\_init, [8:0] sec\_init Input: [8:0] year, [8:0] month

# **Design Implementation**

The module provide the upper limit of each date/time unit and support leap year. During the leap year, the length of February is 29, otherwise is 28.

## **Design Implementatio**

# I/O Pin Assignment

| I/O | switch_0 | switch_0 | switch_alarm | btn_m |
|-----|----------|----------|--------------|-------|
| LOC | V17      | V16      | R2           | T18   |

| I/O | clk | rst | btn_r | btn_l | ssd_ctl[0] | ssd_ctl[1] | ssd_ctl[2] | ssd_ctl[3] |
|-----|-----|-----|-------|-------|------------|------------|------------|------------|
| LOC | W5  | W16 | T17   | W19   | U2         | U4         | V4         | W4         |

| I/O | seg       | gs[0] : | segs[1] | segs[2 | e] segs[3 | s] segs[4] | segs[5] | segs[6]  | segs[7] |
|-----|-----------|---------|---------|--------|-----------|------------|---------|----------|---------|
| LOC | V7        | ĺ       | U7      | V5     | U5        | V8         | U8      | W6       | W7      |
|     |           |         |         |        |           |            |         |          |         |
| I/O | led[0]    | led[1   | ] le    | d[2]   | led[3]    | led[4]     | led[5]  | led[6]   | led[7]  |
| LOC | C U16 E19 |         | U19     |        | V19       | W18        | U15     | U14      | V14     |
|     |           |         |         |        |           |            |         |          |         |
| I/O | led[8]    | led[9]  | led[    | [10]   | led[11]   | led[12]    | led[13] | leds[14] | led[15] |
| LOC | V13       | V3      | W3      |        | U3        | P3         | N3      | P1       | L1      |
|     |           |         |         |        |           |            |         |          |         |

## Conclusion

In lab6, I firstly implement a large project, which is more than 1000 lines of codes. I spent lots of time on the unitset module and how to design a data flow between the timedisplay, alarm, and unitset. I' ve learned a lot while doing this homework.