

# **Watchdog Timer IP**

IP Version: v1.6.0

# **User Guide**

FPGA-IPUG-02097-1.8

January 2025



#### **Disclaimers**

Lattice makes no warranty, representation, or guarantee regarding the accuracy of information contained in this document or the suitability of its products for any particular purpose. All information herein is provided AS IS, with all faults, and all associated risk is the responsibility entirely of the Buyer. The information provided herein is for informational purposes only and may contain technical inaccuracies or omissions, and may be otherwise rendered inaccurate for many reasons, and Lattice assumes no obligation to update or otherwise correct or revise this information. Products sold by Lattice have been subject to limited testing and it is the Buyer's responsibility to independently determine the suitability of any products and to test and verify the same. LATTICE PRODUCTS AND SERVICES ARE NOT DESIGNED, MANUFACTURED, OR TESTED FOR USE IN LIFE OR SAFETY CRITICAL SYSTEMS, HAZARDOUS ENVIRONMENTS, OR ANY OTHER ENVIRONMENTS REQUIRING FAIL-SAFE PERFORMANCE, INCLUDING ANY APPLICATION IN WHICH THE FAILURE OF THE PRODUCT OR SERVICE COULD LEAD TO DEATH, PERSONAL INJURY, SEVERE PROPERTY DAMAGE OR ENVIRONMENTAL HARM (COLLECTIVELY, "HIGH-RISK USES"). FURTHER, BUYER MUST TAKE PRUDENT STEPS TO PROTECT AGAINST PRODUCT AND SERVICE FAILURES, INCLUDING PROVIDING APPROPRIATE REDUNDANCIES, FAIL-SAFE FEATURES, AND/OR SHUT-DOWN MECHANISMS. LATTICE EXPRESSLY DISCLAIMS ANY EXPRESS OR IMPLIED WARRANTY OF FITNESS OF THE PRODUCTS OR SERVICES FOR HIGH-RISK USES. The information provided in this document is proprietary to Lattice Semiconductor, and Lattice reserves the right to make any changes to the information in this document or to any products at any time without notice.

#### **Inclusive Language**

This document was created consistent with Lattice Semiconductor's inclusive language policy. In some cases, the language in underlying tools and other items may not yet have been updated. Please refer to Lattice's inclusive language FAQ 6878 for a cross reference of terms. Note in some cases such as register names and state names it has been necessary to continue to utilize older terminology for compatibility.



# **Contents**

| Con     | ntents    |                                             | 3  |
|---------|-----------|---------------------------------------------|----|
| Abb     | oreviatio | ons in This Document                        | 6  |
| 1.      | Introd    | luction                                     | 7  |
| 1       | 1.        | Overview of the IP                          | 7  |
| 1       | 2.        | Quick Facts                                 | 7  |
| 1       | 3.        | IP Support Summary                          | 7  |
| 1       |           | Features                                    |    |
| 1       | 5.        | Licensing and Ordering Information          | 8  |
| 1       |           | Hardware Support                            |    |
| 1       |           | Minimum Device Requirements                 |    |
| 1       |           | Naming Conventions                          |    |
|         | 1.8.1.    |                                             |    |
|         | 1.8.2.    |                                             |    |
| 2.      | Funct     | ional Descriptions                          |    |
| 2       |           | IP Architecture Overview                    |    |
|         | 2.1.1.    |                                             |    |
|         | 2.1.2.    | <u> </u>                                    |    |
|         | 2.1.3.    |                                             |    |
| 2       |           | Clocking                                    |    |
|         |           | Reset                                       |    |
|         |           | User Interfaces                             |    |
|         |           | Programming Flow                            |    |
|         | 2.5.1.    | Initialization                              |    |
|         | 2.5.2.    |                                             |    |
|         | 2.5.3.    | ·                                           |    |
| 2       |           | Operation Details                           |    |
|         |           | ameter Description                          |    |
|         |           | General                                     |    |
| 4.      |           | Description                                 |    |
| 5.      | _         | er Description                              |    |
|         | _         | WDT MODE                                    |    |
|         |           | WDT_CONTROL                                 |    |
|         |           | TIMEOUT VAL 1                               |    |
|         |           | TIMEOUT VAL 2                               |    |
|         |           | STATUS TIME                                 |    |
|         |           | TIMEOUT CNT 1                               |    |
|         |           | TIMEOUT CNT 2                               |    |
|         |           | INT STATUS REG                              |    |
|         |           | INT_ENABLE_REG                              |    |
|         |           | INT_SET_REG                                 |    |
|         |           | ple Design                                  |    |
|         |           | Example Design Supported Configuration      |    |
|         |           | Overview of the Example Design and Features |    |
|         |           | Example Design Components                   |    |
|         |           | Generating the Example Design               |    |
|         |           | Simulating the Example Design               |    |
|         |           | Hardware Testing                            |    |
| 0       | 6.6.1.    | Hardware Testing Setup                      |    |
|         | 6.6.2.    | Ğ İ                                         |    |
| 7       |           | Expected Outputning with the IP             |    |
| 7.<br>7 | _         | Generating and Instantiating the IP         |    |
| /       |           | Generated Files and File Structure          |    |
|         | 7.1.1.    | Generated Files and File Structure          | 20 |



| 7.2.       | Design Implementation         | 26 |
|------------|-------------------------------|----|
| 7.3.       | Timing Constraints            |    |
| 7.4.       | Specifying the Strategy       |    |
| 7.5.       | Running Functional Simulation | 27 |
| Appendix   | A. Resource Utilization       | 30 |
| Reference  | 25                            | 32 |
| Technical  | Support Assistance            | 33 |
| Revision H | History                       | 34 |



# **Figures**

| Figure 2.1. Functional Block Diagram                                       | 10 |
|----------------------------------------------------------------------------|----|
| Figure 2.2. Watchdog Timer Operation Timing Diagram                        | 12 |
| Figure 6.1. Watchdog Timer in Propel SoC Project                           |    |
| Figure 6.2. Watchdog Timer Example Design Block Diagram                    | 20 |
| Figure 6.3. Create Propel Project                                          | 21 |
| Figure 6.4. Define Instance                                                | 21 |
| Figure 6.5. Sample PDC File Content                                        | 22 |
| Figure 6.6. Sample C-Code for Watchdog Timer IP                            | 22 |
| Figure 6.7. Sample Waveform                                                | 23 |
| Figure 7.1. Module/IP Block Wizard                                         | 24 |
| Figure 7.2. IP Configuration                                               | 25 |
| Figure 7.3. Check Generated Result                                         | 25 |
| Figure 7.4. Simulation Wizard                                              | 27 |
| Figure 7.5. Adding and Reorder Source                                      | 28 |
| Figure 7.6. Parse HDL Files for Simulation                                 | 28 |
| Figure 7.7. Summary                                                        | 29 |
| Figure 7.8. Simulation Waveform                                            | 29 |
| Tables                                                                     |    |
| Table 1.1. Quick Facts                                                     |    |
| Table 1.2. Watchdog Timer IP Support Readiness                             |    |
| Table 2.1. User Interfaces and Supported Protocols                         | 10 |
| Table 3.1. Attributes Table                                                | 13 |
| Table 4.1. Ports Description                                               | 14 |
| Table 5.1. Register Address Map                                            | 15 |
| Table 5.2. Access Type Definition                                          | 15 |
| Table 5.3. WDT_MODE                                                        | 15 |
| Table 5.4. WDT_CONTROL                                                     |    |
| Table 5.5. STATUS_CYCLE_1                                                  |    |
| Table 5.6. STATUS_CYCLE_2                                                  |    |
| Table 5.7. STATUS_TIME                                                     |    |
| Table 5.8. TIMEOUT_CNT_1                                                   |    |
| Table 5.9. TIMEOUT_CNT_2                                                   |    |
| Table 5.10. INT_STATUS_REG                                                 |    |
| Table 5.11. INT_ENABLE_REG                                                 |    |
| Table 5.12. INT_SET_REG                                                    |    |
| Table 6.1. Watchdog Timer IP Configuration Supported by the Example Design |    |
| Table 7.1. Generated File List                                             |    |
| Table A.1. LFMXO5-25-9BBG400I Device Resource Utilization                  |    |
| Table A.2. LFMXO5-25-7BBG400I Device Resource Utilization                  |    |
| Table A.3. LAV-AT- E70-3LFG1156I Device Resource Utilization               | 31 |



# **Abbreviations in This Document**

A list of abbreviations used in this document.

