Introduction

The Atmel® ATmega8A is a low-power CMOS 8-bit microcontroller based on the AVR® enhanced RISC architecture. By executing powerful instructions in a single clock cycle, the ATmega8A achieves throughputs close to 1MIPS per MHz. This empowers system designer to optimize the device for power consumption versus processing speed.

Features

• High-performance, Low-power Atmel AVR 8-bit Microcontroller
• Advanced RISC Architecture
  – 130 Powerful Instructions - Most Single-clock Cycle Execution
  – 32 x 8 General Purpose Working Registers
  – Fully Static Operation
  – Up to 16MIPS Throughput at 16MHz
  – On-chip 2-cycle Multiplier
• High Endurance Non-volatile Memory segments
  – 8KBytes of In-System Self-programmable Flash program memory
  – 512Bytes EEPROM
  – 1KByte Internal SRAM
  – Write/Erase Cycles: 10,000 Flash/100,000 EEPROM
  – Data retention: 20 years at 85°C/100 years at 25°C(1)
  – Optional Boot Code Section with Independent Lock Bits
    • In-System Programming by On-chip Boot Program
    • True Read-While-Write Operation
    – Programming Lock for Software Security
• Atmel QTouch® library support
  – Capacitive touch buttons, sliders and wheels
  – Atmel QTouch and QMatrix acquisition
  – Up to 64 sense channels
• Peripheral Features
  – Two 8-bit Timer/Counters with Separate Prescaler, one Compare Mode
- One 16-bit Timer/Counter with Separate Prescaler, Compare Mode, and Capture Mode
- Real Time Counter with Separate Oscillator
- Three PWM Channels
- 8-channel ADC in TQFP and QFN/MLF package
  - Eight Channels 10-bit Accuracy
- 6-channel ADC in PDIP package
  - Six Channels 10-bit Accuracy
- 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
  - Five Sleep Modes: Idle, ADC Noise Reduction, Power-save, Power-down, and Standby
- I/O and Packages
  - 23 Programmable I/O Lines
  - 28-lead PDIP, 32-lead TQFP, and 32-pad QFN/MLF
- Operating Voltages
  - 2.7 - 5.5V
- Speed Grades
  - 0 - 16MHz
- Power Consumption at 4MHz, 3V, 25°C
  - Active: 3.6mA
  - Idle Mode: 1.0mA
  - Power-down Mode: 0.5μA
# Table of Contents

Introduction...................................................................................................................... 1

Features.......................................................................................................................... 1

1. Description................................................................................................................. 4

2. Configuration Summary............................................................................................. 5

3. Ordering Information.................................................................................................. 6

4. Block Diagram........................................................................................................... 7

5. Pin Configurations..................................................................................................... 8
   5.1. Pin Descriptions........................................................................................................... 10
   5.2. Accessing 16-bit Registers......................................................................................... 12

6. I/O Multiplexing........................................................................................................ 15

7. Resources................................................................................................................ 16

8. Data Retention......................................................................................................... 17

9. About Code Examples............................................................................................. 18

10. Capacitive Touch Sensing...................................................................................... 19

11. Packaging Information......................................................................................... 20
   11.1. 32A............................................................................................................................. 20
   11.2. 28P3.......................................................................................................................... 21
   11.3. 32M1-A....................................................................................................................... 22

12. Errata....................................................................................................................... 23
   12.1. ATmega8A, rev. L........................................................................................................... 23

13. Datasheet Revision History................................................................................. 25
   13.1. Rev.8159F – 07/2015...................................................................................................... 25
   13.2. Rev.8159E – 02/2013...................................................................................................... 25
   13.3. Rev.8159D – 02/11........................................................................................................... 25
   13.4. DRH_Rev.8159C – 07/09.................................................................................................. 25
   13.5. Rev.8159B – 05/09........................................................................................................... 25
   13.6. Rev.8159A – 08/08........................................................................................................... 25
1. **Description**  
The Atmel AVR core combines a rich instruction set with 32 general purpose working registers. All the 32 registers are directly connected to the Arithmetic Logic Unit (ALU), allowing two independent registers to be accessed in one single instruction executed in one clock cycle. The resulting architecture is more code efficient while achieving throughputs up to ten times faster than conventional CISC microcontrollers.

