

# SSD202D TIMER Module Description







© 2022 SigmaStar Technology Corp. All rights reserved.

SigmaStar Technology makes no representations or warranties including, for example but not limited to, warranties of merchantability, fitness for a particular purpose, non-infringement of any intellectual property right or the accuracy or completeness of this document, and reserves the right to make changes without further notice to any products herein to improve reliability, function or design. No responsibility is assumed by SigmaStar Technology arising out of the application or use of any product or circuit described herein; neither does it convey any license under its patent rights, nor the rights of others.

SigmaStar is a trademark of SigmaStar Technology Corp. Other trademarks or names herein are only for identification purposes only and owned by their respective owners.



#### 1. MODULE DESCRIPTION

#### 1.1. Overview

The Timer module is implemented for the counting function. It not only helps CPU get time correctly, but also serves as general counting operation. Three timers are provided in this system.

#### 1.2. Function Description

The Timer has the following features:

- 32-bit counter
- 8-bit divider can be set to enhance precision
- Supports counting for one time or rolling again and again
- Can read current count value
- Interrupt asserted when timer hits the max value

#### 1.3. Operating Flow

- 1. Set divide register for timer counter frequency.
- 2. Set timer max for maximum value of timer.
- 3. Enable interrupt, if needed.
- 4. Trigger timer (counting from 0 to max):
  - set enable register to count and roll.
  - set trigger register to enable counting for one time.
- 5. Read comp register for the current timer value.
  - read LSB first if your system is not 32-bit.



## 2. REGISTER DESCRIPTION

## 2.1. TIMERO Register (Bank = 30)

| TIMERO R            | egister (Bank = 30) |     |                                                                                                                                                   |                                  |
|---------------------|---------------------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------|
| Index<br>(Absolute) | Mnemonic            | Bit | Description                                                                                                                                       |                                  |
| 10h                 | REG3020             | 7:0 | Default: 0x00                                                                                                                                     | Access: R/W                      |
| (3020h)             | -                   | 7:2 | Reserved.                                                                                                                                         |                                  |
|                     | TIMER_TRIG          | 1   | Set: Enable timer to count one time (from 0 to max, then stop).  Clear: By resetting itself or by setting reg_timer_en.                           |                                  |
|                     | TIMER_EN            | 0   | Set: Enable timer counting to be rolled (from 0 to max, then rolled).  Clear: By resetting itself or by setting reg_timer_trig.                   |                                  |
| 10h                 | REG3021             | 7:0 | Default: 0x00                                                                                                                                     | Access : R/W                     |
| (3021h)             | - 6                 | 7:1 | Reserved.                                                                                                                                         |                                  |
|                     | TIMER_INT_EN        | 0   | Set: Enable interrupt. Clear: By resetting itself.                                                                                                |                                  |
| 11h                 | REG3022             | 7:0 | Default: 0x00                                                                                                                                     | Access: RO                       |
| (3022h)             |                     | 7:1 | Reserved.                                                                                                                                         |                                  |
|                     | TIMER_HIT           | 0   | Assert: When counter is enabled and matches reg_timer_max.  Deassert: By writing 1 or by setting reg_timer_en, reg_timer_once, and reg_timer_max. |                                  |
| 12h                 | REG3024             | 7:0 | Default : 0xFF                                                                                                                                    | Access: R/W                      |
| (3024h)             | TIMER_MAX[7:0]      | 7:0 | Timer maximum value.                                                                                                                              |                                  |
| 12h                 | REG3025             | 7:0 | Default: 0xFF                                                                                                                                     | Access: R/W                      |
| (3025h)             | TIMER_MAX[15:8]     | 7:0 | See description of '3024h'.                                                                                                                       |                                  |
| 13h                 | REG3026             | 7:0 | Default: 0xFF                                                                                                                                     | Access: R/W                      |
| (3026h)             | TIMER_MAX[23:16]    | 7:0 | See description of '3024h'.                                                                                                                       |                                  |
| 13h<br>(3027h)      | REG3027             | 7:0 | Default: 0xFF                                                                                                                                     | Access: R/W                      |
|                     | TIMER_MAX[31:24]    | 7:0 | See description of '3024h'                                                                                                                        |                                  |
| 14h                 | REG3028             | 7:0 | Default: 0x00                                                                                                                                     | Access: RO                       |
| (3028h)             | TIMER_CAP[7:0]      | 7:0 | Timer current value.  Note: With non-32-bit-dat                                                                                                   | ta system, please read from LSB. |