| Abbreviation | Definition                                  |
|--------------|---------------------------------------------|
| APB          | Advanced Peripheral Bus                     |
| AXI          | Advanced Extensible Interface               |
| CPU          | Central Processing Unit                     |
| FPGA         | Field Programmable Gate Array               |
| GPIO         | General Purpose Input/Output                |
| HDL          | Hardware Description Language               |
| IP           | Intellectual Property                       |
| LSE          | Lattice Synthesis Engine                    |
| NMI          | Non-Maskable Interrupt                      |
| OSC          | Oscillator                                  |
| PLIC         | Platform-level Interrupt Controller         |
| PLL          | Phase-Locked Loop                           |
| RISC-V       | Reduced Instruction Set Computer Five       |
| RTL          | Register Transfer Level                     |
| Rx           | Receiver                                    |
| SDK          | Software Development Kit                    |
| SoC          | System on Chip                              |
| TCM          | Tightly-Coupled Memory                      |
| UART         | Universal Asynchronous Receiver/Transmitter |
| WDT          | Watchdog Timer                              |



## 1. Introduction

### 1.1. Overview of the IP

The Watchdog Timer IP is designed for use as an indicator that corrective action is needed in response to a computer or processor malfunction. The design features a two-stage timer that supports non-maskable interrupt and a hard reset.

### 1.2. Quick Facts

Table 1.1 shows a summary of the Watchdog Timer IP.

Table 1.1. Quick Facts

| IP Requirements      | Supported FPGA Families  | All                                                                                      |  |  |
|----------------------|--------------------------|------------------------------------------------------------------------------------------|--|--|
|                      | Targeted Devices         | All                                                                                      |  |  |
| Resource Utilization | Resources                | See Appendix A. Resource Utilization                                                     |  |  |
|                      | Supported User Interface | Advanced Peripheral Bus (APB)                                                            |  |  |
|                      | Lattice Implementation   | IP v1.6.0 – Lattice Radiant™ software 2024.2 and Lattice Propel™ Builder software 2024.2 |  |  |
| Design Tool Company  | Synthosis                | Lattice Synthesis Engine (LSE)                                                           |  |  |
| Design Tool Support  | Synthesis                | Synopsys Synplify Pro® for Lattice                                                       |  |  |
|                      | Simulation               | For a list of supported simulators, see the Lattice Radiant Software User Guide.         |  |  |

## 1.3. IP Support Summary

**Table 1.2. Watchdog Timer IP Support Readiness** 

| Lattice Device<br>Family       | Enable<br>APB | Mode  | Timer<br>Stage 1 | Timer<br>Stage 2 | Freq. Unit<br>(Mode = Time) | Sys Clk Freq.<br>(Mode = Time) | Radiant<br>Timing Model | Hardware<br>Validated |
|--------------------------------|---------------|-------|------------------|------------------|-----------------------------|--------------------------------|-------------------------|-----------------------|
| Avant™                         | False         | Cycle | 5000000          | 5000000          | _                           | _                              | Preliminary             | Yes                   |
|                                |               | Cycle | 75000000         | 75000000         | _                           | _                              | Preliminary             | Yes                   |
|                                |               | Time  | 250              | 250              | MHz                         | 150                            | Preliminary             | Yes                   |
|                                | True          | Cycle | 5000000          | 5000000          | _                           | _                              | Preliminary             | Yes                   |
|                                |               | Time  | 500              | 500              | MHz                         | 150                            | Preliminary             | Yes                   |
| Certus™-NX,                    | False         | Cycle | 5000000          | 5000000          | _                           | _                              | Preliminary             | No                    |
| CertusPro™-NX,                 |               | Cycle | 75000000         | 75000000         | _                           | _                              | Preliminary             | No                    |
| CrossLink™-NX,<br>MachXO5™-NX, |               | Time  | 250              | 250              | MHz                         | 150                            | Preliminary             | No                    |
| Certus-N2                      | True          | Cycle | 5000000          | 5000000          | _                           | _                              | Preliminary             | No                    |
|                                |               | Time  | 500              | 500              | MHz                         | 150                            | Preliminary             | No                    |

### 1.4. Features

Key features of the Watchdog Timer IP include:

- Seamlessly works with sleep mode.
- Programmable timer spec 50–500 ms (10 ms increments).
- Two-stage timer that supports warm boot and cold boot resets.
- You can specify in cycles or time.
- Supports trigger input, reset, and NMI output.
- Supports APB interface.



## 1.5. Licensing and Ordering Information

The Watchdog Timer IP is provided at no additional cost with the Lattice Radiant software.

## 1.6. Hardware Support

Refer to the Example Design section for more information on the boards used.

## 1.7. Minimum Device Requirements

There is no limitation in device speed grade for Watchdog Timer IP. See Appendix A. Resource Utilization for minimum required resources to instantiate this IP and maximum clock frequency supported.

## 1.8. Naming Conventions

#### 1.8.1. Nomenclature

The nomenclature used in this document is based on Verilog HDL.

### 1.8.2. Signal Names

Signal Names that end with:

- \_n are active low
- \_*i* are input signals
- \_o are output signals

9



# 2. Functional Descriptions

#### 2.1. IP Architecture Overview

The Watchdog Timer IP performs the following functions:

- Send a non-maskable interrupt to the processor (nmi\_o);
- Send a reset to the processor for system restart (reset o).

The Watchdog Timer IP is a two-stage timer that starts to count depending on the status of the processor. The processor regularly sends a kick signal to the Watchdog Timer to indicate its active and *error-free* status, the absence of the kick signal means there is a hardware malfunction or program error in the processor. The processor is required to have custom application to send the kick signal regularly.

The Watchdog Timer IP uses an up-counter that counts from zero to a timeout value at a rate that is determined by the configurable mode and the clock frequency.

#### 2.1.1. Watchdog Timer Modes

#### Cycle

When in cycle mode, you can configure the timeout in terms of the number of cycles for each stage of the timer. The number of cycles refers to the count the Watchdog Timer needs to reach, to assert the timeout signal.

#### Time

Using the time mode, you can configure the timeout in milliseconds and the clock frequency ranging from 10 kHz to 150 MHz.

#### 2.1.2. Reset Signals

#### 2.1.2.1. Non-APB Mode

#### Warm Boot (nmi\_o)

The warm boot reset is a non-maskable interrupt which serves as a warning to the processor that a system reset is expected. When this port is asserted, the processor must either debug the program error or store the important files in running programs.

#### Cold Boot (reset\_o)

The cold boot or the hard reset, as the name implies, resets the whole system when the second timeout value has been reached.

#### 2.1.2.2. APB Mode

#### Interrupt Signal (int\_o)

Interrupt signal serves as a timeout indicator. When int\_o is set to 1, this implies that either the stage 1 or stage 2 timer has reached the timeout value that you have set. By this time, the processor must either debug the program error or store the important files in running programs.

#### Cold Boot (reset\_o)

The cold boot or the hard reset, as the name implies, resets the whole system when the second timeout value has been reached.

#### 2.1.3. Kick Signal

#### For APB Mode

The IP supports the use of APB interface. If APB mode is enabled, you must send the kick signal through the APB register (WDT\_CONTROL), indicating that the processor is still active and in *error-free* status. This requires the processor to send a kick signal regularly.



#### For Non-APB Mode

If APB mode is not used in the operation, you must send the kick signal through the kick\_i port, indicating that the processor is still active and in "error-free" status. This requires the processor to send a kick signal regularly through a standard GPIO port.

Figure 2.1 shows a functional diagram for the Watchdog Timer IP.



Figure 2.1. Functional Block Diagram

## 2.2. Clocking

The Watchdog Timer IP requires a system clock: clk\_i. You need to provide this clock through an external source and route it to an appropriate pin on the FPGA device. The system clock (externally sourced) provides a timing reference and is used to operate the internal logic of the IP.

This IP supports two different frequency unit (kHz and MHz) ranging from 10 kHz to 150 MHz in the time mode.

#### **2.3.** Reset

The Watchdog Timer IP has one asynchronous active low reset: resetn i.

When asserted, the output ports and registers are forced to their default values. The reset assertion can be asynchronous but reset negation should be synchronous. The IP contains internal logic to synchronously de-assert the internal reset once resetn\_i is de-asserted, so you do not need to implement your own de-assertion logic.

#### 2.4. User Interfaces

Table 2.1. User Interfaces and Supported Protocols

