

## **CoreWatchdog**

## **Product Summary**

### **Intended Use**

 Intended for Use with CoreMP7 to Protect and Recover from Software Errors

### **Key Features**

- Optimized for Use with CoreMP7
- Configurable 16-Bit or 32-Bit Watchdog Timer
- Runs from the Advanced Peripheral Bus (APB)
   Clock (PCLK) No Additional Clock Required
- Pre-scale Provides Clock Division by up to 1,024
- Supplied in SysBASIC Core Bundle

### **Benefits**

- Prevent an Embedded System from Hanging from Software Errors
- Automatically Connect Clocks and Resets in the System in CoreConsole
- Compatible with Advanced Microcontroller Bus Architecture (AMBA) and CoreMP7

## **ARM Supported Families**

- ProASIC<sup>®</sup>3 (M7A3P)
- ProASIC3E (M7A3PE)
- Fusion (M7AFS)

### **Synthesis and Simulation support**

 Supported in the Actel Libero<sup>®</sup> Integrated Design Environment (IDE)

### **Verification and Compliance**

Compliant with AMBA

### **Contents**

| Introduction                           | 1 |
|----------------------------------------|---|
| Functional Description                 | 2 |
| Connecting CoreWatchdog in CoreConsole | 2 |
| CoreWatchdog Configurable Options      | 2 |
| Programmer's Model                     | 3 |
| Resource Usage                         | 4 |
| Ordering Information                   | 4 |
| Datasheet Categories                   | 4 |

## Introduction

CoreWatchdog is an APB slave that provides a means of recovering from software crashes. When enabled, CoreWatchdog will generate a soft reset for the system if the microprocessor fails to refresh it on a regular basis. Figure 1 shows a top-level block diagram of CoreWatchdog.



Figure 1 • CoreWatchdog Block Diagram

## **Functional Description**

CoreWatchdog is similar to a timer module in that it is based on a decrementing counter which can be used to assert a reset signal if it is allowed to time out.

The width of the decrementing counter in the CoreWatchdog module can be statically configured as either 16 or 32 bits. Processor-accessible registers provide a means to control and monitor the operation of the watchdog.

### **Operation**

The operation of CoreWatchdog is based around a counter. The counter is loaded with a value stored in a load register, and if enabled, it will count down towards zero. If the count reaches zero, the watchdog reset (WDOGRES) is asserted and should be used to reset the system. Under normal operation, the count is prevented

from reaching zero by the processor refreshing it at regular intervals.

Counter refresh is effected by writing to the address of the refresh register; any data value may be written. A write to the refresh register address results in the counter being reloaded with the value stored in the load register.

When the counter is already running, writing to the load register will cause the counter to immediately restart at the new value.

The WDOGRES reset signal from CoreWatchdog is asserted for four cycles of PCLK.

A pre-scale unit is used to provide a clock enable pulse for the decrementing counter. The pre-scaler is driven by the APB clock (PCLK) and can be programmed via the watchdog control register to provide an enable pulse every 2, 4, 8, 16, 32, 64, 128, 256, 512, or 1,024 periods of PCLK. This effectively allows the counter to operate from a lower frequency than that at which PCLK is running.

## **Connecting CoreWatchdog in CoreConsole**

Table 1 lists the ports present on the CoreWatchdog module and describes how to connect these in CoreConsole.

Table 1 • CoreWatchdog Connections

| Connection            | CoreConsole Label | Description                                                                                                                                                                                                                  |  |
|-----------------------|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Required Connections  |                   |                                                                                                                                                                                                                              |  |
| APB slave interface   | APBslave          | Connect this interface to any available slave slot on the APB Bus.                                                                                                                                                           |  |
| PCLK                  | PCLK              | APB clock signal.  Normally connected to the HCLK output of the MP7Bridge.                                                                                                                                                   |  |
| PRESETn               | PRESETn           | Active low APB reset input.  Normally connected to the HRESETn output of the MP7Bridge.                                                                                                                                      |  |
| Watchdog reset input  | WDOGRESn          | Active low reset input. Asserted when hardware reset is asserted. Resets t circuitry that generates the WDOGRES output.  Normally connected to the WDOGRESn output of the MP7Bridge.                                         |  |
| Watchdog reset output | WDOGRES           | Active high reset output, asserted for four cycles of PCLK. This signal indicates that the watchdog counter has timed out, and should be used to reset the system. Normally connected to the WDOGRES input of the MP7Bridge. |  |

## **CoreWatchdog Configurable Options**

The width of the counter in CoreWatchdog can be configured as either 16 bits or 32 bits (Table 2).

Table 2 • CoreWatchdog Configurable Options

