



Welcome to E-XFL.COM

#### What is "Embedded - Microcontrollers"?

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

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

#### Details

| Product Status             | Obsolete                                                                 |
|----------------------------|--------------------------------------------------------------------------|
| Core Processor             | AVR                                                                      |
| Core Size                  | 8-Bit                                                                    |
| Speed                      | 16MHz                                                                    |
| Connectivity               | SPI, UART/USART, USI                                                     |
| Peripherals                | Brown-out Detect/Reset, POR, PWM, WDT                                    |
| Number of I/O              | 54                                                                       |
| Program Memory Size        | 16KB (8K x 16)                                                           |
| Program Memory Type        | FLASH                                                                    |
| EEPROM Size                | 512 x 8                                                                  |
| RAM Size                   | 1K x 8                                                                   |
| Voltage - Supply (Vcc/Vdd) | 2.7V ~ 5.5V                                                              |
| Data Converters            | A/D 8x10b                                                                |
| Oscillator Type            | Internal                                                                 |
| Operating Temperature      | -40°C ~ 85°C (TA)                                                        |
| Mounting Type              | Surface Mount                                                            |
| Package / Case             | 64-TQFP                                                                  |
| Supplier Device Package    | 64-TQFP (14x14)                                                          |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/atmega165-16au |

Email: info@E-XFL.COM

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

When the BOOTRST Fuse is programmed, the Boot section size set to 2K bytes and the IVSEL bit in the MCUCR Register is set before any interrupts are enabled, the most typical and general program setup for the Reset and Interrupt Vector Addresses is:

| Address   | Labels | Code            |                  | С | omments                            |
|-----------|--------|-----------------|------------------|---|------------------------------------|
| ;         |        |                 |                  |   |                                    |
| .org 0x10 | 200    |                 |                  |   |                                    |
| 0x1C00    |        | jmp             | RESET            | ; | Reset handler                      |
| 0x1C02    |        | jmp             | EXT_INT0         | ; | IRQ0 Handler                       |
| 0x1C04    |        | jmp             | PCINT0           | ; | PCINT0 Handler                     |
|           |        | • • •           |                  | ; |                                    |
| 0x1C2C    |        | jmp             | SPM_RDY          | ; | Store Program Memory Ready Handler |
| ;         |        |                 |                  |   |                                    |
| 0x1C2E    | RESET: | ldi             | r16,high(RAMEND) | ; | Main program start                 |
| 0x1C2F    |        | out             | SPH,r16          | ; | Set Stack Pointer to top of RAM    |
| 0x1C30    |        | ldi             | r16,low(RAMEND)  |   |                                    |
| 0x1C31    |        | out             | SPL,r16          |   |                                    |
| 0x1C32    |        | sei             |                  | ; | Enable interrupts                  |
| 0x1C33    |        | <instr></instr> | xxx              |   |                                    |

Moving Interrupts Between Application and Boot Space The General Interrupt Control Register controls the placement of the Interrupt Vector table.

MCU Control Register – MCUCR

| Bit           | 7   | 6 | 5 | 4   | 3 | 2 | 1     | 0    | _     |
|---------------|-----|---|---|-----|---|---|-------|------|-------|
|               | JTD | - | - | PUD | - | - | IVSEL | IVCE | MCUCR |
| Read/Write    | R/W | R | R | R/W | R | R | R/W   | R/W  | -     |
| Initial Value | 0   | 0 | 0 | 0   | 0 | 0 | 0     | 0    |       |

### • Bit 1 – IVSEL: Interrupt Vector Select

When the IVSEL bit is cleared (zero), the Interrupt Vectors are placed at the start of the Flash memory. When this bit is set (one), the Interrupt Vectors are moved to the beginning of the Boot Loader section of the Flash. The actual address of the start of the Boot Flash Section is determined by the BOOTSZ Fuses. Refer to the section "Boot Loader Support – Read-While-Write Self-Programming" on page 232 for details. To avoid unintentional changes of Interrupt Vector tables, a special write procedure must be followed to change the IVSEL bit:

- 1.Write the Interrupt Vector Change Enable (IVCE) bit to one.
- 2.Within four cycles, write the desired value to IVSEL while writing a zero to IVCE.

Interrupts will automatically be disabled while this sequence is executed. Interrupts are disabled in the cycle IVCE is set, and they remain disabled until after the instruction following the write to IVSEL. If IVSEL is not written, interrupts remain disabled for four cycles. The I-bit in the Status Register is unaffected by the automatic disabling.