| User Interface Supported Protocols |     | Description                                                            |
|------------------------------------|-----|------------------------------------------------------------------------|
| General – Watchdog Timer           | APB | For APB interface, refer to the AMBA 3 APB Protocol v1.0               |
| Register Access                    |     | Specification for information and timing diagram of the APB interface. |



## 2.5. Programming Flow

#### 2.5.1. Initialization

Initial values for all registers come from the user interface. To change the default configuration, the following Watchdog Timer register should be set properly before programming the absence of a kick signal.

• INT ENABLE REG- Set 'h0 to disable reset interrupt, 'h1 to enable reset interrupt.

#### 2.5.2. Watchdog Timer Non-APB Mode Operation

Below are the recommended steps for performing the Watchdog Timer operation when APB mode is disabled, this assumes that the module is not currently performing any operation or is in IDLE mode.

- 1. Power up.
- 2. Reset de-assertion.
- 3. Timer counter stage 1 starts counting up.
- 4. If a processor is active, write 1 to kick to indicate that it is *alive*.
- 5. If nmi\_o is asserted, this means that the processor did not write to kick for a longer time than the timeout 1 value. This will trigger the start of timer counter stage 2. Do step 4 if processor is active, else proceed to step 6.
- 6. If reset\_o is asserted, this means that the processor did not write to kick for a longer time than the (timeout 1 + timeout 2) value.

#### 2.5.3. Watchdog Timer APB Mode Operation

Below are the recommended steps for performing Watchdog Timer operation when APB mode is enabled, this assumes that the module is not currently performing any operation or is in IDLE mode.

- 1. Power up.
- 2. Reset de-assertion.
- 3. Timer counter stage 1 starts counting up. This can be monitored through the TIMEOUT\_CNT\_1 register.
- 4. You must monitor int\_o by this time.
- 5. If a processor is active, write 1 to kick with the WDT\_CONTROL\_register.
- 6. If the processor does not write to kick for a longer time than the timeout 1 value, this sets the INT\_STATUS\_REG (int\_nmi\_status) to 1 and interrupt status (int\_o) to HIGH. Clear the interrupt status (int\_o) by writing 1 to int\_nmi\_status. Moreover, this triggers the start of timer counter stage 2. Do step 5.
- 7. Timer counter stage 2 starts counting up. The Timer Counter 2 can be monitored through the TIMEOUT\_CNT\_2 register.
- 8. If reset\_o is asserted, this means that the processor did not write to kick for a longer time than the (timeout 1 + timeout 2) value. Also, this sets the INT\_STATUS\_REG (int\_reset\_status) to 1 and interrupt status (int\_o) to HIGH. Clear the interrupt status (int\_o) by writing 1 to int\_reset\_status and int\_nmi\_status registers.

### 2.6. Operation Details

During normal operation, the connected processor regularly sends a *kick* signal to the Watchdog Timer using kick\_i port. After IP reset, timer stage 1 begins to count. Timer stage 1 clears once the processor sends a *kick* signal. However, if Timer Stage 1 reaches the timeout value this asserts the nmi\_o port. This port triggers the counting of Timer Stage 2 and simultaneously notifies the processor by means of the warm boot (*nmi\_o*) that a reset is imminent. Timer Stage 2 continuous to count, unless the processor sends a *kick* signal which clears both Timer Stage 1 and 2. If the Timer Stage 2 reaches the timeout value, cold boot (*reset\_o*) is asserted, which forcefully restart the processor. Refer to Figure 2.2 for a sample Watchdog Timer operation timing diagram.



Figure 2.2. Watchdog Timer Operation Timing Diagram



# 3. IP Parameter Description

The configurable attributes of the Watchdog Timer IP are shown in the following tables. You can configure the IP by setting the attributes accordingly in the IP Module/IP Block Wizard of the Lattice Radiant Software. Wherever applicable, default values are in **bold**.

## 3.1. General

Table 3.1. Attributes Table

| Attribute                                                             | Selectable Values               | Description                                                                                                                                                                       |  |  |
|-----------------------------------------------------------------------|---------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| General                                                               | <u> </u>                        |                                                                                                                                                                                   |  |  |
| Enable APB Checked, <b>Unchecked</b>                                  |                                 | Specifies the use of APB Interface to access the available Watchdog Timer Registers.                                                                                              |  |  |
| Mode                                                                  | Cycle, Time                     | Specifies the Watchdog Timer Mode.                                                                                                                                                |  |  |
| Frequency Unit                                                        | kHz, <b>MHz</b>                 | Specifies the unit for System Clock Frequency. Active if Watchdog Timer Mode == Time.                                                                                             |  |  |
| System Clock Frequency kHz: 10–999, <b>100</b> MHz: 1–150, <b>100</b> |                                 | Specifies the user clock frequency.  Active if Watchdog Timer Mode == Time, else uses the user testbench clock frequency.  Selectable values are dependent on the Frequency Unit. |  |  |
| Timer Stage 1                                                         |                                 |                                                                                                                                                                                   |  |  |
| Timeout (number of cycles)                                            | 500–75000000,<br><b>5000000</b> | Specifies the timeout of Timer Stage 1 in terms of number of cycles.  Active if Watchdog Timer Mode == Cycle.                                                                     |  |  |
| Timeout (ms) <b>50</b> –500                                           |                                 | Specifies the timeout of Timer Stage 1 in terms of ms.  Active if Watchdog Timer Mode == Time.                                                                                    |  |  |
| Timer Stage 2                                                         |                                 |                                                                                                                                                                                   |  |  |
| Timeout (number of cycles)                                            | 500–75000000,<br><b>5000000</b> | Specifies the timeout of Timer Stage 2 in terms of number of cycles.  Active if Watchdog Timer Mode == Cycle.                                                                     |  |  |
| Timeout (ms) <b>50</b> –500                                           |                                 | Specifies the timeout of Timer Stage 2 in terms of ms.  Active if Watchdog Timer Mode == Time.                                                                                    |  |  |



# 4. Signal Description

This section describes the Watchdog Timer IP signals and ports along with their descriptions.

**Table 4.1. Ports Description** 

| Port Name                      | Туре   | Width | Description                                                                                         |  |
|--------------------------------|--------|-------|-----------------------------------------------------------------------------------------------------|--|
| Clock and Reset                |        | •     |                                                                                                     |  |
| clk_i                          | Input  | 1     | System clock.                                                                                       |  |
| resetn_i                       | Input  | 1     | Active low reset.                                                                                   |  |
| reset_o                        | Output | 1     | Cold boot output reset.                                                                             |  |
| Interrupt Port                 |        |       |                                                                                                     |  |
| nmi_o²                         | Output | 1     | Non-maskable interrupt signal.                                                                      |  |
| int_o¹                         | Output | 1     | Bus for reset_o and nmi_o. Indicates if either reset_o and/or nmi_o is high.                        |  |
| Timer Count Ports <sup>2</sup> |        |       |                                                                                                     |  |
| timer1_count_o                 | Output | 27    | Timer count for timer stage 1.                                                                      |  |
| timer2_count_o                 | Output | 27    | Timer count for timer stage 2.                                                                      |  |
| Kick <sup>2</sup>              |        |       |                                                                                                     |  |
| kick_i                         | Input  | 1     | Kick signal indicating that the processor is active and error-free.                                 |  |
| APB Ports <sup>1</sup>         |        |       |                                                                                                     |  |
| apb_psel_i                     | Input  | 1     | APB Select Signal. Indicates that the device is selected, and a data transfer is required.          |  |
| apb_penable_i Input 1          |        | 1     | APB Enable Signal. Indicates the second and subsequent cycles of an APB transfer.                   |  |
| apb_paddr_i                    | Input  | 8     | APB Address signal.                                                                                 |  |
| apb_pwdata_i                   | Input  | 32    | APB Write Data signal.                                                                              |  |
| apb_pwrite_i                   | Input  | 1     | APB Direction Signal. Indicates write or read access.  0 – Read  1 – Write                          |  |
| apb_prdata_o                   | Output | 32    | APB Read Data signal.                                                                               |  |
| apb_pready_o                   | Output | 1     | APB Ready Signal. Indicates transfer completion. The IP uses this signal to extend an APB transfer. |  |
| apb_pslverr_o                  | Output | 1     | APB Error signal. Indicates a transfer failure.                                                     |  |

#### Notes:

- 1. These ports are available only if *Enable APB* is *Checked*.
- 2. These ports are available only if *Enable APB* is *Unchecked*.



# 5. Register Description

This section provides detailed descriptions of the Watchdog Timer IP registers.

The register address map, shown in Table 5.1, specifies the available registers.

