



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 -</u> <u>Microcontrollers</u>"

#### Details

| Product Status             | Active                                                                  |
|----------------------------|-------------------------------------------------------------------------|
| Core Processor             | AVR                                                                     |
| Core Size                  | 8-Bit                                                                   |
| Speed                      | 16MHz                                                                   |
| Connectivity               | SPI, UART/USART, USI                                                    |
| Peripherals                | Brown-out Detect/Reset, LCD, POR, PWM, WDT                              |
| Number of I/O              | 54                                                                      |
| Program Memory Size        | 64KB (32K x 16)                                                         |
| Program Memory Type        | FLASH                                                                   |
| EEPROM Size                | 2K x 8                                                                  |
| RAM Size                   | 4K x 8                                                                  |
| Voltage - Supply (Vcc/Vdd) | 1.8V ~ 5.5V                                                             |
| Data Converters            | A/D 8x10b                                                               |
| Oscillator Type            | Internal                                                                |
| Operating Temperature      | -40°C ~ 85°C (TA)                                                       |
| Mounting Type              | Surface Mount                                                           |
| Package / Case             | 64-VFQFN Exposed Pad                                                    |
| Supplier Device Package    | 64-QFN (9x9)                                                            |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/atmega649a-mu |

Email: info@E-XFL.COM

Address: Room A, 16/F, Full Win Commercial Centre, 573 Nathan Road, Mongkok, Hong Kong

- Real Time Counter with separate oscillator
- Four PWM channels
- 8-channel, 10-bit ADC
- Programmable Serial USART
- Master/Slave SPI Serial Interface
- Universal Serial Interface with Start Condition Detector
- Programmable Watchdog Timer with Separate On-chip oscillator
- On-chip analog comparator
- Interrupt and Wake-up on pin change
- Special microcontroller features
  - Power-on reset and programmable Brown-out detection
  - Internal calibrated oscillator
  - External and internal interrupt sources
  - Five sleep modes: Idle, ADC Noise Reduction, Power-save, Power-down, and Standby
- I/O and packages
  - 54/69 programmable I/O lines
  - 64/100-lead TQFP, 64-pad QFN/MLF, and 64-pad DRQFN
- Speed Grade:
  - ATmega169A/169PA/649A/649P:
    - 0 16MHz @ 1.8 5.5V
  - ATmega3290A/3290PA/6490A/6490P:
    - 0 20MHz @ 1.8 5.5V
- Temperature range:
  - -40°C to 85°C industrial
- Ultra-low power consumption (picoPower<sup>®</sup> devices)
  - Active mode:
    - 1MHz, 1.8V: 215µA
    - 32kHz, 1.8V: 8µA (including oscillator)
    - 32kHz, 1.8V: 25µA (including oscillator and LCD)
  - Power-down mode:
    - 0.1µA at 1.8V
  - Power-save mode:
    - 0.6µA at 1.8V (Including 32kHz RTC)
    - 750nA at 1.8V

### 1. Pin configurations

### 1.1 Pinout - 64A (TQFP) and 64M1 (QFN/MLF)





### 1.2 Pinout - 100A (TQFP)





Note: The large center pad underneath the QFN/MLF packages is made of metal and internally connected to GND. It should be soldered or glued to the board to ensure good mechanical stability. If the center pad is left unconnected, the package might loosen from the board.



### 2. Overview

The Atmel ATmega169A/169PA/329A/329PA/3290A/3290PA/649A/649P/6490A/6490P is a low-power CMOS 8-bit microcontroller based on the Atmel®AVR® enhanced RISC architecture. By executing powerful instructions in a single clock cycle, the ATmega169A/169PA/329A/329PA/3290A/3290PA/649A/649P/6490A/6490P 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 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



#### **Comparison between Atmel** 2.2

# ATmega169A/169PA/329A/329PA/649A/649P/3290A/3290PA/6490A/6490P 1. Differences between: ATmega169A/169PA/329A/329PA/649A/649P/3290A/3290PA/6490A/6490P.

Table 2-1.