The ATmega8A provides the following features: 8K bytes of In-System Programmable Flash with Read-While-Write capabilities, 512 bytes of EEPROM, 1K byte of SRAM, 23 general purpose I/O lines, 32 general purpose working registers, three flexible Timer/Counters with compare modes, internal and external interrupts, a serial programmable USART, one byte oriented Two-wire Serial Interface, a 6-channel ADC (eight channels in TQFP and QFN/MLF packages) with 10-bit accuracy, a programmable Watchdog Timer with Internal Oscillator, an SPI serial port, and five software selectable power saving modes. The Idle mode stops the CPU while allowing the SRAM, Timer/Counters, one SPI port, and interrupt system to continue functioning. The Power-down mode saves the register contents but freezes the Oscillator, disabling all other chip functions until the next Interrupt or Hardware Reset. In Power-save mode, the asynchronous timer continues to run, allowing the user to maintain a timer base while the rest of the device is sleeping. The ADC Noise Reduction mode stops the CPU and all I/O modules except asynchronous timer and ADC, to minimize switching noise during ADC conversions. In Standby mode, the crystal/resonator Oscillator is running while the rest of the device is sleeping. This allows very fast start-up combined with low-power consumption.

Atmel offers the QTouch library for embedding capacitive touch buttons, sliders and wheels functionality into AVR microcontrollers. The patented charge-transfer signal acquisition offers robust sensing and includes fully debounced reporting of touch keys and includes Adjacent Key Suppression® (AKS®) technology for unambiguous detection of key events. The easy-to-use QTouch Composer allows you to explore, develop and debug your own touch applications.

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

The device is supported with a full suite of program and system development tools including: C Compilers, Macro Assemblers, Program Debugger/Simulators, In-Circuit Emulators, and Evaluation kit.
## Configuration Summary

<table>
<thead>
<tr>
<th>Features</th>
<th>ATmega8A</th>
</tr>
</thead>
<tbody>
<tr>
<td>Pin count</td>
<td>32</td>
</tr>
<tr>
<td>Flash (KB)</td>
<td>8</td>
</tr>
<tr>
<td>SRAM (KB)</td>
<td>1</td>
</tr>
<tr>
<td>EEPROM (Bytes)</td>
<td>512</td>
</tr>
<tr>
<td>General Purpose I/O pins</td>
<td>23</td>
</tr>
<tr>
<td>SPI</td>
<td>1</td>
</tr>
<tr>
<td>TWI (I(^2)C)</td>
<td>1</td>
</tr>
<tr>
<td>USART</td>
<td>1</td>
</tr>
<tr>
<td>ADC</td>
<td>10-bit 15ksps</td>
</tr>
<tr>
<td>ADC channels</td>
<td>6 (8 in TQFP and QFN/MLF packages)</td>
</tr>
<tr>
<td>AC propagation delay</td>
<td>Typ 400ns</td>
</tr>
<tr>
<td>8-bit Timer/Counters</td>
<td>2</td>
</tr>
<tr>
<td>16-bit Timer/Counters</td>
<td>1</td>
</tr>
<tr>
<td>PWM channels</td>
<td>3</td>
</tr>
<tr>
<td>RC Oscillator</td>
<td>+/-3%</td>
</tr>
<tr>
<td>Operating voltage</td>
<td>2.7 - 5.5V</td>
</tr>
<tr>
<td>Max operating frequency</td>
<td>16MHz</td>
</tr>
<tr>
<td>Temperature range</td>
<td>-40°C to +105°C</td>
</tr>
</tbody>
</table>
### 3. Ordering Information

<table>
<thead>
<tr>
<th>Speed (MHz)</th>
<th>Power Supply</th>
<th>Ordering Code(2)</th>
<th>Package(1)</th>
<th>Operational Range</th>
</tr>
</thead>
<tbody>
<tr>
<td>16</td>
<td>2.7 - 5.5V</td>
<td>ATmega8A-AU</td>
<td>32A</td>
<td>Industrial (-40°C to 85°C)</td>
</tr>
<tr>
<td></td>
<td></td>
<td>ATmega8A-AUR(3)</td>
<td>32A</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>ATmega8A-PU</td>
<td>28P3</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>ATmega8A-MU</td>
<td>32M1-A</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>ATmega8A-MUR(3)</td>
<td>32M1-A</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>ATmega8A-AN</td>
<td>32A</td>
<td>Extended (-40°C to 105°C)</td>
</tr>
<tr>
<td></td>
<td></td>
<td>ATmega8A-ANR(3)</td>
<td>32A</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>ATmega8A-MN</td>
<td>32M1-A</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>ATmega8A-MNR(3)</td>
<td>32M1-A</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>ATmega8A-PN</td>
<td>28P3</td>
<td></td>
</tr>
</tbody>
</table>

**Note:**

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. Tape and Reel