Table 5.1. Register Address Map

| APB Offset | Register Name  | Bit Width | Access Type | Description                             |  |
|------------|----------------|-----------|-------------|-----------------------------------------|--|
| 0x00       | WDT_MODE       | 32        | RO          | Watchdog Mode Register                  |  |
| 0x04       | WDT_CONTROL    | 32        | RW          | Watchdog Timer Control Register         |  |
| 0x08       | TIMEOUT_VAL_1  | 32        | RO          | Timeout Value Status Register 1 (Cycle) |  |
| 0x0C       | TIMEOUT_VAL_2  | 32        | RO          | Timeout Value Status Register 2 (Cycle) |  |
| 0x10       | STATUS_TIME    | 32        | RO          | Timeout Value Status Register (Time)    |  |
| 0x14       | TIMEOUT_CNT_1  | 32        | RO          | Timeout Counter Register 1              |  |
| 0x18       | TIMEOUT_CNT_2  | 32        | RO          | Timeout Counter Register 2              |  |
| 0x1C       | INT_STATUS_REG | 32        | RW1C        | Interrupt Status Register               |  |
| 0x20       | INT_ENABLE_REG | 32        | RW          | Interrupt Enable Register               |  |
| 0x24       | INT_SET_REG    | 32        | wo          | Interrupt Set Register                  |  |

The behavior of registers to write and read access is defined by its access type, which is defined in Table 5.2.

Table 5.2. Access Type Definition

| Access Type            | Behavior on Read Access | Behavior on Write Access                                                                              |  |  |
|------------------------|-------------------------|-------------------------------------------------------------------------------------------------------|--|--|
| RO                     | Returns register value. | Ignores write access.                                                                                 |  |  |
| WO Returns 0.          |                         | Updates register value.                                                                               |  |  |
| RW                     | Returns register value. | Updates register value.                                                                               |  |  |
| RSVD Ignore when read. |                         | Ignores write access.                                                                                 |  |  |
| RW1C                   | Returns register value. | Writing 1'b1 on the register bit clears the bit to 1'b0. Writing 1'b0 on the register bit is ignored. |  |  |

# 5.1. WDT\_MODE

Table 5.3. WDT\_MODE

| Field  | Name     | Description                                                                                        | Access | Width | Reset |
|--------|----------|----------------------------------------------------------------------------------------------------|--------|-------|-------|
| [31:1] | Reserved |                                                                                                    | RSVD   | 30    |       |
| [0]    | mode     | Watchdog Timer Mode. Specifies the mode of the Watchdog Timer stages.  1'b0 – Cycle.  1'b1 – Time. | RO     | 0     | Mode  |

# 5.2. WDT\_CONTROL

Table 5.4. WDT\_CONTROL

| Field  | Name     | Description                                                                                                                                                                                                  | Access | Width | Reset |
|--------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------|-------|
| [31:1] | Reserved | _                                                                                                                                                                                                            | RSVD   | 30    | _     |
| [0]    | kick     | Watchdog Timer Kick Register. Specifies the external processor status connected to the Watchdog Timer. This register automatically clears after getting a value. 1'b0 – This triggers the timer to count up. | wo     | 1     | 'hO   |



| Field | Name | Description                                 | Access | Width | Reset |
|-------|------|---------------------------------------------|--------|-------|-------|
|       |      | 1'b1 – Indicates that the external          |        |       |       |
|       |      | processor is active and in normal           |        |       |       |
|       |      | operation. This also resets the Timeout     |        |       |       |
|       |      | counter Stage 1 and/or Stage 2. This        |        |       |       |
|       |      | register is automatically cleared and       |        |       |       |
|       |      | returns to default value 0 after writing 1. |        |       |       |

# 5.3. TIMEOUT\_VAL\_1

## Table 5.5. STATUS\_CYCLE\_1

| Field   | Name                 | Description                                                                        | Access | Width | Reset                            |
|---------|----------------------|------------------------------------------------------------------------------------|--------|-------|----------------------------------|
| [31:27] | Reserved             |                                                                                    | RSVD   | 5     |                                  |
| [26:0]  | cycle_timeoutval_st1 | Timeout Value Stage 1. Specifies the timeout value of Timer Stage 1 in Cycle Mode. | RO     | 27    | Timeout<br>(number of<br>cycles) |

# 5.4. TIMEOUT\_VAL\_2

## Table 5.6. STATUS\_CYCLE\_2

| Field   | Name                 | Description                                                                        | Access | Width | Reset                      |
|---------|----------------------|------------------------------------------------------------------------------------|--------|-------|----------------------------|
| [31:27] | Reserved             | 1                                                                                  | RSVD   | 5     | 1                          |
| [26:0]  | cycle_timeoutval_st2 | Timeout Value Stage 1. Specifies the timeout value of Timer Stage 1 in Cycle Mode. | RO     | 27    | Timeout (number of cycles) |

# 5.5. STATUS\_TIME

### Table 5.7. STATUS\_TIME

| Field   | Name                | Description                                                                                                                                                                             | Access | Width | Reset                     |
|---------|---------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------|---------------------------|
| [31:23] | Reserved            | _                                                                                                                                                                                       | RSVD   | 9     | _                         |
| [22:13] | clk_freq            | Clock Frequency. Specifies the System Clock Frequency of the Watchdog Timer, allowed values are 10–999 kHz and 1–150 MHz.                                                               | RO     | 10    | System Clock<br>Frequency |
| [12]    | freq_unit           | Clock Frequency Unit. Specifies the Frequency unit of the clk_freq register field.  1'b0 – MHz  1'b1 – kHz                                                                              | RO     | 1     | Frequency Unit            |
| [11:6]  | time_timeoutval_st2 | Timeout Value Stage 2. Specifies the timeout value of Timer Stage 2 in Time Mode  'b0000 0000 – 50 ms 'b0000 0001 – 60 ms 'b0000 0010 – 70 ms 'b0010 1100 – 490 ms 'b0010 1101 – 500 ms | RO     | 6     | Timeout (ms)              |



| Field | Name                | Description                                                                                                                                                                            | Access | Width | Reset        |
|-------|---------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------|--------------|
| [5:0] | time_timeoutval_st1 | Timeout Value Stage 1. Specifies the timeout value of Timer Stage 1 in Time Mode 'b0000 0000 - 50 ms 'b0000 0001 - 60 ms 'b0000 0010 - 70 ms 'b0010 1100 - 490 ms 'b0010 1101 - 500 ms | RO     | 6     | Timeout (ms) |

# 5.6. TIMEOUT\_CNT\_1

### Table 5.8. TIMEOUT\_CNT\_1

| Field   | Name         | Description                                                                                                                                                                     | Access | Width | Reset |
|---------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------|-------|
| [31:27] | Reserved     | _                                                                                                                                                                               | RSVD   | 5     | _     |
| [26:0]  | timer1_count | Timeout Counter Stage 1. Specifies the 27-bit counter that is incremented by one on the rising edge of the input clock. The counter is reset to zero when the kick is asserted. | RO     | 27    | 'h0   |

# 5.7. TIMEOUT\_CNT\_2

#### Table 5.9. TIMEOUT CNT 2

| Field   | Name         | Description                                                                                                                                                                     | Access | Width | Reset |
|---------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------|-------|
| [31:27] | Reserved     | _                                                                                                                                                                               | RSVD   | 5     | _     |
| [26:0]  | timer2_count | Timeout Counter Stage 2. Specifies the 27-bit counter that is incremented by one on the rising edge of the input clock. The counter is reset to zero when the kick is asserted. | RO     | 27    | 'h0   |

# 5.8. INT\_STATUS\_REG

## Table 5.10. INT\_STATUS\_REG

| Field  | Name             | Description                                                                                                                                                                                                                                                                                            | Access | Width | Reset |
|--------|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------|-------|
| [31:2] | Reserved         | _                                                                                                                                                                                                                                                                                                      | RSVD   | 30    | _     |
| [1]    | int_reset_status | Cold boot reset Interrupt Status Register. Specifies the reset_o interrupt status of the Watchdog Timer.  1'b0 – No interrupt.  1'b1 – This indicates that the processor has not written to kick register for some time and the timeout counter stage 2 has reached the specified timeout value/limit. | RW1C   | 1     | 'h0   |
| [0]    | int_nmi_status   | Warm boot reset Interrupt Status Register. Specifies the nmi_o interrupt status of the Watchdog Timer. Note that this interrupt is non-maskable.  1'b0 – No interrupt.                                                                                                                                 | RW1C   | 1     | 'h0   |