| ATmega169A   | 16Kbyte  | 512Bytes | 1Kbyte | 4 × 25 |
|--------------|----------|----------|--------|--------|
| ATmega169PA  | 16Kbyte  | 512Bytes | 1Kbyte | 4 × 25 |
| ATmega329A   | 32Kbyte  | 1Kbyte   | 2Kbyte | 4 × 25 |
| ATmega329PA  | 32Kbyte  | 1Kbyte   | 2Kbyte | 4 × 25 |
| ATmega3290A  | 32Kbytes | 1Kbyte   | 2Kbyte | 4 × 40 |
| ATmega3290PA | 32Kbyte  | 1Kbyte   | 2Kbyte | 4 × 40 |
| ATmega649A   | 64Kbyte  | 2Kbyte   | 4Kbyte | 4 × 25 |
| ATmega649P   | 64Kbyte  | 2Kbyte   | 4Kbyte | 4 × 25 |
| ATmega6490A  | 64Kbyte  | 2Kbyte   | 4Kbyte | 4 × 40 |
| ATmega6490P  | 64Kbyte  | 2Kbyte   | 4Kbyte | 4 × 40 |

### 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 Atmel ATmega169A/169PA/329A/329PA/3290A/3290PA/649A/649P/6490A/6490P as listed on page 72.

### 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 ATmega169A/169PA/329A/329PA/3290A/3290PA/649A/649P/6490A/6490P as listed on page 73.

### 2.3.5 Port C (PC7...PC0)

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

Port C also serves the functions of special features of the ATmega169A/169PA/329A/329PA/3290A/3290PA/649A/649P/6490A/6490P as listed on page 76.

### 2.3.6 Port D (PD7...PD0)

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

Port D also serves the functions of various special features of the ATmega169A/169PA/329A/329PA/3290A/3290PA/649A/649P/6490A/6490P as listed on page 77.

### 2.3.7 Port E (PE7...PE0)

Port E is an 8-bit bi-directional I/O port with internal pull-up resistors (selected for each bit). The Port E output buffers have symmetrical drive characteristics with both high sink and source capability. As inputs, Port E pins that



### 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 > 470 nF) must be connected to the LCDCAP pin as shown in Figure 24-2, if the LCD module is enabled and configured to use internal power. 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".

### 6. Capacitive touch sensing

The Atmel<sup>®</sup> QTouch<sup>®</sup> Library provides a simple to use solution to realize touch sensitive interfaces on most Atmel AVR<sup>®</sup> microcontrollers. The QTouch Library includes support for the QTouch and QMatrix<sup>®</sup> acquisition methods.

Touch sensing can be added to any application by linking the appropriate Atmel QTouch Library for the AVR Microcontroller. This is done by using a simple set of APIs to define the touch channels and sensors, and then calling the touch sensing API's to retrieve the channel information and determine the touch sensor states.

The QTouch Library is FREE and downloadable from the Atmel website at the following location: www.atmel.com/qtouchlibrary. For implementation details and other information, refer to the Atmel QTouch Library User Guide - also available for download from the Atmel website.

### 7. Register summary