<table>
<thead>
<tr>
<th>Package Type</th>
</tr>
</thead>
<tbody>
<tr>
<td>32A</td>
</tr>
<tr>
<td>32-lead, Thin (1.0mm) Plastic Quad Flat Package (TQFP)</td>
</tr>
<tr>
<td>28P3</td>
</tr>
<tr>
<td>28-lead, 0.300” Wide, Plastic Dual Inline Package (PDIP)</td>
</tr>
<tr>
<td>32M1-A</td>
</tr>
<tr>
<td>32-pad, 5 x 5 x 1.0mm body, lead pitch 0.50mm, Quad Flat No-Lead/Micro Lead Frame Package (QFN/MLF)</td>
</tr>
</tbody>
</table>
4. Block Diagram

Figure 4-1 Block Diagram

- CPU
- USART
- ADC
  - ADC[7:0]
  - AREF
- I/O PORTS
  - PB[7:0]
  - PC[6:0]
  - PD[7:0]
- ADC
  - ADCMUX
- AC
  - AIN0
  - AIN1
- USART
  - RXD
  - TXD
  - XCK
- TWI
  - SDA
  - SCL
- Power Supervision POR/BOD & RESET
  - VCC
  - RESET
  - GND
- Power management and clock control
- Internal Reference
  - Clock generation
  - 1MHz int osc
  - 32.768kHz XOSC
  - External RC Osc
  - 12MHz External RC Osc
  - 8 MHz Crystal Osc
- Power management and clock control
- Watchdog Timer
- Internal Reference
- ADC
  - ADC[7:0]
  - AREF
- AC
  - AIN0
  - AIN1
  - ADCMUX
- USART
  - RXD
  - TXD
  - XCK
- TWI
  - SDA
  - SCL
- SPI
- I/O PORTS
  - PB[7:0]
  - PC[6:0]
  - PD[7:0]
- EXTINT
  - INT[1:0]
- TC 0
  - (8-bit)
- TC 1
  - (16-bit)
- TC 2
  - (8-bit async)
- Power Supervision POR/BOD & RESET
- VCC
- RESET
- GND
- Power management and clock control
- Internal Reference
- ADC
  - ADC[7:0]
  - AREF
- AC
  - AIN0
  - AIN1
  - ADCMUX
- USART
  - RXD
  - TXD
  - XCK
- TWI
  - SDA
  - SCL
- SPI
- I/O PORTS
  - PB[7:0]
  - PC[6:0]
  - PD[7:0]
- EXTINT
  - INT[1:0]
- TC 0
  - (8-bit)
- TC 1
  - (16-bit)
- TC 2
  - (8-bit async)
- Power Supervision POR/BOD & RESET
- VCC
- RESET
- GND
- Power management and clock control
- Internal Reference
- ADC
  - ADC[7:0]
  - AREF
- AC
  - AIN0
  - AIN1
  - ADCMUX
- USART
  - RXD
  - TXD
  - XCK
- TWI
  - SDA
  - SCL
- SPI
- I/O PORTS
  - PB[7:0]
  - PC[6:0]
  - PD[7:0]
- EXTINT
  - INT[1:0]
- TC 0
  - (8-bit)
- TC 1
  - (16-bit)
- TC 2
  - (8-bit async)
5. Pin Configurations

Figure 5-1 PDIP

- **RESET** (PC6) 1
- **RXD** (PD0) 2
- **TXD** (PD1) 3
- **INT0** (PD2) 4
- **INT1** (PD3) 5
- **XCK/T0** (PD4) 6
- **VCC** 7
- **GND** 8
- **XTAL1/TOSC1** (PB6) 9
- **XTAL2/TOSC2** (PB7) 10
- **T1** (PD5) 11
- **AIN0** (PD6) 12
- **AIN1** (PD7) 13
- **ICP1** (PB0) 14
- **PC5 (ADC5/SCL)** 28
- **PC4 (ADC4/SDA)** 27
- **PC3 (ADC3)** 26
- **PC2 (ADC2)** 25
- **PC1 (ADC1)** 24
- **PC0 (ADC0)** 23
- **GND** 22
- **AREF** 21
- **AVCC** 20
- **PB5 (SCK)** 19
- **PB4 (MISO)** 18
- **PB3 (MOSI/OC2)** 17
- **PB2 (SS/OC1B)** 16
- **PB1 (OC1A)** 15

Atmel ATmega8A [DATASHEET]
Figure 5-2 TQFP Top View

PD2 (INT0)  1
PD1 (TXD)   2
PD0 (RXD)   3
PC6 (RESET) 4
PC5 (ADC5/SCL) 5
PC4 (ADC4/SDA) 6
PC3 (ADC3) 7
PC2 (ADC2) 8