| Field | Name | Description                                              | Access | Width | Reset |
|-------|------|----------------------------------------------------------|--------|-------|-------|
|       |      | 1'b1 – This indicates that the processor has not written |        |       |       |
|       |      | to kick register for some time and the timeout counter   |        |       |       |
|       |      | stage 1 has reached the specified timeout value/limit.   |        |       |       |

# 5.9. INT\_ENABLE\_REG

## Table 5.11. INT\_ENABLE\_REG

| Field  | Name         | Description                                                                                                                                                                                                                        | Access | Width | Reset |
|--------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------|-------|
| [31:2] | Reserved     | _                                                                                                                                                                                                                                  | RSVD   | 30    | _     |
| [1]    | int_reset_en | Cold boot reset Interrupt Enable Register. When set to high, it enables the corresponding interrupt status signal (int_reset_status) to trigger the assertion of int_o port. 1'b0 – Interrupt disabled.  1'b1 – Interrupt enabled. | RW     | 1     | 'h0   |
| [0]    | Reserved     | _                                                                                                                                                                                                                                  | RSVD   | 1     | _     |

# 5.10.INT\_SET\_REG

### Table 5.12. INT\_SET\_REG

| Field  | Name          | Description                                                                                                                                                                                                                                                                                                | Access | Width | Reset |
|--------|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------|-------|
| [31:2] | Reserved      | _                                                                                                                                                                                                                                                                                                          | RSVD   | 30    | _     |
| [1]    | int_reset_set | Cold boot reset Interrupt Set Register. You can set the bits in the int_reset_status register. This is intended for debugging and testing purposes, making sure int_o asserts if int_reset_status is set to 1.  1'b0 – Does nothing.  1'b1 – Sets the corresponding bits in the int_reset_status register. | wo     | 1     | 'h0   |
| [0]    | int_nmi_set   | Warm boot reset Interrupt Set Register. You can set the bits in the int_nmi_status register. This is intended for debugging and testing purposes, making sure int_o asserts if int_nmi_status is set to 1.  1'b0 – Does nothing.  1'b1 – Sets the corresponding bits in the int_nmi_status register.       | wo     | 1     | 'h0   |



# 6. Example Design

The Watchdog Timer IP example design allows you to compile, simulate, and test the Watchdog Timer IP on the following Lattice evaluation boards:

LAV-E70-EVN-ES1

# 6.1. Example Design Supported Configuration

Table 6.1. Watchdog Timer IP Configuration Supported by the Example Design

| and the state of t |                                               |  |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------|--|
| Watchdog Timer IP GUI Parameter                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Value                                         |  |
| Enable APB                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | True                                          |  |
| Mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Cycle, Time                                   |  |
| Frequency Unit (Time Mode)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | MHz, kHz                                      |  |
| System Clock Frequency (Time Mode)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 1–150 (MHz Freq Unit), 10–999 (kHz Freq Unit) |  |
| Timer Stage 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 500–7.5e+07 (Cycle Mode), 50–500 (Time Mode)  |  |
| Timer Stage 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 500–7.5e+07 (Cycle Mode), 50–500 (Time Mode)  |  |

## **6.2.** Overview of the Example Design and Features

The example design discussed in this section is created using the RISC-V Rx SoC Project template in the Lattice Propel Design Environment. The generated project includes the following components:

- Processor RISC-V Rx with TCMs and PLIC
- GPIO
- OSC and PLL
- UART Serial port
- AXI Interconnect
- AXI to APB Bridge
- Glue Logic
- System Memory

Watchdog Timer IP is instantiated to the RISC-V SoC project template as shown in the figure below.



Figure 6.1. Watchdog Timer in Propel SoC Project



## 6.3. Example Design Components



Figure 6.2. Watchdog Timer Example Design Block Diagram

The Watchdog Timer example design includes the following blocks:

- RISC-V CPU Passes the C-Code Test Routine through the APB Bridge and handles interrupts.
- AXI-to-APB Bridge Read and write transfer on the AXI4 bus to APB.
- Watchdog Timer IP

### 6.4. Generating the Example Design

Refer to the Lattice Propel SDK User Guide for more details on the Lattice Propel software.

- 1. Launch Lattice Propel Builder software.
- 2. In the Propel Builder software, create a new Lattice Propel System Design Project by clicking the drop down icon and select *New Design*.
- 3. The Create System Design window opens.
  - For Project Type, select SoC Project. Enter a name and a location for the project. Click Next.
  - In Configure Propel Project window, refer to Figure 6.3 and configure the settings based on the device or board that you use. Figure 6.3 shows the configuration used when LAV-AT-E70ES1 Development Board is used for the hardware testing. Click Next.
  - There will be a summary of the project configuration in the Project Information window. Click **Finish.**





Figure 6.3. Create Propel Project

- 4. From the **IP Catalog** > **IP on Server**, download the Watchdog Timer IP. Then, generate the IP. Refer to Generating and Instantiating the IP section for more details.
- 5. After generating the Watchdog Timer IP, the **Define Instance** window opens. Modify the name if needed, then click **OK**.



Figure 6.4. Define Instance

- 6. Connect the instantiated IP to the system. Refer to Figure 6.1 for the connections used in this IP. You need to update/add other components of the system for the clock and reset source, interrupts, and bus interface.
- 7. Click the icon to launch the Lattice Radiant software.
- 8. Update your constraint file accordingly and generate the programming file. See Figure 6.5 for a sample .pdc file content dedicated for LAV-AT-E70ES1.

© 2025 Lattice Semiconductor Corp. All Lattice trademarks, registered trademarks, patents, and disclaimers are as listed at www.latticesemi.com/legal.

All other brand or product names are trademarks or registered trademarks of their respective holders. The specifications and information herein are subject to change without notice.



```
# Reset in push button SW1
ldc_set_location -site {AC17} [get_ports rstn_i]

# Set UART
ldc_set_location -site {T3} [get_ports s1_uart_rxd_i]
ldc_set_location -site {R3} [get_ports s1_uart_txd_o]

# Set LED in GPIO[0:7]
ldc_set_location -site {N7} [get_ports {s0_gpio[0]}]
ldc_set_location -site {L7} [get_ports {s0_gpio[1]}]
ldc_set_location -site {L8} [get_ports {s0_gpio[2]}]

# WDT
ldc_set_location -site {N10} [get_ports wdt_inst_reset_o_port]
```

Figure 6.5. Sample PDC File Content

- 9. After adding the constraint file, you may now run the compilation process and generate the bit stream file.
- 10. In the Lattice Propel Builder software, run Lattice Propel by clicking the icon. Then create a C/C++ project using the Hello World Project template.
- 11. Create your C-code from the main.c file accordingly. Figure 6.6 shows a sample C-code for the Watchdog Timer IP, this is to display the TIMER\_CNT\_1, TIMER\_CNT\_2, and INT\_STATUS\_REG using UART.

```
П
c main.c × h utils.h
                               gpio.c
                                                gpio.h
128⊖ int main(void) {
             static uint8 t idx = 0;
            static uint8_t pin_state = 0xFF;
unsigned int temp_read = 0;
            printf("Started!\nHello RISC-V world!\n");
            while (true) {
                 reg_32b_read(WDT_INST_BASE_ADDR + 0x14, (uint32_t *) &temp_read);
printf("Timeout Count 1 : 0x%x \r\n", temp_read);
                  reg_32b_read(\wordthing) = \text{Normal (n in temp read);}
printf("Timeout Count 2 : 0x%x \r\n", temp_read);
 141
                  reg_32b_read(WDT_INST_BASE_ADDR + 0x1C, (uint32_t *) &temp_read);
printf("Interrupt Status : 0x%x \r\n", temp_read);
                 reg_32b read(wDT_INST_BASE_ADDR + 0x1C, (uint32 t *) &temp_read);
printf("Interrupt Status : 0x%x \r\n", temp_read);
 145
 147
                 #ifdef GPIO INST BASE ADDR
 148
                  gpio_output_write(&gpio_inst, idx, pin_state);
 150
                 printf("0x%02X\n",(pin_state ^ (1<<idx)));</pre>
                  #endif
                 if (++idx == LED_COUNT) {
                       idx = 0;
                       pin_state = ~pin_state;
                 if (RTL_SIM) {
                       delay(1);
                 } else {
                       delay(500);
 164
 166
            return 0;
```

Figure 6.6. Sample C-Code for Watchdog Timer IP