| Address | Name    | Bit 7  | Bit 6  | Bit 5  | Bit 4  | Bit 3  | Bit 2  | Bit 1  | Bit 0  | Page |
|---------|---------|--------|--------|--------|--------|--------|--------|--------|--------|------|
| (0xFF)  | LCDDR19 | SEG339 | SEG338 | SEG337 | SEG336 | SEG335 | SEG334 | SEG333 | SEG332 | 236  |
| (0xFE)  | LCDDR18 | SEG331 | SEG330 | SEG329 | SEG328 | SEG327 | SEG326 | SEG325 | SEG324 | 236  |
| (0xFD)  | LCDDR17 | SEG323 | SEG322 | SEG321 | SEG320 | SEG319 | SEG318 | SEG317 | SEG316 | 236  |
| (0xFC)  | LCDDR16 | SEG315 | SEG314 | SEG313 | SEG312 | SEG311 | SEG310 | SEG309 | SEG308 | 236  |
| (0xFB)  | LCDDR15 | SEG307 | SEG306 | SEG305 | SEG304 | SEG303 | SEG302 | SEG301 | SEG300 | 236  |
| (0xFA)  | LCDDR14 | SEG239 | SEG238 | SEG237 | SEG236 | SEG235 | SEG234 | SEG233 | SEG232 | 236  |
| (0xF9)  | LCDDR13 | SEG231 | SEG230 | SEG229 | SEG228 | SEG227 | SEG226 | SEG225 | SEG224 | 236  |
| (0xF8)  | LCDDR12 | SEG223 | SEG222 | SEG221 | SEG220 | SEG219 | SEG218 | SEG217 | SEG216 | 236  |
| (0xF7)  | LCDDR11 | SEG215 | SEG214 | SEG213 | SEG212 | SEG211 | SEG210 | SEG209 | SEG208 | 236  |
| (0xF6)  | LCDDR10 | SEG207 | SEG206 | SEG205 | SEG204 | SEG203 | SEG202 | SEG201 | SEG200 | 236  |
| (0xF5)  | LCDDR09 | SEG139 | SEG138 | SEG137 | SEG136 | SEG135 | SEG134 | SEG133 | SEG132 | 236  |

Note: Registers with bold type only available in Atmel ATmega3290A/3290PA/6490A/6490P.



