



Welcome to **E-XFL.COM** 

What is "Embedded - Microcontrollers"?

"Embedded - Microcontrollers" refer to small, integrated circuits designed to perform specific tasks within larger systems. These microcontrollers are essentially compact computers on a single chip, containing a processor core, memory, and programmable input/output peripherals. They are called "embedded" because they are embedded within electronic devices to control various functions, rather than serving as standalone computers. Microcontrollers are crucial in modern electronics, providing the intelligence and control needed for a wide range of applications.

Applications of "<u>Embedded - Microcontrollers</u>"

| z<br>ART/USART, USI<br>1-out Detect/Reset, LCD, POR, PWM, WDT |
|---------------------------------------------------------------|
| z<br>ART/USART, USI                                           |
| ART/USART, USI                                                |
| ART/USART, USI                                                |
| ART/USART, USI                                                |
|                                                               |
| n-out Detect/Reset, LCD, POR, PWM, WDT                        |
|                                                               |
|                                                               |
| (32K x 16)                                                    |
| l .                                                           |
| 3                                                             |
| 3                                                             |
| ~ 5.5V                                                        |
| x10b                                                          |
| al                                                            |
| ~ 85°C (TA)                                                   |
| ce Mount                                                      |
| QFP                                                           |
| QFP (14x14)                                                   |
|                                                               |
|                                                               |

# 1. Pin Configurations

Figure 1-1. Pinout ATmega3290/6490

### **TQFP**





# 2. Overview

The ATmega329/3290/649/6490 is a low-power CMOS 8-bit microcontroller based on the AVR enhanced RISC architecture. By executing powerful instructions in a single clock cycle, the ATmega329/3290/649/6490 achieves throughputs approaching 1 MIPS per MHz allowing the system designer to optimize power consumption versus processing speed.

# 2.1 Block Diagram

Figure 2-1. Block Diagram





The Atmel® AVR® core combines a rich instruction set with 32 general purpose working registers. All the 32 registers are directly connected to the Arithmetic Logic Unit (ALU), allowing two independent registers to be accessed in one single instruction executed in one clock cycle. The resulting architecture is more code efficient while achieving throughputs up to ten times faster than conventional CISC microcontrollers.

The Atmel ATmega329/3290/649/6490 provides the following features: 32/64K bytes of In-System Programmable Flash with Read-While-Write capabilities, 1/2K bytes EEPROM, 2/4K byte SRAM, 54/69 general purpose I/O lines, 32 general purpose working registers, a JTAG interface for Boundary-scan, On-chip Debugging support and programming, a complete On-chip LCD controller with internal contrast control, three flexible Timer/Counters with compare modes, internal and external interrupts, a serial programmable USART, Universal Serial Interface with Start Condition Detector, an 8-channel, 10-bit ADC, a programmable Watchdog Timer with internal Oscillator, an SPI serial port, and five software selectable power saving modes. The Idle mode stops the CPU while allowing the SRAM, Timer/Counters, SPI port, and interrupt system to continue functioning. The Power-down mode saves the register contents but freezes the Oscillator, disabling all other chip functions until the next interrupt or hardware reset. In Power-save mode, the asynchronous timer and the LCD controller continues to run, allowing the user to maintain a timer base and operate the LCD display while the rest of the device is sleeping. The ADC Noise Reduction mode stops the CPU and all I/O modules except asynchronous timer, LCD controller and ADC, to minimize switching noise during ADC conversions. In Standby mode, the crystal/resonator Oscillator is running while the rest of the device is sleeping. This allows very fast start-up combined with low-power consumption.

The device is manufactured using Atmel's high density non-volatile memory technology. The On-chip In-System re-Programmable (ISP) Flash allows the program memory to be reprogrammed In-System through an SPI serial interface, by a conventional non-volatile memory programmer, or by an On-chip Boot program running on the AVR core. The Boot program can use any interface to download the application program in the Application Flash memory. Software in the Boot Flash section will continue to run while the Application Flash section is updated, providing true Read-While-Write operation. By combining an 8-bit RISC CPU with In-System Self-Programmable Flash on a monolithic chip, the Atmel ATmega329/3290/649/6490 is a powerful microcontroller that provides a highly flexible and cost effective solution to many embedded control applications.

The Atmel ATmega329/3290/649/6490 is supported with a full suite of program and system development tools including: C Compilers, Macro Assemblers, Program Debugger/Simulators, In-Circuit Emulators, and Evaluation kits.



## 2.2 Comparison between ATmega329, ATmega3290, ATmega649 and ATmega6490

The ATmega329, ATmega3290, ATmega649, and ATmega6490 differs only in memory sizes, pin count and pinout. Table 2-1 on page 6 summarizes the different configurations for the four devices.

 Table 2-1.
 Configuration Summary

| Device     | Flash    | EEPROM   | RAM     | LCD<br>Segments | General Purpose<br>I/O Pins |
|------------|----------|----------|---------|-----------------|-----------------------------|
| ATmega329  | 32Kbytes | 1Kbytes  | 2Kbytes | 4 x 25          | 54                          |
| ATmega3290 | 32Kbytes | 1K bytes | 2Kbytes | 4 x 40          | 69                          |
| ATmega649  | 64Kbytes | 2Kbytes  | 4Kbytes | 4 x 25          | 54                          |
| ATmega6490 | 64Kbytes | 2Kbytes  | 4Kbytes | 4 x 40          | 69                          |

# 2.3 Pin Descriptions

The following section describes the I/O-pin special functions.

2.3.1 V<sub>CC</sub>

Digital supply voltage.

2.3.2 GND

Ground.

#### 2.3.3 Port A (PA7..PA0)

Port A is an 8-bit bi-directional I/O port with internal pull-up resistors (selected for each bit). The Port A output buffers have symmetrical drive characteristics with both high sink and source capability. As inputs, Port A pins that are externally pulled low will source current if the pull-up resistors are activated. The Port A pins are tri-stated when a reset condition becomes active, even if the clock is not running.

Port A also serves the functions of various special features of the ATmega329/3290/649/6490 as listed on page 67.

### 2.3.4 Port B (PB7..PB0)

Port B is an 8-bit bi-directional I/O port with internal pull-up resistors (selected for each bit). The Port B output buffers have symmetrical drive characteristics with both high sink and source capability. As inputs, Port B pins that are externally pulled low will source current if the pull-up resistors are activated. The Port B pins are tri-stated when a reset condition becomes active, even if the clock is not running.

Port B has better driving capabilities than the other ports.

Port B also serves the functions of various special features of the ATmega329/3290/649/6490 as listed on page 68.



### 2.3.9 Port G (PG5..PG0)

Port G is a 6-bit bi-directional I/O port with internal pull-up resistors (selected for each bit). The Port G output buffers have symmetrical drive characteristics with both high sink and source capability. As inputs, Port G pins that are externally pulled low will source current if the pull-up resistors are activated. The Port G pins are tri-stated when a reset condition becomes active, even if the clock is not running.

Port G also serves the functions of various special features of the ATmega329/3290/649/6490 as listed on page 75.

### 2.3.10 Port H (PH7..PH0)

Port H is a 8-bit bi-directional I/O port with internal pull-up resistors (selected for each bit). The Port H output buffers have symmetrical drive characteristics with both high sink and source capability. As inputs, Port H pins that are externally pulled low will source current if the pull-up resistors are activated. The Port H pins are tri-stated when a reset condition becomes active, even if the clock is not running.

Port H also serves the functions of various special features of the ATmega3290/6490 as listed on page 75.

### 2.3.11 Port J (PJ6..PJ0)

Port J is a 7-bit bi-directional I/O port with internal pull-up resistors (selected for each bit). The Port J output buffers have symmetrical drive characteristics with both high sink and source capability. As inputs, Port J pins that are externally pulled low will source current if the pull-up resistors are activated. The Port J pins are tri-stated when a reset condition becomes active, even if the clock is not running.