12. This environment is now ready to run your tests on the device. Refer to the *Propel Tutorial – Hello World* section of the Lattice Propel SDK User Guide for the step-by-step guide.

### 6.5. Simulating the Example Design

Refer to the System Simulation Flow section of the Lattice Propel SDK User Guide.

© 2025 Lattice Semiconductor Corp. All Lattice trademarks, registered trademarks, patents, and disclaimers are as listed at www.latticesemi.com/legal.

All other brand or product names are trademarks or registered trademarks of their respective holders. The specifications and information herein are subject to change without notice.



## 6.6. Hardware Testing

### 6.6.1. Hardware Testing Setup

Download the generated bitstream file from the *Generating the Example Design* section to the LAV-AT-E70ES1 Development Board from the Lattice Radiant Programmer.

### 6.6.2. Expected Output

Below is a sample waveform captured by Reveal Inserter and Reveal Analyzer tools. Refer to the relevant sections in the Lattice Radiant Software user guide for more information on how to use the Reveal Inserter and Reveal Analyzer tools.



Figure 6.7. Sample Waveform



# 7. Designing with the IP

This section provides information on how to generate the Watchdog Timer IP using the Lattice Radiant Software and how to run simulation and synthesis. For more details on the Lattice Radiant Software, refer to the Lattice Radiant Software user guide.

## 7.1. Generating and Instantiating the IP

The Lattice Radiant Software allows you to customize and generate modules and IPs and integrate them into the device architecture. The procedure for generating the Watchdog Timer IP in Lattice Radiant Software is described below. To generate the Watchdog Timer IP:

- 1. Create a new Lattice Radiant Software project or open an existing project.
- In the IP Catalog tab, double-click on Watchdog Timer under IP, Processors\_Controllers\_and\_Peripherals category.
   The Module/IP Block Wizard opens, as shown in Figure 7.1. Enter values in the Component name and the Create in fields and click Next.



Figure 7.1. Module/IP Block Wizard

3. In the next **Module/IP Block Wizard** window, customize the selected Watchdog Timer IP using drop-down menus and check boxes. Figure 7.2 shows an example configuration of the Watchdog Timer IP. For details on the configuration options, refer to the IP Parameter Description section.





Figure 7.2. IP Configuration

4. Click **Generate**. The **Check Generated Result** dialog box opens, showing design block messages and results as shown in Figure 7.3.



Figure 7.3. Check Generated Result

5. Click **Finish**. All the generated files are placed under the directory paths in the **Create in** and the **Component name** fields, as shown in Figure 7.1.

© 2025 Lattice Semiconductor Corp. All Lattice trademarks, registered trademarks, patents, and disclaimers are as listed at www.latticesemi.com/legal.

All other brand or product names are trademarks or registered trademarks of their respective holders. The specifications and information herein are subject to change without notice.



#### 7.1.1. Generated Files and File Structure

The generated Watchdog Timer IP package includes the closed-box (<Component Name>\_bb.v) and instance templates (<Component Name>\_tmpl.v/vhd) that can be used to instantiate the core in a top-level design. An example RTL top-level reference source file (<Component Name>.v) that can be used as an instantiation template for the IP is also provided. You may also use this top-level reference as the starting template for the top-level for their complete design. The generated files are listed in Table 7.1.

Table 7.1. Generated File List

| Attribute                                        | Description                                                                                  |
|--------------------------------------------------|----------------------------------------------------------------------------------------------|
| constraints/ <component name="">.ldc</component> | This file contains the Pre-Synthesis Constraints for this IP.                                |
| misc/ <component name="">_tmpl.v</component>     | These files provide instance templates for the IP.                                           |
| misc/ <component name="">_tmpl.vhd</component>   | These files provide instance templates for the IP.                                           |
| rtl/ <component name="">.v</component>           | This file provides an example RTL top file that instantiates the IP.                         |
| rtl/ <component name="">_bb.v</component>        | This file provides the synthesis closed box.                                                 |
| testbench/dut_inst.v                             | This file contains the instance of the generated IP.                                         |
| testbench/dut_params.v                           | This file contains the parameter settings of the generated IP.                               |
| testbench/tb_apb_mst.v                           | This file contains additional testbench RTL for APB and is imported in testbench top module. |
| testbench/tb_top.v                               | This file is the testbench top module for the IP.                                            |
| component.xml                                    | Contains the ipxact: component information of the IP.                                        |
| design.xml                                       | Documents the configuration parameters of the IP in IP-XACT 2014 format.                     |
| <component name="">.ipx</component>              | This file contains the information on the files associated to the generated IP.              |
| <component name="">.cfg</component>              | This file contains the parameter values used in IP configuration.                            |

## 7.2. Design Implementation

Completing your design includes additional steps to specify analog properties, pin assignments, and timing and physical constraints. You can add and edit the constraints using the Device Constraint Editor or by manually creating a PDC File.

Post-Synthesis constraint files (.pdc) contain both timing and non-timing constraint.pdc source files for storing logical timing/physical constraints. Constraints that are added using the Device Constraint Editor are saved to the active .pdc file. The active post-synthesis design constraint file is then used as input for post-synthesis processes.

Refer to the relevant sections in the Lattice Radiant Software user guide for more information on how to create or edit constraints and how to use the Device Constraint Editor.

# **7.3.** Timing Constraints

You need to provide proper timing and physical design constraints to ensure that your design meets the desired performance goals on the FPGA device. Add the content of the following IP constraint file to your design constraints:

<Component Name>/constraints/<Component Name>.ldc

The above constraint file has been verified during IP evaluation with the IP instantiated directly at the top-level module. You can modify the constraints in this file provided you understand the effect of each constraint.

To use this constraint file, copy the contents of <Component Name>.ldc to the top-level design constrain for pre-synthesis.

Refer to the Lattice Radiant Timing Constraints Methodology (FPGA-AN-02059) for details on how to constrain your design.

© 2025 Lattice Semiconductor Corp. All Lattice trademarks, registered trademarks, patents, and disclaimers are as listed at www.latticesemi.com/legal.

All other brand or product names are trademarks or registered trademarks of their respective holders. The specifications and information herein are subject to change without notice.



## 7.4. Specifying the Strategy

The Radiant software provides two predefined strategies: Area and Timing. It also enables you to create customized strategies. For details on how to create a new strategy, refer to the Strategies section of the Lattice Radiant Software user guide.

## 7.5. Running Functional Simulation

You can run functional simulation after the IP is generated.

To run functional simulation:

1. Click the button located on the **Toolbar** to initiate the **Simulation Wizard**, as shown in Figure 7.4.



Figure 7.4. Simulation Wizard

2. Click **Next** to open the **Add and Reorder Source** window, as shown in Figure 7.5. Confirm that the **Source Files** are as shown in Figure 3.5. Remove other files if there are any.





Figure 7.5. Adding and Reorder Source

3. Click **Next**. The **Parse HDL files for simulation** window are as shown. Confirm that the Simulation Top Module is *tb top*.



Figure 7.6. Parse HDL Files for Simulation

4. Click **Next**. The Summary window is shown. Change the **Default Run** time to 0.





Figure 7.7. Summary

5. Click **Finish** to run the simulation. The waveforms in **Figure 7.8** shows an example simulation result. **Note:** It is necessary to follow the procedure above until it is fully automated in the Lattice Radiant Software Suite.



Figure 7.8. Simulation Waveform



# **Appendix A. Resource Utilization**

Table A.1 shows the resource utilization of the Watchdog Timer IP for the LFMXO5-25-9BBG400I device using Synplify Pro of Lattice Radiant software 2022.1. Default configuration is used, and some attributes are changed from the default value to show the effect on resource utilization.

Table A.1. LFMXO5-25-9BBG400I Device Resource Utilization

| Configuration                                                                                        | Clk Fmax (MHz) <sup>1</sup> | Registers | LUTs | EBRs |
|------------------------------------------------------------------------------------------------------|-----------------------------|-----------|------|------|
| Default                                                                                              | 169.66                      | 51        | 100  | 0    |
| Enable APB = Checked Others = Default                                                                | 200                         | 109       | 181  | 0    |
| Timer Stage 1 Number of Cycles: 500, Timer Stage 2 Number of Cycles: 500, Others = Default           | 200                         | 37        | 73   | 0    |
| Timer Stage 1 Number of Cycles: 75000000, Timer Stage 2 Number of Cycles: 75000000, Others = Default | 200                         | 51        | 98   | 0    |
| Mode: Time, System Clock Frequency: 150, Others = Default                                            | 200                         | 51        | 106  | 0    |
| Mode: Time, Timer Stage 1 Timeout: 500, Timer Stage 2 Timeout: 500, Others = Default                 | 189.97                      | 52        | 107  | 0    |