(INT1) PD3 9
(XCK/T0) PD4 10
GND 11
VCC 12
GND 13
VCC 14
(XTAL1/TOSC1) PB6 15
(XTAL2/TOSC2) PB7 16

PD5 17
(AIN0) PD6 18
(AIN1) PD7 19
(ICP1) PB0 20
(OCA1) PB1 21
(OCA1B) PB2 22
(MOSI) PB3 23
(MISO) PB4 24

PC0 (ADC0) 25
PC1 (ADC1) 26
PC0 (ADC0) 27
GND 28
ADC7 29
AREF 30
ADC6 31
AVCC 32
PB5 (SCK) 33
5.1. Pin Descriptions

5.1.1. \( V_{CC} \)
Digital supply voltage.

5.1.2. GND
Ground.

5.1.3. Port B (PB7:PB0) – XTAL1/XTAL2/TOSC1/TOSC2
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.
Depending on the clock selection fuse settings, PB6 can be used as input to the inverting Oscillator amplifier and input to the internal clock operating circuit.

Depending on the clock selection fuse settings, PB7 can be used as output from the inverting Oscillator amplifier.

If the Internal Calibrated RC Oscillator is used as chip clock source, PB7:6 is used as TOSC2:1 input for the Asynchronous Timer/Counter2 if the AS2 bit in ASSR is set.

The various special features of Port B are elaborated in Alternate Functions of Port B and System Clock and Clock Options.

5.1.4. Port C (PC5:PC0)
Port C is an 7-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.

5.1.5. PC6/RESET
If the RSTDISBL Fuse is programmed, PC6 is used as an I/O pin. Note that the electrical characteristics of PC6 differ from those of the other pins of Port C.

If the RSTDISBL Fuse is unprogrammed, PC6 is used as a Reset input. A low level on this pin for longer than the minimum pulse length will generate a Reset, even if the clock is not running. The minimum pulse length is given in Table 30-5. Shorter pulses are not guaranteed to generate a Reset.

The various special features of Port C are elaborated in Alternate Functions of Port C.

5.1.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 ATmega8A as listed in Alternate Functions of Port D.

5.1.7. RESET
Reset input. A low level on this pin for longer than the minimum pulse length will generate a reset, even if the clock is not running. The minimum pulse length is given in Table 30-5. Shorter pulses are not guaranteed to generate a reset.

5.1.8. \( V_{\text{CC}} \)
\( V_{\text{CC}} \) is the supply voltage pin for the A/D Converter, Port C (3:0), and ADC (7:6). It should be externally connected to \( V_{\text{CC}} \), even if the ADC is not used. If the ADC is used, it should be connected to \( V_{\text{CC}} \) through a low-pass filter. Note that Port C (5:4) use digital supply voltage, \( V_{\text{CC}} \).

5.1.9. AREF
AREF is the analog reference pin for the A/D Converter.

5.1.10. ADC7:6 (TQFP and QFN/MLF Package Only)
In the TQFP and QFN/MLF package, ADC7:6 serve as analog inputs to the A/D converter. These pins are powered from the analog supply and serve as 10-bit ADC channels.
5.2. **Accessing 16-bit Registers**

The TCNT1, OCR1A/B, and ICR1 are 16-bit registers that can be accessed by the AVR CPU via the 8-bit data bus. A 16-bit register must be byte accessed using two read or write operations. The 16-bit timer has a single 8-bit register for temporary storing of the High byte of the 16-bit access. The same temporary register is shared between all 16-bit registers within the 16-bit timer. Accessing the Low byte triggers the 16-bit read or write operation. When the Low byte of a 16-bit register is written by the CPU, the High byte stored in the temporary register, and the Low byte written are both copied into the 16-bit register in the same clock cycle. When the Low byte of a 16-bit register is read by the CPU, the High byte of the 16-bit register is copied into the temporary register in the same clock cycle as the Low byte is read.

Not all 16-bit accesses uses the temporary register for the High byte. Reading the OCR1A/B 16-bit registers does not involve using the temporary register.

To do a 16-bit write, the High byte must be written before the Low byte. For a 16-bit read, the Low byte must be read before the High byte.

The following code examples show how to access the 16-bit Timer Registers assuming that no interrupts updates the temporary register. The same principle can be used directly for accessing the OCR1A/B and ICR1 Registers. Note that when using "C", the compiler handles the 16-bit access.

### Assembly Code Example

```assembly
:;
; Set TCNT1 to 0x01FF
ldi r17,0x01
ldi r16,0xFF
out TCNT1H,r17
out TCNT1L,r16

; Read TCNT1 into r17:r16
in r16,TCNT1L
in r17,TCNT1H
:;
```