Port J also serves the functions of various special features of the ATmega3290/6490 as listed on page 75.

#### 2.3.12 **RESET**

Reset input. A low level on this pin for longer than the minimum pulse length will generate a reset, even if the clock is not running. The minimum pulse length is given in "System and Reset Characteristics" on page 330. Shorter pulses are not guaranteed to generate a reset.

## 2.3.13 XTAL1

Input to the inverting Oscillator amplifier and input to the internal clock operating circuit.

# 2.3.14 XTAL2

Output from the inverting Oscillator amplifier.

### 2.3.15 AVCC

AVCC is the supply voltage pin for Port F and the A/D Converter. It should be externally connected to  $V_{CC}$ , even if the ADC is not used. If the ADC is used, it should be connected to  $V_{CC}$  through a low-pass filter.

#### 2.3.16 AREF

This is the analog reference pin for the A/D Converter.



### 2.3.17 LCDCAP

An external capacitor (typical > 470nF) must be connected to the LCDCAP pin as shown in Figure 23-2. This capacitor acts as a reservoir for LCD power ( $V_{LCD}$ ). A large capacitance reduces ripple on  $V_{LCD}$  but increases the time until  $V_{LCD}$  reaches its target value.

## 3. Resources

A comprehensive set of development tools, application notes and datasheets are available for download on http://www.atmel.com/avr.

## 4. Data Retention

Reliability Qualification results show that the projected data retention failure rate is much less than 1 PPM over 20 years at 85°C or 100 years at 25°C.

# 5. About Code Examples

This documentation contains simple code examples that briefly show how to use various parts of the device. These code examples assume that the part specific header file is included before compilation. Be aware that not all C compiler vendors include bit definitions in the header files and interrupt handling in C is compiler dependent. Please confirm with the C compiler documentation for more details.

For I/O Registers located in extended I/O map, "IN", "OUT", "SBIS", "SBIC", "CBI", and "SBI" instructions must be replaced with instructions that allow access to extended I/O. Typically "LDS" and "STS" combined with "SBRS", "SBRC", "SBR", and "CBR".



# ■ ATmega329/3290/649/6490

