

**Application Note** 

# 78K0

## **8-Bit Single-Chip Microcontrollers**

Window Watchdog Timer

78K0/Fx2 Series

78K0/Kx2 Series

78K0/Lx2 Series

Document No. U18758EE1V1AN00 Date Published 5<sup>th</sup> July 2007 © NEC Electronics Corporation 2007 Printed in Germany [MEMO]

- The information in this document is current as of April, 2007. The information is subject to change without notice. For actual design-in, refer to the latest publications of NEC Electronics data sheets or data books, etc., for the most up-to-date specifications of NEC Electronics products. Not all products and/or types are available in every country. Please check with an NEC Electronics sales representative for availability and additional information.
- No part of this document may be copied or reproduced in any form or by any means without the prior written consent of NEC Electronics. NEC Electronics assumes no responsibility for any errors that may appear in this document.
- NEC Electronics does not assume any liability for infringement of patents, copyrights or other intellectual property rights of third parties by or arising from the use of NEC Electronics products listed in this document or any other liability arising from the use of such products. No license, express, implied or otherwise, is granted under any patents, copyrights or other intellectual property rights of NEC Electronics or others.
- Descriptions of circuits, software and other related information in this document are provided for illustrative purposes in semiconductor product operation and application examples. The incorporation of these circuits, software and information in the design of a customer's equipment shall be done under the full responsibility of the customer. NEC Electronics assumes no responsibility for any losses incurred by customers or third parties arising from the use of these circuits, software and information.
- While NEC Electronics endeavors to enhance the quality, reliability and safety of NEC Electronics
  products, customers agree and acknowledge that the possibility of defects thereof cannot be eliminated
  entirely. To minimize risks of damage to property or injury (including death) to persons arising from
  defects in NEC Electronics products, customers must incorporate sufficient safety measures in their
  design, such as redundancy, fire-containment and anti-failure features.
- NEC Electronics products are classified into the following three quality grades: "Standard", "Special" and "Specific".

The "Specific" quality grade applies only to NEC Electronics products developed based on a customerdesignated "quality assurance program" for a specific application. The recommended applications of an NEC Electronics product depend on its quality grade, as indicated below. Customers must check the quality grade of each NEC Electronics product before using it in a particular application.

- "Standard": Computers, office equipment, communications equipment, test and measurement equipment, audio and visual equipment, home electronic appliances, machine tools, personal electronic equipment and industrial robots.
- "Special": Transportation equipment (automobiles, trains, ships, etc.), traffic control systems, anti-disaster systems, anti-crime systems, safety equipment and medical equipment (not specifically designed for life support).
- "Specific": Aircraft, aerospace equipment, submersible repeaters, nuclear reactor control systems, life support systems and medical equipment for life support, etc.

The quality grade of NEC Electronics products is "Standard" unless otherwise expressly specified in NEC Electronics data sheets or data books, etc. If customers wish to use NEC Electronics products in applications not intended by NEC Electronics, they must contact an NEC Electronics sales representative in advance to determine NEC Electronics' willingness to support a given application.

#### (Note)

(1) "NEC Electronics" as used in this statement means NEC Electronics Corporation and also includes its majority-owned subsidiaries.

(2) "NEC Electronics products" means any product developed or manufactured by or for NEC Electronics (as defined above).

M8E 02. 11-1

### **Regional Information**

Some information contained in this document may vary from country to country. Before using any NEC product in your application, please contact the NEC office in your country to obtain a list of authorized representatives and distributors. They will verify:

- Device availability
- Ordering information
- Product release schedule
- · Availability of related technical literature
- Development environment specifications (for example, specifications for third-party tools and components, host computers, power plugs, AC supply voltages, and so forth)
- Network requirements

In addition, trademarks, registered trademarks, export restrictions, and other legal issues may also vary from country to country.

#### NEC Electronics America Inc.

Santa Clara, California Tel: 408-588-6000 800-366-9782 Fax: 408-588-6130 800-729-9288

#### NEC Electronics (Europe) GmbH

Duesseldorf, Germany Tel: 0211-65 030 Fax: 0211-65 03 1327