| Address          | Name     | Bit 7   | Bit 6  | Bit 5   | Bit 4    | Bit 3             | Bit 2         | Bit 1             | Bit 0   | Page |
|------------------|----------|---------|--------|---------|----------|-------------------|---------------|-------------------|---------|------|
| (0xF4)           | LCDDR08  | SEG131  | SEG130 | SEG129  | SEG128   | SEG127            | SEG126        | SEG125            | SEG124  | 236  |
| (0xF3)           | LCDDR07  | SEG123  | SEG122 | SEG121  | SEG120   | SEG119            | SEG118        | SEG117            | SEG116  | 236  |
| (0xF2)           | LCDDR06  | SEG115  | SEG114 | SEG113  | SEG112   | SEG111            | SEG110        | SEG109            | SEG108  | 236  |
| (0xF1)           | LCDDR05  | SEG107  | SEG106 | SEG105  | SEG104   | SEG103            | SEG102        | SEG101            | SEG100  | 236  |
| (0xF0)           | LCDDR04  | SEG039  | SEG038 | SEG037  | SEG036   | SEG035            | SEG034        | SEG033            | SEG032  | 236  |
| (0xEF)           | LCDDR03  | SEG031  | SEG030 | SEG029  | SEG028   | SEG027            | SEG026        | SEG025            | SEG024  | 236  |
| (0xEE)           | LCDDR02  | SEG023  | SEG022 | SEG021  | SEG020   | SEG019            | SEG018        | SEG017            | SEG016  | 236  |
| (0xED)           | LCDDR01  | SEG015  | SEG014 | SEG013  | SEG012   | SEG011            | SEG010        | SEG009            | SEG008  | 236  |
| (0xEC)           | LCDDR00  | SEG007  | SEG006 | SEG005  | SEG004   | SEG003            | SEG002        | SEG001            | SEG000  | 236  |
| (0xEB)           | Reserved | -       | -      | -       | -        | -                 | -             | -                 | -       |      |
| (0xEA)           | Reserved | -       | -      | -       | -        | -                 | -             | -                 | -       |      |
| (0xE9)           | Reserved | -       | -      | -       | -        | -                 | -             | -                 | -       |      |
| (0xE8)           | Reserved | -       | -      | -       | -        | -                 | -             | -                 | -       |      |
| (0xE0)<br>(0xE7) | LCDCCR   | LCDDC2  | LCDDC1 | LCDDC0  | LCDMDT   | LCDCC3            | LCDCC2        | LCDCC1            | LCDCC0  | 234  |
| (0xE7)<br>(0xE6) | LCDFRR   |         | LCDPS2 | LCDPS1  | LCDPS0   |                   | LCDCD2        | LCDCD1            | LCDCD0  | 233  |
| (0xE0)<br>(0xE5) | LCDCRB   | LCDCS   | LCD2B  | LCDMUX1 | LCDMUX0  | LCDPM3            | LCDPM2        | LCDPM1            | LCDPM0  | 232  |
| (0xE3)<br>(0xE4) | LCDCRA   | LCDEN   | LCDAB  | -       | LCDIF    | LCDIE             | LCDBD         | LCDCCD            | LCDBL   | 231  |
| (0xE4)<br>(0xE3) | Reserved | -       | -      | -       | -        | -                 | -             | -                 | -       | 201  |
| (0xE3)<br>(0xE2) | Reserved | -       | -      | -       | -        | -                 | -             | -                 | -       |      |
| , ,              | Reserved | -       | -      | -       | -        | -                 | -             | -                 | -       |      |
| (0xE1)           | Reserved | -       | -      | -       | -        | -                 | -             | -                 | _       |      |
| (0xE0)<br>(0xDF) | Reserved | -       | -      | -       | -        | -                 | -             | -                 | -       |      |
| , ,              | Reserved | -       | -      | _       | -        | -                 | -             | -                 | -       |      |
| (0xDE)<br>(0xDD) | PORTJ    | _       | PORTJ6 | PORTJ5  | PORTJ4   | PORTJ3            | PORTJ2        | PORTJ1            | PORTJ0  | 93   |
| (0xDD)<br>(0xDC) | DDRJ     | -       | DDJ6   | DDJ5    | DDJ4     | DDJ3              | DDJ2          | DDJ1              | DDJ0    | 93   |
| . ,              | PINJ     | -       | PINJ6  | PINJ5   | PINJ4    | PINJ3             | PINJ2         | PINJ1             | PINJO   | 93   |
| (0xDB)           | PORTH    | PORTH7  | PORTH6 | PORTH5  | PORTH4   | PORTH3            | PORTH2        | PORTH1            | PORTH0  | 93   |
| (0xDA)           | DDRH     | DDH7    | DDH6   | DDH5    | DDH4     | DDH3              | DDH2          | DDH1              | DDH0    | 93   |
| (0xD9)           | PINH     | PINH7   | PINH6  | PINH5   | PINH4    | PINH3             | PINH2         | PINH1             | PINH0   | 93   |
| (0xD8)           | Reserved | F INTI/ | -      | -       | -        | FINITS            | -             | -                 | FINIT   |      |
| (0xD7)           | Reserved | -       |        |         |          | -                 |               |                   | -       |      |
| (0xD6)           | Reserved | -       | -      | -       | -        | -                 | -             | -                 | -       |      |
| (0xD5)           |          | -       | -      | -       |          | -                 | -             |                   | -       |      |
| (0xD4)           | Reserved | -       | -      | -       | -        | -                 | -             | -                 | -       |      |
| (0xD3)           | Reserved | -       | -      | -       | -        | -                 | -             | -                 | -       |      |
| (0xD2)           | Reserved | -       | -      | -       | -        | -                 | -             | -                 | -       |      |
| (0xD1)           | Reserved | -       | -      | -       | -        | -                 | -             | -                 | -       |      |
| (0xD0)           | Reserved | -       | -      | -       | -        | -                 | -             | -                 | -       |      |
| (0xCF)           | Reserved | -       | -      | -       | -        | -                 | -             | -                 | -       |      |
| (0xCE)           | Reserved | -       | -      | -       | -        | -                 | -             | -                 | -       |      |
| (0xCD)           | Reserved | -       | -      | -       | -        | -                 | -             | -                 | -       |      |
| (0xCC)           | Reserved | -       | -      | -       | -        | -                 | -             | -                 | -       |      |
| (0xCB)           | Reserved | -       | -      | -       | -        | -                 | -             | -                 | -       |      |
| (0xCA)           | Reserved | -       | -      | -       | -        | -                 | -             | -                 | -       |      |
| (0xC9)           | Reserved | -       | -      | -       | -        | -                 | -             | -                 | -       |      |
| (0xC8)           | Reserved | -       | -      | -       | -        | -                 | -             | -                 | -       |      |
| (0xC7)           | Reserved | -       | -      | -       | -        | -                 | -             | -                 | -       |      |
| (0xC6)           | UDR0     |         |        |         | USART0 D | ata Register      |               |                   |         | 186  |
| (0xC5)           | UBRR0H   |         |        |         |          |                   | USART0 Baud R | ate Register High |         | 190  |
| (0xC4)           | UBRR0L   |         |        |         |          | Rate Register Low |               |                   |         | 190  |
| (0xC3)           | Reserved | -       | -      | -       | -        | -                 | -             | -                 | -       |      |
| (0xC2)           | UCSR0C   | -       | UMSEL0 | UPM01   | UPM00    | USBS0             | UCSZ01        | UCSZ00            | UCPOL0  | 189  |
| (0xC1)           | UCSR0B   | RXCIE0  | TXCIE0 | UDRIE0  | RXEN0    | TXEN0             | UCSZ02        | RXB80             | TXB80   | 188  |
| (0xC0)           | UCSR0A   | RXC0    | TXC0   | UDRE0   | FE0      | DOR0              | UPE0          | U2X0              | MPCM0   | 187  |
| (0xBF)           | Reserved | -       | -      | -       | -        | -                 | -             | -                 | -       |      |
| (0xBE)           | Reserved | -       | -      | -       | -        | -                 | -             | -                 | -       |      |
| (0xBD)           | Reserved | -       | -      | -       | -        | -                 | -             | -                 | -       |      |
| (0xBC)           | Reserved | -       | -      | -       | -        | -                 | -             | -                 | -       |      |
| (0xBB)           | Reserved | -       | -      | -       | -        | -                 | -             | -                 | -       |      |
| (0xBA)           | USIDR    |         |        |         | USI Data | a Register        |               |                   |         | 197  |
| (0xB9)           | USISR    | USISIF  | USIOIF | USIPF   | USIDC    | USICNT3           | USICNT2       | USICNT1           | USICNT0 | 198  |
| (0xB8)           | USICR    | USISIE  | USIOIE | USIWM1  | USIWM0   | USICS1            | USICS0        | USICLK            | USITC   | 198  |
|                  | Reserved | -       | -      | -       | -        | -                 | -             | -                 | -       |      |
| , ,              | Reserveu |         |        |         |          |                   |               |                   |         | -    |
| (0xB7)           | ASSR     | -       | -      | -       | EXCLK    | AS2               | TCN2UB        | OCR2UB            | TCR2UB  | 153  |
| , ,              |          | -       | -      | -       | EXCLK    | AS2               | TCN2UB        | OCR2UB            | TCR2UB  | 153  |