| TIMERO Register (Bank = 30) |                   |     |                                                                                                                                                                              |                                          |
|-----------------------------|-------------------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------|
| Index<br>(Absolute)         | Mnemonic          | Bit | Description                                                                                                                                                                  |                                          |
| 14h                         | REG3029           | 7:0 | Default: 0x00                                                                                                                                                                | Access : RO                              |
| (3029h)                     | TIMER_CAP[15:8]   | 7:0 | See description of '3028h'.                                                                                                                                                  |                                          |
| 15h                         | REG302A           | 7:0 | Default: 0x00                                                                                                                                                                | Access : RO                              |
| (302Ah)                     | TIMER_CAP[23:16]  | 7:0 | See description of '3028h'.                                                                                                                                                  |                                          |
| 15h                         | REG302B           | 7:0 | Default: 0x00                                                                                                                                                                | Access : RO                              |
| (302Bh)                     | TIMER_CAP[31:24]  | 7:0 | See description of '3028h'.                                                                                                                                                  | 7.                                       |
| 16h                         | REG302C           | 7:0 | Default: 0x00                                                                                                                                                                | Access : R/W                             |
| (302Ch)                     | TIMER_DEVIDE[7:0] | 7:0 | Timer divide counter number Default = 12M (216(clk_xiu)) 8'b0000: timer counter = clk 8'b0001: timer counter = clk 8'b0010: timer counter = clk 8'b1111: timer counter = clk | /18).<br>_xiu/1.<br>c_xiu/2.<br>c_xiu/3. |

## 2.2. TIMER1 Register (Bank = 30)

| TIMER1 Register (Bank = 30) |              |     | XXX                                                                                |              |
|-----------------------------|--------------|-----|------------------------------------------------------------------------------------|--------------|
| Index<br>(Absolute)         | Mnemonic     | Bit | Description                                                                        |              |
| 20h                         | REG3040      | 7:0 | Default: 0x00                                                                      | Access : R/W |
| (3040h)                     | - /          | 7:2 | Reserved.                                                                          |              |
|                             | TIMER_TRIG   | 1   | Set: Enable timer to count or stop). Clear: By resetting itself or by              | ·            |
|                             | TIMER_EN     | 0   | Set: Enable timer counting to<br>then rolled).<br>Clear: By resetting itself or by | ·            |
| 20h                         | REG3041      | 7:0 | Default: 0x00                                                                      | Access : R/W |
| (3041h)                     | -            | 7:1 | Reserved.                                                                          |              |
|                             | TIMER_INT_EN | 0   | Set: Enable interrupt. Clear: By resetting itself.                                 |              |
| 21h                         | REG3042      | 7:0 | Default: 0x00                                                                      | Access: RO   |
| (3042h)                     | -            | 7:1 | Reserved.                                                                          |              |
|                             | TIMER_HIT    | 0   | Assert: When counter is enable reg_timer_max. Deassert: By writing 1 or by s       |              |



| TIMER1 Re           | TIMER1 Register (Bank = 30) |     |                                                                                                                                                                              |                                        |  |
|---------------------|-----------------------------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------|--|
| Index<br>(Absolute) | Mnemonic                    | Bit | Description                                                                                                                                                                  |                                        |  |
|                     |                             |     | reg_timer_once, and reg_tim                                                                                                                                                  | ner_max.                               |  |
| 22h                 | REG3044                     | 7:0 | Default : 0xFF                                                                                                                                                               | Access : R/W                           |  |
| (3044h)             | TIMER_MAX[7:0]              | 7:0 | Timer maximum value.                                                                                                                                                         |                                        |  |
| 22h                 | REG3045                     | 7:0 | Default : 0xFF                                                                                                                                                               | Access : R/W                           |  |
| (3045h)             | TIMER_MAX[15:8]             | 7:0 | See description of '3044h'.                                                                                                                                                  |                                        |  |
| 23h                 | REG3046                     | 7:0 | Default : 0xFF                                                                                                                                                               | Access : R/W                           |  |
| (3046h)             | TIMER_MAX[23:16]            | 7:0 | See description of '3044h'.                                                                                                                                                  |                                        |  |
| 23h                 | REG3047                     | 7:0 | Default: 0xFF                                                                                                                                                                | Access : R/W                           |  |
| (3047h)             | TIMER_MAX[31:24]            | 7:0 | See description of '3044h'.                                                                                                                                                  | $\Delta \square \Delta$                |  |
| 24h                 | REG3048                     | 7:0 | Default: 0x00                                                                                                                                                                | Access : RO                            |  |
| (3048h)             | TIMER_CAP[7:0]              | 7:0 | Timer current value.  Note: With non-32-bit-data s                                                                                                                           | system, please read from LSB.          |  |
| 24h                 | REG3049                     | 7:0 | Default: 0x00                                                                                                                                                                | Access : RO                            |  |
| (3049h)             | TIMER_CAP[15:8]             | 7:0 | See description of '3048h'.                                                                                                                                                  |                                        |  |
| 25h                 | REG304A                     | 7:0 | Default: 0x00                                                                                                                                                                | Access : RO                            |  |
| (304Ah)             | TIMER_CAP[23:16]            | 7:0 | See description of '3048h'.                                                                                                                                                  |                                        |  |
| 25h                 | REG304B                     | 7:0 | Default: 0x00                                                                                                                                                                | Access : RO                            |  |
| (304Bh)             | TIMER_CAP[31:24]            | 7:0 | See description of '3048h'.                                                                                                                                                  |                                        |  |
| 26h                 | REG304C                     | 7:0 | Default: 0x00                                                                                                                                                                | Access : R/W                           |  |
| (304Ch)             | TIMER_DEVIDE[7:0]           | 7:0 | Timer divide counter number Default = 12M (216(clk_xiu), 8'b0000: timer counter = clk 8'b0001: timer counter = clk 8'b0010: timer counter = clk 8'b1111: timer counter = clk | /18).<br>_xiu/1.<br>_xiu/2.<br>_xiu/3. |  |