- Note: If Interrupt Vectors are placed in the Boot Loader section and Boot Lock bit BLB02 is programmed, interrupts are disabled while executing from the Application section. If Interrupt Vectors are placed in the Application section and Boot Lock bit BLB12 is programed, interrupts are disabled while executing from the Boot Loader section. Refer to the section "Boot Loader Support – Read-While-Write Self-Programming" on page 232 for details on Boot Lock bits.
- Bit 0 IVCE: Interrupt Vector Change Enable



**Toggling the Pin** 

Writing a logic one to PINxn toggles the value of PORTxn, independent on the value of DDRxn. Note that the SBI instruction can be used to toggle one single bit in a port.

Switching Between Input and Output When switching between tri-state ( $\{DDxn, PORTxn\} = 0b00$ ) and output high ( $\{DDxn, PORTxn\} = 0b11$ ), an intermediate state with either pull-up enabled  $\{DDxn, PORTxn\} = 0b01$ ) or output low ( $\{DDxn, PORTxn\} = 0b10$ ) must occur. Normally, the pull-up enabled state is fully acceptable, as a high-impedant environment will not notice the difference between a strong high driver and a pull-up. If this is not the case, the PUD bit in the MCUCR Register can be set to disable all pull-ups in all ports.

Switching between input with pull-up and output low generates the same problem. The user must use either the tri-state ( $\{DDxn, PORTxn\} = 0b00$ ) or the output high state ( $\{DDxn, PORTxn\} = 0b11$ ) as an intermediate step.

Table 25 summarizes the control signals for the pin value.

| DDxn | PORTxn | PUD<br>(in MCUCR) | I/O    | Pull-up | Comment                                     |
|------|--------|-------------------|--------|---------|---------------------------------------------|
| 0    | 0      | X                 | Input  | No      | Tri-state (Hi-Z)                            |
| 0    | 1      | 0                 | Input  | Yes     | Pxn will source current if ext. pulled low. |
| 0    | 1      | 1                 | Input  | No      | Tri-state (Hi-Z)                            |
| 1    | 0      | Х                 | Output | No      | Output Low (Sink)                           |
| 1    | 1      | Х                 | Output | No      | Output High (Source)                        |

 Table 25.
 Port Pin Configurations

### **Reading the Pin Value**

Independent of the setting of Data Direction bit DDxn, the port pin can be read through the PINxn Register bit. As shown in Figure 23, the PINxn Register bit and the preceding latch constitute a synchronizer. This is needed to avoid metastability if the physical pin changes value near the edge of the internal clock, but it also introduces a delay. Figure 24 shows a timing diagram of the synchronization when reading an externally applied pin value. The maximum and minimum propagation delays are denoted  $t_{pd,max}$  and  $t_{pd,min}$  respectively.

Figure 24. Synchronization when Reading an Externally Applied Pin value





how waveforms are generated on the Output Compare outputs OC1x. For more details about advanced counting sequences and waveform generation, see "Modes of Operation" on page 103.

The Timer/Counter Overflow Flag (TOV1) is set according to the mode of operation selected by the WGM13:0 bits. TOV1 can be used for generating a CPU interrupt.

Input Capture Unit The Timer/Counter incorporates an Input Capture unit that can capture external events and give them a time-stamp indicating time of occurrence. The external signal indicating an event, or multiple events, can be applied via the ICP1 pin or alternatively, via the analog-comparator unit. The time-stamps can then be used to calculate frequency, duty-cycle, and other features of the signal applied. Alternatively the time-stamps can be used for creating a log of the events.

The Input Capture unit is illustrated by the block diagram shown in Figure 42. The elements of the block diagram that are not directly a part of the Input Capture unit are gray shaded. The small "n" in register and bit names indicates the Timer/Counter number.



Figure 42. Input Capture Unit Block Diagram

When a change of the logic level (an event) occurs on the *Input Capture pin* (ICP1), alternatively on the *Analog Comparator output* (ACO), and this change confirms to the setting of the edge detector, a capture will be triggered. When a capture is triggered, the 16-bit value of the counter (TCNT1) is written to the *Input Capture Register* (ICR1). The *Input Capture Flag* (ICF1) is set at the same system clock as the TCNT1 value is copied into ICR1 Register. If enabled (ICIE1 = 1), the Input Capture Flag generates an Input Capture interrupt. The ICF1 Flag is automatically cleared when the interrupt is executed. Alternatively the ICF1 Flag can be cleared by software by writing a logical one to its I/O bit location.

Reading the 16-bit value in the *Input Capture Register* (ICR1) is done by first reading the low byte (ICR1L) and then the high byte (ICR1H). When the low byte is read the high byte is copied into the high byte temporary register (TEMP). When the CPU reads the ICR1H I/O location it will access the TEMP Register.