### 8. Instruction set summary

| Mnemonics        | Operands          | Description                                                | Operation                                                                                                              | Flags      | #Clocks |
|------------------|-------------------|------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------|------------|---------|
| ARITHMETIC AND L | OGIC INSTRUCTIONS | 3                                                          | -                                                                                                                      |            |         |
| ADD              | Rd, Rr            | Add two Registers                                          | $Rd \leftarrow 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 \leftarrow Rdh:Rdl + K$                                                                                       | Z,C,N,V,S  | 2       |
| SUB              | Rd, Rr            | Subtract two Registers                                     | $Rd \leftarrow Rd - Rr$                                                                                                | Z,C,N,V,H  | 1       |
| SUBI             | Rd, K             | Subtract Constant from Register                            | $Rd \leftarrow Rd - K$                                                                                                 | Z,C,N,V,H  | 1       |
| SBC              | Rd, Rr            | Subtract with Carry two Registers                          | $Rd \leftarrow Rd - Rr - C$                                                                                            | Z,C,N,V,H  | 1       |
| SBCI             | Rd, K             | Subtract with Carry Constant from Reg.                     | $Rd \leftarrow Rd - K - C$                                                                                             | Z,C,N,V,H  | 1       |
| SBIW             | Rdl,K             | Subtract Immediate from Word                               | Rdh:RdI ← Rdh:RdI - K                                                                                                  | Z,C,N,V,S  | 2       |
| AND              | Rd, Rr            | Logical AND Registers                                      | $Rd \leftarrow Rd \bullet Rr$                                                                                          | Z,N,V      | 1       |
| ANDI             | Rd, K             | Logical AND Register and Constant                          | $Rd \leftarrow Rd \bullet K$                                                                                           | Z,N,V      | 1       |
| OR               | Rd, Rr            | Logical OR Registers                                       | $Rd \leftarrow Rd \vee Rr$                                                                                             | Z,N,V      | 1       |
| ORI              | Rd, K             | Logical OR Register and Constant                           | $Rd \leftarrow Rd \vee K$                                                                                              | Z,N,V      | 1       |
| EOR              | Rd, Rr            | Exclusive OR Registers                                     | $Rd \leftarrow Rd \oplus Rr$                                                                                           | Z,N,V      | 1       |
| COM              | Rd                | One's Complement                                           | $Rd \leftarrow 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 \leftarrow Rd \vee 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                |                                                            | 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 \leftarrow Rd \bullet Rd$                                                                                          | Z,N,V      | 1       |
| CLR              | Rd                | Clear Register                                             | $Rd \leftarrow Rd \oplus Rd$                                                                                           | Z,N,V      | 1       |
| SER              | Rd                | Set Register                                               | Rd ← 0xFF                                                                                                              | None       | 1       |
| MUL              | Rd, Rr            | Multiply Unsigned                                          | $R1:R0 \leftarrow Rd \times Rr$                                                                                        | Z,C        | 2       |
| MULS             | Rd, Rr            | Multiply Signed                                            | $R1:R0 \leftarrow Rd \times Rr$                                                                                        | Z,C        | 2       |
| MULSU            | Rd, Rr            | Multiply Signed with Unsigned                              | $\begin{array}{l} \text{R1:R0} \leftarrow \text{Rd x Rr} \\ \text{R1:R0} \leftarrow (\text{Rd x Rr}) << 1 \end{array}$ | Z,C<br>Z,C | 2       |
| FMUL<br>FMULS    | Rd, Rr<br>Rd, Rr  | Fractional Multiply Unsigned<br>Fractional Multiply Signed | $R1:R0 \leftarrow (Rd x Rr) \le 1$<br>R1:R0 $\leftarrow$ (Rd x Rr) $\le 1$                                             | Z,C<br>Z,C | 2       |
| FMULSU           | Rd, Rr            | Fractional Multiply Signed with Unsigned                   | $R1:R0 \leftarrow (Rd x Rr) \le 1$                                                                                     | Z,C        | 2       |
| BRANCH INSTRUCT  |                   | Tractional Multiply Signed with Onsigned                   |                                                                                                                        | 2,0        | 2       |
| RJMP             | k                 | Relative Jump                                              | $PC \leftarrow PC + k + 1$                                                                                             | None       | 2       |
| IJMP             | ĸ                 | Indirect Jump to (Z)                                       | $PC \leftarrow Z$                                                                                                      | None       | 2       |
| JMP              | k                 | Direct Jump                                                | $PC \leftarrow k$                                                                                                      | None       | 3       |
| RCALL            | k                 | Relative Subroutine Call                                   | $PC \leftarrow PC + k + 1$                                                                                             | None       | 3       |
| ICALL            | N .               | 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 \leftarrow STACK$                                                                                                  | 1          | 4       |
| CPSE             | Rd,Rr             | Compare, Skip if Equal                                     | if (Rd = Rr) PC $\leftarrow$ PC + 2 or 3                                                                               | None       | 1/2/3   |
| CP               | 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 ← PC + 2 or 3                                                                                          | None       | 1/2/3   |
| SBIC             | P, b              | Skip if Bit in I/O Register Cleared                        | if (P(b)=0) PC ← 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 ← PC + 2 or 3                                                                                           | None       | 1/2/3   |
| BRBS             | s, k              | Branch if Status Flag Set                                  | if $(SREG(s) = 1)$ then $PC \leftarrow PC+k + 1$                                                                       | None       | 1/2     |
| BRBC             | s, k              | Branch if Status Flag Cleared                              | if $(SREG(s) = 0)$ then $PC \leftarrow 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 \oplus V=1)$ then PC $\leftarrow$ PC + k + 1                                                                    | None       | 1/2     |
| BRHS             | k                 | Branch if Half Carry Flag Set                              | if (H = 1) then PC $\leftarrow$ PC + k + 1                                                                             | None       | 1/2     |
| BRHC             | k                 | Branch if Half Carry Flag Cleared                          | if (H = 0) then PC $\leftarrow$ PC + k + 1<br>if (T = 1) then PC $\leftarrow$ PC + k + 1                               | None       | 1/2     |
| BRTS             | k k               | Branch if T Flag Set                                       | if (T = 1) then PC $\leftarrow$ PC + k + 1<br>if (T = 0) then PC $\leftarrow$ PC + k + 1                               | None       | 1/2     |
| BRTC             | k                 | Branch if T Flag Cleared                                   | if (T = 0) then PC $\leftarrow$ PC + k + 1<br>if (V = 1) then PC $\leftarrow$ 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     |