# 2.3. TIMER2 Register (Bank = 30)

| TIMER2 Re        | TIMER2 Register (Bank = 30) |     |                                      |                              |  |
|------------------|-----------------------------|-----|--------------------------------------|------------------------------|--|
| Index (Absolute) | Mnemonic                    | Bit | Description                          |                              |  |
| 30h              | REG3060                     | 7:0 | Default: 0x00                        | Access : R/W                 |  |
| (3060h)          | -                           | 7:2 | Reserved.                            |                              |  |
|                  | TIMER_TRIG                  | 1   | Set: Enable timer to count or stop). | ne time (from 0 to max, then |  |



| TIMER2 Re           | egister (Bank = 30) |     |                                                                                                                                                   |  |
|---------------------|---------------------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Index<br>(Absolute) | Mnemonic            | Bit | Description                                                                                                                                       |  |
|                     |                     |     | Clear: By resetting itself or by setting reg_timer_en.                                                                                            |  |
|                     | TIMER_EN            | 0   | Set: Enable timer counting to be rolled (from 0 to max, then rolled).  Clear: By resetting itself or by setting reg_timer_trig.                   |  |
| 30h                 | REG3061             | 7:0 | Default: 0x00 Access: R/W                                                                                                                         |  |
| (3061h)             | -                   | 7:1 | Reserved.                                                                                                                                         |  |
|                     | TIMER_INT_EN        | 0   | Set: Enable interrupt. Clear: By resetting itself.                                                                                                |  |
| 31h                 | REG3062             | 7:0 | Default: 0x00 Access: RO                                                                                                                          |  |
| (3062h)             | -                   | 7:1 | Reserved.                                                                                                                                         |  |
|                     | TIMER_HIT           | 0   | Assert: When counter is enabled and matches reg_timer_max.  Deassert: By writing 1 or by setting reg_timer_en, reg_timer_once, and reg_timer_max. |  |
| 32h<br>(3064h)      | REG3064             | 7:0 | Default: 0xFF Access: R/W                                                                                                                         |  |
|                     | TIMER_MAX[7:0]      | 7:0 | Timer maximum value.                                                                                                                              |  |
| 32h                 | REG3065             | 7:0 | Default: 0xFF Access: R/W                                                                                                                         |  |
| (3065h)             | TIMER_MAX[15:8]     | 7:0 | See description of '3064h'.                                                                                                                       |  |
| 33h                 | REG3066             | 7:0 | Default : 0xFF                                                                                                                                    |  |
| (3066h)             | TIMER_MAX[23:16]    | 7:0 | See description of '3064h'.                                                                                                                       |  |
| 33h                 | REG3067             | 7:0 | Default: 0xFF Access: R/W                                                                                                                         |  |
| (3067h)             | TIMER_MAX[31:24]    | 7:0 | See description of '3064h'.                                                                                                                       |  |
| 34h                 | REG3068             | 7:0 | Default: 0x00 Access: RO                                                                                                                          |  |
| (3068h)             | TIMER_CAP[7:0]      | 7:0 | Timer current value.  Note: With non-32-bit-data system, please read from LSE                                                                     |  |
| 34h                 | REG3069             | 7:0 | Default: 0x00 Access: RO                                                                                                                          |  |
| (3069h)             | TIMER_CAP[15:8]     | 7:0 | See description of '3068h'.                                                                                                                       |  |
| 35h                 | REG306A             | 7:0 | Default: 0x00 Access: RO                                                                                                                          |  |
| (306Ah)             | TIMER_CAP[23:16]    | 7:0 | See description of '3068h'.                                                                                                                       |  |
| 35h<br>(306Bh)      | REG306B             | 7:0 | Default: 0x00 Access: RO                                                                                                                          |  |
|                     | TIMER_CAP[31:24]    | 7:0 | See description of '3068h'.                                                                                                                       |  |
| 36h                 | REG306C             | 7:0 | Default: 0x00 Access: R/W                                                                                                                         |  |
| (306Ch)             | TIMER_DEVIDE[7:0]   | 7:0 | Timer divide counter number.  Default = 12M (216(clk_xiu)/18).  8'b0000: timer counter = clk_xiu/1.                                               |  |



| TIMER2 Register (Bank = 30) |          |     |                                                                                                                        |
|-----------------------------|----------|-----|------------------------------------------------------------------------------------------------------------------------|
| Index (Absolute)            | Mnemonic | Bit | Description                                                                                                            |
|                             |          |     | 8'b0001: timer counter = clk_xiu/2.<br>8'b0010: timer counter = clk_xiu/3.<br><br>8'b1111: timer counter = clk_xiu/16. |

