

# **Application Note**

NVDS Operation in the Z8 Encore!<sup>®</sup> and Z8 Encore! XP<sup>®</sup> Microcontrollers

#### AN031001-0710

#### Introduction

The *Z8 Encore!* <sup>®</sup> and *Z8 Encore! XP*<sup>®</sup> families have parts containing Non-Volatile Data Storage (NVDS) of up to 256 bytes. This memory can perform over 100,000 write cycles. This Application Note describes the necessary operations and procedures to access the NVDS.

## **NVDS Operations**

The NVDS memory on the *Z8 Encore!* <sup>®</sup> and *Z8 Encore! XP*<sup>®</sup> microcontroller acts like an Electrically Erasable Programmable Read-Only Memory (EEPROM) emulated within the Flash memory that is capable of up to 100,000 write cycles. Different devices feature multiple NVDS array sizes.

| Part<br>Number | Flash<br>(KB) | RAM<br>(B) | NVDS<br>(64B) | ADC |
|----------------|---------------|------------|---------------|-----|
|                | 10            | 256        | No            | Vaa |
| Z8F1232        | 12            | 256        | No            | Yes |
| Z8F1233        | 12            | 256        | No            | No  |
|                |               |            |               |     |
| Z8F0830        | 8             | 256        | Yes           | Yes |
| Z8F0831        | 8             | 256        | Yes           | No  |
|                |               |            |               |     |
| Z8F0430        | 4             | 256        | Yes           | Yes |
| Z8F0431        | 4             | 256        | Yes           | No  |
|                |               |            |               |     |
| Z8F0230        | 2             | 256        | Yes           | Yes |
| Z8F0231        | 2             | 256        | Yes           | No  |
|                |               |            |               |     |
| Z8F0130        | 1             | 256        | Yes           | Yes |
| Z8F0131        | 1             | 256        | Yes           | No  |

 Table 1. F0830 series Part Selection Guide

| Part<br>Number | Flash<br>(KB) | RAM<br>(B) | NVDS<br>(100B) | ADC | I/O Pins |
|----------------|---------------|------------|----------------|-----|----------|
| Z8F083A        | 8             | 256        | Yes            | Yes | 17/23    |
| Z8F043A        | 4             | 256        | Yes            | Yes | 17/23    |

 Table 2. F083A series Part Selection Guide

| Part<br>Number | Flash<br>(KB) | RAM<br>(B) | NVDS <sup>1</sup><br>(B) | <b>I/O</b> | Comparator | Advanced<br>Analog <sup>2</sup> | ADC<br>Inputs | Packages           |
|----------------|---------------|------------|--------------------------|------------|------------|---------------------------------|---------------|--------------------|
| Z8F082A        | 8             | 1024       | 0                        | 6–23       | Yes        | Yes                             | 4–8           | 8-, 20- and 28-pin |
| Z8F081A        | 8             | 1024       | 0                        | 6–25       | Yes        | No                              | 0             | 8-, 20- and 28-pin |
| Z8F042A        | 4             | 1024       | 128                      | 6–23       | Yes        | Yes                             | 4-8           | 8-, 20- and 28-pin |
| Z8F041A        | 4             | 1024       | 128                      | 6–25       | Yes        | No                              | 0             | 8-, 20- and 28-pin |
| Z8F022A        | 2             | 512        | 64                       | 6–23       | Yes        | Yes                             | 4-8           | 8-, 20- and 28-pin |
| Z8F021A        | 2             | 512        | 64                       | 6-25       | Yes        | No                              | 0             | 8-, 20- and 28-pin |
| Z8F012A        | 1             | 256        | 16                       | 6–23       | Yes        | Yes                             | 4-8           | 8-, 20- and 28-pin |
| Z8F011A        | 1             | 256        | 16                       | 6–25       | Yes        | No                              | 0             | 8-, 20- and 28-pin |
|                |               |            |                          |            |            |                                 |               |                    |

Table3. F082A series Part Selection Guide

