# Accessing 16-bit I/O Registers

# Features

- Routines for Accessing 16-bit I/O Registers
- Macros Included for the FPSLIC<sup>™</sup> AVR<sup>®</sup> Core and IAR C Compiler

# Description

All FPSLIC devices include a 16-bit timer. These I/O modules have 16-bit registers that can be accessed from the FPSLIC AVR core using the *in* and *out* instructions. Because the FPSLIC microcontroller has an 8-bit I/O bus, access to the I/O register must be performed in two instruction cycles. An interrupt can occur between the instructions. If the interrupt function accesses the same resources (16-bit timer), the 16-bit I/O register access must be made an atomic operation, i.e., an operation that cannot be interrupted.

I/O modules with 16-bit registers include a temporary register for the high byte (bits 15 to 8). Note that the 16-bit timer (timer 1) has only one temporary register that is shared between all its 16-bit register pairs. A 16-bit I/O read is normally done like this:

;Reading low byte into r16,this triggers the high byte to be latched

in the temporary shadow register.

;Reading high byte from the temporary

Cycle 1: in r16, TCNT1L Cycle 2: in r17, TCNT1H

#### Figure 1. 16-bit I/O Register Read



register.

Note: Circled numbers indicate cycle number.

If an interrupt occurs between the two instructions for any of the operations and the interrupt handler accesses any of the timer 1's low bytes, the temporary register might change its value. Returning from the interrupt, the FPSLIC AVR core now reads the corrupted value into register R17.



**IOK** - 40K Gates of AT40K FPGA with 8-bit **AV**<sup>®</sup> Microcontroller and 36K Bytes of SRAM

# Application Note







#### A 16-bit I/O write is done as follows:

|          |     |             | ; r17 contains the high byte while r16<br>; contains the low byte that is to be<br>; written. |
|----------|-----|-------------|-----------------------------------------------------------------------------------------------|
| Cycle 1: | out | TCNT1H, r17 | ; Writing the high byte to the ; temporary register.                                          |
| Cycle 2: | out | TCNT1L, r16 | ; Writing both the low byte and the ; temporary register into the I/O register.               |

#### Figure 2. 16-bit I/O Register Write



Note: Circled numbers indicate cycle number.

Note that the read and the write operations differ in the order the high and low I/O register is accessed. If the order is reversed, the high value will be incorrectly read or written.

## Solution

To avoid the situations described above, the following macros for the AVR assembler and the IAR C compiler can be used.

#### **AVR Assembler Macros**

```
.macro outw
 cli
 out
         @2, @0
         @2-1, @1
 out
 sei
.endmacro
.macro
         inw
 cli
         @2, @0-1
 in
 in
         @1, @0
 sei
.endmacro
```

#### Usage

| .include | "AT94Kdef.inc"   |
|----------|------------------|
| inw      | r17, r16, TCNT1H |
| outw     | TCNT1H, r17, r16 |

- ; Reads the counter value (high, low, adr)
- ; Writes the counter value (adr, high, low )

# **FPSLIC**

#### IAR C Macros

```
#include <ina90.h>
#define outw( ADDRESS, VAL )\
{\
    _CLI();
    ADDRESS = VAL;\
    _SEI();\
}
#define inw( ADDRESS, VAL )\
{\
    _CLI();
    VAL = ADDRESS;\
    _SEI();\
}
```

#### Usage

#include <ioAT94K.h>

| inw( TCNT1, i )  | ;/* Reads the counter value */  |
|------------------|---------------------------------|
| outw( TCNT1, i ) | ;/* Writes the counter value */ |

## Notes

Note: 1. The outw and the inw macros use four instruction cycles, which is the same amount of cycles the ret instruction uses. In doing so, the macros will not increase the worst case interrupt response time.





## **Atmel Headquarters**

Corporate Headquarters 2325 Orchard Parkway San Jose, CA 95131 TEL (408) 441-0311 FAX (408) 487-2600

#### Europe

Atmel SarL Route des Arsenaux 41 Casa Postale 80 CH-1705 Fribourg Switzerland TEL (41) 26-426-5555 FAX (41) 26-426-5500

#### Asia

Atmel Asia, Ltd. Room 1219 Chinachem Golden Plaza 77 Mody Road Tsimhatsui East Kowloon Hong Kong TEL (852) 2721-9778 FAX (852) 2722-1369

#### Japan

Atmel Japan K.K. 9F, Tonetsu Shinkawa Bldg. 1-24-8 Shinkawa Chuo-ku, Tokyo 104-0033 Japan TEL (81) 3-3523-3551 FAX (81) 3-3523-7581

Atmel FPSLIC Hotline 1-(408) 436-4119

Atmel FPSLIC e-mail fpslic@atmel.com

FAQ Available from Website

### **Atmel Operations**

Atmel Colorado Springs 1150 E. Cheyenne Mtn. Blvd. Colorado Springs, CO 80906 TEL (719) 576-3300 FAX (719) 540-1759

Atmel Rousset

Zone Industrielle 13106 Rousset Cedex France TEL (33) 4-4253-6000 FAX (33) 4-4253-6001

#### Atmel Smart Card ICs

Scottish Enterprise Technology Park East Kilbride, Scotland G75 0QR TEL (44) 1355-803-000 FAX (44) 1355-242-743

#### Atmel Grenoble

Avenue de Rochepleine BP 123 38521 Saint-Egreve Cedex France TEL (33) 4-7658-3000 FAX (33) 4-7658-3480

> *Fax-on-Demand* North America: 1-(800) 292-8635 International:

1-(408) 441-0732

*e-mail* literature@atmel.com

Web Site http://www.atmel.com

BBS 1-(408) 436-4309

#### © Atmel Corporation 2000.

Atmel Corporation makes no warranty for the use of its products, other than those expressly contained in the Company's standard warranty which is detailed in Atmel's Terms and Conditions located on the Company's web site. The Company assumes no responsibility for any errors which may appear in this document, reserves the right to change devices or specifications detailed herein at any time without notice, and does not make any commitment to update the information contained herein. No licenses to patents or other intellectual property of Atmel are granted by the Company in connection with the sale of Atmel products, expressly or by implication. Atmel's products are not authorized for use as critical components in life support devices or systems.

Marks bearing <sup>®</sup> and/or <sup>™</sup> are registered trademarks and trademarks of Atmel Corporation.

Terms and product names in this document may be trademarks of others.