(ICF1), and this can be used to cause an Input Capture Interrupt, if this interrupt is enabled.

When the ICR1 is used as TOP value (see description of the WGM13:0 bits located in the TCCR1A and the TCCR1B Register), the ICP1 is disconnected and consequently the Input Capture function is disabled.

### Bit 5 – Reserved Bit

This bit is reserved for future use. For ensuring compatibility with future devices, this bit must be written to zero when TCCR1B is written.

### • Bit 4:3 – WGM13:2: Waveform Generation Mode

See TCCR1A Register description.

### Bit 2:0 – CS12:0: Clock Select

The three Clock Select bits select the clock source to be used by the Timer/Counter, see Figure 49 and Figure 50.

| CS12 | CS11 | CS10 | Description                                             |
|------|------|------|---------------------------------------------------------|
| 0    | 0    | 0    | No clock source (Timer/Counter stopped).                |
| 0    | 0    | 1    | clk <sub>I/O</sub> /1 (No prescaling)                   |
| 0    | 1    | 0    | clk <sub>I/O</sub> /8 (From prescaler)                  |
| 0    | 1    | 1    | clk <sub>I/O</sub> /64 (From prescaler)                 |
| 1    | 0    | 0    | clk <sub>I/O</sub> /256 (From prescaler)                |
| 1    | 0    | 1    | clk <sub>I/O</sub> /1024 (From prescaler)               |
| 1    | 1    | 0    | External clock source on T1 pin. Clock on falling edge. |
| 1    | 1    | 1    | External clock source on T1 pin. Clock on rising edge.  |

Table 52. Clock Select Bit Description

If external pin modes are used for the Timer/Counter1, transitions on the T1 pin will clock the counter even if the pin is configured as an output. This feature allows software control of the counting.

### Timer/Counter1 Control Register C – TCCR1C



### • Bit 7 – FOC1A: Force Output Compare for Unit A

### • Bit 6 – FOC1B: Force Output Compare for Unit B

The FOC1A/FOC1B bits are only active when the WGM13:0 bits specifies a non-PWM mode. However, for ensuring compatibility with future devices, these bits must be set to zero when TCCR1A is written when operating in a PWM mode. When writing a logical one to the FOC1A/FOC1B bit, an immediate compare match is forced on the Waveform Generation unit. The OC1A/OC1B output is changed according to its COM1x1:0 bits setting. Note that the FOC1A/FOC1B bits are implemented as strobes. Therefore it is the value present in the COM1x1:0 bits that determine the effect of the forced compare.



The Timer/Counter Overflow Flag (TOV2) is set each time the counter reaches MAX. If the interrupt is enabled, the interrupt handler routine can be used for updating the compare value.

In fast PWM mode, the compare unit allows generation of PWM waveforms on the OC2A pin. Setting the COM2A1:0 bits to two will produce a non-inverted PWM and an inverted PWM output can be generated by setting the COM2A1:0 to three (See Table 56 on page 132). The actual OC2A value will only be visible on the port pin if the data direction for the port pin is set as output. The PWM waveform is generated by setting (or clearing) the OC2A Register at the compare match between OCR2A and TCNT2, and clearing (or setting) the OC2A Register at the timer clock cycle the counter is cleared (changes from MAX to BOTTOM).

The PWM frequency for the output can be calculated by the following equation:

$$f_{OCnxPWM} = \frac{f_{\mathsf{clk\_I/O}}}{N \cdot 256}$$

The *N* variable represents the prescale factor (1, 8, 32, 64, 128, 256, or 1024).

The extreme values for the OCR2A Register represent special cases when generating a PWM waveform output in the fast PWM mode. If the OCR2A is set equal to BOTTOM, the output will be a narrow spike for each MAX+1 timer clock cycle. Setting the OCR2A equal to MAX will result in a constantly high or low output (depending on the polarity of the output set by the COM2A1:0 bits.)

A frequency (with 50% duty cycle) waveform output in fast PWM mode can be achieved by setting OC2A to toggle its logical level on each compare match (COM2A1:0 = 1). The waveform generated will have a maximum frequency of  $f_{oc2} = f_{clk\_l/O}/2$  when OCR2A is set to zero. This feature is similar to the OC2A toggle in CTC mode, except the double buffer feature of the Output Compare unit is enabled in the fast PWM mode.

