## **Features**

- High-performance, Low-power AVR®8-bit Microcontroller
- Advanced RISC Architecture
  - 131 Powerful Instructions Most Single-clock Cycle Execution
  - 32 x 8 General Purpose Working Registers
  - Fully Static Operation
  - Up to 16 MIPS Throughput at 16 MHz
  - On-chip 2-cycle Multiplier
- · Nonvolatile Program and Data Memories
  - 16K Bytes of In-System Self-Programmable Flash

Endurance: 10,000 Write/Erase Cycles

- Optional Boot Code Section with Independent Lock Bits

In-System Programming by On-chip Boot Program

True Read-While-Write Operation

- 512 Bytes EEPROM

Endurance: 100,000 Write/Erase Cycles

- 1K Byte Internal SRAM
- Programming Lock for Software Security
- JTAG (IEEE std. 1149.1 Compliant) Interface
  - Boundary-scan Capabilities According to the JTAG Standard
  - Extensive On-chip Debug Support
  - Programming of Flash, EEPROM, Fuses, and Lock Bits through the JTAG Interface
- · Peripheral Features
  - Two 8-bit Timer/Counters with Separate Prescalers and Compare Modes
  - One 16-bit Timer/Counter with Separate Prescaler, Compare Mode, and Capture Mode
  - Real Time Counter with Separate Oscillator
  - Four PWM Channels
  - 8-channel, 10-bit ADC
    - 8 Single-ended Channels
    - 7 Differential Channels in TQFP Package Only
    - 2 Differential Channels with Programmable Gain at 1x, 10x, or 200x
  - Byte-oriented Two-wire Serial Interface
  - Programmable Serial USART
  - Master/Slave SPI Serial Interface
  - Programmable Watchdog Timer with Separate On-chip Oscillator
  - On-chip Analog Comparator
- · Special Microcontroller Features
  - Power-on Reset and Programmable Brown-out Detection
  - Internal Calibrated RC Oscillator
  - External and Internal Interrupt Sources
  - Six Sleep Modes: Idle, ADC Noise Reduction, Power-save, Power-down, Standby and Extended Standby
- VO and Packages
  - 32 Programmable I/O Lines
  - 40-pin PDIP, 44-lead TQFP, and 44-pad MLF
- · Operating Voltages
  - 2.7 5.5V for ATmega16L
  - 4.5 5.5V for ATmega16
- Speed Grades
  - 0 8 MHz for ATmega16L
  - 0 16 MHz for ATmega16



8-bit AVR®
Microcontroller
with 16K Bytes
In-System
Programmable
Flash

ATmega16 ATmega16L

**Preliminary** 