| Address                                   | Name            | Bit 7      | Bit 6       | Bit 5   | Bit 4           | Bit 3                     | Bit 2      | Bit 1         | Bit 0      | Page       |
|-------------------------------------------|-----------------|------------|-------------|---------|-----------------|---------------------------|------------|---------------|------------|------------|
|                                           | TCNT1L          | Dit 7      | Dito        | Dit 3   |                 | unter1 Low                | Dit 2      | Dit 1         | Dit 0      | 136        |
| (0x84)                                    | Reserved        | -          | -           |         | -               | -                         | -          |               | -          | 130        |
| (0x83)                                    | TCCR1C          | FOC1A      | FOC1B       | -       |                 |                           |            | -             |            | 125        |
| (0x82)                                    |                 |            |             | -       | -               | -                         | -          | -             | -          | 135        |
| (0x81)                                    | TCCR1B          | ICNC1      | ICES1       | -       | WGM13           | WGM12                     | CS12       | CS11          | CS10       | 134        |
| (0x80)                                    | TCCR1A          | COM1A1     | COM1A0      | COM1B1  | COM1B0          | -                         | -          | WGM11         | WGM10      | 132        |
| (0x7F)                                    | DIDR1           | -          | -           | -       | -               | -                         | -          | AIN1D         | AINOD      | 210        |
| (0x7E)                                    | DIDR0           | ADC7D      | ADC6D       | ADC5D   | ADC4D           | ADC3D                     | ADC2D      | ADC1D         | ADC0D      | 227        |
| (0x7D)                                    | Reserved        | -          | -           | -       | -               | -                         | -          | -             | -          |            |
| (0x7C)                                    | ADMUX           | REFS1      | REFS0       | ADLAR   | MUX4            | MUX3                      | MUX2       | MUX1          | MUX0       | 223        |
| (0x7B)                                    | ADCSRB          | -          | ACME        | -       | -               | -                         | ADTS2      | ADTS1         | ADTS0      | 209/227    |
| (0x7A)                                    | ADCSRA          | ADEN       | ADSC        | ADATE   | ADIF            | ADIE                      | ADPS2      | ADPS1         | ADPS0      | 225        |
| (0x79)                                    | ADCH            |            |             |         | ADC Data F      | Register High             |            |               |            | 226        |
| (0x78)                                    | ADCL            |            |             |         | ADC Data I      | Register Low              |            |               |            | 226        |
| (0x77)                                    | Reserved        | -          | -           | -       | -               | -                         | -          | -             | -          |            |
| (0x76)                                    | Reserved        | -          | -           | -       | -               | -                         | -          | -             | -          |            |
| (0x75)                                    | Reserved        | -          | -           | -       | -               | -                         | -          | -             | -          |            |
| (0x74)                                    | Reserved        | -          | -           | -       | -               | -                         | -          | -             | -          |            |
| (0x73)                                    | PCMSK3          | -          | PCINT30     | PCINT29 | PCINT28         | PCINT27                   | PCINT26    | PCINT25       | PCINT24    | 57         |
| (0x72)                                    | Reserved        | -          | -           | -       | -               | -                         | -          | -             | -          |            |
| (0x71)                                    | Reserved        | -          | -           | -       | -               | -                         | -          | -             | -          |            |
| (0x70)                                    | TIMSK2          | -          | -           | -       | -               | -                         | -          | OCIE2A        | TOIE2      | 156        |
| (0x6F)                                    | TIMSK1          | -          | -           | ICIE1   | -               | -                         | OCIE1B     | OCIE1A        | TOIE1      | 137        |
| (0x6E)                                    | TIMSK0          | -          | -           | -       | -               | -                         | -          | OCIE0A        | TOIE0      | 106        |
| (0x6D)                                    | PCMSK2          | PCINT23    | PCINT22     | PCINT21 | PCINT20         | PCINT19                   | PCINT18    | PCINT17       | PCINT16    | 57         |
| (0x6C)                                    | PCMSK1          | PCINT15    | PCINT14     | PCINT13 | PCINT12         | PCINT11                   | PCINT10    | PCINT9        | PCINT8     | 58         |
| (0x6B)                                    | PCMSK0          | PCINT7     | PCINT6      | PCINT5  | PCINT4          | PCINT3                    | PCINT2     | PCINT1        | PCINT0     | 58         |
| ` ,                                       | Reserved        | -          | -           | -       | -               | -                         | -          | -             | -          |            |
| (0x6A)                                    | EICRA           | -          | -           | -       | -               | -                         | -          | ISC01         | ISC00      | 55         |
| (0x69)                                    | Reserved        | -          | <u> </u>    | -       | -               | -                         | -          | -             | -          | 33         |
| (0x68)                                    | Reserved        | -          |             | -       | -               | _                         | -          | -             | -          |            |
| (0x67)                                    | OSCCAL          | -          | -           |         |                 | n Register [CAL7          |            | -             | _          | 32         |
| (0x66)                                    |                 | -          | -           |         |                 |                           |            |               |            | 32         |
| (0x65)                                    | Reserved<br>PRR | -          | <u> </u>    | -       | - PRLCD         | PRTIM1                    | -<br>PRSPI | -<br>PSUSART0 | -<br>PRADC | 40         |
| (0x64)                                    |                 |            |             |         |                 |                           |            |               |            | 40         |
| (0x63)                                    | Reserved        | -          | -           | -       | -               | -                         | -          | -             | -          |            |
| (0x62)                                    | Reserved        | -          | -           | -       | -               | -                         | -          | -             | -          | 00         |
| (0x61)                                    | CLKPR           | CLKPCE     | -           | -       | -               | CLKPS3                    | CLKPS2     | CLKPS1        | CLKPS0     | 33         |
| (0x60)                                    | WDTCR           | -          |             | -       | WDCE            | WDE                       | WDP2       | WDP1          | WDP0       | 48         |
| 0x3F (0x5F)                               | SREG            | I          | Т           | Н       | S               | V                         | N          | Z             | С          | 12         |
| 0x3E (0x5E)                               | SPH             |            |             |         |                 | inter High                |            |               |            | 14         |
| 0x3D (0x5D)                               | SPL             |            |             |         |                 | ointer Low                |            | 1             |            | 14         |
| 0x3C (0x5C)                               | Reserved        | -          | -           | -       | -               | -                         | -          | -             | -          |            |
| 0x3B (0x5B)                               | Reserved        | -          | -           | -       | -               | -                         | -          | -             | -          |            |
| 0x3A (0x5A)                               | Reserved        | -          | -           | -       | -               | -                         | -          | -             | -          |            |
| 0x39 (0x59)                               | Reserved        | -          | -           | -       | -               | -                         | -          | -             | -          |            |
| 0x38 (0x58)                               | Reserved        | -          | -           | -       | -               | -                         | -          | -             | •          |            |
| 0x37 (0x57)                               | SPMCSR          | SPMIE      | RWWSB       | -       | RWWSRE          | BLBSET                    | PGWRT      | PGERS         | SPMEN      | 291        |
| 0x36 (0x56)                               | Reserved        |            |             |         |                 |                           |            |               |            |            |
| 0x35 (0x55)                               | MCUCR           | JTD        | -           | -       | PUD             | -                         | -          | IVSEL         | IVCE       | 52/87/254  |
| 0x34 (0x54)                               | MCUSR           | -          | -           | -       | JTRF            | WDRF                      | BORF       | EXTRF         | PORF       | 47         |
| 0x33 (0x53)                               | SMCR            | -          | -           | -       | -               | SM2                       | SM1        | SM0           | SE         | 39         |
| 0x32 (0x52)                               | Reserved        | -          | -           | -       | -               | -                         | -          | -             | -          |            |
| 0x31 (0x51)                               | OCDR            | IDRD/OCDR7 | OCDR6       | OCDR5   | OCDR4           | OCDR3                     | OCDR2      | OCDR1         | OCDR0      | 250        |
| 0x30 (0x50)                               | ACSR            | ACD        | ACBG        | ACO     | ACI             | ACIE                      | ACIC       | ACIS1         | ACIS0      | 209        |
| 0x2F (0x4F)                               | Reserved        | -          | -           | -       | -               | -                         | -          | -             | -          |            |
| 0x2E (0x4E)                               | SPDR            |            |             |         | SPI Data        | a Register                |            |               |            | 167        |
| 0x2D (0x4D)                               | SPSR            | SPIF       | WCOL        | -       | -               | -                         | -          | -             | SPI2X      | 167        |
| 0x2D (0x4D)<br>0x2C (0x4C)                | SPCR            | SPIE       | SPE         | DORD    | MSTR            | CPOL                      | CPHA       | SPR1          | SPR0       | 165        |
| 0x2C (0x4C)<br>0x2B (0x4B)                | GPIOR2          |            | -: <b>-</b> | _ 55    |                 | ose I/O Register          | 2          | 2             | 2          | 25         |
| 0x2B (0x4B)<br>0x2A (0x4A)                | GPIOR1          | -          |             |         |                 | se I/O Register           |            |               |            | 25         |
| , ,                                       | Reserved        | -          | -           | -       | - General Furpo | - Included                | -          | -             | -          | 25         |
| 0x29 (0x49)                               | Reserved        | -          | -           | -       | -               |                           | -          | -             | -          |            |
|                                           | i reserveu      | •          | •           |         |                 | •                         | •          | •             | •          |            |
| 0x28 (0x48)                               | OCDA            |            |             |         | Timor/Countary  | Justinuit Compare 1       |            |               |            | 105        |
| 0x28 (0x48)<br>0x27 (0x47)<br>0x26 (0x46) | OCR0A<br>TCNT0  |            |             |         |                 | Output Compare A Counter0 |            |               |            | 105<br>105 |



# ATmega329/3290/649/6490

| Address     | Name     | Bit 7  | Bit 6  | Bit 5  | Bit 4         | Bit 3            | Bit 2  | Bit 1             | Bit 0    | Page    |
|-------------|----------|--------|--------|--------|---------------|------------------|--------|-------------------|----------|---------|
| 0x25 (0x45) | Reserved | -      | -      | -      | -             | -                | -      | -                 | -        |         |
| 0x24 (0x44) | TCCR0A   | FOC0A  | WGM00  | COM0A1 | COM0A0        | WGM01            | CS02   | CS01              | CS00     | 103     |
| 0x23 (0x43) | GTCCR    | TSM    | -      | -      | -             | -                | -      | PSR2              | PSR10    | 108/157 |
| 0x22 (0x42) | EEARH    | -      | -      | -      | -             | -                | EEPRO  | DM Address Regist | ter High | 22      |
| 0x21 (0x41) | EEARL    |        |        |        | EEPROM Addre  | ess Register Low | '      |                   |          | 22      |
| 0x20 (0x40) | EEDR     |        |        |        | EEPROM D      | ata Register     |        |                   |          | 22      |
| 0x1F (0x3F) | EECR     | -      | -      | -      | -             | EERIE            | EEMWE  | EEWE              | EERE     | 22      |
| 0x1E (0x3E) | GPIOR0   |        |        |        | General Purpo | se I/O Register  |        |                   |          | 25      |
| 0x1D (0x3D) | EIMSK    | PCIE3  | PCIE2  | PCIE1  | PCIE0         | -                | -      | -                 | INT0     | 55      |
| 0x1C (0x3C) | EIFR     | PCIF3  | PCIF2  | PCIF1  | PCIF0         | -                | -      | -                 | INTF0    | 56      |
| 0x1B (0x3B) | Reserved | -      | -      | -      | -             | -                | -      | -                 | -        |         |
| 0x1A (0x3A) | Reserved | -      | -      | -      | -             | -                | -      | -                 | -        |         |
| 0x19 (0x39) | Reserved | -      | -      | -      | -             | -                | -      | -                 | -        |         |
| 0x18 (0x38) | Reserved | -      | -      | -      | -             | -                | -      | -                 | -        |         |
| 0x17 (0x37) | TIFR2    | -      | -      | -      | -             | -                | -      | OCF2A             | TOV2     | 157     |
| 0x16 (0x36) | TIFR1    | -      | -      | ICF1   | -             | -                | OCF1B  | OCF1A             | TOV1     | 138     |
| 0x15 (0x35) | TIFR0    | -      | -      | -      | -             | -                | -      | OCF0A             | TOV0     | 106     |
| 0x14 (0x34) | PORTG    | -      | -      | -      | PORTG4        | PORTG3           | PORTG2 | PORTG1            | PORTG0   | 89      |
| 0x13 (0x33) | DDRG     | -      | -      | -      | DDG4          | DDG3             | DDG2   | DDG1              | DDG0     | 89      |
| 0x12 (0x32) | PING     | -      | -      | PING5  | PING4         | PING3            | PING2  | PING1             | PING0    | 89      |
| 0x11 (0x31) | PORTF    | PORTF7 | PORTF6 | PORTF5 | PORTF4        | PORTF3           | PORTF2 | PORTF1            | PORTF0   | 89      |
| 0x10 (0x30) | DDRF     | DDF7   | DDF6   | DDF5   | DDF4          | DDF3             | DDF2   | DDF1              | DDF0     | 89      |
| 0x0F (0x2F) | PINF     | PINF7  | PINF6  | PINF5  | PINF4         | PINF3            | PINF2  | PINF1             | PINF0    | 89      |
| 0x0E (0x2E) | PORTE    | PORTE7 | PORTE6 | PORTE5 | PORTE4        | PORTE3           | PORTE2 | PORTE1            | PORTE0   | 88      |
| 0x0D (0x2D) | DDRE     | DDE7   | DDE6   | DDE5   | DDE4          | DDE3             | DDE2   | DDE1              | DDE0     | 88      |
| 0x0C (0x2C) | PINE     | PINE7  | PINE6  | PINE5  | PINE4         | PINE3            | PINE2  | PINE1             | PINE0    | 89      |
| 0x0B (0x2B) | PORTD    | PORTD7 | PORTD6 | PORTD5 | PORTD4        | PORTD3           | PORTD2 | PORTD1            | PORTD0   | 88      |
| 0x0A (0x2A) | DDRD     | DDD7   | DDD6   | DDD5   | DDD4          | DDD3             | DDD2   | DDD1              | DDD0     | 88      |
| 0x09 (0x29) | PIND     | PIND7  | PIND6  | PIND5  | PIND4         | PIND3            | PIND2  | PIND1             | PIND0    | 88      |
| 0x08 (0x28) | PORTC    | PORTC7 | PORTC6 | PORTC5 | PORTC4        | PORTC3           | PORTC2 | PORTC1            | PORTC0   | 88      |
| 0x07 (0x27) | DDRC     | DDC7   | DDC6   | DDC5   | DDC4          | DDC3             | DDC2   | DDC1              | DDC0     | 88      |
| 0x06 (0x26) | PINC     | PINC7  | PINC6  | PINC5  | PINC4         | PINC3            | PINC2  | PINC1             | PINC0    | 88      |
| 0x05 (0x25) | PORTB    | PORTB7 | PORTB6 | PORTB5 | PORTB4        | PORTB3           | PORTB2 | PORTB1            | PORTB0   | 87      |
| 0x04 (0x24) | DDRB     | DDB7   | DDB6   | DDB5   | DDB4          | DDB3             | DDB2   | DDB1              | DDB0     | 87      |
| 0x03 (0x23) | PINB     | PINB7  | PINB6  | PINB5  | PINB4         | PINB3            | PINB2  | PINB1             | PINB0    | 87      |
| 0x02 (0x22) | PORTA    | PORTA7 | PORTA6 | PORTA5 | PORTA4        | PORTA3           | PORTA2 | PORTA1            | PORTA0   | 87      |
| 0x01 (0x21) | DDRA     | DDA7   | DDA6   | DDA5   | DDA4          | DDA3             | DDA2   | DDA1              | DDA0     | 87      |
| 0x00 (0x20) | PINA     | PINA7  | PINA6  | PINA5  | PINA4         | PINA3            | PINA2  | PINA1             | PINA0    | 87      |

Note:

- 1. For compatibility with future devices, reserved bits should be written to zero if accessed. Reserved I/O memory addresses should never be written.
- 2. I/O Registers within the address range 0x00 0x1F are directly bit-accessible using the SBI and CBI instructions. In these registers, the value of single bits can be checked by using the SBIS and SBIC instructions.
- 3. Some of the Status Flags are cleared by writing a logical one to them. Note that, unlike most other AVRs, the CBI and SBI instructions will only operate on the specified bit, and can therefore be used on registers containing such Status Flags. The CBI and SBI instructions work with registers 0x00 to 0x1F only.
- 4. When using the I/O specific commands IN and OUT, the I/O addresses 0x00 0x3F must be used. When addressing I/O Registers as data space using LD and ST instructions, 0x20 must be added to these addresses. The ATmega329/3290/649/6490 is a complex microcontroller with more peripheral units than can be supported within the 64 location reserved in Opcode for the IN and OUT instructions. For the Extended I/O space from 0x60 0xFF in SRAM, only the ST/STS/STD and LD/LDS/LDD instructions can be used.



# 7. Instruction Set Summary

| Mnemonics        | Operands          | Description                              | Operation                                                                                    | Flags      | #Clocks |
|------------------|-------------------|------------------------------------------|----------------------------------------------------------------------------------------------|------------|---------|
| ARITHMETIC AND L | OGIC INSTRUCTIONS | 5                                        |                                                                                              |            |         |
| ADD              | Rd, Rr            | Add two Registers                        | Rd ← Rd + Rr                                                                                 | Z,C,N,V,H  | 1       |
| ADC              | Rd, Rr            | Add with Carry two Registers             | $Rd \leftarrow Rd + Rr + C$                                                                  | Z,C,N,V,H  | 1       |
| ADIW             | Rdl,K             | Add Immediate to Word                    | Rdh:Rdl ← Rdh:Rdl + K                                                                        | Z,C,N,V,S  | 2       |
| SUB              | Rd, Rr            | Subtract two Registers                   | Rd ← Rd - Rr                                                                                 | Z,C,N,V,H  | 1       |
| SUBI             | Rd, K             | Subtract Constant from Register          | Rd ← Rd - K                                                                                  | Z,C,N,V,H  | 1       |
| SBC              | Rd, Rr            | Subtract with Carry two Registers        | Rd ← Rd - Rr - C                                                                             | Z,C,N,V,H  | 1       |
| SBCI             | Rd, K             | Subtract with Carry Constant from Reg.   | Rd ← Rd - K - C                                                                              | Z,C,N,V,H  | 1       |
| SBIW             | Rdl,K             | Subtract Immediate from Word             | Rdh:Rdl ← Rdh:Rdl - K                                                                        | Z,C,N,V,S  | 2       |
| AND              | Rd, Rr            | Logical AND Registers                    | Rd ← Rd • Rr                                                                                 | Z,N,V      | 1       |
| ANDI             | Rd, K             | Logical AND Register and Constant        | Rd ← Rd • K                                                                                  | Z,N,V      | 1       |
| OR               | Rd, Rr            | Logical OR Registers                     | Rd ← Rd v Rr                                                                                 | Z,N,V      | 1       |
| ORI              | Rd, K             | Logical OR Register and Constant         | Rd ← Rd v K                                                                                  | Z,N,V      | 1       |
| EOR              | Rd, Rr            | Exclusive OR Registers                   | Rd ← Rd ⊕ Rr                                                                                 | Z,N,V      | 1       |
| COM              | Rd                | One's Complement                         | Rd ← 0xFF – Rd                                                                               | Z,C,N,V    | 1       |
| NEG              | Rd                | Two's Complement                         | Rd ← 0x00 – Rd                                                                               | Z,C,N,V,H  | 1       |
| SBR              | Rd,K              | Set Bit(s) in Register                   | Rd ← Rd v K                                                                                  | Z,N,V      | 1       |
| CBR              | Rd,K              | Clear Bit(s) in Register                 | $Rd \leftarrow Rd \bullet (0xFF - K)$                                                        | Z,N,V      | 1       |
| INC              | Rd                | Increment                                | Rd ← Rd + 1                                                                                  | Z,N,V      | 1       |
| DEC              | Rd                | Decrement                                | Rd ← Rd – 1                                                                                  | Z,N,V      | 1       |
| TST              | Rd                | Test for Zero or Minus                   | Rd ← Rd • Rd                                                                                 | Z,N,V      | 1       |
| CLR              | Rd                | Clear Register                           | Rd ← Rd ⊕ Rd                                                                                 | Z,N,V      | 1       |
| SER              | Rd                | Set Register                             | Rd ← 0xFF                                                                                    | None       | 1       |
| MUL              | Rd, Rr            | Multiply Unsigned                        | R1:R0 ← Rd x Rr                                                                              | Z,C        | 2       |
| MULS             | Rd, Rr            | Multiply Signed                          | R1:R0 ← Rd x Rr                                                                              | Z,C        | 2       |
| MULSU            | Rd, Rr            | Multiply Signed with Unsigned            | R1:R0 ← Rd x Rr                                                                              | Z,C        | 2       |
| FMUL             | Rd, Rr            | Fractional Multiply Unsigned             | R1:R0 ← (Rd x Rr) << 1                                                                       | Z,C        | 2       |
| FMULS            | Rd, Rr            | Fractional Multiply Signed               | R1:R0 ← (Rd x Rr) << 1                                                                       | Z,C        | 2       |
| FMULSU           | Rd, Rr            | Fractional Multiply Signed with Unsigned | R1:R0 ← (Rd x Rr) << 1                                                                       | Z.C        | 2       |
| BRANCH INSTRUC   | TIONS             |                                          |                                                                                              |            |         |
| RJMP             | k                 | Relative Jump                            | PC ← PC + k + 1                                                                              | None       | 2       |
| IJMP             |                   | Indirect Jump to (Z)                     | PC ← Z                                                                                       | None       | 2       |
| JMP              | k                 | Direct Jump                              | PC ← k                                                                                       | None       | 3       |
| RCALL            | k                 | Relative Subroutine Call                 | PC ← PC + k + 1                                                                              | None       | 3       |
| ICALL            |                   | Indirect Call to (Z)                     | PC ← Z                                                                                       | None       | 3       |
| CALL             | k                 | Direct Subroutine Call                   | PC ← k                                                                                       | None       | 4       |
| RET              |                   | Subroutine Return                        | PC ← STACK                                                                                   | None       | 4       |
| RETI             |                   | Interrupt Return                         | PC ← STACK                                                                                   | ı          | 4       |
| CPSE             | Rd,Rr             | Compare, Skip if Equal                   | if (Rd = Rr) PC ← PC + 2 or 3                                                                | None       | 1/2/3   |
| СР               | Rd,Rr             | Compare                                  | Rd – Rr                                                                                      | Z, N,V,C,H | 1       |
| CPC              | Rd,Rr             | Compare with Carry                       | Rd – Rr – C                                                                                  | Z, N,V,C,H | 1       |
| CPI              | Rd,K              | Compare Register with Immediate          | Rd – K                                                                                       | Z, N,V,C,H | 1       |
| SBRC             | Rr, b             | Skip if Bit in Register Cleared          | if (Rr(b)=0) PC ← PC + 2 or 3                                                                | None       | 1/2/3   |
| SBRS             | Rr, b             | Skip if Bit in Register is Set           | if $(Rr(b)=1)$ PC $\leftarrow$ PC + 2 or 3                                                   | None       | 1/2/3   |
| SBIC             | P, b              | Skip if Bit in I/O Register Cleared      | if $(P(b)=0)$ PC $\leftarrow$ PC + 2 or 3                                                    | None       | 1/2/3   |
| SBIS             | P, b              | Skip if Bit in I/O Register is Set       | if $(P(b)=1)$ PC $\leftarrow$ PC + 2 or 3                                                    | None       | 1/2/3   |
| BRBS             | s, k              | Branch if Status Flag Set                | if (SREG(s) = 1) then PC←PC+k + 1                                                            | None       | 1/2     |
| BRBC             | s, k              | Branch if Status Flag Cleared            | if (SREG(s) = 0) then PC←PC+k + 1                                                            | None       | 1/2     |
| BREQ             | k                 | Branch if Equal                          | if $(Z = 1)$ then $PC \leftarrow PC + k + 1$                                                 | None       | 1/2     |
| BRNE             | k                 | Branch if Not Equal                      | if $(Z = 0)$ then $PC \leftarrow PC + k + 1$                                                 | None       | 1/2     |
| BRCS             | k                 | Branch if Carry Set                      | if (C = 1) then PC $\leftarrow$ PC + k + 1                                                   | None       | 1/2     |
| BRCC             | k                 | Branch if Carry Cleared                  | if (C = 0) then $PC \leftarrow PC + k + 1$                                                   | None       | 1/2     |
| BRSH             | k                 | Branch if Same or Higher                 | if (C = 0) then PC $\leftarrow$ PC + k + 1                                                   | None       | 1/2     |
| BRLO             | k                 | Branch if Lower                          | if (C = 1) then PC $\leftarrow$ PC + k + 1                                                   | None       | 1/2     |
| BRMI             | k                 | Branch if Minus                          | if $(N = 1)$ then $PC \leftarrow PC + k + 1$                                                 | None       | 1/2     |
| BRPL             | k                 | Branch if Plus                           | if $(N = 0)$ then $PC \leftarrow PC + k + 1$                                                 | None       | 1/2     |
| BRGE             | k                 | Branch if Greater or Equal, Signed       | if $(N \oplus V = 0)$ then $PC \leftarrow PC + k + 1$                                        | None       | 1/2     |
| BRLT             | k                 | Branch if Less Than Zero, Signed         | if (N ⊕ V= 1) then PC ← PC + k + 1                                                           | None       | 1/2     |
| BRHS             | k                 | Branch if Half Carry Flag Set            | if (H = 1) then PC ← PC + k + 1                                                              | None       | 1/2     |
| BRHC             | k                 | Branch if Half Carry Flag Cleared        | if $(H = 1)$ then $PC \leftarrow PC + k + 1$<br>if $(H = 0)$ then $PC \leftarrow PC + k + 1$ | None       | 1/2     |
|                  |                   |                                          | , ,                                                                                          |            |         |
| BRTS             | k                 | Branch if T Flag Set                     | if (T = 1) then PC $\leftarrow$ PC + k + 1                                                   | None       | 1/2     |



| Mnomonios          | Operands          | Description                                                     | Operation                                                                                | Flags        | #Clocks    |
|--------------------|-------------------|-----------------------------------------------------------------|------------------------------------------------------------------------------------------|--------------|------------|
| Mnemonics          | Operands          |                                                                 | Operation                                                                                |              |            |
| BRTC               | k                 | Branch if T Flag Cleared                                        | if (T = 0) then PC ← PC + k + 1                                                          | None         | 1/2        |
| BRVS               | k                 | Branch if Overflow Flag is Set                                  | if $(V = 1)$ then $PC \leftarrow PC + k + 1$                                             | None         | 1/2        |
| BRVC<br>BRIE       | k<br>k            | Branch if Overflow Flag is Cleared  Branch if Interrupt Enabled | if (V = 0) then PC $\leftarrow$ PC + k + 1<br>if (I = 1) then PC $\leftarrow$ PC + k + 1 | None<br>None | 1/2<br>1/2 |
| BRID               | k                 | Branch if Interrupt Disabled                                    | if ( I = 0) then PC ← PC + k + 1                                                         | None         | 1/2        |
| BIT AND BIT-TEST I |                   | Branch in Interrupt Bisabled                                    | TI (1 = 0) then I O = I O = K = I                                                        | None         | 1/2        |
| SBI                | P,b               | Set Bit in I/O Register                                         | I/O(P,b) ← 1                                                                             | None         | 2          |
| CBI                | P,b               | Clear Bit in I/O Register                                       | I/O(P,b) ← 0                                                                             | None         | 2          |
| LSL                | Rd                | Logical Shift Left                                              | $Rd(n+1) \leftarrow Rd(n), Rd(0) \leftarrow 0$                                           | Z,C,N,V      | 1          |
| LSR                | Rd                | Logical Shift Right                                             | $Rd(n) \leftarrow Rd(n+1), Rd(7) \leftarrow 0$                                           | Z,C,N,V      | 1          |
| ROL                | Rd                | Rotate Left Through Carry                                       | $Rd(0)\leftarrow C,Rd(n+1)\leftarrow Rd(n),C\leftarrow Rd(7)$                            | Z,C,N,V      | 1          |
| ROR                | Rd                | Rotate Right Through Carry                                      | $Rd(7)\leftarrow C,Rd(n)\leftarrow Rd(n+1),C\leftarrow Rd(0)$                            | Z,C,N,V      | 1          |
| ASR                | Rd                | Arithmetic Shift Right                                          | $Rd(n) \leftarrow Rd(n+1), n=06$                                                         | Z,C,N,V      | 1          |
| SWAP               | Rd                | Swap Nibbles                                                    | Rd(30)←Rd(74),Rd(74)←Rd(30)                                                              | None         | 1          |
| BSET               | S                 | Flag Set                                                        | SREG(s) ← 1                                                                              | SREG(s)      | 1          |
| BCLR               | S                 | Flag Clear                                                      | $SREG(s) \leftarrow 0$                                                                   | SREG(s)      | 1          |
| BST<br>BLD         | Rr, b<br>Rd, b    | Bit Store from Register to T  Bit load from T to Register       | $T \leftarrow Rr(b)$ $Rd(b) \leftarrow T$                                                | None         | 1          |
| SEC                | nu, b             | Set Carry                                                       | C ← 1                                                                                    | C            | 1 1        |
| CLC                |                   | Clear Carry                                                     | C ← 0                                                                                    | С            | 1          |
| SEN                |                   | Set Negative Flag                                               | N ← 1                                                                                    | N            | 1          |
| CLN                |                   | Clear Negative Flag                                             | N ← 0                                                                                    | N            | 1          |
| SEZ                |                   | Set Zero Flag                                                   | Z ← 1                                                                                    | Z            | 1          |
| CLZ                |                   | Clear Zero Flag                                                 | Z ← 0                                                                                    | Z            | 1          |
| SEI                |                   | Global Interrupt Enable                                         | 1←1                                                                                      | 1            | 1          |
| CLI                |                   | Global Interrupt Disable                                        | 1←0                                                                                      | 1            | 1          |
| SES                |                   | Set Signed Test Flag                                            | S ← 1                                                                                    | S            | 1          |
| CLS                |                   | Clear Signed Test Flag                                          | S ← 0                                                                                    | S            | 1          |
| SEV                |                   | Set Twos Complement Overflow.                                   | V ← 1                                                                                    | V            | 1          |
| CLV<br>SET         |                   | Clear Twos Complement Overflow Set T in SREG                    | V ← 0<br>T ← 1                                                                           | T            | 1 1        |
| CLT                |                   | Clear T in SREG                                                 | T ← 0                                                                                    |              | 1          |
| SEH                |                   | Set Half Carry Flag in SREG                                     | H ← 1                                                                                    | Н            | 1          |
| CLH                |                   | Clear Half Carry Flag in SREG                                   | H ← 0                                                                                    | Н            | 1          |
| DATA TRANSFER II   | NSTRUCTIONS       |                                                                 |                                                                                          |              |            |
| MOV                | Rd, Rr            | Move Between Registers                                          | Rd ← Rr                                                                                  | None         | 1          |
| MOVW               | Rd, Rr            | Copy Register Word                                              | $Rd+1:Rd \leftarrow Rr+1:Rr$                                                             | None         | 1          |
| LDI                | Rd, K             | Load Immediate                                                  | Rd ← K                                                                                   | None         | 1          |
| LD                 | Rd, X             | Load Indirect                                                   | $Rd \leftarrow (X)$                                                                      | None         | 2          |
| LD                 | Rd, X+            | Load Indirect and Post-Inc.                                     | $Rd \leftarrow (X), X \leftarrow X + 1$                                                  | None         | 2          |
| LD                 | Rd, - X           | Load Indirect and Pre-Dec.                                      | $X \leftarrow X - 1$ , $Rd \leftarrow (X)$                                               | None         | 2          |
| LD<br>LD           | Rd, Y             | Load Indirect Load Indirect and Post-Inc.                       | $Rd \leftarrow (Y)$                                                                      | None         | 2          |
| LD                 | Rd, Y+<br>Rd, - Y | Load Indirect and Pre-Dec.                                      | $Rd \leftarrow (Y), Y \leftarrow Y + 1$ $Y \leftarrow Y - 1, Rd \leftarrow (Y)$          | None<br>None | 2          |
| LDD                | Rd,Y+q            | Load Indirect with Displacement                                 | $Rd \leftarrow (Y + q)$                                                                  | None         | 2          |
| LD                 | Rd, Z             | Load Indirect                                                   | $Rd \leftarrow (Z)$                                                                      | None         | 2          |
| LD                 | Rd, Z+            | Load Indirect and Post-Inc.                                     | $Rd \leftarrow (Z), Z \leftarrow Z+1$                                                    | None         | 2          |
| LD                 | Rd, -Z            | Load Indirect and Pre-Dec.                                      | $Z \leftarrow Z - 1$ , $Rd \leftarrow (Z)$                                               | None         | 2          |
| LDD                | Rd, Z+q           | Load Indirect with Displacement                                 | $Rd \leftarrow (Z + q)$                                                                  | None         | 2          |
| LDS                | Rd, k             | Load Direct from SRAM                                           | Rd ← (k)                                                                                 | None         | 2          |
| ST                 | X, Rr             | Store Indirect                                                  | (X) ← Rr                                                                                 | None         | 2          |
| ST                 | X+, Rr            | Store Indirect and Post-Inc.                                    | $(X) \leftarrow Rr, X \leftarrow X + 1$                                                  | None         | 2          |
| ST                 | - X, Rr           | Store Indirect and Pre-Dec.                                     | $X \leftarrow X - 1, (X) \leftarrow Rr$                                                  | None         | 2          |
| ST                 | Y, Rr             | Store Indirect                                                  | (Y) ← Rr                                                                                 | None         | 2          |
| ST                 | Y+, Rr            | Store Indirect and Post-Inc.                                    | $(Y) \leftarrow Rr, Y \leftarrow Y + 1$                                                  | None         | 2          |
| ST                 | - Y, Rr           | Store Indirect with Displacement                                | $Y \leftarrow Y - 1, (Y) \leftarrow Rr$                                                  | None         | 2          |
| STD<br>ST          | Y+q,Rr<br>Z, Rr   | Store Indirect with Displacement Store Indirect                 | $(Y + q) \leftarrow Rr$ $(Z) \leftarrow Rr$                                              | None<br>None | 2          |
| ST                 | Z+, Rr            | Store Indirect Store Indirect and Post-Inc.                     | $(Z) \leftarrow \square$<br>$(Z) \leftarrow Rr, Z \leftarrow Z + 1$                      | None         | 2          |
| ST                 | -Z, Rr            | Store Indirect and Prosenic.  Store Indirect and Pre-Dec.       | $Z \leftarrow Z - 1$ , $(Z) \leftarrow Rr$                                               | None         | 2          |
| STD                | Z+q,Rr            | Store Indirect with Displacement                                | $(Z+q) \leftarrow Rr$                                                                    | None         | 2          |
| STS                | k, Rr             | Store Direct to SRAM                                            | (k) ← Rr                                                                                 | None         | 2          |
| LPM                |                   | Load Program Memory                                             | R0 ← (Z)                                                                                 | None         | 3          |
| LPM                | Rd, Z             | Load Program Memory                                             | $Rd \leftarrow (Z)$                                                                      | None         | 3          |
| LPM                | Rd, Z+            | Load Program Memory and Post-Inc                                | $Rd \leftarrow (Z), Z \leftarrow Z+1$                                                    | None         | 3          |
| SPM                | İ                 | Store Program Memory                                            | (Z) ← R1:R0                                                                              | None         | -          |



# 8. Ordering Information

# 8.1 ATmega329

| Speed (MHz) <sup>(3)</sup> | Power Supply | Ordering Code <sup>(2)</sup>                                                                         | Package Type <sup>(1)</sup> | Operational Range             |
|----------------------------|--------------|------------------------------------------------------------------------------------------------------|-----------------------------|-------------------------------|
| 8                          | 1.8 - 5.5V   | ATmega329V-8AU<br>ATmega329V-8AUR <sup>(4)</sup><br>ATmega329V-8MU<br>ATmega329V-8MUR <sup>(4)</sup> | 64A<br>64A<br>64M1<br>64M1  | Industrial<br>(-40°C to 85°C) |
| 16                         | 2.7 - 5.5V   | ATmega329-16AU<br>ATmega329-16AUR <sup>(4)</sup><br>ATmega329-16MU<br>ATmega329-16MUR <sup>(4)</sup> | 64A<br>64A<br>64M1<br>64M1  | Industrial<br>(-40°C to 85°C) |

Notes: 1. This device can also be supplied in wafer form. Please contact your local Atmel sales office for detailed ordering information and minimum quantities.

- 2. Pb-free packaging alternative, complies to the European Directive for Restriction of Hazardous Substances (RoHS directive). Also Halide free and fully Green.
- 3. For Speed vs.  $V_{CC}$  see Figure 28-1 on page 328 and Figure 28-2 on page 328.
- 4. Tape & Reel

|             | Package Type                                                                                 |  |  |  |  |
|-------------|----------------------------------------------------------------------------------------------|--|--|--|--|
| 64 <b>A</b> | 64-lead, 14 x 14 x 1.0 mm, Thin Profile Plastic Quad Flat Package (TQFP)                     |  |  |  |  |
| 64M1        | 64-pad, 9 x 9 x 1.0 mm, Quad Flat No-Lead/Micro Lead Frame Package (QFN/MLF)                 |  |  |  |  |
| 100A        | 100-lead, 14 x 14 x 1.0 mm, 0.5 mm Lead Pitch, Thin Profile Plastic Quad Flat Package (TQFP) |  |  |  |  |



# 8.2 ATmega3290

| Speed (MHz) <sup>(3)</sup> | Power Supply | Ordering Code <sup>(2)</sup>                       | Package Type <sup>(1)</sup> | Operational Range             |
|----------------------------|--------------|----------------------------------------------------|-----------------------------|-------------------------------|
| 8                          | 1.8 - 5.5V   | ATmega3290V-8AU<br>ATmega3290V-8AUR <sup>(4)</sup> | 100A<br>100A                | Industrial<br>(-40°C to 85°C) |
| 16                         | 2.7 - 5.5V   | ATmega3290-16AU<br>ATmega3290-16AUR <sup>(4)</sup> | 100A<br>100A                | Industrial<br>(-40°C to 85°C) |

Notes:

- 1. This device can also be supplied in wafer form. Please contact your local Atmel sales office for detailed ordering information and minimum quantities.
- 2. Pb-free packaging alternative, complies to the European Directive for Restriction of Hazardous Substances (RoHS directive). Also Halide free and fully Green.
- 3. For Speed vs.  $V_{\rm CC}$  see Figure 28-1 on page 328 and Figure 28-2 on page 328.
- 4. Tape & Reel

|      | Package Type                                                                                 |  |  |  |  |
|------|----------------------------------------------------------------------------------------------|--|--|--|--|
| 64A  | 64-lead, 14 x 14 x 1.0 mm, Thin Profile Plastic Quad Flat Package (TQFP)                     |  |  |  |  |
| 64M1 | 64-pad, 9 x 9 x 1.0 mm, Quad Flat No-Lead/Micro Lead Frame Package (QFN/MLF)                 |  |  |  |  |
| 100A | 100-lead, 14 x 14 x 1.0 mm, 0.5 mm Lead Pitch, Thin Profile Plastic Quad Flat Package (TQFP) |  |  |  |  |



# 8.4 ATmega6490

| Speed (MHz) <sup>(3)</sup> | Power Supply | Ordering Code <sup>(2)</sup>                       | Package Type <sup>(1)</sup> | Operational Range             |
|----------------------------|--------------|----------------------------------------------------|-----------------------------|-------------------------------|
| 8                          | 1.8 - 5.5V   | ATmega6490V-8AU<br>ATmega6490V-8AUR <sup>(4)</sup> | 100A<br>100A                | Industrial<br>(-40°C to 85°C) |
| 16                         | 2.7 - 5.5V   | ATmega6490-16AU<br>ATmega6490-16AUR <sup>(4)</sup> | 100A<br>100A                | Industrial<br>(-40°C to 85°C) |

Notes:

- 1. This device can also be supplied in wafer form. Please contact your local Atmel sales office for detailed ordering information and minimum quantities.
- 2. Pb-free packaging alternative, complies to the European Directive for Restriction of Hazardous Substances (RoHS directive). Also Halide free and fully Green.
- 3. For Speed Grades see Figure 28-1 on page 328 and Figure 28-2 on page 328.
- 4. Tape & Reel

|      | Package Type                                                                                 |  |  |  |  |
|------|----------------------------------------------------------------------------------------------|--|--|--|--|
| 64A  | 64-lead, 14 x 14 x 1.0 mm, Thin Profile Plastic Quad Flat Package (TQFP)                     |  |  |  |  |
| 64M1 | 64-pad, 9 x 9 x 1.0 mm, Quad Flat No-Lead/Micro Lead Frame Package (QFN/MLF)                 |  |  |  |  |
| 100A | 100-lead, 14 x 14 x 1.0 mm, 0.5 mm Lead Pitch, Thin Profile Plastic Quad Flat Package (TQFP) |  |  |  |  |



# 9. Packaging Information

# 9.1 64A





# COMMON DIMENSIONS

(Unit of Measure = mm)

| SYMBOL | MIN        | NOM   | MAX   | NOTE   |
|--------|------------|-------|-------|--------|
| Α      | _          | _     | 1.20  |        |
| A1     | 0.05       | _     | 0.15  |        |
| A2     | 0.95       | 1.00  | 1.05  |        |
| D      | 15.75      | 16.00 | 16.25 |        |
| D1     | 13.90      | 14.00 | 14.10 | Note 2 |
| E      | 15.75      | 16.00 | 16.25 |        |
| E1     | 13.90      | 14.00 | 14.10 | Note 2 |
| В      | 0.30       | _     | 0.45  |        |
| С      | 0.09       | _     | 0.20  |        |
| L      | 0.45       | _     | 0.75  |        |
| е      | e 0.80 TYP |       |       |        |

# 2010-10-20

# Notes:

- 1. This package conforms to JEDEC reference MS-026, Variation AEB.
- Dimensions D1 and E1 do not include mold protrusion. Allowable protrusion is 0.25 mm per side. Dimensions D1 and E1 are maximum plastic body size dimensions including mold mismatch.

TITLE

3. Lead coplanarity is 0.10 mm maximum.

| <b>64A</b> , 64-lead, 14 x 14 mm Body Size, 1.0 mm Body Thickness, |
|--------------------------------------------------------------------|
| 0.8 mm Lead Pitch, Thin Profile Plastic Quad Flat Package (TQFP)   |

| DRAWING NO. | REV. |
|-------------|------|
| 64A         | С    |



### 9.2 64M1





# 9.3 100A



# COMMON DIMENSIONS

(Unit of Measure = mm)

| (0 0)  |          |       |       |        |  |
|--------|----------|-------|-------|--------|--|
| SYMBOL | MIN      | NOM   | MAX   | NOTE   |  |
| А      | _        | _     | 1.20  |        |  |
| A1     | 0.05     | _     | 0.15  |        |  |
| A2     | 0.95     | 1.00  | 1.05  |        |  |
| D      | 15.75    | 16.00 | 16.25 |        |  |
| D1     | 13.90    | 14.00 | 14.10 | Note 2 |  |
| Е      | 15.75    | 16.00 | 16.25 |        |  |
| E1     | 13.90    | 14.00 | 14.10 | Note 2 |  |
| В      | 0.17     | _     | 0.27  |        |  |
| С      | 0.09     | _     | 0.20  |        |  |
| L      | 0.45     | _     | 0.75  |        |  |
| е      | 0.50 TVP |       |       |        |  |

#### Notes:

- 1. This package conforms to JEDEC reference MS-026, Variation AED.
- Dimensions D1 and E1 do not include mold protrusion. Allowable protrusion is 0.25 mm per side. Dimensions D1 and E1 are maximum plastic body size dimensions including mold mismatch.
- 3. Lead coplanarity is 0.08 mm maximum.

2010-10-20

|              |                                            | TITLE                                                                                                                                 | DRAWING NO. | REV. |
|--------------|--------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------|-------------|------|
| <u>AIMEL</u> | 2325 Orchard Parkway<br>San Jose, CA 95131 | <b>100A</b> , 100-lead, 14 x 14 mm Body Size, 1.0 mm Body Thickness, 0.5 mm Lead Pitch, Thin Profile Plastic Quad Flat Package (TQFP) | 100A        | D    |



## 10. Errata

### 10.1 ATmega329

### 10.1.1 ATmega329 rev. C

Interrupts may be lost when writing the timer registers in the asynchronous timer

### 1. Interrupts may be lost when writing the timer registers in the asynchronous timer

The interrupt will be lost if a timer register that is synchronous timer clock is written when the asynchronous Timer/Counter register (TCNTx) is 0x00.

#### Problem Fix/Wortkaround

Always check that the asynchronous Timer/Counter register neither have the value 0xFF nor 0x00 before writing to the asynchronous Timer Control Register (TCCRx), asynchronous Timer Counter Register (TCNTx), or asynchronous Output Compare Register (OCRx).

### 10.1.2 ATmega329 rev. B

Not sampled.

### 10.1.3 ATmega329 rev. A

- LCD contrast voltage too high
- · Interrupts may be lost when writing the timer registers in the asynchronous timer

### 1. LCD contrast voltage too high

When the LCD is active and using low power waveform, the LCD contrast voltage can be too high. This occurs when  $V_{CC}$  is higher than  $V_{LCD}$ , and when using low LCD drivetime.

#### Problem Fix/Workaround

There are several possible workarounds:

- Use normal waveform instead of low power waveform
- Use drivetime of 375 µs or longer

#### 2. Interrupts may be lost when writing the timer registers in the asynchronous timer

The interrupt will be lost if a timer register that is synchronous timer clock is written when the asynchronous Timer/Counter register (TCNTx) is 0x00.

### **Problem Fix/Wortkaround**

Always check that the asynchronous Timer/Counter register neither have the value 0xFF nor 0x00 before writing to the asynchronous Timer Control Register (TCCRx), asynchronous Timer Counter Register (TCNTx), or asynchronous Output Compare Register (OCRx).



#### 11.5 Rev. 2552G - 07/06

- 1. Updated Table 14-2 on page 104, Table 14-4 on page 104, Table 16-3 on page 133, Table 16-5 on page 134, Table 16-5 on page 134, Table 17-2 on page 153 and Table 17-4 on page 154.
- 2. Updated "Fast PWM Mode" on page 124.
- 3. Updated Features in "USI Universal Serial Interface" on page 195.
- 4. Added "Clock speed considerations." on page 202.
- 5. "Errata" on page 379.

#### 11.6 Rev. 2552F - 06/06

- 1. Updated "Calibrated Internal RC Oscillator" on page 29.
- 2. Updated "OSCCAL Oscillator Calibration Register" on page 32
- 3. Added Table 28-2 on page 329.

### 11.7 Rev. 2552E - 04/06

1. Updated "Calibrated Internal RC Oscillator" on page 29.

#### 11.8 Rev. 2552D – 03/06

1. Updated "Errata" on page 379.

### 11.9 Rev. 2552C - 03/06

- 1. Added "Resources" on page 9.
- 2. Added Addresses in Registers.
- 3. Updated number of General Purpose I/O pins.
- 4. Updated code example in "Bit 0 IVCE: Interrupt Vector Change Enable" on page 53.
- 5. Updated Introduction in "I/O-Ports" on page 59.
- 6. Updated "SPI Serial Peripheral Interface" on page 158.
- 7. Updated "Bit 6 ACBG: Analog Comparator Bandgap Select" on page 209.
- 8. Updated Features in "Analog to Digital Converter" on page 211.
- 9. Updated "Prescaling and Conversion Timing" on page 214.
- 10. Updated features in "LCD Controller" on page 228.
- 11. Updated "ATmega329/3290/649/6490 Boot Loader Parameters" on page 290.
- 12. Updated "DC Characteristics" on page 310.
- 13. Updated "" on page 334.



### 11.10 Rev. 2552B - 05/05

- 1. MLF-package alternative changed to "Quad Flat No-Lead/Micro Lead Frame Package QFN/MLF".
- 2. Added "Pin Change Interrupt Timing" on page 54.
- 3. Updated Table 23-6 on page 242, Table 23-7 on page 243 and Table 27-15 on page 310.
- 4. Added Figure 27-12 on page 312.
- 5. Updated Figure 22-9 on page 219 and Figure 27-5 on page 304.
- 6. Updated algorithm "Enter Programming Mode" on page 299.
- 7. Added "Supply Current of I/O modules" on page 340.
- 8. Updated "Ordering Information" on page 372.

### 11.11 Rev. 2552A -11/04

1. Initial version.





Atmel Corporation

2325 Orchard Parkway San Jose, CA 95131 USA

**Tel**: (+1)(408) 441-0311 **Fax**: (+1)(408) 487-2600

www.atmel.com

Atmel Asia Limited

Unit 1-5 & 16, 19/F BEA Tower, Millennium City 5 418 Kwun Tong Road Kwun Tong, Kowloon HONG KONG **Tel**: (+852) 2245-6100

Fax: (+852) 2722-1369

Atmel Munich GmbH

Business Campus Parkring 4 D-85748 Garching b. Munich GERMANY

**Tel**: (+49) 89-31970-0 **Fax**: (+49) 89-3194621

Atmel Japan

9F, Tonetsu Shinkawa Bldg. 1-24-8 Shinkawa Chuo-ku, Tokyo 104-0033

JAPAN

**Tel**: (+81)(3) 3523-3551 **Fax**: (+81)(3) 3523-7581

### © 2011 Atmel Corporation. All rights reserved.

Atmel<sup>®</sup>, Atmel logo and combinations thereof, AVR<sup>®</sup> and others are registered trademarks or trademarks of Atmel Corporation or its subsidiaries. Other terms and product names may be trademarks of others.

Disclaimer: The information in this document is provided in connection with Atmel products. No license, express or implied, by estoppel or otherwise, to any intellectual property right is granted by this document or in connection with the sale of Atmel products. EXCEPT AS SET FORTH IN THE ATMEL TERMS AND CONDITIONS OF SALES LOCATED ON THE ATMEL WEBSITE, ATMEL ASSUMES NO LIABILITY WHATSOEVER AND DISCLAIMS ANY EXPRESS, IMPLIED OR STATUTORY WARRANTY RELATING TO ITS PRODUCTS INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTY OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, OR NON-INFRINGEMENT. IN NO EVENT SHALL ATMEL BE LIABLE FOR ANY DIRECT, INDIRECT, CONSEQUENTIAL, PUNITIVE, SPECIAL OR INCIDENTAL DAMAGES (INCLUDING, WITHOUT LIMITATION, DAMAGES FOR LOSS AND PROFITS, BUSINESS INTERRUPTION, OR LOSS OF INFORMATION) ARISING OUT OF THE USE OR INABILITY TO USE THIS DOCUMENT, EVEN IF ATMEL HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES. Atmel makes no representations or warranties with respect to the accuracy or completeness of the contents of this document and reserves the right to make changes to specifications and product descriptions at any time without notice. Atmel does not make any commitment to update the information contained herein. Unless specifically provided otherwise, Atmel products are not suitable for, and shall not be used in, automotive applications. Atmel products are not intended, authorized, or warranted for use as components in applications intended to support or sustain life.