Phase Correct PWM Mode The phase correct PWM mode (WGM21:0 = 1) provides a high resolution phase correct PWM waveform generation option. The phase correct PWM mode is based on a dualslope operation. The counter counts repeatedly from BOTTOM to MAX and then from MAX to BOTTOM. In non-inverting Compare Output mode, the Output Compare (OC2A) is cleared on the compare match between TCNT2 and OCR2A while upcounting, and set on the compare match while downcounting. In inverting Output Compare mode, the operation is inverted. The dual-slope operation has lower maximum operation frequency than single slope operation. However, due to the symmetric feature of the dual-slope PWM modes, these modes are preferred for motor control applications.

The PWM resolution for the phase correct PWM mode is fixed to eight bits. In phase correct PWM mode the counter is incremented until the counter value matches MAX. When the counter reaches MAX, it changes the count direction. The TCNT2 value will be equal to MAX for one timer clock cycle. The timing diagram for the phase correct PWM mode is shown on Figure 59. The TCNT2 value is in the timing diagram shown as a histogram for illustrating the dual-slope operation. The diagram includes non-inverted and inverted PWM outputs. The small horizontal line marks on the TCNT2 slopes represent compare matches between OCR2A and TCNT2.



| Parity Checker              | The Parity Checker is active when the high USART Parity mode (UPM1) bit is set. Type of Parity Check to be performed (odd or even) is selected by the UPM0 bit. When enabled, the Parity Checker calculates the parity of the data bits in incoming frames and compares the result with the parity bit from the serial frame. The result of the check is stored in the receive buffer together with the received data and stop bits. The Parity Error (UPE) Flag can then be read by software to check if the frame had a Parity Error. |
|-----------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                             | The UPE bit is set if the next character that can be read from the receive buffer had a Parity Error when received and the Parity Checking was enabled at that point (UPM1 = 1). This bit is valid until the receive buffer (UDR) is read.                                                                                                                                                                                                                                                                                              |
| Disabling the Receiver      | In contrast to the Transmitter, disabling of the Receiver will be immediate. Data from ongoing receptions will therefore be lost. When disabled (i.e., the RXEN is set to zero) the Receiver will no longer override the normal function of the RxD port pin. The Receiver buffer FIFO will be flushed when the Receiver is disabled. Remaining data in the buffer will be lost                                                                                                                                                         |
| Flushing the Receive Buffer | The receiver buffer FIFO will be flushed when the Receiver is disabled, i.e., the buffer will be emptied of its contents. Unread data will be lost. If the buffer has to be flushed during normal operation, due to for instance an error condition, read the UDR I/O location until the RXC Flag is cleared. The following code example shows how to flush the receive buffer.                                                                                                                                                         |

| Assembly Code Example <sup>(1)</sup>                                         |
|------------------------------------------------------------------------------|
| USART_Flush:                                                                 |
| sbis UCSRA, RXC                                                              |
| ret                                                                          |
| in r16, UDR                                                                  |
| rjmp USART_Flush                                                             |
| C Code Example <sup>(1)</sup>                                                |
| <pre>void USART_Flush( void )</pre>                                          |
| {                                                                            |
| unsigned char dummy;                                                         |
| <pre>while ( UCSRA &amp; (1&lt;<rxc) )="" dummy="UDR;&lt;/pre"></rxc)></pre> |
| }                                                                            |

Note: 1. See "About Code Examples" on page 6.

Asynchronous Data Reception The USART includes a clock recovery and a data recovery unit for handling asynchronous data reception. The clock recovery logic is used for synchronizing the internally generated baud rate clock to the incoming asynchronous serial frames at the RxD pin. The data recovery logic samples and low pass filters each incoming bit, thereby improving the noise immunity of the Receiver. The asynchronous reception operational range depends on the accuracy of the internal baud rate clock, the rate of the incoming frames, and the frame size in number of bits.