| Part<br>Number | Flash<br>(KB) |      | Program<br>RAM (B) |     | I/O   | ADC<br>Inputs | SPI | I <sup>2</sup> C | UARTs | Packages                  |
|----------------|---------------|------|--------------------|-----|-------|---------------|-----|------------------|-------|---------------------------|
| Z8F2480        | 24            | 2048 | 1024               | -   | 17–37 | 7–8           | 0-1 | 1                | 1–2   | 20-, 28-, 40-, and 44-pin |
| Z8F1680        | 16            | 2048 | 1024               | 256 | 17–37 | 7–8           | 0–1 | 1                | 1–2   | 20-, 28-, 40-, and 44-pin |
| Z8F0880        | 8             | 1024 | 1024               | 128 | 17–37 | 7–8           | 0–1 | 1                | 1–2   | 20-, 28-, 40-, and 44-pin |

 Table 4. F1680 series Part Selection Guide

The NVDS is implemented by special purpose Zilog® software stored in areas of program memory not accessible to the user. These special-purpose routines use the flash memory to store and read the data. The routines incorporate a dynamic addressing scheme to maximize the Write/Erase endurance of the Flash.

The following routines are required to access the NVDS:

- 1. Write routine
- 2. Read routine

Both of these routines are accessed with a CALL instruction to a pre-defined address outside the program memory that is not accessible to the user. Both the NVDS address and data are single-byte values. These routines save the working register set before they are used (hence, 16 bytes of stack space is needed). After finishing the call to these routines, the working register set of the user code is recovered.

This section discusses the following topics in detail:

- Interrupt Handling During NVDS Operation
- Flash Frequency Register Initialization
- NVDS Write Operation
- NVDS Read Operation
- Power Failure Protection
- Optimizing NVDS Memory Usage for Execution Speed

When the Z8 Encore! XP F042A Series device is in the DEBUG Mode, you can view the NVDS memory locations by performing the following steps in ZDS II:

- 1. Navigate to View  $\rightarrow$  Debug Windows  $\rightarrow$  Memory. The Memory Window appears.
- 2. In the Memory Window, select the NVDS option from the Space drop down menu to view the NVDS contents.

### Interrupt Handling during NVDS Operation

Interrupts should be disabled before executing any NVDS operation (read or write) since they can alter the working register and existing stack contents.

## **Flash Frequency Register Initialization**

The Flash Frequency Registers must be programmed based on the system clock frequency.

```
void init_NVDS (void)
{
   FFREQH = (SYSCLOCK/1000) >> 8;
   FFREQL = (SYSCLOCK/1000) & 0xFF;
}
```

**Note:** SYSCLOCK is the system clock frequency in hertz. For proper NVDS operation, the flash frequency registers should always have the proper value. Hence, whenever the system clock is changed, the flash frequency register should also be updated. Improper values stored in the flash frequency register could result to corrupted data in the NVDS area.

## **NVDS Write Operation**

Steps in writing a byte to the NVDS array:

- 1. Push the address of the NVDS array to be written on the stack
- 2. Push the data byte to be written on the stack
- 3. Issue a CALL instruction to the address of the Byte-Write routine
- 4. Pop the data byte and address off the stack

The write status byte resides in working register R0 after the CALL to the Byte Write instruction is executed. The bit fields of this status byte are defined in Table 5 and Table 6. The write routine uses 13 bytes (F082A series) to 16 bytes (F0830, F083A and F1680 series) of stack space in addition to the two bytes of address and data pushed by the user code.

| BITS             | 7 | 6 | 5        | 4 | 3 | 2  | 1      | 0  |
|------------------|---|---|----------|---|---|----|--------|----|
| FIELD            |   |   | Reserved |   |   | FE | IGADDR | WE |
| DEFAULT<br>VALUE | 0 | 0 | 0        | 0 | 0 | 0  | 0      | 0  |

 Table 5. Write Status Byte (F0830, F083A and F1680 series)

| BITS             | 7 | 6    | 5     | 4 | 3    | 2  | 1   | 0   |
|------------------|---|------|-------|---|------|----|-----|-----|
| FIELD            |   | Rese | erved |   | RCPY | PF | AWE | DWE |
| DEFAULT<br>VALUE | 0 | 0    | 0     | 0 | 0    | 0  | 0   | 0   |

 Table 6. NVDS Status Byte (F082A series)

NVDS writes exhibit a non-uniform execution time (refer to the timing tables) due to the flash memory architecture. A maintenance operation (every 200 writes for the F0830, F083A and F1680 series / every 400 to 500 writes for the F082A series) is necessary which takes up to 58 ms (F0830, F083A and F1680 series) to 61 ms (F082A series) to complete. Slower system clock speeds result in proportionally higher execution times. NVDS byte writes to invalid addresses (those exceeding the NVDS array size) have no effect. Illegal write operations have a 2  $\mu$ s (F082A series) to 7  $\mu$ s execution time (F0830, F083A and F1680 series).