### C Code Example

```c
unsigned int i;

/* Set TCNT1 to 0x01FF */
TCNT1 = 0x1FF;

/* Read TCNT1 into i */
i = TCNT1;
```

**Note:** 1. See *About Code Examples*.

The assembly code example returns the TCNT1 value in the r17:r16 Register pair.

It is important to notice that accessing 16-bit registers are atomic operations. If an interrupt occurs between the two instructions accessing the 16-bit register, and the interrupt code updates the temporary register by accessing the same or any other of the 16-bit Timer Registers, then the result of the access outside the interrupt will be corrupted. Therefore, when both the main code and the interrupt code update the temporary register, the main code must disable the interrupts during the 16-bit access.

The following code examples show how to do an atomic read of the TCNT1 Register contents. Reading any of the OCR1A/B or ICR1 Registers can be done by using the same principle.
Assemble Code Example

TIM16_ReadTCNT1:
    ; Save global interrupt flag
    in     r18,SREG
    ; Disable interrupts
    cli
    ; Read TCNT1 into r17:r16
    in     r16,TCNT1L
    in     r17,TCNT1H
    ; Restore global interrupt flag
    out    SREG,r18
    ret

C Code Example

unsigned int TIM16_ReadTCNT1( void )
{
    unsigned char sreg;
    unsigned int i;
    /* Save global interrupt flag */
    sreg = SREG;
    /* Disable interrupts */
    CLI();
    /* Read TCNT1 into i */
    i = TCNT1;
    /* Restore global interrupt flag */
    SREG = sreg;
    return i;
}

Note: 1. See About Code Examples.

The assembly code example returns the TCNT1 value in the r17:r16 Register pair.

The following code examples show how to do an atomic write of the TCNT1 Register contents. Writing any of the OCR1A/B or ICR1 Registers can be done by using the same principle.

Assembly Code Example

TIM16_WriteTCNT1:
    ; Save global interrupt flag
    in     r18,SREG
    ; Disable interrupts
    cli
    ; Set TCNT1 to r17:r16
    out    TCNT1H,r17
    out    TCNT1L,r16
    ; Restore global interrupt flag
    out    SREG,r18
    ret

C Code Example

void TIM16_WriteTCNT1( unsigned int i )
{
    unsigned char sreg;
    unsigned int i;
    /* Save global interrupt flag */
sreg = SREG;
/* Disable interrupts */
CLI();
/* Set TCNT1 to i */
TCNT1 = i;
/* Restore global interrupt flag */
SREG = sreg;
}

Note: 1. See About Code Examples.

The assembly code example requires that the r17:r16 Register pair contains the value to be written to TCNT1.
6. **I/O Multiplexing**

Each pin is by default controlled by the PORT as a general purpose I/O and alternatively it can be assigned to one of the peripheral functions. This table describes the peripheral signals multiplexed to the PORT I/O pins.

**Table 6-1  PORT Function Multiplexing**

<table>
<thead>
<tr>
<th>PAD</th>
<th>Pin #</th>
<th>EXTINT</th>
<th>PCINT</th>
<th>AC</th>
<th>Custom</th>
<th>OSC</th>
<th>TC1(16-bit)</th>
<th>TC2(8-bit)</th>
<th>USART</th>
<th>SPI</th>
<th>Misc</th>
</tr>
</thead>
<tbody>
<tr>
<td>PD[4]</td>
<td>14</td>
<td>PCINT20</td>
<td>ACO</td>
<td>-</td>
<td>-</td>
<td>O1CA</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td></td>
<td></td>
</tr>
<tr>
<td>PB[6]</td>
<td>1</td>
<td>PCINT06</td>
<td>-</td>
<td>-</td>
<td>EXTCLK</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td></td>
<td></td>
</tr>
<tr>
<td>PD[5]</td>
<td>2</td>
<td>PCINT21</td>
<td>AINP1</td>
<td>-</td>
<td>-</td>
<td>CLK1</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td></td>
<td>SII</td>
</tr>
<tr>
<td>PD[6]</td>
<td>3</td>
<td>PCINT22</td>
<td>AINP0</td>
<td>-</td>
<td>-</td>
<td>ICP1</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td></td>
<td>SDO</td>
</tr>
<tr>
<td>PD[7]</td>
<td>4</td>
<td>PCINT23</td>
<td>AINN0</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>TC2-OCB</td>
<td>-</td>
<td>-</td>
<td></td>
<td>SDI</td>
</tr>
<tr>
<td>PB[2]</td>
<td>5</td>
<td>PCINT02</td>
<td>-</td>
<td>CLO0</td>
<td>CLKOUT</td>
<td>TC1-OCB</td>
<td>-</td>
<td>-</td>
<td>SS</td>
<td></td>
<td></td>
</tr>
<tr>
<td>PB[3]</td>
<td>6</td>
<td>PCINT03</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>TC2-OCA</td>
<td>TXD</td>
<td>MOSI</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>PB[4]</td>
<td>7</td>
<td>PCINT04</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>RXD</td>
<td>MISO</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>PB[5]</td>
<td>8</td>
<td>PCINT05</td>
<td>-</td>
<td>CLO1</td>
<td>-</td>
<td>-</td>
<td>XCK</td>
<td>SCK</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>PC[4]</td>
<td>9</td>
<td>PCINT12</td>
<td>AINN1</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>PC[5]</td>
<td>10</td>
<td>PCINT13</td>
<td>AINN2</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>PC[6]/</td>
<td>13</td>
<td>PCINT14</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>HVRST/d</td>
<td></td>
<td></td>
</tr>
<tr>
<td>VCC</td>
<td>11</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>GND</td>
<td>12</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>
7. **Resources**

