# Engineering



Timer

Design

Preliminary

2015.01.20

Version 1.0



SUNPLUS TECHNOLOGY CO. reserves the right to change this documentation without prior notice. Information provided by SUNPLUS TECHNOLOGY CO. is believed to be accurate and reliable. However, SUNPLUS TECHNOLOGY CO. makes no warranty for any error that may appear in this document.

Contact your local SUNPLUS sales office or your distributor to obtain the latest version of device specifications before placing your order. No responsibility is assumed by SUNPLUS for any infringement of patent or other rights of third parties that may result from its use.

In addition, SUNPLUS products are not authorized for use as critical components in life support devices/systems or aviation devices/systems, where a malfunction or failure of the product may reasonably be expected to result in significant injury to the user, without the express written approval of SUNPLUS.

SUNPLUS and SUNPLUS logo are trademarks or registered trademarks of SUNPLUS corporation or its subsidiaries.

Copyright © 2007 Sunmedia Corporation



## 0.1 Target

• Write a sequential design with verilog.

## 0.2 Specification

• File Name: TIMER.v

• Module Name: TIMER

• I/O Port

| Port Name | Width Attribute | Description                                                                                                |
|-----------|-----------------|------------------------------------------------------------------------------------------------------------|
| SYSCLK    | 1 Input         | System Clock All registers must be synchronous with this clock. The period time of this clock is 1 second. |
| RST_B     | 1 Input         | Global Reset Signal Asynchronous reset. Active low.                                                        |
| TIME_MIN  | 3 Input         | Minute Number The number which the minute should reach.                                                    |
| TIME_SEC  | 6 Input         | Second Number The number which the second should reach.                                                    |
| START     | 1 Input         | Start Timer One pulse signal. When START==1, It start to timer.                                            |
| MINUTE    | 3 Output        | Timer Output the Current Minute Number Minute of timer.                                                    |
| SECOND    | 6 Output        | Timer Output the Current Second Number Second of timer.                                                    |
| TIME_UP   | 1 Output        | <b>Time End</b> One pulse signal. Active high.                                                             |

# 0.3 Requirement

- Synchronous with the rising edge of system clock
- Asynchronous reset
- Match HE coding style, run he\_vcheck to ensure quality of design
- When start the timer, TIME\_MIN and TIME\_SEC are valid and mustn't change until time end
- If TIME\_MIN and TIME\_SEC are both 0, TIME\_UP will be valid with START at the same time
- After TIME\_UP asserted, MINUTE and SECOND must hold until RST\_B is valid.
- RST\_B will be valid before every START



## 0.4 Waveform



Figure 0.4.1: Waveform of Timer

2015.01.20 Version: 1.0