| Configurable Option | Default Setting | Description                                    |  |  |
|---------------------|-----------------|------------------------------------------------|--|--|
| Counter width       | 32 bits         | Sets the width of the counter in CoreWatchdog. |  |  |
|                     |                 | Possible settings are "32 bit" and "16 bit."   |  |  |

2 Advanced v0.1



## **Programmer's Model**

Table 3 gives the CoreWatchdog registers.

Table 3 • CoreWatchdog Registers

| Offset | Туре       | Width    | Reset Value          | Name        | Description            |
|--------|------------|----------|----------------------|-------------|------------------------|
| 0x00   | Read/Write | 16 or 32 | 0x0000 or 0x00000000 | WdogLoad    | Load value for counter |
| 0x04   | Read       | 16 or 32 | OxFFFF or OxFFFFFFF  | WdogValue   | Current counter value  |
| 0x08   | Read/Write | 5        | 0x00                 | WdogControl | Control register       |
| 0x0C   | Write      | _        | -                    | WdogRefresh | Refresh register       |

### Load Register - WdogLoad

This register contains the value from which the watchdog counter is to decrement. When this register is written to, the counter is loaded with the value written and begins to decrement if the watchdog is enabled.

The load register is either 16 or 32 bits wide, depending on how CoreWatchdog is configured.

## **Current Value Register – WdogValue**

This register gives the current value of the decrementing counter. The reset output signal is asserted if the counter reaches zero.

The current value register is either 16 or 32 bits wide, depending on how CoreWatchdog is configured.

# Watchdog Control Register – WdogControl

The bit assignments for the WdogControl register are given in Table 4.

Table 4 • Bit Assignments for the WdogControl Register

| Bit(s) | Name            | Туре       | Function                                                                                                                                                                                                                                                                                                                             |
|--------|-----------------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:5   | -               | -          | Unused; reads zero.                                                                                                                                                                                                                                                                                                                  |
| 4      | Watchdog Enable | Read/Write | Enable bit for watchdog:  0 = Watchdog disabled (default)  1 = Watchdog enabled                                                                                                                                                                                                                                                      |
| 3:0    | Pre-scale       | Read/Write | Pre-scale field. Determines effective clock rate for counter based on PCLK:  0000 = divide by 2 (default)  0001 = divide by 4  0010 = divide by 8  0011 = divide by 16  0100 = divide by 32  0101 = divide by 64  0110 = divide by 128  0111 = divide by 256  1000 = divide by 512  1001 = divide by 1,024  Others = divide by 1,024 |

#### CoreWatchdog

## Watchdog Refresh Register – WdogRefresh

A write to this register will cause the counter to be reloaded with the value in the load register. Any data may be written. This register reads zero.

## **Resource Usage**

In a ProASIC3E device, the utilization is as follows:

Configured with 16-bit counter: 280 tiles
Configured with 32-bit counter: 490 tiles

## **Ordering Information**

CoreWatchdog is included in the SysBASIC core bundle that is supplied with the Actel CoreConsole IP Deployment Platform tool. The obfuscated RTL version of SysBASIC (SysBASIC-OC) is available for free with CoreConsole. The source RTL version of SysBASIC (SysBASIC-RM) can be ordered through your local Actel sales representative. CoreWatchdog cannot be ordered separately from the SysBASIC core bundle.

## **Datasheet Categories**

In order to provide the latest information to designers, some datasheets are published before data has been fully characterized. Datasheets are designated as "Product Brief," "Advanced," and "Production." The definitions of these categories are as follows:

### **Product Brief**

The product brief is a summarized version of an advanced or production datasheet containing general product information. This brief summarizes specific device and family information for unreleased products.

### **Advanced**

This datasheet version contains initial estimated information based on simulation, other products, devices, or speed grades. This information can be used as estimates, but not for production.

## **Unmarked (production)**

This datasheet version contains information that is considered to be final.

4 Advanced v0.1

Actel and the Actel logo are registered trademarks of Actel Corporation.

All other trademarks are the property of their owners.



#### www.actel.com

### **Actel Corporation**

2061 Stierlin Court Mountain View, CA 94043-4655 USA **Phone** 650.318.4200 **Fax** 650.318.4600

### Actel Europe Ltd.

Dunlop House, Riverside Way Camberley, Surrey GU15 3YL United Kingdom

**Phone** +44 (0) 1276 401 450 **Fax** +44 (0) 1276 401 490

### **Actel Japan**

www.jp.actel.com

EXOS Ebisu Bldg. 4F 1-24-14 Ebisu Shibuya-ku Tokyo 150 Japan

**Phone** +81.03.3445.7671 **Fax** +81.03.3445.7668

## **Actel Hong Kong**

www.actel.com.cn

Suite 2114, Two Pacific Place 88 Queensway, Admiralty Hong Kong

**Phone** +852 2185 6460 **Fax** +852 2185 6488