A comprehensive set of development tools, application notes and datasheets are available for download on http://www.atmel.com/avr.
8. **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.
9. **About Code Examples**

This datasheet 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”.
10. Capacitive Touch Sensing

The Atmel QTouch Library provides a simple to use solution to realize touch sensitive interfaces on most Atmel AVR microcontrollers. The QTouch Library includes support for the QTouch and QMatrix 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.
11. Packaging Information

11.1. 32A

**Notes:**

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

**COMMON DIMENSIONS**

(Unit of measure = mm)

<table>
<thead>
<tr>
<th>SYMBOL</th>
<th>MIN</th>
<th>NOM</th>
<th>MAX</th>
<th>NOTE</th>
</tr>
</thead>
<tbody>
<tr>
<td>A</td>
<td>–</td>
<td>–</td>
<td>1.20</td>
<td></td>
</tr>
<tr>
<td>A1</td>
<td>0.05</td>
<td>–</td>
<td>0.15</td>
<td></td>
</tr>
<tr>
<td>A2</td>
<td>0.95</td>
<td>1.00</td>
<td>1.05</td>
<td></td>
</tr>
<tr>
<td>D</td>
<td>8.75</td>
<td>9.00</td>
<td>9.25</td>
<td></td>
</tr>
<tr>
<td>D1</td>
<td>6.90</td>
<td>7.00</td>
<td>7.10</td>
<td>Note 2</td>
</tr>
<tr>
<td>E</td>
<td>8.75</td>
<td>9.00</td>
<td>9.25</td>
<td></td>
</tr>
<tr>
<td>E1</td>
<td>6.90</td>
<td>7.00</td>
<td>7.10</td>
<td>Note 2</td>
</tr>
<tr>
<td>B</td>
<td>0.30</td>
<td>–</td>
<td>0.45</td>
<td></td>
</tr>
<tr>
<td>C</td>
<td>0.09</td>
<td>–</td>
<td>0.20</td>
<td></td>
</tr>
<tr>
<td>L</td>
<td>0.45</td>
<td>–</td>
<td>0.75</td>
<td></td>
</tr>
<tr>
<td>e</td>
<td>0.80 TYP</td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

2010-10-20
11.2. **28P3**

**COMMON DIMENSIONS**
(Unit of Measure = mm)

<table>
<thead>
<tr>
<th>SYMBOL</th>
<th>MIN</th>
<th>NOM</th>
<th>MAX</th>
<th>NOTE</th>
</tr>
</thead>
<tbody>
<tr>
<td>A</td>
<td>–</td>
<td>–</td>
<td>4.5724</td>
<td></td>
</tr>
<tr>
<td>A1</td>
<td>0.508</td>
<td>–</td>
<td>–</td>
<td></td>
</tr>
<tr>
<td>D</td>
<td>34.544</td>
<td>–</td>
<td>34.798</td>
<td>Note 1</td>
</tr>
<tr>
<td>E</td>
<td>7.620</td>
<td>–</td>
<td>8.255</td>
<td></td>
</tr>
<tr>
<td>E1</td>
<td>7.112</td>
<td>–</td>
<td>7.493</td>
<td>Note 1</td>
</tr>
<tr>
<td>B</td>
<td>0.381</td>
<td>–</td>
<td>0.533</td>
<td></td>
</tr>
<tr>
<td>B1</td>
<td>1.143</td>
<td>–</td>
<td>1.397</td>
<td></td>
</tr>
<tr>
<td>B2</td>
<td>0.762</td>
<td>–</td>
<td>1.143</td>
<td></td>
</tr>
<tr>
<td>L</td>
<td>3.175</td>
<td>–</td>
<td>3.429</td>
<td></td>
</tr>
<tr>
<td>C</td>
<td>0.203</td>
<td>–</td>
<td>0.356</td>
<td></td>
</tr>
<tr>
<td>eB</td>
<td>–</td>
<td>–</td>
<td>10.160</td>
<td></td>
</tr>
<tr>
<td>e</td>
<td>–</td>
<td>–</td>
<td>2.540 TYP</td>
<td></td>
</tr>
</tbody>
</table>