### 9.2 Atmel ATmega169PA

| Speed [MHz] <sup>(3)</sup> | Power supply | Ordering code <sup>(2)</sup>                                                                                                                               | Package type <sup>(1)</sup>                | Operational range                           |
|----------------------------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------|---------------------------------------------|
| 16                         | 1.8 - 5.5V   | ATmega169PA-AU<br>ATmega169PA-AUR <sup>(4)</sup><br>ATmega169PA-MU<br>ATmega169PA-MUR <sup>(4)</sup><br>ATmega169PA-MCH<br>ATmega169PA-MCHR <sup>(4)</sup> | 64A<br>64A<br>64M1<br>64M1<br>64MC<br>64MC | Industrial<br>(-40°C to 85°C)               |
|                            |              | ATmega169PA-AN<br>ATmega169PA-ANR <sup>(4)</sup><br>ATmega169PA-MN<br>ATmega169PA-MNR <sup>(4)</sup>                                                       | 64A<br>64A<br>64M1<br>64M1                 | Extended<br>(-40°C to 105°C) <sup>(5)</sup> |

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, 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 29-1 on page 330.

- 4. Tape & Reel.
- 5. See characterization specification at 105°C.

| Package type                                                                                            |  |  |  |  |  |  |
|---------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| 64-lead, thin (1.0mm) plastic Gull Wing Quad Flat Package (TQFP)                                        |  |  |  |  |  |  |
| 64-pad, 9 × 9 × 1.0mm body, lead pitch 0.50mm, Quad Flat No-Lead/Micro Lead Frame Package (QFN/MLF)     |  |  |  |  |  |  |
| 64-lead (2-row Staggered), 7 × 7 × 1.0mm body, 4.0 × 4.0mm Exposed Pad, Quad Flat No-Lead Package (QFN) |  |  |  |  |  |  |