| [                       |    |    | 1        |             |
|-------------------------|----|----|----------|-------------|
| (XCK/T0) PB0 🗆          | 1  | 40 |          | PA0 (ADC0)  |
| (T1) PB1 🗆              | 2  | 39 |          | PA1 (ADC1)  |
| (INT2/AIN0) PB2         | 3  | 38 |          | PA2 (ADC2)  |
| (OC0/AIN1) PB3          | 4  | 37 |          | PA3 (ADC3)  |
| ( <del>SS</del> ) PB4 🗆 | 5  | 36 |          | PA4 (ADC4)  |
| (MOSI) PB5 🗆            | 6  | 35 |          | PA5 (ADC5)  |
| (MISO) PB6 🗆            | 7  | 34 |          | PA6 (ADC6)  |
| (SCK) PB7 🗆             | 8  | 33 |          | PA7 (ADC7)  |
| RESET                   | 9  | 32 |          | AREF        |
| VCC 🗆                   | 10 | 31 |          | GND         |
| GND □                   | 11 | 30 | $\vdash$ | AVCC        |
| XTAL2                   | 12 | 29 |          | PC7 (TOSC2) |
| XTAL1                   | 13 | 28 | $\vdash$ | PC6 (TOSC1) |
| (RXD) PD0 🗆             | 14 | 27 |          | PC5 (TDI)   |
| (TXD) PD1 🗆             | 15 | 26 |          | PC4 (TDO)   |
| (INT0) PD2 🗆            | 16 | 25 |          | PC3 (TMS)   |
| (INT1) PD3 🗆            | 17 | 24 |          | PC2 (TCK)   |
| (OC1B) PD4 🗆            | 18 | 23 |          | PC1 (SDA)   |
| (OC1A) PD5 🗆            | 19 | 22 |          | PC0 (SCL)   |
| (ICP) PD6 🗆             | 20 | 21 |          | PD7 (OC2)   |
|                         |    |    |          |             |



## Register File Data Address Space R0 \$0000 \$0001 R1 R2 \$0002 ... ... R29 \$001D R30 \$001E R31 \$001F I/O Registers \$00 \$0020 \$01 \$0021 \$02 \$0022 ... ... \$3D \$005D \$3E \$005E \$3F \$005F Internal SRAM \$0060 \$0061

•••

\$045E \$045F



## **Instruction Set Summary**

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

| Mnemonics        | Operands     | Description                      | Operation                                                          | Flags   |
|------------------|--------------|----------------------------------|--------------------------------------------------------------------|---------|
| BRIE             | k            | Branch if Interrupt Enabled      | if ( I = 1) then PC ← PC + k + 1                                   | None    |
| BRID             | k            | Branch if Interrupt Disabled     | if ( I = 0) then PC ← PC + k + 1                                   | None    |
| DATA TRANSFER    | INSTRUCTIONS |                                  |                                                                    |         |
| MOV              | Rd, Rr       | Move Between Registers           | Rd ← Rr                                                            | None    |
| MOVW             | Rd, Rr       | Copy Register Word               | Rd+1:Rd ← Rr+1:Rr                                                  | None    |
| LDI              | Rd, K        | Load Immediate                   | Rd ← K                                                             | None    |
| LD               | Rd, X        | Load Indirect                    | Rd ← (X)                                                           | None    |
| LD               | Rd, X+       | Load Indirect and Post-Inc.      | Rd ← (X), X ← X + 1                                                | None    |
| LD               | Rd, - X      | Load Indirect and Pre-Dec.       | X ← X - 1, Rd ← (X)                                                | None    |
| LD               | Rd, Y        | Load Indirect                    | Rd ← (Y)                                                           | None    |
| LD               | Rd, Y+       | Load Indirect and Post-Inc.      | Rd ← (Y), Y ← Y + 1                                                | None    |
| LD               | Rd, - Y      | Load Indirect and Pre-Dec.       | Y ← Y - 1, Rd ← (Y)                                                | None    |
| LDD              | Rd,Y+q       | Load Indirect with Displacement  | Rd ← (Y + q)                                                       | None    |
| LD               | Rd, Z        | Load Indirect                    | Rd ← (Z)                                                           | None    |
| LD               | Rd, Z+       | Load Indirect and Post-Inc.      | Rd ← (Z), Z ← Z+1                                                  | None    |
| LD               | Rd, -Z       | Load Indirect and Pre-Dec.       | Z ← Z - 1, Rd ← (Z)                                                | None    |
| LDD              | Rd, Z+q      | Load Indirect with Displacement  | Rd ← (Z + q)                                                       | None    |
| LDS              | Rd, k        | Load Direct from SRAM            | Rd ← (k)                                                           | None    |
| ST               | X, Rr        | Store Indirect                   | (X) ← Rr                                                           | None    |
| ST               | X+, Rr       | Store Indirect and Post-Inc.     | (X) ← Rr, X ← X + 1                                                | None    |
| ST               | - X, Rr      | Store Indirect and Pre-Dec.      | X ← X - 1, (X) ← Pr                                                | None    |
| ST               | Y, Rr        | Store Indirect                   | (Y) ← Rr                                                           | None    |
| ST               | Y+, Rr       | Store Indirect and Post-Inc.     | (Y) ← Rr, Y ← Y + 1                                                | None    |
| ST               | - Y, Rr      | Store Indirect and Pre-Dec.      | Y ← Y - 1, (Y) ← Rr                                                | None    |
| STD              | Y+q,Rr       | Store Indirect with Displacement | (Y + q) ← Rr                                                       | None    |
| ST               | Z, Rr        | Store Indirect                   | (Z) ← Rr                                                           | None    |
| ST               | Z+, Rr       | Store Indirect and Post-Inc.     | (Z) ← Rr, Z ← Z + 1                                                | None    |
| ST               | -Z, Rr       | Store Indirect and Pre-Dec.      | Z ← Z - 1, (Z) ← Rr                                                | None    |
| STD              | Z+q,Rr       | Store Indirect with Displacement | (Z + q) ← Rr                                                       | None    |
| STS              | k, Rr        | Store Direct to SRAM             | (k) ← Br                                                           | None    |
| LPM              |              | Load Program Memory              | R0 ← (Z)                                                           | None    |
| LPM              | Rd, Z        | Load Program Memory              | Rd ← (Z)                                                           | None    |
| LPM              | Rd, Z+       | Load Program Memory and Post-Inc | Rd ← (Z), Z ← Z+1                                                  | None    |
| SPM              |              | Store Program Memory             | (Z) ← R1:R0                                                        | None    |
| IN               | Rd, P        | In Port                          | Rd ← P                                                             | None    |
| OUT              | P, Rr        | Out Port                         | P ← Rr                                                             | None    |
| PUSH             | Rr           | Push Register on Stack           | STACK ← Rr                                                         | None    |
| POP              | Rd           | Pop Register from Stack          | Rd ← STACK                                                         | None    |
| BIT AND BIT-TEST | INSTRUCTIONS |                                  |                                                                    |         |
| SBI              | P,b          | Set Bit in I/O Register          | I/O(P,b) ← 1                                                       | None    |
| CBI              | P,b          | Clear Bit in I/O Register        | I/O(P,b) ← 0                                                       | None    |
| LSL              | Rd           | Logical Shift Left               | Rd(n+1) ← Rd(n), Rd(0) ← 0                                         | Z,C,N,V |
| LSR              | Rd           | Logical Shift Right              | Rd(n) ← Rd(n+1), Rd(7) ← 0                                         | Z,C,N,V |
| ROL              | Rd           | Rotate Left Through Carry        | $Rd(0) \leftarrow C, Rd(n+1) \leftarrow Rd(n), C \leftarrow Rd(7)$ | Z,C,N,V |
| ROR              | Rd           | Rotate Right Through Carry       | $Rd(7) \leftarrow C, Rd(n) \leftarrow Rd(n+1), C \leftarrow Rd(0)$ | Z,C,N,V |
| ASR              | Rd           | Arithmetic Shift Right           | Rd(n) ← Rd(n+1), n=06                                              | Z,C,N,V |
| SWAP             | Rd           | Swap Nibbles                     | Rd(30) ←Rd(74),Rd(74)←Rd(30)                                       | None    |
| BSET             | s            | Flag Set                         | SREG(s) ← 1                                                        | SREG(s) |
| BCLR             | s            | Flag Clear                       | SREG(s) ← 0                                                        | SREG(s) |
| BST              | Rr, b        | Bit Store from Register to T     | T ← Rr(b)                                                          | Т       |
| вш               | Rd, b        | Bit load from T to Register      | Rd(b) ← T                                                          | None    |
| SEC              |              | Set Carry                        | C ← 1                                                              | С       |
| CLC              |              | Clear Carry                      | C ← 0                                                              | С       |
| SEN              |              | Set Negative Flag                | N ← 1                                                              | N       |
| CLN              |              | Clear Negative Flag              | N ← 0                                                              | N       |
| SEZ              |              | Set Zero Flag                    | Z←1                                                                | Z       |
| CLZ              |              | Clear Zero Flag                  | Z ← 0                                                              | Z       |
| SEI              |              | Global Interrupt Enable          | I ← 1                                                              | 1       |
| CLI              |              | Global Interrupt Disable         | 1←0                                                                | 1       |
| SES              |              | Set Signed Test Flag             | S ← 1                                                              | S       |
| CLS              | 1            | Clear Signed Test Flag           | S ← 0                                                              | S       |
| SEV              |              | Set Twos Complement Overflow.    | V ← 1                                                              | V       |
| CLV              |              | Clear Twos Complement Overflow   | V ← 0                                                              | V       |
| SET              |              | Set T in SREG                    | T ← 1                                                              | Ť       |
|                  |              | Clear T in SREG                  | T ← 0                                                              | Ť       |
| CLT              | 1            |                                  |                                                                    |         |

| Mnemonics                | Operands | Description                   | Operation                                | Flags | #Clocks |
|--------------------------|----------|-------------------------------|------------------------------------------|-------|---------|
| CLH                      |          | Clear Half Carry Flag in SREG | H ← 0                                    | Н     | 1       |
| MCU CONTROL INSTRUCTIONS |          |                               |                                          |       |         |
| NOP                      |          | No Operation                  |                                          | None  | 1       |
| SLEEP                    |          | Sleep                         | (see specific descr. for Sleep function) | None  | 1       |
| WDR                      |          | Watchdog Reset                | (see specific descr. for WDR/timer)      | None  | 1       |
| BREAK                    |          | Break                         | For On-Chip Debug Only                   | None  | N/A     |