#### Sucursal en España

Madrid, Spain Tel: 091-504 27 87 Fax: 091-504 28 60

#### Succursale Française

Vélizy-Villacoublay, France Tel: 01-30-67 58 00 Fax: 01-30-67 58 99 
 Filiale Italiana

 Milano, Italy

 Tel:
 02-66 75 41

 Fax:
 02-66 75 42 99

Branch The Netherlands Eindhoven, The Netherlands Tel: 040-244 58 45 Fax: 040-244 45 80

#### Branch Sweden

Taeby, Sweden Tel: 08-63 80 820 Fax: 08-63 80 388

#### United Kingdom Branch

Milton Keynes, UK Tel: 01908-691-133 Fax: 01908-670-290 NEC Electronics Hong Kong Ltd.

Hong Kong Tel: 2886-9318 Fax: 2886-9022/9044

NEC Electronics Hong Kong Ltd. Seoul Branch Seoul, Korea Tel: 02-528-0303

Fax: 02-528-4411

#### NEC Electronics Singapore Pte. Ltd.

Singapore Tel: 65-6253-8311 Fax: 65-6250-3583

#### NEC Electronics Taiwan Ltd.

Taipei, Taiwan Tel: 02-2719-2377 Fax: 02-2719-5951

### Introduction

| Target Readers      | This application note is intended for users who understand the functions of the 78K0/Fx2/Kx2/Lx2 and will use this product to design application systems.                                                                                                                                                                                                                                                                                                                                                        |
|---------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Purpose             | The purpose of this application note is to help users to understand the functionality, benefits and how to use the window – watchdog timer, implemented in several microcontrollers of the 78K0/Fx2/Kx2 and Lx2 – subseries. The handling and usage shown in this document are for reference only. Correct operation is not guaranteed if these samples are implemented as they are described here. The user has to adapt the usage and handling of the window watchdog timer to his application specific needs. |
| Organization        | <ul> <li>This manual consists of the following main sections.</li> <li>Reason for using a window watchdog</li> <li>Functionality of a window watchdog</li> <li>Usage example of a window watchdog in an application</li> <li>Hints for handling during stand – by modes</li> <li>Register settings for window watchdog settings</li> </ul>                                                                                                                                                                       |
| How to Read This Ma | nual<br>It is assumed that the reader of this manual has general knowledge in<br>the fields of electrical engineering, logic circuits, and microcontrollers.                                                                                                                                                                                                                                                                                                                                                     |
|                     | <ul> <li>To gain a general understanding of functions:</li> <li>→ Read this manual in the order of the <b>CONTENTS</b>. The mark "<r>" shows major revised points. The revised points can be easily searched by copying an "<r>" in the PDF file and specifying it in the "Find what:" field.</r></r></li> </ul>                                                                                                                                                                                                 |
|                     | • To learn more about the 78K0/Kx2's hardware functions: $\rightarrow$ See the user's manual of each 78K0 product.                                                                                                                                                                                                                                                                                                                                                                                               |
| Conventions         | Data significance:Higher digits on the left and lower digits on the rightActive low representation:xxx (overscore over pin or signal name)Note:Footnote for item marked with Note in the textCaution:Information requiring particular attentionRemark:Supplementary informationNumeral representation:BinaryxxxxDecimalxxxxHexadecimalxxxxH                                                                                                                                                                      |

### **Table of Contents**