|              | f <sub>osc</sub> = 3.6864 MHz |        |       | f <sub>osc</sub> = 4.0000 MHz |         |       |         | f <sub>osc</sub> = 7.3728 MHz |         |        |         |        |
|--------------|-------------------------------|--------|-------|-------------------------------|---------|-------|---------|-------------------------------|---------|--------|---------|--------|
| Baud<br>Bate | U2X                           | = 0    | U2X   | = 1                           | U2X = 0 |       | U2X = 1 |                               | U2X = 0 |        | U2X = 1 |        |
| (bps)        | UBRR                          | Error  | UBRR  | Error                         | UBRR    | Error | UBRR    | Error                         | UBRR    | Error  | UBRR    | Error  |
| 2400         | 95                            | 0.0%   | 191   | 0.0%                          | 103     | 0.2%  | 207     | 0.2%                          | 191     | 0.0%   | 383     | 0.0%   |
| 4800         | 47                            | 0.0%   | 95    | 0.0%                          | 51      | 0.2%  | 103     | 0.2%                          | 95      | 0.0%   | 191     | 0.0%   |
| 9600         | 23                            | 0.0%   | 47    | 0.0%                          | 25      | 0.2%  | 51      | 0.2%                          | 47      | 0.0%   | 95      | 0.0%   |
| 14.4k        | 15                            | 0.0%   | 31    | 0.0%                          | 16      | 2.1%  | 34      | -0.8%                         | 31      | 0.0%   | 63      | 0.0%   |
| 19.2k        | 11                            | 0.0%   | 23    | 0.0%                          | 12      | 0.2%  | 25      | 0.2%                          | 23      | 0.0%   | 47      | 0.0%   |
| 28.8k        | 7                             | 0.0%   | 15    | 0.0%                          | 8       | -3.5% | 16      | 2.1%                          | 15      | 0.0%   | 31      | 0.0%   |
| 38.4k        | 5                             | 0.0%   | 11    | 0.0%                          | 6       | -7.0% | 12      | 0.2%                          | 11      | 0.0%   | 23      | 0.0%   |
| 57.6k        | 3                             | 0.0%   | 7     | 0.0%                          | 3       | 8.5%  | 8       | -3.5%                         | 7       | 0.0%   | 15      | 0.0%   |
| 76.8k        | 2                             | 0.0%   | 5     | 0.0%                          | 2       | 8.5%  | 6       | -7.0%                         | 5       | 0.0%   | 11      | 0.0%   |
| 115.2k       | 1                             | 0.0%   | 3     | 0.0%                          | 1       | 8.5%  | 3       | 8.5%                          | 3       | 0.0%   | 7       | 0.0%   |
| 230.4k       | 0                             | 0.0%   | 1     | 0.0%                          | 0       | 8.5%  | 1       | 8.5%                          | 1       | 0.0%   | 3       | 0.0%   |
| 250k         | 0                             | -7.8%  | 1     | -7.8%                         | 0       | 0.0%  | 1       | 0.0%                          | 1       | -7.8%  | 3       | -7.8%  |
| 0.5M         | _                             | -      | 0     | -7.8%                         | _       | _     | 0       | 0.0%                          | 0       | -7.8%  | 1       | -7.8%  |
| 1M           | -                             | _      | _     | -                             | -       | -     | -       | -                             | -       | -      | 0       | -7.8%  |
| Max. (1)     | 230.4                         | 1 kbps | 460.8 | 3 kbps                        | 250     | kbps  | 0.5     | Vbps                          | 460.8   | 8 kbps | 921.6   | 3 kbps |

 Table 73. Examples of UBRR Settings for Commonly Used Oscillator Frequencies (Continued)

1. UBRR = 0, Error = 0.0%



### Analog Comparator Multiplexed Input

It is possible to select any of the ADC7..0 pins to replace the negative input to the Analog Comparator. The ADC multiplexer is used to select this input, and consequently, the ADC must be switched off to utilize this feature. If the Analog Comparator Multiplexer Enable bit (ACME in ADCSRB) is set and the ADC is switched off (ADEN in ADCSRA is zero), MUX2..0 in ADMUX select the input pin to replace the negative input to the Analog Comparator, as shown in Table 79. If ACME is cleared or ADEN is set, AIN1 is applied to the negative input to the Analog Comparator.

| ACME | ADEN | MUX20 | Analog Comparator Negative Input |
|------|------|-------|----------------------------------|
| 0    | х    | ххх   | AIN1                             |
| 1    | 1    | ххх   | AIN1                             |
| 1    | 0    | 000   | ADC0                             |
| 1    | 0    | 001   | ADC1                             |
| 1    | 0    | 010   | ADC2                             |
| 1    | 0    | 011   | ADC3                             |
| 1    | 0    | 100   | ADC4                             |
| 1    | 0    | 101   | ADC5                             |
| 1    | 0    | 110   | ADC6                             |
| 1    | 0    | 111   | ADC7                             |

### Table 79. Analog Comparator Multiplexed Input

| <b>Digital Input</b> | Disable | Register |
|----------------------|---------|----------|
| 1 – DIDR1            |         |          |

| Bit           | 7 | 6 | 5 | 4 | 3 | 2 | 1     | 0     | _     |
|---------------|---|---|---|---|---|---|-------|-------|-------|
|               | - | - | - | - | - | - | AIN1D | AIN0D | DIDR1 |
| Read/Write    | R | R | R | R | R | R | R/W   | R/W   |       |
| Initial Value | 0 | 0 | 0 | 0 | 0 | 0 | 0     | 0     |       |

### • Bit 1, 0 – AIN1D, AIN0D: AIN1, AIN0 Digital Input Disable