Note: 1. Dimensions D and E1 do not include mold Flash or Protrusion. Mold Flash or Protrusion shall not exceed 0.25mm (0.010").

**TITLE**
28P3, 28-lead (0.300\(^\circ\)/7.62mm Wide) Plastic Dual Inline Package (PDIP)

**DRAWING NO.**
28P3

**REV.**
B

---

Atmel ATmega8A [DATASHEET]
Atmel-8159FS-8-bit AVR Microcontroller Datasheet Summary-09/2015 21
11.3. 32M1-A

**COMMON DIMENSIONS**

(Unit of Measure = mm)

<table>
<thead>
<tr>
<th>SYMBOL</th>
<th>MIN</th>
<th>NOM</th>
<th>MAX</th>
<th>NOTE</th>
</tr>
</thead>
<tbody>
<tr>
<td>A</td>
<td>0.80</td>
<td>0.90</td>
<td>1.00</td>
<td></td>
</tr>
<tr>
<td>A1</td>
<td>–</td>
<td>0.02</td>
<td>0.05</td>
<td></td>
</tr>
<tr>
<td>A2</td>
<td>–</td>
<td>0.65</td>
<td>1.00</td>
<td></td>
</tr>
<tr>
<td>A3</td>
<td></td>
<td>0.20 REF</td>
<td></td>
<td></td>
</tr>
<tr>
<td>b</td>
<td>0.18</td>
<td>0.23</td>
<td>0.30</td>
<td></td>
</tr>
<tr>
<td>D</td>
<td>4.90</td>
<td>5.00</td>
<td>5.10</td>
<td></td>
</tr>
<tr>
<td>D1</td>
<td>4.70</td>
<td>4.75</td>
<td>4.80</td>
<td></td>
</tr>
<tr>
<td>D2</td>
<td>2.95</td>
<td>3.10</td>
<td>3.25</td>
<td></td>
</tr>
<tr>
<td>E</td>
<td>4.90</td>
<td>5.00</td>
<td>5.10</td>
<td></td>
</tr>
<tr>
<td>E1</td>
<td>4.70</td>
<td>4.75</td>
<td>4.80</td>
<td></td>
</tr>
<tr>
<td>E2</td>
<td>2.95</td>
<td>3.10</td>
<td>3.25</td>
<td></td>
</tr>
<tr>
<td>e</td>
<td></td>
<td>0.50 BSC</td>
<td></td>
<td></td>
</tr>
<tr>
<td>L</td>
<td>0.30</td>
<td>0.40</td>
<td>0.50</td>
<td></td>
</tr>
<tr>
<td>P</td>
<td>–</td>
<td>–</td>
<td>0.60</td>
<td></td>
</tr>
<tr>
<td>Θ</td>
<td>–</td>
<td>–</td>
<td>12°</td>
<td></td>
</tr>
<tr>
<td>K</td>
<td>0.20</td>
<td>–</td>
<td>–</td>
<td></td>
</tr>
</tbody>
</table>

Note: JEDEC Standard MO-220, Fig 2 (Anvil Singulation), VHHD-2.

---

Package Drawing Contact: packagedrawings@atmel.com

**Package**

32M1-A, 32-pad, 5 x 5 x 1.0mm Body, Lead Pitch 0.50mm, 3.10mm Exposed Pad, Micro Lead Frame Package (MLF)

**Drawing No.**

32M1-A

**Rev.**

F

03/14/2014

Atmel ATmega8A [DATASHEET] 22

Atmel-8159FS-8-bit AVR Microcontroller_Datasheet_Summary-09/2015
12. **Errata**
The revision letter in this section refers to the revision of the ATmega8A device.

12.1. **ATmega8A, rev. L**
- First Analog Comparator conversion may be delayed
- Interrupts may be lost when writing the timer registers in the asynchronous timer
- Signature may be Erased in Serial Programming Mode
- CKOPT Does not Enable Internal Capacitors on XTALn/TOSCn Pins when 32kHz Oscillator is Used to Clock the Asynchronous Timer/Counter2
- Reading EEPROM by using ST or STS to set EERE bit triggers unexpected interrupt request

1. **First Analog Comparator conversion may be delayed**
   If the device is powered by a slow rising \( V_{CC} \), the first Analog Comparator conversion will take longer than expected on some devices.

   **Problem Fix / Workaround:**
   When the device has been powered or reset, disable then enable the Analog Comparator before the first conversion.

2. **Interrupts may be lost when writing the timer registers in the asynchronous timer**
   The interrupt will be lost if a timer register that is synchronous timer clock is written when the asynchronous Timer/Counter register (TCNTx) is 0x00.

   **Problem Fix / 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).