| CHAP | TER 1 | REASON FOR A WINDOW WATCHDOG                                                         | 8  |
|------|-------|--------------------------------------------------------------------------------------|----|
| 1.1  | Reas  | on and benefit of a watchdog in general                                              | 8  |
| 1.2  |       | antage of a window watchdog compared to a usual watchdog                             |    |
| СНАР | TER 2 | FUNCTIONALITY OF A WINDOW WATCHDOG                                                   | 9  |
| 2.1  | Fund  | lamental description of the window watchdog timer in 78K0/Fx2/Kx2/Lx2                | 9  |
| 2.2  |       | low open / window close period                                                       |    |
| 2.3  | Optio | on Byte                                                                              | 11 |
| СНАР | TER 3 | WINDOW WATCHDOG IN THE APPLICATION                                                   | 13 |
| 3.1  | Supe  | ervision of window close time to find proper WDT restart condition                   | 13 |
| 3.2  |       | restart during window open period                                                    |    |
| 3.3  | Hand  | lling of timer H1 for window close supervision                                       | 14 |
| СНАР | TER 4 | HANDLING THE WINDOW OPEN PERIOD                                                      | 15 |
| СНАР | TER 5 | HANDLING OF THE INTERNAL LOW-SPEED OSCILLATOR                                        | 16 |
| 5.1  | Stop  | of internal low-speed oscillator                                                     | 16 |
| 5.2  | Wind  | low Watchdog in HALT and STOP – mode                                                 | 17 |
|      | 5.2.1 | Functionality when internal low-speed osc. can be stopped by software (LSROSC=0)     | 17 |
|      | 5.2.2 | Functionality when internal low-speed oscillator can not be stopped by SW (LSROSC=1) | 17 |
| СНАР | TER 6 | OPTION BYTE SETTING FOR WINDOW WATCHDOG                                              | 18 |
| 6.1  | Form  | nat of the Option Byte                                                               | 18 |
| 6.2  | Exan  | nple: Setting of the Option Byte in the user's source file                           | 19 |
|      | 6.2.1 | Setting of the Option Byte using relocatable segments                                | 19 |
|      | 6.2.  | 1.1 Example: Selection of the watchdog's behavior                                    | 19 |
|      |       | 6.2.1.1.1 in C – language                                                            | 19 |
|      |       | 6.2.1.1.2 in assembler ( IAR – workbench, used in Europe )                           | 19 |
|      | 6.2.2 | Setting of the Option Byte using absolute addressing                                 | 20 |
|      |       | 6.2.2.1.1 in C – language                                                            | 20 |
|      |       | 6.2.2.1.2 in assembler ( IAR – workbench, used in Europe )                           | 20 |
|      |       | 6.2.2.1.3 in assembler ( Japanese Tool, not available in Europe )                    | 20 |

### List of Figures

| Figure 2-2. Window close period / window open period                     | 10 |
|--------------------------------------------------------------------------|----|
| Figure 2-3. Option byte for watchdog timer settings                      | 11 |
| Figure 2-4. Timing selection of the window watchdog                      | 12 |
| Figure 3-1. Timer H1 supervise the window close time                     | 13 |
| Figure 3-2. WDT restart during open window time range                    | 14 |
| Figure 3-3. Sequential restart of the WDT using timer H1                 | 14 |
| Figure 4-1. Simplified operating system, handling watchdog timer restart | 15 |
| Figure 5-1. Format of internal oscillation mode register ( RCM )         | 16 |
| Figure 6-1. Format of option byte                                        | 18 |

#### CHAPTER 1 REASON FOR A WINDOW WATCHDOG

#### 1.1 Reason and benefit of a watchdog in general

In an application, after reset, the microcontroller has to control the functionality of a device. Usually the system works properly up to the time, the device is switched off.

In rare cases, it might happen that the microcontroller is running out of control. Several reasons can be responsible for that phenomena and the effect of being out of control to the application can show a lot of different behaviors.

One example for malfunction might be a software bug, which guides the software into an endless loop. In thiscase, the microcontroller shows no reaction or action at all for ever. So, the application is out of order. The user has to initiate a reset (e.g. by switching off and on the power) to reactivate the application.

A watchdog is an internal or external peripheral, which has to be restarted by the software sequential within a pre-defined timing range. If the software runs fail (e.g. by stucking in an endless loop) and the watchdog is not restarted within the expected time, the watchdog generates an hardware reset. Using such kind of security - peripheral, it is given that an application does not stuck for all time and the application restarts and recovers. This does not prohibit the malfunction, but it recovers the application.

#### 1.2 Advantage of a window watchdog compared to a usual watchdog