When this bit is written logic one, the digital input buffer on the AIN1/0 pin is disabled. The corresponding PIN Register bit will always read as zero when this bit is set. When an analog signal is applied to the AIN1/0 pin and the digital input from this pin is not needed, this bit should be written logic one to reduce power consumption in the digital input buffer.



### ADC Control and Status Register A – ADCSRA

| Bit           | 7    | 6    | 5     | 4    | 3    | 2     | 1     | 0     | _      |
|---------------|------|------|-------|------|------|-------|-------|-------|--------|
|               | ADEN | ADSC | ADATE | ADIF | ADIE | ADPS2 | ADPS1 | ADPS0 | ADCSRA |
| Read/Write    | R/W  | R/W  | R/W   | R/W  | R/W  | R/W   | R/W   | R/W   |        |
| Initial Value | 0    | 0    | 0     | 0    | 0    | 0     | 0     | 0     |        |

### • Bit 7 – ADEN: ADC Enable

Writing this bit to one enables the ADC. By writing it to zero, the ADC is turned off. Turning the ADC off while a conversion is in progress, will terminate this conversion.

### Bit 6 – ADSC: ADC Start Conversion

In Single Conversion mode, write this bit to one to start each conversion. In Free Running mode, write this bit to one to start the first conversion. The first conversion after ADSC has been written after the ADC has been enabled, or if ADSC is written at the same time as the ADC is enabled, will take 25 ADC clock cycles instead of the normal 13. This first conversion performs initialization of the ADC.

ADSC will read as one as long as a conversion is in progress. When the conversion is complete, it returns to zero. Writing zero to this bit has no effect.

### • Bit 5 – ADATE: ADC Auto Trigger Enable

When this bit is written to one, Auto Triggering of the ADC is enabled. The ADC will start a conversion on a positive edge of the selected trigger signal. The trigger source is selected by setting the ADC Trigger Select bits, ADTS in ADCSRB.

### • Bit 4 – ADIF: ADC Interrupt Flag

This bit is set when an ADC conversion completes and the Data Registers are updated. The ADC Conversion Complete Interrupt is executed if the ADIE bit and the I-bit in SREG are set. ADIF is cleared by hardware when executing the corresponding interrupt handling vector. Alternatively, ADIF is cleared by writing a logical one to the flag. Beware that if doing a Read-Modify-Write on ADCSRA, a pending interrupt can be disabled. This also applies if the SBI and CBI instructions are used.

### • Bit 3 – ADIE: ADC Interrupt Enable

When this bit is written to one and the I-bit in SREG is set, the ADC Conversion Complete Interrupt is activated.



### JTAG Interface and On-chip Debug System

| Features               | <ul> <li>JTAG (IEEE std. 1149.1 Compliant) Interface</li> <li>Boundary-scan Capabilities According to the IEEE std. 1149.1 (JTAG) Standard</li> <li>Debugger Access to: <ul> <li>-All Internal Peripheral Units</li> <li>-Internal and External RAM</li> <li>-The Internal Register File</li> <li>-Program Counter</li> <li>-EEPROM and Flash Memories</li> </ul> </li> <li>Extensive On-chip Debug Support for Break Conditions, Including <ul> <li>-AVR Break Instruction</li> <li>Break on Change of Program Memory Flow</li> <li>-Single Step Break</li> <li>-Program Memory Break Points on Single Address or Address Range</li> <li>Data Memory Break Points on Single Address or Address Range</li> </ul> </li> <li>Programming of Flash, EEPROM, Fuses, and Lock Bits through the JTAG Interface</li> <li>On-chip Debugging Supported by AVR Studio<sup>®</sup></li> </ul> |  |  |  |  |
|------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| Overview               | <ul> <li>The AVR IEEE std. 1149.1 compliant JTAG interface can be used for</li> <li>Testing PCBs by using the JTAG Boundary-scan capability</li> <li>Programming the non-volatile memories, Fuses and Lock bits</li> <li>On-chip debugging</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |
|                        | A brief description is given in the following sections. Detailed descriptions for Program-<br>ming via the JTAG interface, and using the Boundary-scan Chain can be found in the<br>sections "Programming via the JTAG Interface" on page 266 and "IEEE 1149.1 (JTAG)<br>Boundary-scan" on page 212, respectively. The On-chip Debug support is considered<br>being private JTAG instructions, and distributed within ATMEL and to selected third<br>party vendors only.                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |
|                        | Figure 97 shows a block diagram of the JTAG interface and the On-chip Debug system.<br>The TAP Controller is a state machine controlled by the TCK and TMS signals. The TAP<br>Controller selects either the JTAG Instruction Register or one of several Data Registers<br>as the scan chain (Shift Register) between the TDI – input and TDO – output. The<br>Instruction Register holds JTAG instructions controlling the behavior of a Data Register.                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |
|                        | The ID-Register, Bypass Register, and the Boundary-scan Chain are the Data Registers used for board-level testing. The JTAG Programming Interface (actually consisting of several physical and virtual Data Registers) is used for serial programming via the JTAG interface. The Internal Scan Chain and Break Point Scan Chain are used for On-chip debugging only.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |
| Test Access Port – TAP | <ul> <li>The JTAG interface is accessed through four of the AVR's pins. In JTAG terminology, these pins constitute the Test Access Port – TAP. These pins are:</li> <li>TMS: Test mode select. This pin is used for navigating through the TAP-controller state machine.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |
|                        | <ul> <li>TDI: Test Data In. Serial input data to be shifted in to the Instruction Register or Data Register (Scan Chains).</li> <li>TDO: Test Data Out. Serial output data from Instruction Register or Data Register</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |
|                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |







Scanning the RESET Pin The RESET pin accepts 5V active low logic for standard reset operation, and 12V active high logic for High Voltage Parallel programming. An observe-only cell as shown in Figure 103 is inserted both for the 5V reset signal; RSTT, and the 12V reset signal; RSTHV.

Figure 103. Observe-only Cell





| Bit Number | Signal Name        | Module |
|------------|--------------------|--------|
| 168        | MUXEN_3            | ADC    |
| 167        | MUXEN_2            |        |
| 166        | MUXEN_1            |        |
| 165        | MUXEN_0            |        |
| 164        | NEGSEL_2           |        |
| 163        | NEGSEL_1           |        |
| 162        | NEGSEL_0           |        |
| 161        | PASSEN             |        |
| 160        | PRECH              |        |
| 159        | ST                 |        |
| 158        | VCCREN             | -      |
| 157        | PE0.Data           | Port E |
| 156        | PE0.Control        | -      |
| 155        | PE0.Pull-up_Enable | -      |
| 154        | PE1.Data           |        |
| 153        | PE1.Control        |        |
| 152        | PE1.Pull-up_Enable |        |
| 151        | PE2.Data           |        |
| 150        | PE2.Control        |        |
| 149        | PE2.Pull-up_Enable |        |
| 148        | PE3.Data           |        |
| 147        | PE3.Control        |        |
| 146        | PE3.Pull-up_Enable |        |
| 145        | PE4.Data           |        |
| 144        | PE4.Control        |        |
| 143        | PE4.Pull-up_Enable |        |
| 142        | PE5.Data           |        |
| 141        | PE5.Control        |        |
| 140        | PE5.Pull-up_Enable |        |
| 139        | PE6.Data           |        |
| 138        | PE6.Control        | 1      |
| 137        | PE6.Pull-up_Enable | 1      |
| 136        | PE7.Data           | 1      |
| 135        | PE7.Control        | 1      |
| 134        | PE7.Pull-up_Enable | 1      |
| 122        | PB0 Data           | Port B |

Table 90. ATmega165 Boundary-scan Order (Continued)



| Bit Number | Signal Name        | Module                                   |
|------------|--------------------|------------------------------------------|
| 96         | EXTCLK (XTAL1)     | Clock input and Oscillators for the main |
| 95         | OSCCK              | clock<br>(Observe-only)                  |
| 94         | RCCK               |                                          |
| 93         | OSC32CK            |                                          |
| 92         | PD0.Data           | Port D                                   |
| 91         | PD0.Control        |                                          |
| 90         | PD0.Pull-up_Enable |                                          |
| 89         | PD1.Data           |                                          |
| 88         | PD1.Control        |                                          |
| 87         | PD1.Pull-up_Enable |                                          |
| 86         | PD2.Data           |                                          |
| 85         | PD2.Control        |                                          |
| 84         | PD2.Pull-up_Enable |                                          |
| 83         | PD3.Data           |                                          |
| 82         | PD3.Control        |                                          |
| 81         | PD3.Pull-up_Enable |                                          |
| 80         | PD4.Data           |                                          |
| 79         | PD4.Control        |                                          |
| 78         | PD4.Pull-up_Enable |                                          |
| 77         | PD5.Data           |                                          |
| 76         | PD5.Control        |                                          |
| 75         | PD5.Pull-up_Enable |                                          |
| 74         | PD6.Data           |                                          |
| 73         | PD6.Control        |                                          |
| 72         | PD6.Pull-up_Enable |                                          |
| 71         | PD7.Data           |                                          |
| 70         | PD7.Control        |                                          |
| 69         | PD7.Pull-up_Enable |                                          |
| 68         | PG0.Data           | Port G                                   |
| 67         | PG0.Control        |                                          |
| 66         | PG0.Pull-up_Enable |                                          |
| 65         | PG1.Data           |                                          |
| 64         | PG1.Control        |                                          |
| 63         | PG1.Pull-up_Enable | ]                                        |
| 62         | PC0.Data           | Port C                                   |
| 61         | PC0.Control        |                                          |