### 9.8 Atmel ATmega649P

| Speed [MHz] <sup>(3)</sup> | Power supply | Ordering code <sup>(2)</sup>                                                                     | Package type <sup>(1)</sup> | Operational range             |
|----------------------------|--------------|--------------------------------------------------------------------------------------------------|-----------------------------|-------------------------------|
| 16                         | 1.8 - 5.5 V  | ATmega649P-AU<br>ATmega649P-AUR <sup>(4)</sup><br>ATmega649P-MU<br>ATmega649P-MUR <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 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 29-1 on page 330.

4. Tape & Reel.

| Package type                                                                |  |  |  |  |  |
|-----------------------------------------------------------------------------|--|--|--|--|--|
| 64-lead, 14 × 14 × 1.0mm, Thin Profile Plastic Quad Flat Package (TQFP)     |  |  |  |  |  |
| 64-pad, 9 × 9 × 1.0mm, Quad Flat No-Lead/Micro Lead Frame Package (QFN/MLF) |  |  |  |  |  |

### 9.10 Atmel ATmega6490P

| Speed [MHz] <sup>(3)</sup> | Power supply | Ordering code <sup>(2)</sup>                     | Package type <sup>(1)</sup> | Operational range             |
|----------------------------|--------------|--------------------------------------------------|-----------------------------|-------------------------------|
| 20                         | 1.8 - 5.5V   | ATmega6490P-AU<br>ATmega6490P-AUR <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 complies to the European Directive for Restriction of Hazardous Substances (RoHS directive). Also Halide free and fully Green.