A usual watchdog has only one (selectable) time period within the watchdog can be restarted. The restart can be anywhere up to the time where the watchdog time has elapsed. There is only one restriction for proper functionality of the application: restart has to be done before watchdog - timer overflows.

If the microcontroller stucks in an endless loop in which restarting of the watchdog – timer is implemented accidently, the microcontroller will also stuck for ever, as if no watchdog is implemented at all.

The window watchdog timer (WDT) has two time stamps within the restart is allowed: A dedicated time after WDT start and the overflow time, the so called "open window". When a restart is triggered during this time frame, WDT restart is done. If the restart is triggered outside this window, a reset of the microcontroller is initiated.

The chance that the microcontroller will stuck just within an endless loop where a restart of the watchdog – timer is implemented by accident might be very seldom. Stucking in an endless loop where a restart of the watchdog – timer is implemented just within the watchdog window open time frame might be nearly impossible.

So, the window watchdog increase the security level of the system, compared to a simple watchdog.

An internal window watchdog is implemented in 78K0/Fx2/Kx2/Lx2 subseries.

#### CHAPTER 2 FUNCTIONALITY OF A WINDOW WATCHDOG

#### 2.1 Fundamental description of the window watchdog timer in 78K0/Fx2/Kx2/Lx2

The block diagram of the watchdog timer (WDT) in 78K0/Fx2/Kx2/Lx2 is shown in Figure 2-1.



Figure 2-1. Block diagram of window watchdog timer

Operation can be enabled or disabled by means of setting of bit WDTON in the option byte. The window watchdog timer is clocked with the internal low-speed oscillator. The overflow time and open window time can be selected. When enabled, the window watchdog timer has to be restarted by software within the choosen open window time; otherwise an internal reset is generated.

#### 2.2 Window open / window close period

A usual watchdog timer has to be restarted during any time but before watchdog timer has elapsed to perform proper functionality of the application.

In opposite to a usual watchdog timer, the window watchdog timer has to be restarted during a specific time period, the so called window open period (see: Figure 2-2). If there is no restart during the window open period, the watchdog overflows and generates an internal reset, same as a usual watchdog timer.

If there is an attempt to restart the window watchdog timer before window open period begins, there is also an internal reset generated. This feature is not implemented in an usual watchdog timer.



Figure 2-2. Window close period / window open period

The open window period can be selected within four steps: 25%, 50%, 75% and 100%.

When 100% window open period is selected, the functionality is the same like a simple watchdog timer, due to restart access can be done within any time below watchdog timer overflow.

In this application note, as an example, 25% window open period is chosen.

#### 2.3 Option Byte

In case of 78K0/Fx2/Kx2/Lx2, the fundamental setting of the watchdog timer (WDT) is done within the option byte. The option byte selects if the watchdog timer is enabled or not. When it is enabled, the watch timer overflow time is valid, set with bits WDCS2 – WDCS0. Furthermore, the open window time-frame can be fixed in four levels.





Due to the option byte is located within the flash area, its setting can not be changed by software. This is an additional security item.

#### **Remarks:**

Window open period (Window1, Window0):

Take care that the window open period is wide enough for usual handling and WDT retrigger even when CPU is under highest load and interrupt handling is necessary. If necessary, select a wider window period.

Watchdogtimer enable / disable ( WDTON ):

When WDT is enabled, be aware that the watchdog timer starts operation just after reset release. For proper functionality of the application, you have to take care to restart the WDT periodical or stop the internal low-speed oscillator (if LSROSC = 0).

Internal low-speed oscillator can be switched off / cannot be switched off by software (LSROSC):

If you choose "cannot be switched off by software", be aware that you have to take care to restart the WDT periodical in any case, even in HALT and in STOP mode.

The correspondence between bit – setting in option byte and timing is described in the Figure 2-4.



Figure 2-4. Timing selection of the window watchdog

#### CHAPTER 3 WINDOW WATCHDOG IN THE APPLICATION

#### 3.1 Supervision of window close time to find proper WDT restart condition

After the watchdog timer is restarted, the watchdog timer must not be resetted during the window close time, otherwise a reset is generated. Therefore, the time when the window is closed has to be supervised. This can be done with a timer.