|                        | \<br>۲ <sub>A</sub> : |     |     |        |                                           |
|------------------------|-----------------------|-----|-----|--------|-------------------------------------------|
| Parameter              | Min                   | Тур | Max | Units  | Notes                                     |
| NVDS Byte Read Time    | 71                    | —   | 256 | μs     | With system clock at 20 MHz               |
| NVDS Byte Program Time | 126                   | _   | 136 | μs     | With system clock at 20 MHz               |
| Data Retention         | 10                    | _   | _   | years  | 25°C                                      |
| Endurance              | 100,000               | _   | —   | Cycles | Cumulative write cycles for entire memory |

 Table 7. F0830 and F083A NVDS timing values

|                        | -      |                  |                                  |        | ZILO                                      |
|------------------------|--------|------------------|----------------------------------|--------|-------------------------------------------|
|                        | Т      | $A = 0^{\circ}C$ | 7 to 3.6V<br>to +70⁰0<br>to +105 | ;      |                                           |
| Parameter              | Min    | Тур              | Max                              | Units  | Notes                                     |
| NVDS Byte Read Time    | 34     | _                | 519                              | μs     | With system clock at 20 MHz               |
| NVDS Byte Program Time | 0.171  | _                | 39.7                             | ms     | With system clock at 20 MHz               |
| Data Retention         | 20     |                  |                                  | years  | 25°C                                      |
| Endurance              | 50,000 |                  | _                                | cycles | Cumulative write cycles for entire memory |

Table 8. F1680 NVDS timing values

## **NVDS Read Operation**

Steps in reading a byte from the NVDS array:

- 1. Push the address of the NVDS array to be read
- 2. Issue a CALL instruction to the address of the Byte-Read routine
- 3. Pop the address off the stack

At the return from the sub-routine, the read byte resides in working register R0, and the read status byte resides in working register R1. The bit fields of this status byte are defined in Table 6 and Table 9. The read routine uses 9 bytes (F082A series) to 16 bytes (F0830, F083A and F1680 series) of stack space in addition to the 1 byte of address pushed by the user.

| BITS             | 7 | 6        | 5 | 4  | 3        | 2  | 1      | 0        |
|------------------|---|----------|---|----|----------|----|--------|----------|
| FIELD            |   | Reserved |   | DE | Reserved | FE | IGADDR | Reserved |
| DEFAULT<br>VALUE | 0 | 0        | 0 | 0  | 0        | 0  | 0      | 0        |

 Table 9. Read Status Byte (F0830, F083A and F1680 series)

Because of the Flash memory architecture, NVDS reads exhibit a non-uniform execution time. A read operation takes 71  $\mu$ s - 258  $\mu$ s (F0830, F083A and F1680 series) or 44  $\mu$ s - 489  $\mu$ s (F082A series) for a system clock of 20 MHz. Slower system clock speeds result in proportionally higher execution times. NVDS byte reads from invalid addresses (those exceeding the NVDS array size) return 0xFF. Illegal read operations have an execution time of 2  $\mu$ s (F082A series) to 6  $\mu$ s (F0830, F0383A and F1680 series). The status byte returned by the NVDS read routine is 0x00 for successful read. If the status byte is non-zero, there is a corrupted value in the NVDS array at the location being read. In this case, the value returned in R0 is the byte most recently written to the array that does not have an error.

# NVDS Operation in the Z8 Encore!<sup>®</sup> and Z8 Encore! XP<sup>®</sup> MCU's Application Note Zilog

|                        |         |     | 7 to 3.6V<br>to +105 |        |                                           |
|------------------------|---------|-----|----------------------|--------|-------------------------------------------|
| Parameter              | Min     | Тур | Мах                  | Units  | Notes                                     |
| NVDS Byte Read Time    | 34      | _   | 519                  | μs     | With system clock at 20 MHz               |
| NVDS Byte Program Time | 0.171   | _   | 39.7                 | ms     | With system clock at 20 MHz               |
| Data Retention         | 100     | _   | _                    | years  | 25°C                                      |
| Endurance              | 160,000 | _   | _                    | cycles | Cumulative write cycles for entire memory |

Table 10. F082A NVDS timing values

## **Power Failure Protection**