#### Note:

Table A.2 shows the resource utilization of the Watchdog Timer IP for the LFMXO5-25-7BBG400I device using Synplify Pro of Lattice Radiant software 2022.1. Default configuration is used, and some attributes are changed from the default value to show the effect on resource utilization.

Table A.2. LFMXO5-25-7BBG400I Device Resource Utilization

| Configuration                                                                                              | Clk Fmax (MHz) <sup>1</sup> | Registers | LUTs | EBRs |
|------------------------------------------------------------------------------------------------------------|-----------------------------|-----------|------|------|
| Default                                                                                                    | 132.14                      | 51        | 100  | 0    |
| Enable APB = Checked Others = Default                                                                      | 152.02                      | 109       | 181  | 0    |
| Timer Stage 1 Number of Cycles: 500, Timer Stage 2 Number of Cycles: 500, Others = Default                 | 170.45                      | 36        | 73   | 0    |
| Timer Stage 1 Number of Cycles: 75000000,<br>Timer Stage 2 Number of Cycles: 75000000,<br>Others = Default | 143.74                      | 51        | 98   | 0    |
| Mode: Time, System Clock Frequency: 150, Others = Default                                                  | 172.56                      | 51        | 107  | 0    |
| Mode: Time, Timer Stage 1 Timeout: 500, Timer Stage 2 Timeout: 500, Others = Default                       | 163.99                      | 52        | 107  | 0    |

#### Note:

 Fmax is generated when the FPGA design only contains Watchdog Timer IP, and the target frequencies are 150 MHz (for configured System Clock Frequency) and 100MHz (for other configurations). These values may be reduced when user logic is added to the FPGA design.

<sup>1.</sup> Fmax is generated when the FPGA design only contains Watchdog Timer IP, and the target frequencies are 150 MHz (for configured *System Clock Frequency*) and 100MHz (for other configurations). These values may be reduced when user logic is added to the FPGA design.



Table A.3 shows the resource utilization of the Watchdog Timer IP for the LAV-AT-E70-3LFG1156I device using Synplify Pro of Lattice Radiant software 2022.1. Default configuration is used, and some attributes are changed from the default value to show the effect on resource utilization.

Table A.3. LAV-AT- E70-3LFG1156I Device Resource Utilization

| Configuration                             | Clk Fmax (MHz) <sup>1</sup> | Registers | LUTs | EBRs |
|-------------------------------------------|-----------------------------|-----------|------|------|
| Default                                   | 245.58                      | 51        | 77   | 0    |
| Enable APB = Checked                      | 231.70                      | 109       | 164  | 0    |
| Others = Default                          | 251.70                      | 103       | 104  | O .  |
| Timer Stage 1 Number of Cycles: 500,      |                             |           |      |      |
| Timer Stage 2 Number of Cycles: 500,      | 251.76                      | 37        | 57   | 0    |
| Others = Default                          |                             |           |      |      |
| Timer Stage 1 Number of Cycles: 75000000, |                             |           |      |      |
| Timer Stage 2 Number of Cycles: 75000000, | 251.76                      | 51        | 77   | 0    |
| Others = Default                          |                             |           |      |      |
| Mode: Time,                               |                             |           |      |      |
| System Clock Frequency: 150,              | 251.76                      | 51        | 77   | 0    |
| Others = Default                          |                             |           |      |      |
| Mode: Time,                               |                             |           |      |      |
| Timer Stage 1 <i>Timeout</i> : 500,       | 251.76                      | 52        | 77   | 0    |
| Timer Stage 2 <i>Timeout</i> : 500,       | 231.70                      | J2        | ,,   | J    |
| Others = Default                          |                             |           |      |      |

#### Note:

Table A.4 shows the resource utilization of the Watchdog Timer IP for the LN2-CT-20-1ASG410I device using Synplify Pro of Lattice Radiant software 2024.2. Default configuration is used, and some attributes are changed from the default value to show the effect on resource utilization.

Table A.4. LN2-CT-20-1ASG410I Device Resource Utilization

| Configuration                                                                                        | Clk Fmax (MHz) <sup>1</sup> | Registers | LUTs | EBRs |
|------------------------------------------------------------------------------------------------------|-----------------------------|-----------|------|------|
| Default                                                                                              | 250                         | 52        | 80   | 0    |
| Enable APB = Checked Others = Default                                                                | 250                         | 129       | 151  | 0    |
| Timer Stage 1 Number of Cycles: 500, Timer Stage 2 Number of Cycles: 500, Others = Default           | 250                         | 38        | 57   | 0    |
| Timer Stage 1 Number of Cycles: 75000000, Timer Stage 2 Number of Cycles: 75000000, Others = Default | 250                         | 56        | 85   | 0    |
| Mode: Time, System Clock Frequency: 150, Others = Default                                            | 250                         | 52        | 76   | 0    |
| Mode: Time, Timer Stage 1 Timeout: 500, Timer Stage 2 Timeout: 500, Others = Default                 | 250                         | 55        | 63   | 0    |

#### Note:

1. Fmax is generated when the FPGA design only contains Watchdog Timer IP, and the target frequency is 100 MHz. These values may be reduced when user logic is added to the FPGA design.

<sup>1.</sup> Fmax is generated when the FPGA design only contains Watchdog Timer IP, and the target frequencies are 150 MHz (for configured *System Clock Frequency*) and 100MHz (for other configurations). These values may be reduced when user logic is added to the FPGA design.



# References

- AMBA 3 APB Protocol v1.0 Specification
- Lattice Radiant Timing Constraints Methodology (FPGA-AN-02059)
- Avant Evaluation Board User Guide (FPGA-EB-02057)
- Avant-E web page
- Avant-G web page
- Avant-X web page
- Certus-N2 web page
- Certus-NX web page
- CertusPro-NX web page
- CrossLink web page
- CrossLink-NX web page
- Mach-NX web page
- MachXO5-NX web page
- Lattice Propel Design Environment web page
- Lattice Propel SDK User Guide
- Lattice Radiant Software web page
- Lattice Solutions IP Cores web page
- Lattice Insights web page for Lattice Semiconductor training courses and learning plans



# **Technical Support Assistance**

Submit a technical support case through www.latticesemi.com/techsupport.

For frequently asked questions, refer to the Lattice Answer Database at www.latticesemi.com/Support/AnswerDatabase.



# **Revision History**

## Revision 1.8, IP v1.6.0, January 2025

| Section                          | Change Summary                                                                                                                                                                                                                                                                                                          |  |
|----------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| All                              | Added the IP version information on the cover page.                                                                                                                                                                                                                                                                     |  |
|                                  | Removed the previous 3.4. Hardware Evaluation section.                                                                                                                                                                                                                                                                  |  |
|                                  | Made editorial fixes.                                                                                                                                                                                                                                                                                                   |  |
| Abbreviations in This Document   | Replaced acronyms with abbreviations and updated this section.                                                                                                                                                                                                                                                          |  |
| Introduction                     | <ul> <li>Moved introductory paragraph in the 1. Introduction section to the 1.1. Overview of the IP section and updated the heading numbers of remaining sections accordingly.</li> <li>Updated Table 1.1. Quick Facts.</li> <li>Added the 1.3. IP Support Summary, 1.5. Licensing and Ordering Information,</li> </ul> |  |
|                                  | <ul> <li>1.6. Hardware Support, and 1.7. Minimum Device Requirements sections and updated the heading numbers of remaining sections accordingly.</li> <li>Renamed the previous 1.3. Conventions section to 1.8. Naming Conventions and removed the Attribute information.</li> </ul>                                    |  |
| Functional Descriptions          | <ul> <li>Renamed the previous 2.1 Overview section to 2.1. IP Architecture Overview and updated its content.</li> <li>Added non-APB Mode and APB Mode to the 2.1.2. Reset Signals section.</li> <li>Added the 2.2. Clocking, 2.3. Reset, and 2.4. User Interfaces sections.</li> </ul>                                  |  |
|                                  | <ul> <li>Moved the 2.6. Programming Flow section to the 2.5. Programming Flow section and updated its content.</li> <li>Moved the previous 2.5. Timing Diagrams section to the 2.6. Operation Details section and updated its content.</li> </ul>                                                                       |  |
| IP Parameter Description         | Moved the content from previous 2.3. Attribute Summary section to this section and updated its content.                                                                                                                                                                                                                 |  |
| Signal Description               | Moved the content from previous 2.2. Signal Description section to this section and updated its content.                                                                                                                                                                                                                |  |
| Register Description             | Moved the content from previous 2.4. Register Description section to this section and updated its content.                                                                                                                                                                                                              |  |
| Example Design                   | Added this section.                                                                                                                                                                                                                                                                                                     |  |
| Designing with the IP            | • Renamed the previous 3. IP Generation and Evaluation section to the 7. Designing with the IP and updated its content.                                                                                                                                                                                                 |  |
|                                  | <ul> <li>Moved the content from previous 3.1. Generation and Synthesis section to the</li> <li>7.1. Generating and Instantiating the IP section and updated its content, including all the figures.</li> </ul>                                                                                                          |  |
|                                  | <ul> <li>Removed the <i>eval/constraint.pdc</i> attribute from Table 7.1. Generated File List.</li> <li>Moved the content from previous 3.3. Constraining the IP section to the 7.3. Timing Constraints section and updated its content.</li> </ul>                                                                     |  |
|                                  | <ul> <li>Added the 7.2. Design Implementation and 7.4. Specifying the Strategy sections.</li> <li>Moved the content from previous 3.2. Running Functional Simulation section to the 7.5. Running Functional Simulation section and updated its content.</li> </ul>                                                      |  |
|                                  |                                                                                                                                                                                                                                                                                                                         |  |
| Appendix A. Resource Utilization | Added resource utilizations for the Lattice Radiant software version 2024.2.                                                                                                                                                                                                                                            |  |