The window watchdog timer is clocked with the internal low-speed oscillator. This internal low-speed oscillator has a tolerance. To eliminate this tolerance, the timer which supervises the window watchdog timer should be clocked with the same oscillator in best case. So, timer H1 is optimal to be used for the supervision of the window – close time, due to the same clock source is used ( see: Figure 2-2 ). Of course, when you are aware about that tolerance, any other time base is also suitable.



Figure 3-1. Timer H1 supervise the window close time

#### 3.2 WDT restart during window open period

To avoid that the window watchdog generates a reset, it has to be restarted during window open time only. If the watchdog timer overflows, a reset is generated. If the software attempts to restart the WDT below the window range, a reset is also generated. See Figure 3-2 for proper restart handling of the WDT.



Figure 3-2. WDT restart during open window time range

There is one exception for restart – timing. Just after reset release, restarting the watchdog timer is independent from the selected window open time. That means, after reset release the first restart access can be done within any time but before watchdog timer overflow.

#### 3.3 Handling of timer H1 for window close supervision

Figure 3-3 shows the handling for proper restart handling of the window watchdog timer.



Figure 3-3. Sequential restart of the WDT using timer H1

#### CHAPTER 4 HANDLING THE WINDOW OPEN PERIOD

The software has to be prepared to restart the window watchdog just during window open time.

Figure 4-1 shows an example of a simplified operating system, focused on the window watchdog timer handling, for proper WDT restart using timer H1.



Figure 4-1. Simplified operating system, handling watchdog timer restart

In the example above, after reset release, timer H1 is initialized that its overflow – interrupt occurs after window close time has elapsed. WDT is restarted and timer H1 is started.

An timer H1 interrupt service routine is implemented to set a marker bit that window close time has been elapsed, for further action in the operating system.

In the endless loop of the operating system, one of its tasks is to detect if timer H1 has had an overflow or not (WDT restart marker = 1 ?). If the marker is set, the task has to restart the WDT, the marker has to be resetted and the timer H1 has to restart for supervision of the next window close period.

User has to take care that the microcontroller is able to restart the WDT between window close time has elapsed and watchdog timer overflows ( the window open time ), even at the highest load of the CPU. Don't forget that e.g. interrupts can lengthen the operation time. If the expected time might exceed the window open period, either the WDT overflow time has to be lengthened or an extended window open time has to be selected.

**Remark**: It is dangerous to implement the WDT restart in the H1 interrupt service routine. Therefore restarting of the WDT within an interrupt routine is not recommended.

Reason: If the CPU stucks in an endless loop but interrupt handling is enabled, there is no reset due to WDT restart is done in time within the interrupt service routine.

#### CHAPTER 5 HANDLING OF THE INTERNAL LOW-SPEED OSCILLATOR

#### 5.1 Stop of internal low-speed oscillator

The value of bit 0 (LSROSC) in the option byte selects if the internal low-speed oscillator can be stopped by software or not (see: Figure 2-3).

When stopping of the internal low-speed oscillator is enabled (LSROSC = 0), Bit 1 of the RCM register (LSRSTOP) can be used to run or stop the internal low-speed oscillator (see: Figure 5-1).

|             | Figure 5-1. Format of internal oscillation mode register ( RCM ) |                                           |                                       |               |                 |                  |         |       |
|-------------|------------------------------------------------------------------|-------------------------------------------|---------------------------------------|---------------|-----------------|------------------|---------|-------|
| Address: FF | A0H After r                                                      | eset: 80H <sup>Note</sup>                 | R/W <sup>Note 2</sup>                 |               |                 |                  |         |       |
| Symbol      | <7>                                                              | 6                                         | 5                                     | 4             | 3               | 2                | <1>     | <0>   |
| RCM         | RSTS                                                             | 0                                         | 0                                     | 0             | 0               | 0                | LSRSTOP | RSTOP |
|             |                                                                  |                                           |                                       |               |                 |                  |         |       |
|             | LSRSTOP                                                          |                                           | Int                                   | ernal low-spe | ed oscillator o | oscillating/stop | oped    |       |
|             | 0                                                                | Internal low-speed oscillator oscillating |                                       |               |                 |                  |         |       |
|             | 1                                                                | Internal low-                             | Internal low-speed oscillator stopped |               |                 |                  |         |       |