| Table 90. | ATmega165 Boundary-scan Order | (Continued) |
|-----------|-------------------------------|-------------|



Figure 111. Parallel Programming



Table 107. Pin Name Mapping

| Signal Name in<br>Programming Mode | Pin Name | I/O | Function                                                           |
|------------------------------------|----------|-----|--------------------------------------------------------------------|
| RDY/BSY                            | PD1      | 0   | 0: Device is busy programming, 1: Device is ready for new command. |
| ŌĒ                                 | PD2      | Ι   | Output Enable (Active low).                                        |
| WR                                 | PD3      | Ι   | Write Pulse (Active low).                                          |
| BS1                                | PD4      | I   | Byte Select 1 ("0" selects low byte, "1" selects high byte).       |
| XA0                                | PD5      | I   | XTAL Action Bit 0                                                  |
| XA1                                | PD6      | I   | XTAL Action Bit 1                                                  |
| PAGEL                              | PD7      | Ι   | Program Memory and EEPROM data Page Load.                          |
| BS2                                | PA0      | I   | Byte Select 2 ("0" selects low byte, "1" selects 2'nd high byte).  |
| DATA                               | PB7-0    | I/O | Bi-directional Data bus (Output when $\overline{OE}$ is low).      |



# Programming Command Register

The Programming Command Register is a 15-bit register. This register is used to serially shift in programming commands, and to serially shift out the result of the previous command, if any. The JTAG Programming Instruction Set is shown in Table 115. The state sequence when shifting in the programming commands is illustrated in Figure 125.

Figure 124. Programming Command Register





### Table 118. SPI Timing Parameters

|    | Description          | Mode  | Min                  | Тур | Max |    |
|----|----------------------|-------|----------------------|-----|-----|----|
| 13 | Setup                | Slave | 10                   |     |     |    |
| 14 | Hold                 | Slave | t <sub>ck</sub>      |     |     |    |
| 15 | SCK to out           | Slave |                      | 15  |     |    |
| 16 | SCK to SS high       | Slave | 20                   |     |     | ns |
| 17 | SS high to tri-state | Slave |                      | 10  |     |    |
| 18 | SS low to SCK        | Slave | 20 • t <sub>ck</sub> |     |     | 1  |

1. In SPI Programming mode the minimum SCK high/low period is: Note:

- 2  $t_{CLCL}$  for  $f_{CK}$  < 12 MHz - 3  $t_{CLCL}$  for  $f_{CK}$  > 12 MHz











### ATmega165 Typical Characteristics

**Active Supply Current** 

The following charts show typical behavior. These figures are not tested during manufacturing. All current consumption measurements are performed with all I/O pins configured as inputs and with internal pull-ups enabled. A sine wave generator with rail-to-rail output is used as clock source.

All Active- and Idle current consumption measurements are done with all bits in the PRR register set and thus, the corresponding I/O modules are turned off. Also the Analog Comparator is disabled during these measurements. Table 120 and Table 121 on page 290 show the additional current consumption compared to I<sub>CC</sub> Active and I<sub>CC</sub> Idle for every I/O module controlled by the Power Reduction Register. See "Power Reduction Register" on page 34 for details.

The power consumption in Power-down mode is independent of clock selection.

The current consumption is a function of several factors such as: operating voltage, operating frequency, loading of I/O pins, switching rate of I/O pins, code executed and ambient temperature. The dominating factors are operating voltage and frequency.

The current drawn from capacitive loaded pins may be estimated (for one pin) as  $C_L^*V_{CC}^*f$  where  $C_L$  = load capacitance,  $V_{CC}$  = operating voltage and f = average switching frequency of I/O pin.

The parts are characterized at frequencies higher than test limits. Parts are not guaranteed to function properly at frequencies higher than the ordering code indicates.

The difference between current consumption in Power-down mode with Watchdog Timer enabled and Power-down mode with Watchdog Timer disabled represents the differential current drawn by the Watchdog Timer.

### Figure 132. Active Supply Current vs. Frequency (0.1 - 1.0 MHz)







Figure 135. Active Supply Current vs.  $V_{\text{CC}}$  (Internal RC Oscillator, 1 MHz)







**Idle Supply Current** 











### **Packaging Information**