3. **Signature may be Erased in Serial Programming Mode**
   If the signature bytes are read before a chiperase command is completed, the signature may be erased causing the device ID and calibration bytes to disappear. This is critical, especially, if the part is running on internal RC oscillator.

   **Problem Fix / Workaround:**
   Ensure that the chiperase command has exceeded before applying the next command.

4. **CKOPT Does not Enable Internal Capacitors on XTALn/TOSCn Pins when 32kHz Oscillator is Used to Clock the Asynchronous Timer/Counter2**
   When the internal RC Oscillator is used as the main clock source, it is possible to run the Timer/Counter2 asynchronously by connecting a 32kHz Oscillator between XTAL1/TOSC1 and XTAL2/TOSC2. But when the internal RC Oscillator is selected as the main clock source, the CKOPT Fuse does not control the internal capacitors on XTAL1/TOSC1 and XTAL2/TOSC2. As long as there are no capacitors connected to XTAL1/TOSC1 and XTAL2/TOSC2, safe operation of the Oscillator is not guaranteed.

   **Problem Fix / Workaround:**
   Use external capacitors in the range of 20 - 36 pF on XTAL1/TOSC1 and XTAL2/TOSC2. This will be fixed in ATmega8A Rev. G where the CKOPT Fuse will control internal capacitors also when internal RC Oscillator is selected as main clock source. For ATmega8A Rev. G, CKOPT = 0 (programmed) will enable the internal capacitors on XTAL1 and XTAL2. Customers who want...
compatibility between Rev. G and older revisions, must ensure that CKOPT is unprogrammed (CKOPT = 1).

5. **Reading EEPROM by using ST or STS to set EERE bit triggers unexpected interrupt request.**
Reading EEPROM by using the ST or STS command to set the EERE bit in the EECR register triggers an unexpected EEPROM interrupt request.

**Problem Fix / Workaround:**
Always use OUT or SBI to set EERE in EECR.
13. Datasheet Revision History

Please note that the referring page numbers in this section are referred to this document. The referring revision in this section refers to the document revision.

13.1. Rev.8159F – 07/2015
1. New workflow used for the publication.

13.2. Rev.8159E – 02/2013
1. Applied the Atmel new page layout for datasheets including new logo and last page.
2. Removed the reference to the debuggers and In-Circuit Emulators.
3. Added Capacitive touch sensing.
4. Added Electrical Characteristics – TA = -40°C to 105°C.
5. Added Typical Characteristics – TA = -40°C to 105°C.

13.3. Rev.8159D – 02/11
1. Updated the datasheet according to the Atmel new Brand Style Guide.
2. Updated Performing Page Erase by SPM by adding an extra note.
3. Updated Ordering Information to include Tape & Reel.

13.4. DRH_Rev.8159C – 07/09
1. Updated Errata.

13.5. Rev.8159B – 05/09
1. Updated System and Reset Characteristics with new BODLEVEL values
2. Updated ADC Characteristics with new VINT values.
4. Updated Errata. ATmega8A, rev L.
5. Created a new Table Of Contents.

13.6. Rev.8159A – 08/08
1. Initial revision (Based on the ATmega8/L datasheet 2486T-AVR-05/08)
2. Changes done compared to ATmega8/L datasheet 2486T-AVR-05/08:
   – All Electrical Characteristics are moved to Electrical Characteristics – TA = -40°C to 85°C.
   – Updated DC Characteristics with new $V_{OL}$ Max (0.9V and 0.6V) and typical value for $I_{CC}$.
   – Added Speed Grades.
   – Added a new sub section System and Reset Characteristics.
   – Updated System and Reset Characteristics with new $V_{BOT}$ BODLEVEL = 0 (3.6V, 4.0V and 4.2V).
– Register descriptions are moved to sub section at the end of each chapter.
– New graphics in Typical Characteristics – TA = -40°C to 85°C.
– New Ordering Information.