When stopping of the internal low-speed oscillator is enabled (LSROSC = 0) and Bit 1 of the RCM register is set by software (LSRSTOP = 1), the watchdog timer (and the timer H1 if clocked with the internal low-speed oscillator ) will halt counting.

This feature can be used for halting the watchdog timer for a certain time.

When the internal low-speed oscillator is stopped, the counter values in WDT (and H1) keep their values and there is no reset of its counter values. Keep that in mind, when you will enable internal lowspeed oscillator operation again.

#### 5.2 Window Watchdog in HALT and STOP – mode

#### 5.2.1 Functionality when internal low-speed osc. can be stopped by software (LSROSC=0)

When stopping of the internal low-speed oscillator is enabled (LSROSC = 0), the internal low-speed oscillator is halted automatically, when the HALT or STOP instruction is executed. So, also the watchdog timer stops its operation during HALT and STOP – mode, when enabled (WDTON = 1).

In this case it is not necessary to set LSRSTOP = 1 by software before entering HALT or STOP to economize power consumption.

After HALT or STOP release, internal low-speed oscillator starts operation again.

During HALT and STOP, the counter values in WDT (and H1, when clocked with internal low-speed oscillator) keep their values; there is no reset of its counter values.

#### 5.2.2 Functionality when internal low-speed oscillator can not be stopped by SW (LSROSC=1)

When the watchdog timer is enabled (WDTON = 1) and stopping of the internal low-speed oscillator is not possible (LSROSC = 1), the internal low-speed oscillator, the watchdog (and the timer H1, when clocked with internal low-speed osc.) keeps operation, even when the HALT or STOP instruction is executed.

In this case, user has to take care that the CPU has to be waked up cyclic to restart the watchdog timer.

This will increase the power consumption, especially during STOP – mode.

For cyclic restart of the watchdog timer, a timer has to be used, which is able to operate during standby. E.g. timer H1 operating with internal low-speed oscillator, watch timer using 32 kHz sub clock or a timer clocked externally.

### CHAPTER 6 OPTION BYTE SETTING FOR WINDOW WATCHDOG

#### 6.1 Format of the Option Byte

The selection for window watchdog / internal low-speed oscillator functionality is done by setting of the option byte.

#### Figure 6-1. Format of option byte

Address: 0080H/1080H

| 001/100011 |         |         |       |                |               |       |        |
|------------|---------|---------|-------|----------------|---------------|-------|--------|
| 7          | 6       | 5       | 4     | 3              | 2             | 1     | 0      |
| 0          | WINDOW1 | WINDOW0 | WDTON | WDCS2          | WDCS1         | WDCS0 | LSROSC |
|            | •       |         |       | •              | •             | •     |        |
| WINDOW1    | WINDOW0 |         | Wat   | tchdog timer w | indow open pe | riod  |        |
| 0          | 0       | 25%     |       |                |               |       |        |
| 0          | 1       | 50%     |       |                |               |       |        |
| 1          | 0       | 75%     |       |                |               |       |        |
| 1          | 1       | 100%    |       |                |               |       |        |

| WDTON | Operation control of watchdog timer counter/illegal access detection                                      |
|-------|-----------------------------------------------------------------------------------------------------------|
| 0     | Counter operation disabled (counting stopped after reset), illegal access detection operation<br>disabled |
| 1     | Counter operation enabled (counting started after reset), illegal access detection operation enabled      |