## Revision 1.7, April 2024

| Section                | Change Summary                                                                                                        |
|------------------------|-----------------------------------------------------------------------------------------------------------------------|
| All                    | <ul> <li>Renamed document from Watchdog Timer IP Core - Lattice Radiant Software to<br/>Watchdog Timer IP.</li> </ul> |
|                        | • Changed black box to closed-box.                                                                                    |
| Inclusive Language     | Added the inclusive language boilerplate.                                                                             |
| Functional Description | Added information on kick signal in the Overview subsection.                                                          |
|                        | Moved the content for reset ports to the Reset Ports subsection.                                                      |

© 2025 Lattice Semiconductor Corp. All Lattice trademarks, registered trademarks, patents, and disclaimers are as listed at www.latticesemi.com/legal.

All other brand or product names are trademarks or registered trademarks of their respective holders. The specifications and information herein are subject to change without notice.

35



| Section    | Change Summary                                                                                                                           |  |
|------------|------------------------------------------------------------------------------------------------------------------------------------------|--|
|            | Added the Kick Signal subsection.                                                                                                        |  |
|            | <ul> <li>Updated the description for apb_psel_i and apb_pready_o in Table 2.1. Watchdog<br/>Timer IP Core Signal Description.</li> </ul> |  |
| References | Updated references.                                                                                                                      |  |

#### Revision 1.6, November 2023

| Section                          | Change Summary                                                                                                                                                                                                                                                                                                                                                     |
|----------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Disclaimers                      | Updated this section.                                                                                                                                                                                                                                                                                                                                              |
| Functional Description           | <ul> <li>Replaced 'computer' with 'processor' throughout this section.</li> <li>Updated Table 2.1. Watchdog Timer IP Core Signal Description.</li> <li>Updated Table 2.4. Register Address Map to replace the Access Type for WDT_MODE from RW to RO.</li> <li>Updated the Register Description section.</li> <li>Updated the Programming Flow section.</li> </ul> |
| IP Generation and Evaluation     | <ul> <li>Updated Figure 3.2. Configure the User Interface of Watchdog Timer IP Core.</li> <li>Updated Table 3.1. Generated File List to add testbench/dut_inst.v, testbench/dut_params.v, and eval/constraint.pdc.</li> <li>Added the Constraining the IP section</li> </ul>                                                                                       |
| Technical Support Assistance     | Updated to add the link for the Lattice Answer Database.                                                                                                                                                                                                                                                                                                           |
| References                       | Updated to add the link for Lattice Insights.                                                                                                                                                                                                                                                                                                                      |
| Appendix A. Resource Utilization | Updated to replace 500E with E70.                                                                                                                                                                                                                                                                                                                                  |

#### Revision 1.5, October 2022

| Section                          | Change Summary                                                                                                                                                                                                                                                                                                                                                                                  |
|----------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction                     | Added the feature Supports APB Interface to Features.                                                                                                                                                                                                                                                                                                                                           |
| Functional Description           | <ul> <li>Updated Figure 2.1. Functional Block Diagram and Figure 2.2. Timing Diagram.</li> <li>Newly added the Register Description and Programming Flow sections.</li> <li>In Table 2.1. Watchdog Timer IP Core Signal Description:         <ul> <li>removed WDT Ports;</li> <li>added APB Ports.</li> </ul> </li> <li>Table 2.2. Attributes Table: added the Enable APB attribute.</li> </ul> |
| IP Generation and Evaluation     | Table 2.3. Attributes Descriptions: added the Enable APB attribute.  Updated Figure 3.1. Module/IP Block Wizard, Figure 3.2. Configure the User Interface of Watchdog Timer IP Core, Figure 3.3. Check Generating Result, Figure 3.4. Simulation Wizard, Figure 3.5. Adding and Reordering Source, and Figure 3.6. Simulation Waveform.                                                         |
| Appendix A. Resource Utilization | <ul> <li>Updated Table A.1. Resource Utilization (LFMXO5-25-9BBG400I) and Table A.2. Resource Utilization (LFMXO5-25-7BBG400I).</li> <li>Newly added Table A.3. Resource Utilization (LAV-AT- E70-3LFG1156I).</li> </ul>                                                                                                                                                                        |

#### Revision 1.4, May 2022

| Section                          | Change Summary                                                                                                                                           |
|----------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction                     | Updated Table 1.1. Quick Facts. Added Table A.2. Resource Utilization (LFMXO5-25-7BBG400I) to the Resource Utilization row.                              |
| IP Generation and Evaluation     | Updated Figure 3.1. Module/IP Block Wizard, Figure 3.2. Configure the User Interface of Watchdog Timer IP Core, and Figure 3.3. Check Generating Result. |
| Appendix A. Resource Utilization | Updated Table A.1. Resource Utilization (LFMXO5-25-9BBG400I) and Table A.2. Resource Utilization (LFMXO5-25-7BBG400I).                                   |



#### Revision 1.3, June 2021

| Section      | Change Summary                                                                               |
|--------------|----------------------------------------------------------------------------------------------|
| Introduction | Remove second paragraph.      Hedged Table 1.1. Quick Facts                                  |
|              | <ul> <li>Updated Table 1.1. Quick Facts.</li> <li>Revised Supported FPGA Families</li> </ul> |
|              | Revised Targeted Devices                                                                     |
|              | Revised Lattice Implementation.                                                              |
|              | Revised reference to Lattice Radiant Software User Guide                                     |
| References   | Revised reference to Lattice Radiant Software User Guide and removed link.                   |

#### Revision 1.2, June 2020

| Section                          | Change Summary                                                                                                                                                                                                  |
|----------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction                     | Added Certus-NX support.                                                                                                                                                                                        |
|                                  | Updated Table 1.1 to add LFD2NX-40 as targeted device.                                                                                                                                                          |
|                                  | Updated Synopsis Synplify Pro version.                                                                                                                                                                          |
|                                  | Updated Lattice Implementation to Lattice Radiant 2.1.                                                                                                                                                          |
| Attribute Summary                | Removed Calculated group. The calculated <i>Timeout (number of cycles)</i> are now reflected in Timer Stage N group. Default value of <i>Timeout (number of cycles) is changed</i> due to IP Engine limitation. |
| IP Generation and Evaluation     | Updated Figure 3.2.                                                                                                                                                                                             |
| Appendix A. Resource Utilization | <ul> <li>Updated device to LIFCL-40-9BG400I.</li> <li>Added column for Fmax in Table A1.</li> </ul>                                                                                                             |
| All                              | Updated references to Lattice Radiant Software 2.1 User Guide.                                                                                                                                                  |

#### Revision 1.1, February 2020

| Section      | Change Summary                                        |
|--------------|-------------------------------------------------------|
| Introduction | Updated Table 1.1 to add LIFCL-17 as targeted device. |

## Revision 1.0, December 2019

| Section | Change Summary   |
|---------|------------------|
| All     | Initial release. |



www.latticesemi.com