The NVDS routines employ error checking mechanisms to ensure a power failure endangers only the most recently written byte. Bytes previously written to the array are not modified. For this protection to function, the VBO must be enabled and configured for a threshold voltage of 2.4 V or greater.

A System Reset (such as a pin reset or watchdog timer reset) that occurs during a write operation may alter the byte currently being written. All other bytes in the array are unaffected.

## **Optimizing NVDS Memory Usage for Execution Speed**

As listed in Table 11 and Table 12, the NVDS read time varies drastically, this discrepancy being a trade-off for minimizing the frequency of writes that require post-write page erases. The time required for reading data from address N is a function of the number of writes to addresses; other than N after the most recent write to N. Neglecting effects caused by page erases and results caused by the initial condition in which the NVDS is blank, the rule of thumb is that every write since the most recent page erase causes read times of unwritten addresses to increase by 0.8  $\mu$ s, up to a maximum of 258  $\mu$ s.

| Operation     | Minimum<br>Latency (μs) |     |  |
|---------------|-------------------------|-----|--|
| Read          | 71                      | 258 |  |
| Write         | 126                     | 136 |  |
| Illegal Read  | 6                       | 6   |  |
| Illegal Write | 7                       | 7   |  |

 Table 11. NVDS Latency (F0830, F083A and F1680 series)

|                      |         |         | Read (128 byte array)     | 883  | 7609            |
|----------------------|---------|---------|---------------------------|------|-----------------|
|                      |         |         | Write (16 byte array)     | 4973 | 5009            |
| Operation            | Minimum | Maximum | Write (64 byte array)     | 4971 | 5013            |
|                      | Latency | Latency | Write (128 byte array) 49 |      | 5023            |
| Read (16 byte array) | 875     | 9961    | Illegal Read              | 43   | <mark>43</mark> |
| Read (64 byte array) | 876     | 8952    | Illegal Write             | 31   | 31              |

 Table 12. NVDS Latency (F082A series)

If NVDS read performance is critical to your software architecture, you can optimize your code for speed by using either of the methods listed below.

- 1. Periodically refresh all addresses that are used. This is the most useful method. The optimal use of NVDS in terms of speed is to rotate the writes evenly among all addresses planned to use, bringing all reads closer to the minimum read time. Because the minimum read time is much less than the write time, however, actual speed benefits are not always realized.
- 2. Use as few unique addresses as possible. This helps to optimize the impact of refreshing.

### Summary

This application note describes the basic NVDS routines and its principles. It also describes the necessary procedures on how operate the NVDS and its features. It also shows the minimum and maximum latency times for both read and write operations. The Z8 Encore! XP NVDS can be used for data-logging applications, wherein data needs to be preserved even after power-off.

## **Flowchart**



### Warning: DO NOT USE IN LIFE SUPPORT

#### LIFE SUPPORT POLICY

ZILOG'S PRODUCTS ARE NOT AUTHORIZED FOR USE AS CRITICAL COMPONENTS IN LIFE SUPPORT DEVICES OR SYSTEMS WITHOUT THE EXPRESS PRIOR WRITTEN APPROVAL OF THE PRESIDENT AND GENERAL COUNSEL OF ZILOG CORPORATION.

#### As used herein

Life support devices or systems are devices which (a) are intended for surgical implant into the body, or (b) support or sustain life and whose failure to perform when properly used in accordance with instructions for use provided in the labeling can be reasonably expected to result in a significant injury to the user. A critical component is any component in a life support device or system whose failure to perform can be reasonably expected to cause the failure of the life support device or system or to affect its safety or effectiveness.

#### **Document Disclaimer**

©2010 by Zilog, Inc. All rights reserved. Information in this publication concerning the devices, applications, or technology described is intended to suggest possible uses and may be superseded. ZILOG, INC. DOES NOT ASSUME LIABILITY FOR OR PROVIDE A REPRESENTATION OF ACCURACY OF THE INFORMATION, DEVICES, OR TECHNOLOGY DESCRIBED IN THIS DOCUMENT. ZILOG ALSO DOES NOT ASSUME LIABILITY FOR INTELLECTUAL PROPERTY INFRINGEMENT RELATED IN ANY MANNER TO USE OF INFORMATION, DEVICES, OR TECHNOLOGY DESCRIBED HEREIN OR OTHERWISE. The information contained within this document has been verified according to the general principles of electrical and mechanical engineering.

Z8 Encore! XP is a registered trademark of Zilog, Inc. All other product or service names are the property of their respective owners.