3. For Speed vs.  $V_{\text{CC}}$  see Figure 29-2 on page 330.

4. Tape & Reel.

Package Type

100-lead, 14 × 14 × 1.0mm, 0.5mm Lead Pitch, Thin Profile Plastic Quad Flat Package (TQFP)



### 10. Packaging Information

### 10.1 64A



Atmel





### **Atmel**

### 11. Errata

### 11.1 Atmel ATmega169A

No known errata

### 11.2 Atmel ATmega169A/169PA Rev. A to F

Not sampled.

### 11.3 Atmel ATmega169PA Rev. G

No known errata.

### 11.4 Atmel ATmega329A/329PA rev. A

- · Interrupts may be lost when writing the timer registers in the asynchronous timer
- Using BOD disable will make the chip reset

### 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/ Workaround**

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).

### 2. Using BOD disable will make the chip reset

If the part enters sleep with the BOD turned off with the BOD disable option enabled, a BOD reset will be generated at wakeup and the chip will reset.

### **Problem Fix/Workaround**

Do not use BOD disable

### 11.5 Atmel ATmega329A/329PA rev. B

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/ Workaround**

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.6 Atmel ATmega329A/329PA 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/ Workaround**

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.7 Atmel ATmega3290A/3290PA rev. A

- · Interrupts may be lost when writing the timer registers in the asynchronous timer
- Using BOD disable will make the chip reset

#### 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/ Workaround**

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).

#### 2. Using BOD disable will make the chip reset

If the part enters sleep with the BOD turned off with the BOD disable option enabled, a BOD reset will be generated at wakeup and the chip will reset.

#### **Problem Fix/Workaround**

Do not use BOD disable

### 11.8 Atmel ATmega3290A/3290PA rev. B

• 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/ Workaround**

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).



### 12.5 Rev. 8284B - 03/11

- 1. Updated the datasheet according to the Atmel new Brand Style Guide.
- 2. Updated all "Ordering information" on page 20.
- 3. Updated "Packaging Information" on page 30.

### 12.6 Rev. 8284A - 10/10

1. Initial revision



## Atmel Enabling Unlimited Possibilities<sup>®</sup>



Atmel Corporation 1600 Technology Drive, San Jose, CA 95110 USA T: (+1)(408) 441.0311 F: (+1)(408) 436.4200 | www.atmel.com

Atmel<sup>®</sup>, Atmel logo and combinations thereof, Enabling Unlimited Possibilities<sup>®</sup>, AVR <sup>®</sup> and others are registered trademarks or trademarks of Atmel Corporation in U.S. and other countries. Other terms and product names may be trademarks of others.

2014 Atmel Corporation. / Rev.: Atmel-8284FS-AVR-ATmega169A/PA/329A/PA/649A/P/3290A/PA/6490A/P-Datasheet 07/2014

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 products 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.

SAFETY-CRITICAL, MILITARY, AND AUTOMOTIVE APPLICATIONS DISCLAIMER: Atmel products are not designed for and will not be used in connection with any applications where the failure of such products would reasonably be expected to result in significant personal injury or death ("Safety-Critical Applications") without an Atmel officer's specific written consent. Safety-Critical Applications include, without limitation, life support devices and systems, equipment or systems for the operation of nuclear facilities and weapons systems. Atmel products are not designed nor intended for use in military or aerospace applications or environments unless specifically designated by Atmel as military-grade. Atmel products are not designed how intended for use in automotive applications unless specifically designated by Atmel as automotive-grade.