| WDCS2 | WDCS1 | WDCS0 | Watchdog timer overflow time      |
|-------|-------|-------|-----------------------------------|
| 0     | 0     | 0     | 2 <sup>10</sup> /feL (3.88 ms)    |
| 0     | 0     | 1     | 2 <sup>11</sup> /faL (7.76 ms)    |
| 0     | 1     | 0     | 2 <sup>12</sup> /faL (15.52 ms)   |
| 0     | 1     | 1     | 2 <sup>19</sup> /faL (31.03 ms)   |
| 1     | 0     | 0     | 2 <sup>14</sup> /faL (62.06 ms)   |
| 1     | 0     | 1     | 2 <sup>15</sup> /fa∟ (124.12 ms)  |
| 1     | 1     | 0     | 2 <sup>16</sup> /fal (248.24 ms)  |
| 1     | 1     | 1     | 2 <sup>17</sup> /finL (496.48 ms) |

| LSROSC | Internal low-speed oscillator operation                                                   |
|--------|-------------------------------------------------------------------------------------------|
| 0      | Can be stopped by software (stopped when 1 is written to bit 0 (LSRSTOP) of RCM register) |
| 1      | Cannot be stopped (not stopped even if 1 is written to LSRSTOP bit)                       |

**Note** Set the same value at address 0080H and 1080H because 0080H and 1080H are switched during the boot swap operation.

#### 6.2 Example: Setting of the Option Byte in the user's source file

The option byte(s) has (have) a specific location within the microcontrollers address range. The address of the option byte is specified in the microcontrollers ".xcl – file", delivered by NEC.

#### 6.2.1 Setting of the Option Byte using relocatable segments

As an example, the following segment definition is included in a specific xcl – file for the WDT - Option Byte:

#### 6.2.1.1 Example: Selection of the watchdog's behavior

#### 6.2.1.1.1 in C - language

**# pragma location = "OPTBYTE"** // Definition of the segment for the option byte (.xcl – file)

\_\_root const unsigned char myoptionbyte[ 2 ] = {0x10, 0x00};

// Watchdog timer operation enabled
 // Window open period of watchdog timer: 25%,
 // Overflow time of watchdog timer: 2<sup>10</sup>/fRL
 // Low-speed oscillator can be stopped by software
 // Second value just to fillup the odd address

#### 6.2.1.1.2 in assembler (IAR – workbench, used in Europe)

| RSEG<br>DB | OPTBYTE<br>00010000B | <ul> <li>; Reference to .xcl – file, address 0x0080</li> <li>; Watchdog timer operation enabled</li> <li>; Window open period of watchdog timer: 25%,</li> <li>; Overflow time of watchdog timer: 2<sup>10</sup>/fRL,</li> <li>; Internal low-speed oscillator can be stopped by software</li> </ul> |
|------------|----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| DB         | 0000000B             | ; Second value just to fillup the odd address                                                                                                                                                                                                                                                        |

#### 6.2.2 Setting of the Option Byte using absolute addressing

#### 6.2.2.1.1 in C – language

#### \_\_root const unsigned char myoptionbyte @ 0x0080 = 0x39;

- // Absolute addressing at address 0x0080
- // Watchdog timer operation enabled
- // Window open period: 50%
- // Overflow time of watchdog timer: 214/fRL
- // Low-speed oscillator cannot be stopped by SW

#### 6.2.2.1.2 in assembler (IAR – workbench, used in Europe)

| 0x0080<br>00111001B | <ul> <li>; Absolute addressing at address 0x0080</li> <li>; Watchdog timer operation enabled</li> <li>; Window open period: 50%</li> <li>; Overflow time of watchdog timer: 2<sup>14</sup>/fRL</li> <li>; Low-speed oscillator cannot be stopped by software</li> </ul> |
|---------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                     | , et === == == == == == == == == == == == =                                                                                                                                                                                                                             |
|                     |                                                                                                                                                                                                                                                                         |

#### 6.2.2.1.3 in assembler ( Japanese Tool, not available in Europe )

| OPT CSEG AT<br>OPTION: DB | <ul> <li><b>0080H</b> ; Set absolute addressing at 0080 hex.</li> <li><b>39H</b> ; Enables watchdog timer operation<br/>; Window open period: 50%<br/>; Overflow time of watchdog timer: 2<sup>14</sup>/fRL<br/>; Low-speed oscillator cannot be stopped by software</li> </ul> |
|---------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|---------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|